From 296009b6f0a740e41e9deae693c87ecb2670aca2 Mon Sep 17 00:00:00 2001 From: zhichen Date: Thu, 14 Mar 2019 13:57:58 +0800 Subject: [PATCH 1/3] add front-end test unit #803 --- .../resources/static/console-fe/.gitignore | 5 + .../static/console-fe/.vscode/settings.json | 36 -- .../console-fe/build/webpack.dev.conf.js | 2 +- .../static/console-fe/test/.editorconfig | 17 + .../static/console-fe/test/.gitignore | 9 + .../static/console-fe/test/README.md | 40 ++ .../static/console-fe/test/commons/commons.md | 1 + .../static/console-fe/test/config.json | 14 + .../resources/static/console-fe/test/hosts | 0 .../static/console-fe/test/install.sh | 4 + .../static/console-fe/test/package.json | 25 + .../resources/static/console-fe/test/run.bat | 7 + .../resources/static/console-fe/test/run.sh | 5 + .../sample/configurationManagement.spec.js | 527 ++++++++++++++++++ .../test/uploadfiles/uploadfiles.md | 1 + 15 files changed, 656 insertions(+), 37 deletions(-) delete mode 100644 console/src/main/resources/static/console-fe/.vscode/settings.json create mode 100644 console/src/main/resources/static/console-fe/test/.editorconfig create mode 100644 console/src/main/resources/static/console-fe/test/.gitignore create mode 100644 console/src/main/resources/static/console-fe/test/README.md create mode 100644 console/src/main/resources/static/console-fe/test/commons/commons.md create mode 100644 console/src/main/resources/static/console-fe/test/config.json create mode 100644 console/src/main/resources/static/console-fe/test/hosts create mode 100644 console/src/main/resources/static/console-fe/test/install.sh create mode 100644 console/src/main/resources/static/console-fe/test/package.json create mode 100644 console/src/main/resources/static/console-fe/test/run.bat create mode 100644 console/src/main/resources/static/console-fe/test/run.sh create mode 100644 console/src/main/resources/static/console-fe/test/sample/configurationManagement.spec.js create mode 100644 console/src/main/resources/static/console-fe/test/uploadfiles/uploadfiles.md diff --git a/console/src/main/resources/static/console-fe/.gitignore b/console/src/main/resources/static/console-fe/.gitignore index aa6e4c4e6..5539ad8a5 100644 --- a/console/src/main/resources/static/console-fe/.gitignore +++ b/console/src/main/resources/static/console-fe/.gitignore @@ -9,3 +9,8 @@ # misc .DS_Store npm-debug.log* + +# test +test/uirecorder.log +test/reports +test/screenshots/* \ No newline at end of file diff --git a/console/src/main/resources/static/console-fe/.vscode/settings.json b/console/src/main/resources/static/console-fe/.vscode/settings.json deleted file mode 100644 index 6779945fa..000000000 --- a/console/src/main/resources/static/console-fe/.vscode/settings.json +++ /dev/null @@ -1,36 +0,0 @@ -/* - * Copyright 1999-2018 Alibaba Group Holding Ltd. - * Licensed under the Apache License, Version 2.0 (the "License"); - * you may not use this file except in compliance with the License. - * You may obtain a copy of the License at - * http://www.apache.org/licenses/LICENSE-2.0 - * Unless required by applicable law or agreed to in writing, software - * distributed under the License is distributed on an "AS IS" BASIS, - * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. - * See the License for the specific language governing permissions and - * limitations under the License. - */ - -{ - "editor.tabSize": 2, - "editor.formatOnSave": true, - "[javascript]": { - "editor.formatOnSave": true, - "editor.formatOnPaste": false - }, - "[javascriptreact]": { - "editor.formatOnSave": true, - "editor.formatOnPaste": false - }, - "[typescript]": { - "editor.formatOnSave": true, - "editor.formatOnPaste": false - }, - "[typescriptreact]": { - "editor.formatOnSave": true, - "editor.formatOnPaste": false - }, - "[html]": { - "editor.formatOnSave": false - } -} diff --git a/console/src/main/resources/static/console-fe/build/webpack.dev.conf.js b/console/src/main/resources/static/console-fe/build/webpack.dev.conf.js index 210e08ab3..354dfbc85 100644 --- a/console/src/main/resources/static/console-fe/build/webpack.dev.conf.js +++ b/console/src/main/resources/static/console-fe/build/webpack.dev.conf.js @@ -26,7 +26,7 @@ module.exports = Object.assign({}, base, { context: ['/'], changeOrigin: true, secure: false, - target: 'http://localhost:8848', + target: 'http://10.101.109.214:8848/', pathRewrite: {'^/v1' : '/nacos/v1'} }], disableHostCheck: true, diff --git a/console/src/main/resources/static/console-fe/test/.editorconfig b/console/src/main/resources/static/console-fe/test/.editorconfig new file mode 100644 index 000000000..5a13b97d0 --- /dev/null +++ b/console/src/main/resources/static/console-fe/test/.editorconfig @@ -0,0 +1,17 @@ +# EditorConfig helps developers define and maintain consistent +# coding styles between different editors and IDEs +# editorconfig.org + +root = true + +# Apply for all files +[*] + +charset = utf-8 + +indent_style = space +indent_size = 4 + +end_of_line = lf +insert_final_newline = true +trim_trailing_whitespace = true diff --git a/console/src/main/resources/static/console-fe/test/.gitignore b/console/src/main/resources/static/console-fe/test/.gitignore new file mode 100644 index 000000000..704c683c5 --- /dev/null +++ b/console/src/main/resources/static/console-fe/test/.gitignore @@ -0,0 +1,9 @@ +.DS_Store +.idea +node_modules +npm-debug.log +uirecorder.log +reports +screenshots/**/*.png +screenshots/**/*.html +screenshots/**/*.json diff --git a/console/src/main/resources/static/console-fe/test/README.md b/console/src/main/resources/static/console-fe/test/README.md new file mode 100644 index 000000000..db1efe2c7 --- /dev/null +++ b/console/src/main/resources/static/console-fe/test/README.md @@ -0,0 +1,40 @@ +## 使用说明 + +### 安装依赖 +```sh +npm install uirecorder mocha -g +npm install +``` + +### 安装chrome浏览器插件 +```sh +npm run installdriver +``` + +### 开始录制测试用例 +```sh +// xxx.spec.js 为你的测试用例文件名称 +uirecorder sample/xxx.spec.js +``` + +### 回归测试 +#### 启动服务 +```sh +npm run server +``` + +#### 单个文件测试 +```sh +// xxx.spec.js 为你的测试用例文件名称 +npm run singletest sample/xxx.spec.js +``` + +#### 并发测试 +```sh +npm run paralleltest +``` + +### 查看报告 +```sh +open reports/index.html +``` \ No newline at end of file diff --git a/console/src/main/resources/static/console-fe/test/commons/commons.md b/console/src/main/resources/static/console-fe/test/commons/commons.md new file mode 100644 index 000000000..730f82ee0 --- /dev/null +++ b/console/src/main/resources/static/console-fe/test/commons/commons.md @@ -0,0 +1 @@ +Please save common test case here. \ No newline at end of file diff --git a/console/src/main/resources/static/console-fe/test/config.json b/console/src/main/resources/static/console-fe/test/config.json new file mode 100644 index 000000000..a6e6c57ab --- /dev/null +++ b/console/src/main/resources/static/console-fe/test/config.json @@ -0,0 +1,14 @@ +{ + "webdriver": { + "host": "127.0.0.1", + "port": "4444", + "browsers": "chrome" + }, + "vars": {}, + "recorder": { + "pathAttrs": "data-id,data-name,type,data-type,role,data-role,data-value", + "attrValueBlack": "", + "classValueBlack": "", + "hideBeforeExpect": "" + } +} \ No newline at end of file diff --git a/console/src/main/resources/static/console-fe/test/hosts b/console/src/main/resources/static/console-fe/test/hosts new file mode 100644 index 000000000..e69de29bb diff --git a/console/src/main/resources/static/console-fe/test/install.sh b/console/src/main/resources/static/console-fe/test/install.sh new file mode 100644 index 000000000..67759d807 --- /dev/null +++ b/console/src/main/resources/static/console-fe/test/install.sh @@ -0,0 +1,4 @@ +ls ~/nvm || git clone https://github.com/creationix/nvm.git ~/nvm +source ~/nvm/nvm.sh +nvm install v7.10.0 +npm install diff --git a/console/src/main/resources/static/console-fe/test/package.json b/console/src/main/resources/static/console-fe/test/package.json new file mode 100644 index 000000000..8f7971df1 --- /dev/null +++ b/console/src/main/resources/static/console-fe/test/package.json @@ -0,0 +1,25 @@ +{ + "name": "Nacos-console-fe-test", + "version": "1.0.0", + "description": "", + "main": "", + "dependencies": { + "chai": "3.5.0", + "jwebdriver": "2.2.6", + "mocha": "3.1.2", + "mocha-parallel-tests": "1.2.4", + "mochawesome-uirecorder": "1.5.25", + "resemblejs-node": "1.0.0", + "selenium-standalone": "6.x.x" + }, + "devDependencies": { + }, + "scripts": { + "installdriver": "./node_modules/.bin/selenium-standalone install --drivers.firefox.baseURL=http://npm.taobao.org/mirrors/geckodriver --baseURL=http://npm.taobao.org/mirrors/selenium --drivers.chrome.baseURL=http://npm.taobao.org/mirrors/chromedriver --drivers.ie.baseURL=http://npm.taobao.org/mirrors/selenium", + "server": "./node_modules/.bin/selenium-standalone start", + "test": "./node_modules/.bin/mocha \"!(node_modules)/**/*.spec.js\" --reporter mochawesome-uirecorder --bail", + "singletest": "./node_modules/.bin/mocha --reporter mochawesome-uirecorder --bail", + "paralleltest": "./node_modules/.bin/mocha-parallel-tests \"!(node_modules)/**/*.spec.js\" --reporter mochawesome-uirecorder --max-parallel 5 --bail" + }, + "author": "" +} diff --git a/console/src/main/resources/static/console-fe/test/run.bat b/console/src/main/resources/static/console-fe/test/run.bat new file mode 100644 index 000000000..da1ec2421 --- /dev/null +++ b/console/src/main/resources/static/console-fe/test/run.bat @@ -0,0 +1,7 @@ +@echo off + +if "%1" neq "" ( + npm run singletest %1 %2 +) else ( + npm run paralleltest +) diff --git a/console/src/main/resources/static/console-fe/test/run.sh b/console/src/main/resources/static/console-fe/test/run.sh new file mode 100644 index 000000000..6f479e13e --- /dev/null +++ b/console/src/main/resources/static/console-fe/test/run.sh @@ -0,0 +1,5 @@ +if [ "$1" = "" ]; then + npm run paralleltest +else + npm run singletest $1 $2 +fi diff --git a/console/src/main/resources/static/console-fe/test/sample/configurationManagement.spec.js b/console/src/main/resources/static/console-fe/test/sample/configurationManagement.spec.js new file mode 100644 index 000000000..b20c77a3d --- /dev/null +++ b/console/src/main/resources/static/console-fe/test/sample/configurationManagement.spec.js @@ -0,0 +1,527 @@ +const fs = require('fs'); +const path = require('path'); +const chai = require("chai"); +const should = chai.should(); +const JWebDriver = require('jwebdriver'); +chai.use(JWebDriver.chaiSupportChainPromise); +const resemble = require('resemblejs-node'); +resemble.outputSettings({ + errorType: 'flatDifferenceIntensity' +}); + +const rootPath = getRootPath(); + +module.exports = function(){ + + let driver, testVars; + + before(function(){ + let self = this; + driver = self.driver; + testVars = self.testVars; + }); + + it('url: http://127.0.0.1:8811', async function(){ + await driver.url(_(`http://127.0.0.1:8811`)); + }); + + it('waitBody: ', async function(){ + await driver.sleep(500).wait('body', 30000).html().then(function(code){ + isPageError(code).should.be.false; + }); + }); + + it('click: #username, 89, 41, 0', async function(){ + await driver.sleep(300).wait('#username', 30000) + .sleep(300).mouseMove(89, 41).click(0); + }); + + it('sendKeys: nacos', async function(){ + await driver.sendKeys('nacos'); + }); + + it('click: #password, 53, 34, 0', async function(){ + await driver.sleep(300).wait('#password', 30000) + .sleep(300).mouseMove(53, 34).click(0); + }); + + it('sendKeys: nacos', async function(){ + await driver.sendKeys('nacos'); + }); + + it('click: 提交 ( //button[text()="提交"], 321, 30, 0 )', async function(){ + await driver.sleep(300).wait('//button[text()="提交"]', 30000) + .sleep(300).mouseMove(321, 30).click(0); + }); + + it('click: div:nth-child(1) > div.next-form-item-control > span.next-medium > input[type="text"], 178, 9, 0', async function(){ + await driver.sleep(300).wait('div:nth-child(1) > div.next-form-item-control > span.next-medium > input[type="text"]', 30000) + .sleep(300).mouseMove(178, 9).click(0); + }); + + it('sendKeys: test_test', async function(){ + await driver.sendKeys('test_test'); + }); + + it('click: 查询 ( //button[text()="查询"], 3, 9, 0 )', async function(){ + await driver.sleep(300).wait('//button[text()="查询"]', 30000) + .sleep(300).mouseMove(3, 9).click(0); + }); + + it('click: #viewFramework-product-body i.next-icon-add, 15, 27, 0', async function(){ + await driver.sleep(300).wait('#viewFramework-product-body i.next-icon-add', 30000) + .sleep(300).mouseMove(15, 27).click(0); + }); + + it('click: Data ID: ( #dataId, 154, 20, 0 )', async function(){ + await driver.sleep(300).wait('#dataId', 30000) + .sleep(300).mouseMove(154, 20).click(0); + }); + + it('sendKeys: test_test', async function(){ + await driver.sendKeys('test_test'); + }); + + it('dblClick: Group: ( #group, 89, 11, 0 )', async function(){ + await driver.sleep(300).wait('#group', 30000) + .sleep(300).mouseMove(89, 11).click(0).click(0); + }); + + it('click: #viewFramework-product-body i.next-icon-delete-filling, 11, 7, 0', async function(){ + await driver.sleep(300).wait('#viewFramework-product-body i.next-icon-delete-filling', 30000) + .sleep(300).mouseMove(11, 7).click(0); + }); + + it('sendKeys: test', async function(){ + await driver.sendKeys('test'); + }); + + it('click: 更多高级选项 ( //a[text()="更多高级选项"], 61, 3, 0 )', async function(){ + await driver.sleep(300).wait('//a[text()="更多高级选项"]', 30000) + .sleep(300).mouseMove(61, 3).click(0); + }); + + it('click: span.next-select-trigger-search > input[role="combobox"]:nth-child(1), 66, 8, 0', async function(){ + await driver.sleep(300).wait('span.next-select-trigger-search > input[role="combobox"]:nth-child(1)', 30000) + .sleep(300).mouseMove(66, 8).click(0); + }); + + it('click: span.next-select-trigger-search > input[role="combobox"]:nth-child(1), 71, 16, 0', async function(){ + await driver.sleep(300).wait('span.next-select-trigger-search > input[role="combobox"]:nth-child(1)', 30000) + .sleep(300).mouseMove(71, 16).click(0); + }); + + it('click: 归属应用: ( #appName, 50, 19, 0 )', async function(){ + await driver.sleep(300).wait('#appName', 30000) + .sleep(300).mouseMove(50, 19).click(0); + }); + + it('click: 收起 ( //a[text()="收起"], 16, 5, 0 )', async function(){ + await driver.sleep(300).wait('//a[text()="收起"]', 30000) + .sleep(300).mouseMove(16, 5).click(0); + }); + + it('click: #desc, 77, 40, 0', async function(){ + await driver.sleep(300).wait('#desc', 30000) + .sleep(300).mouseMove(77, 40).click(0); + }); + + it('sendKeys: test', async function(){ + await driver.sendKeys('test'); + }); + + it('scrollElementTo: #viewFramework-product-body, 0, 49', async function(){ + await driver.sleep(300).wait('#viewFramework-product-body', 30000) + .sleep(300).scrollElementTo(0, 49); + }); + + it('click: #container div.view-line, 60, 15, 0', async function(){ + await driver.sleep(300).wait('#container div.view-line', 30000) + .sleep(300).mouseMove(60, 15).click(0); + }); + + it('sendKeys: test', async function(){ + await driver.sendKeys('test'); + }); + + it('scrollElementTo: #viewFramework-product-body, 0, 155', async function(){ + await driver.sleep(300).wait('#viewFramework-product-body', 30000) + .sleep(300).scrollElementTo(0, 155); + }); + + it('click: 发布 ( //button[text()="发布"], 39, 9, 0 )', async function(){ + await driver.sleep(300).wait('//button[text()="发布"]', 30000) + .sleep(300).mouseMove(39, 9).click(0); + }); + + it('× click: 确定 ( //button[text()="确定"], 13, 9, 0 )', async function(){ + await driver.sleep(300).wait('//button[text()="确定"]', 30000) + .sleep(300).mouseMove(13, 9).click(0); + }); + + it('click: 返回 ( //button[text()="返回"], 39, 18, 0 )', async function(){ + await driver.sleep(300).wait('//button[text()="返回"]', 30000) + .sleep(300).mouseMove(39, 18).click(0); + }); + + it('scrollElementTo: #viewFramework-product-body, 0, 0', async function(){ + await driver.sleep(300).wait('#viewFramework-product-body', 30000) + .sleep(300).scrollElementTo(0, 0); + }); + + it('click: 详情 ( //a[text()="详情"], 12, 7, 0 )', async function(){ + await driver.sleep(300).wait('//a[text()="详情"]', 30000) + .sleep(300).mouseMove(12, 7).click(0); + }); + + it('scrollElementTo: #viewFramework-product-body, 0, 22', async function(){ + await driver.sleep(300).wait('#viewFramework-product-body', 30000) + .sleep(300).scrollElementTo(0, 22); + }); + + it('click: test ( #content, 225, 35, 0 )', async function(){ + await driver.sleep(300).wait('#content', 30000) + .sleep(300).mouseMove(225, 35).click(0); + }); + + it('click: #backarrow, 13, 10, 0', async function(){ + await driver.sleep(300).wait('#backarrow', 30000) + .sleep(300).mouseMove(13, 10).click(0); + }); + + it('scrollElementTo: #viewFramework-product-body, 0, 0', async function(){ + await driver.sleep(300).wait('#viewFramework-product-body', 30000) + .sleep(300).scrollElementTo(0, 0); + }); + + it('click: 示例代码 ( //a[text()="示例代码"], 29, 6, 0 )', async function(){ + await driver.sleep(300).wait('//a[text()="示例代码"]', 30000) + .sleep(300).mouseMove(29, 6).click(0); + }); + + it('click: Spring Boot ( li[role="tab"]:nth-child(2) > div.next-tabs-tab-inner, 63, 22, 0 )', async function(){ + await driver.sleep(300).wait('li[role="tab"]:nth-child(2) > div.next-tabs-tab-inner', 30000) + .sleep(300).mouseMove(63, 22).click(0); + }); + + it('click: i.next-icon-close, 9, 10, 0', async function(){ + await driver.sleep(300).wait('i.next-icon-close', 30000) + .sleep(300).mouseMove(9, 10).click(0); + }); + + it('click: 编辑 ( //a[text()="编辑"], 14, 6, 0 )', async function(){ + await driver.sleep(300).wait('//a[text()="编辑"]', 30000) + .sleep(300).mouseMove(14, 6).click(0); + }); + + it('scrollElementTo: #viewFramework-product-body, 0, 134', async function(){ + await driver.sleep(300).wait('#viewFramework-product-body', 30000) + .sleep(300).scrollElementTo(0, 134); + }); + + it('click: label:nth-child(2) > span.next-radio > input[type="radio"][role="radio"].next-radio-input, 7, 1, 0', async function(){ + await driver.sleep(300).wait('label:nth-child(2) > span.next-radio > input[type="radio"][role="radio"].next-radio-input', 30000) + .sleep(300).mouseMove(7, 1).click(0); + }); + + it('click: label:nth-child(1) > span.next-radio > input[type="radio"][role="radio"].next-radio-input, 8, 8, 0', async function(){ + await driver.sleep(300).wait('label:nth-child(1) > span.next-radio > input[type="radio"][role="radio"].next-radio-input', 30000) + .sleep(300).mouseMove(8, 8).click(0); + }); + + it('click: test ( #container div.view-line, 47, 11, 0 )', async function(){ + await driver.sleep(300).wait('#container div.view-line', 30000) + .sleep(300).mouseMove(47, 11).click(0); + }); + + it('sendKeys: _test', async function(){ + await driver.sendKeys('_test'); + }); + + it('click: test ( #desc, 76, 25, 0 )', async function(){ + await driver.sleep(300).wait('#desc', 30000) + .sleep(300).mouseMove(76, 25).click(0); + }); + + it('sendKeys: _test', async function(){ + await driver.sendKeys('_test'); + }); + + it('click: 发布 ( //button[text()="发布"], 41, 15, 0 )', async function(){ + await driver.sleep(300).wait('//button[text()="发布"]', 30000) + .sleep(300).mouseMove(41, 15).click(0); + }); + + it('click: 确认发布 ( //button[text()="确认发布"], 61, 16, 0 )', async function(){ + await driver.sleep(300).wait('//button[text()="确认发布"]', 30000) + .sleep(300).mouseMove(61, 16).click(0); + }); + + it('click: 确定 ( //button[text()="确定"], 31, 15, 0 )', async function(){ + await driver.sleep(300).wait('//button[text()="确定"]', 30000) + .sleep(300).mouseMove(31, 15).click(0); + }); + + it('click: 返回 ( //button[text()="返回"], 25, 6, 0 )', async function(){ + await driver.sleep(300).wait('//button[text()="返回"]', 30000) + .sleep(300).mouseMove(25, 6).click(0); + }); + + it('scrollElementTo: #viewFramework-product-body, 0, 0', async function(){ + await driver.sleep(300).wait('#viewFramework-product-body', 30000) + .sleep(300).scrollElementTo(0, 0); + }); + + it('click: 更多 ( #viewFramework-product-body span:nth-child(9), 19, 12, 0 )', async function(){ + await driver.sleep(300).wait('#viewFramework-product-body span:nth-child(9)', 30000) + .sleep(300).mouseMove(19, 12).click(0); + }); + + it('click: 历史版本 ( //span[text()="历史版本"], 0, 3, 0 )', async function(){ + await driver.sleep(300).wait('//span[text()="历史版本"]', 30000) + .sleep(300).mouseMove(0, 3).click(0); + }); + + it('click: 配置列表 ( //div[text()="配置列表"], 120, 36, 0 )', async function(){ + await driver.sleep(300).wait('//div[text()="配置列表"]', 30000) + .sleep(300).mouseMove(120, 36).click(0); + }); + + it('click: 更多 ( #viewFramework-product-body tr.first > td[type="body"][role="gridcell"].last > div.next-table-cell-wrapper > div > span:nth-child(9), 10, 8, 0 )', async function(){ + await driver.sleep(300).wait('#viewFramework-product-body tr.first > td[type="body"][role="gridcell"].last > div.next-table-cell-wrapper > div > span:nth-child(9)', 30000) + .sleep(300).mouseMove(10, 8).click(0); + }); + + it('click: div:nth-child(1) > div.next-form-item-control > span.next-medium > input[type="text"], 163, 21, 0', async function(){ + await driver.sleep(300).wait('div:nth-child(1) > div.next-form-item-control > span.next-medium > input[type="text"]', 30000) + .sleep(300).mouseMove(163, 21).click(0); + }); + + it('click: span.next-input > input[role="combobox"], 31, 19, 0', async function(){ + await driver.sleep(300).wait('span.next-input > input[role="combobox"]', 30000) + .sleep(300).mouseMove(31, 19).click(0); + }); + + it('sendKeys: test', async function(){ + await driver.sendKeys('test'); + }); + + it('click: 查询 ( //button[text()="查询"], 8, 25, 0 )', async function(){ + await driver.sleep(300).wait('//button[text()="查询"]', 30000) + .sleep(300).mouseMove(8, 25).click(0); + }); + + it('click: div:nth-child(1) > div.next-form-item-control > span.next-medium > input[type="text"], 91, 18, 0', async function(){ + await driver.sleep(300).wait('div:nth-child(1) > div.next-form-item-control > span.next-medium > input[type="text"]', 30000) + .sleep(300).mouseMove(91, 18).click(0); + }); + + it('sendKeys: test_test', async function(){ + await driver.sendKeys('test_test'); + }); + + it('click: 查询 ( //button[text()="查询"], 17, 17, 0 )', async function(){ + await driver.sleep(300).wait('//button[text()="查询"]', 30000) + .sleep(300).mouseMove(17, 17).click(0); + }); + + it('click: 删除 ( //a[text()="删除"], 7, 8, 0 )', async function(){ + await driver.sleep(300).wait('//a[text()="删除"]', 30000) + .sleep(300).mouseMove(7, 8).click(0); + }); + + it('click: 确认 ( //button[text()="确认"], 21, 15, 0 )', async function(){ + await driver.sleep(300).wait('//button[text()="确认"]', 30000) + .sleep(300).mouseMove(21, 15).click(0); + }); + + it('click: 确定 ( //button[text()="确定"], 25, 14, 0 )', async function(){ + await driver.sleep(300).wait('//button[text()="确定"]', 30000) + .sleep(300).mouseMove(25, 14).click(0); + }); + + function _(str){ + if(typeof str === 'string'){ + return str.replace(/\{\{(.+?)\}\}/g, function(all, key){ + return testVars[key] || ''; + }); + } + else{ + return str; + } + } + +}; + +if(module.parent && /mocha\.js/.test(module.parent.id)){ + runThisSpec(); +} + +function runThisSpec(){ + // read config + let webdriver = process.env['webdriver'] || ''; + let proxy = process.env['wdproxy'] || ''; + let config = require(rootPath + '/config.json'); + let webdriverConfig = Object.assign({},config.webdriver); + let host = webdriverConfig.host; + let port = webdriverConfig.port || 4444; + let match = webdriver.match(/([^\:]+)(?:\:(\d+))?/); + if(match){ + host = match[1] || host; + port = match[2] || port; + } + let testVars = config.vars; + let browsers = webdriverConfig.browsers; + browsers = browsers.replace(/^\s+|\s+$/g, ''); + delete webdriverConfig.host; + delete webdriverConfig.port; + delete webdriverConfig.browsers; + + // read hosts + let hostsPath = rootPath + '/hosts'; + let hosts = ''; + if(fs.existsSync(hostsPath)){ + hosts = fs.readFileSync(hostsPath).toString(); + } + let specName = path.relative(rootPath, __filename).replace(/\\/g,'/').replace(/\.js$/,''); + + browsers.split(/\s*,\s*/).forEach(function(browserName){ + let caseName = specName + ' : ' + browserName; + + let browserInfo = browserName.split(' '); + browserName = browserInfo[0]; + let browserVersion = browserInfo[1]; + + describe(caseName, function(){ + + this.timeout(600000); + this.slow(1000); + + let driver; + before(function(){ + let self = this; + let driver = new JWebDriver({ + 'host': host, + 'port': port + }); + let sessionConfig = Object.assign({}, webdriverConfig, { + 'browserName': browserName, + 'version': browserVersion, + 'ie.ensureCleanSession': true, + 'chromeOptions': { + 'args': ['--enable-automation'] + } + }); + if(proxy){ + sessionConfig.proxy = { + 'proxyType': 'manual', + 'httpProxy': proxy, + 'sslProxy': proxy + } + } + else if(hosts){ + sessionConfig.hosts = hosts; + } + + try { + self.driver = driver.session(sessionConfig).windowSize(1024, 768).config({ + pageloadTimeout: 30000, // page onload timeout + scriptTimeout: 5000, // sync script timeout + asyncScriptTimeout: 10000 // async script timeout + }); + } catch (e) { + console.log(e); + } + + self.testVars = testVars; + let casePath = path.dirname(caseName); + self.screenshotPath = rootPath + '/screenshots/' + casePath; + self.diffbasePath = rootPath + '/diffbase/' + casePath; + self.caseName = caseName.replace(/.*\//g, '').replace(/\s*[:\.\:\-\s]\s*/g, '_'); + mkdirs(self.screenshotPath); + mkdirs(self.diffbasePath); + self.stepId = 0; + return self.driver; + }); + + module.exports(); + + beforeEach(function(){ + let self = this; + self.stepId ++; + if(self.skipAll){ + self.skip(); + } + }); + + afterEach(async function(){ + let self = this; + let currentTest = self.currentTest; + let title = currentTest.title; + if(currentTest.state === 'failed' && /^(url|waitBody|switchWindow|switchFrame):/.test(title)){ + self.skipAll = true; + } + if(!/^(closeWindow):/.test(title)){ + let filepath = self.screenshotPath + '/' + self.caseName + '_' + self.stepId; + let driver = self.driver; + try{ + // catch error when get alert msg + await driver.getScreenshot(filepath + '.png'); + let url = await driver.url(); + let html = await driver.source(); + html = '\n' + html; + fs.writeFileSync(filepath + '.html', html); + let cookies = await driver.cookies(); + fs.writeFileSync(filepath + '.cookie', JSON.stringify(cookies)); + } + catch(e){} + } + }); + + after(function(){ + return this.driver.close(); + }); + + }); + }); +} + +function getRootPath(){ + let rootPath = path.resolve(__dirname); + while(rootPath){ + if(fs.existsSync(rootPath + '/config.json')){ + break; + } + rootPath = rootPath.substring(0, rootPath.lastIndexOf(path.sep)); + } + return rootPath; +} + +function mkdirs(dirname){ + if(fs.existsSync(dirname)){ + return true; + }else{ + if(mkdirs(path.dirname(dirname))){ + fs.mkdirSync(dirname); + return true; + } + } +} + +function callSpec(name){ + try{ + require(rootPath + '/' + name)(); + } + catch(e){ + console.log(e) + process.exit(1); + } +} + +function isPageError(code){ + return code == '' || / jscontent="errorCode" jstcache="\d+"|diagnoseConnectionAndRefresh|dnserror_unavailable_header|id="reportCertificateErrorRetry"|400 Bad Request|403 Forbidden|404 Not Found|500 Internal Server Error|502 Bad Gateway|503 Service Temporarily Unavailable|504 Gateway Time-out/i.test(code); +} + +function catchError(error){ + +} diff --git a/console/src/main/resources/static/console-fe/test/uploadfiles/uploadfiles.md b/console/src/main/resources/static/console-fe/test/uploadfiles/uploadfiles.md new file mode 100644 index 000000000..b9f2a65c2 --- /dev/null +++ b/console/src/main/resources/static/console-fe/test/uploadfiles/uploadfiles.md @@ -0,0 +1 @@ +Please save upload files here. From 662264f1182ddf7f1f7b0a0b30f4b170159fb9e1 Mon Sep 17 00:00:00 2001 From: zhichen Date: Thu, 14 Mar 2019 14:00:37 +0800 Subject: [PATCH 2/3] roll back webpack.dev.config.js --- .../main/resources/static/console-fe/build/webpack.dev.conf.js | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/console/src/main/resources/static/console-fe/build/webpack.dev.conf.js b/console/src/main/resources/static/console-fe/build/webpack.dev.conf.js index 354dfbc85..8d2696e34 100644 --- a/console/src/main/resources/static/console-fe/build/webpack.dev.conf.js +++ b/console/src/main/resources/static/console-fe/build/webpack.dev.conf.js @@ -26,7 +26,7 @@ module.exports = Object.assign({}, base, { context: ['/'], changeOrigin: true, secure: false, - target: 'http://10.101.109.214:8848/', + target: 'http://localhost:8848/', pathRewrite: {'^/v1' : '/nacos/v1'} }], disableHostCheck: true, From 8329f5296854abb202becd42ee5672d234aa2451 Mon Sep 17 00:00:00 2001 From: zhichen Date: Thu, 14 Mar 2019 14:03:47 +0800 Subject: [PATCH 3/3] roll back webpack.dev.config.js --- .../main/resources/static/console-fe/build/webpack.dev.conf.js | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/console/src/main/resources/static/console-fe/build/webpack.dev.conf.js b/console/src/main/resources/static/console-fe/build/webpack.dev.conf.js index 8d2696e34..210e08ab3 100644 --- a/console/src/main/resources/static/console-fe/build/webpack.dev.conf.js +++ b/console/src/main/resources/static/console-fe/build/webpack.dev.conf.js @@ -26,7 +26,7 @@ module.exports = Object.assign({}, base, { context: ['/'], changeOrigin: true, secure: false, - target: 'http://localhost:8848/', + target: 'http://localhost:8848', pathRewrite: {'^/v1' : '/nacos/v1'} }], disableHostCheck: true,