我有一个非常大的测试套件edit_person_test.js,我试图将其分解为更小的测试套件。我想从主套件中调用较小的套件,如add_person_cancel.js,并将主套件before()中创建的数据传递到较小的测试套件(edit_person_test.js第75行)。但是,当我尝试访问较小的测试套件中的数据时,它仍然为空。如何创建一个数据副本并将其传递到每个较小的测试套件中?
// Very large parent suite add_person_test.js
define([
'intern!object',
'pages/PersonTabPage',
'pages/AddPersonPage',
'data-objects/PersonData',
'./add_person_cancel'
], function(registerSuite, PersonTabPage, AddPersonPage, Person, addPersonCancel) {
registerSuite(function() {
var personTabPage = null;
var addPersonPage = null;
var person = null;
return {
// Assumes we are logged in
name: 'Edit Person Test',
before: function() {
person = new Person(); // randomly generated data to create person with
personTabPage = new PersonTabPage(this.remote, this.timeout);
addPersonPage = new AddPersonPage(this.remote, this.timeout);
},
// calling smaller suite here
AddPersonCancel: addPersonCancel.CancelAddPersonTest(personTabPage, addPersonPage, person),
};
});
});
// Smaller test suite add_person_cancel.js
define(function() {
return function(personTabPage, addPersonPage, person) {
return {
// Assumes we are logged in
name: 'Cancel Add Person Test',
OpenAddPersonPage: function() {
logger.info(person);
return personTabPage.clickAddPerson()
.getAccumulatedState();
},
ValidateButtonDisabledStatus: function() {
return addPersonPage.personButtonStatus(function(status) {
assert.isFalse(status, 'Buttons are enabled even before entering person name');
})
.getAccumulatedState();
},
EnterNameClickCancelButton: function() {
return addPersonPage.enterFirstName(person.firstName)
.enterLastName(person.lastName)
.clickCancelButton()
.waitForPageReady()
.getAccumulatedState();
},
CheckPersonNameNotSaved: function() {
return personTabPage
.findInPersonsTableAssertion(person.firstName + ' ' + person.lastName, false, function(result) {
assert.isFalse(result, 'Person name is saved even on closing the trowser using Cancel button');
})
.getAccumulatedState();
}
};
};
});
答案 0 :(得分:1)
此CancelAddPersonTest函数错误:
AddPersonCancel: addPersonCancel.CancelAddPersonTest(personTabPage, addPersonPage, person),
这个调用是在构造对象文字时发生的,此时没有任何东西运行过(你仍然在创建定义测试结构的对象文字),所以你传递的所有变量都是null,并且永远都是。
最简单的解决方案是尽早创建一个对象,然后将其传递给CancelAddPersonTest
而不是单个变量:
var personState = {
personTabPage: null,
addPersonPage: null,
person: null
};
return {
// ...
before: function() {
personState.person = new Person(); // randomly generated data to create person with
personState.personTabPage = new PersonTabPage(this.remote, this.timeout);
personState.addPersonPage = new AddPersonPage(this.remote, this.timeout);
},
// ...
AddPersonCancel: addPersonCancel.CancelAddPersonTest(personState)
};
现在,在CancelAddPersonTest
中使用该对象的属性,因为您现在尝试使用这些参数,并且可以按照您的意愿使用。