先不要急着看码例。首先我们有必要探讨一下端到端测试到底是什么,然后才能学习如何为Node.js平台项目进行测试。
第一,端到端测试是黑箱测试的工具之一。这就意味着写测试的人只审查软件功能,不知道软件内部如何实现,即不看源代码。
第二,端到端测试也可以用作用户验收测试(UAT)。 用户验收测试是验证这个解决方案对用户来说确实可用的过程,关注的不是拼写之类的小错误,而是那些会使系统瘫痪、或使系统功能无法满足用户需求的问题。
“端到端测试也可以用作用户验收测试(UAT)”,见RisingStack
Nightwatch.js让大家能“在Node.js平台上省时省力地编写运行于Selenium/WebDriver服务器上的端到端测试”。
Nightwatch带有以下功能:
内置测试运行程序,
能控制selenium服务器,
支持由供应商提供并运行的selenium主机,比如BrowserStack或SauceLabs上的主机,
用CSS和Xpath选择元素。
想在本地运行Nightwatch,要稍微多做点事。在本地环境里需要有一个独立Selenium服务器,以及webdriver程序,这样才能使用Chrome/Firefox浏览器对程序进行本地测试。
有了以上三个工具,我们就要实施下图所示的工作流程了。
感谢:nightwatchjs.org提供的图片
只要运行npm install nightwatch --save-dev命令就可以将Nightwatch添加到项目里去。
_这个命令把Nightwatch的可执行文件放到了./node_modules/.bin文件夹里,这样就不用全局安装了。_
Selenium是多平台上网站浏览器自动化的工具套件。
先决条件:确保JDK安装好了,版本至少是7。如果还没装,可以到这里下载。
Selenium服务器是一个Java程序。Nightwatch用了这个程序就可以连接到各种各样的浏览器上去。在这里可以下载二进制执行文件。
下载了JAR文件后,在项目里创建一个bin文件夹,把文件放进去。我们要设置好让Nightwatch使用这个文件,这样就不必手动启动Selenium服务器程序了。
ChromeDriver是一个独立的服务器,为Chromium浏览器实现了W3C的WebDriver有线协议。
去下载页面获取可执行文件,同样把文件放到bin文件夹里去。
基本Nightwatch配置可以通过一个json配置文件来完成。
我们创建一个nightwatch.json文件,填上以下内容:
{
"src_folders" : ["tests"],
"output_folder" : "reports",
"selenium" : {
"start_process" : true,
"server_path" : "./bin/selenium-server-standalone-3.3.1.jar",
"log_path" : "",
"port" : 4444,
"cli_args" : {
"webdriver.chrome.driver" : "./bin/chromedriver"
}
},
"test_settings" : {
"default" : {
"launch_url" : "http://localhost",
"selenium_port" : 4444,
"selenium_host" : "localhost",
"desiredCapabilities": {
"browserName": "chrome",
"javascriptEnabled": true,
"acceptSslCerts": true
}
}
}
}
有了这个配置文件,我们就告诉了Nightwatch去哪里找Selenium服务器和Chromedriver的二进制执行文件,以及想运行的测试在哪里。
译注:下面是广告
RisingStack专家关于Node.js监控与调试的建议
目前为止,我们安装好了Nightwatch,下载好了独立的Selenium服务器,以及Chromedriver程序。做好了这几步,必备工具就都齐了,可以用Node.js平台和Selenium软件创建端到端测试了。
让我们在tests文件夹里添加一个新文件,叫作homepage.js。
我们这个例子是从Nightwatch初学指南里来的。我们的测试脚本会去Google网站,搜索Rembrandt这个词,然后查看维基页面:
module.exports = {
'Demo test Google' : function (client) {
client
.url('http://www.google.com')
.waitForElementVisible('body', 1000)
.assert.title('Google')
.assert.visible('input[type=text]')
.setValue('input[type=text]', 'rembrandt van rijn')
.waitForElementVisible('button[name=btnG]', 1000)
.click('button[name=btnG]')
.pause(1000)
.assert.containsText('ol#rso li:first-child',
'Rembrandt - Wikipedia')
.end()
}
}
接下来只要运行Nightwatch程序本身就行了!关于这一步,我建议在package.json的脚本部分加一段新脚本:
"scripts": {
"test-e2e": "nightwatch"
}
最后一步要做的就是用这个命令运行测试:
`npm run test-e2e`
如果一切顺利,测试就会打开Chrome浏览器,然后访问Google和维基。
既然已经明白了端到端测试是什么,也懂得如何设置Nightwatch了,那就该开始把它加到项目里去了。
为了做到这一点,还有一些问题要考虑,但请记住,没有万能的方法。根据企业需求不同,以下问题的答案可能也会不同:
在哪里运行测试?是在产品发布前?还是在产品发布后?什么时候生成测试用的容器?
要测试什么情景?
什么时候由谁来写端到端测试?
在这一章的Node.js at Scale里我们学习了:
如何设置Nightwatch;
如何设置Nightwatch来使用独立Selenium服务器;
如何编写基本端到端测试。
在下一章里,我们要探究如何监控用于产品发布的Node.js平台基础结构。
原文来自:众成翻译
声明:所有来源为“聚合数据”的内容信息,未经本网许可,不得转载!如对内容有异议或投诉,请与我们联系。邮箱:marketing@think-land.com
涉农贷款地址识别,支持对私和对公两种方式。输入地址的行政区划越完整,识别准确度越高。
根据给定的手机号、姓名、身份证、人像图片核验是否一致
通过企业关键词查询企业涉讼详情,如裁判文书、开庭公告、执行公告、失信公告、案件流程等等。
IP反查域名是通过IP查询相关联的域名信息的功能,它提供IP地址历史上绑定过的域名信息。
结合权威身份认证的精准人脸风险查询服务,提升人脸应用及身份认证生态的安全性。人脸风险情报库,覆盖范围广、准确性高,数据权威可靠。