Sah*_*gal 4 testing automation json data-driven-tests protractor
我是量角器的新手.任何人都可以指导我使用量角器进行数据驱动测试.下面是代码,配置文件和testdata.json文件.
'use strict';
var testData = require('../example/Test Data/Test.json');
describe('LoginPage', function() {
var loginData = require('../example/Test Data/Test.json');
testData.forEach(function (data) {
it("data.description", function (data) {
browser.get("http://127.0.0.1:8080/#/login");
element(by.model("username")).sendKeys(data.username);
element(by.model("password")).sendKeys(data.passwordField);
element(by.buttonText("Authenticate")).click();
});
});
});
Run Code Online (Sandbox Code Playgroud)
配置文件:
// An example configuration file.
exports.config = {
directConnect: true,
//seleniumAddress: 'http://localhost:4444/wd/hub',
// Capabilities to be passed to the webdriver instance.
capabilities: {
'browserName': 'chrome'
},
// Framework to use. Jasmine is recommended.
framework: 'jasmine',
// Spec patterns are relative to the current working directory when
// protractor is called.
specs: ['Testpage.js'],
// Options to be passed to Jasmine.
jasmineNodeOpts: {
defaultTimeoutInterval: 30000
}
};
Run Code Online (Sandbox Code Playgroud)
Json文件:
[
{
"username": "admin",
"passwordField": "admin"
},
{
"username": "admin1",
"passwordField": "admin2"
}
]
Run Code Online (Sandbox Code Playgroud)
问题是,它不是在获取数据,而是在所有输入框中编写未定义的内容.请帮忙
我们有jasmine-data-provider软件包,它将帮助我们使用Protractor进行数据驱动测试.
Code Snippet:
var using = require(‘jasmine-data-provider);
var loginData = require('../example/Test Data/Test.json');
describe('Data driven test spec', function () { /*define sets of input data as array in method called arrayOfData*/
function arrayOfData() {
return [
{
"username": "admin",
"passwordField": "admin"
},
{
"username": "admin1",
"passwordField": "admin2"
}
]
//or return loginData json object here
} /*below one will loop the test case based on data size and pass single data set every time till complete the end of array*/
using(arrayofData, function (inputData) {
it('test case logic to be executed for each set of data', function () {
browser.get("http://127.0.0.1:8080/#/login");
element(by.model("username")).sendKeys(inputData.username);
element(by.model("password")).sendKeys(inputData.passwordField);
element(by.buttonText("Authenticate")).click();
});
});
});
Run Code Online (Sandbox Code Playgroud)
注意:如果您的计算机中尚未安装jasmine-data-provider软件包,请在运行测试脚本之前通过运行以下命令进行安装.
npm install jasmine-data-provider
Run Code Online (Sandbox Code Playgroud)
我假设它是一个对象数组,您可以迭代每个数组元素并直接访问其内容,您不需要testdata.forEach(),您可以尝试这样的事情 -
'use strict';
var testData = require('../example/Test Data/Test.json');
describe('LoginPage', function() {
it("data.description", function () {
browser.get("http://127.0.0.1:8080/#/login");
element(by.model("username")).sendKeys(testData[0].username);
element(by.model("password")).sendKeys(testData[0].passwordField);
element(by.buttonText("Authenticate")).click();
});
});
});
Run Code Online (Sandbox Code Playgroud)
我尚未测试上述代码,您应该使用页面对象,而不是在测试中直接使用它们!
| 归档时间: |
|
| 查看次数: |
10499 次 |
| 最近记录: |