首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >在实习生测试套件之间传递数据

在实习生测试套件之间传递数据
EN

Stack Overflow用户
提问于 2015-12-22 16:23:03
回答 1查看 99关注 0票数 0

我有一个非常大的测试套件edit_person_test.js,我试图将它分解成更小的测试套件。我想从主套件中调用较小的套件(如add_person_cancel.js ),并将在主套件的and ()中创建的数据传递给较小的测试套件(edit_person_test.js第75行)。但是,当我尝试在较小的测试套件中访问数据时,它仍然是空的。如何创建数据的一个副本并将其传递到每个较小的测试套件中?

代码语言:javascript
复制
// 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),

  };
});
});
代码语言:javascript
复制
// 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();
      }
    };
  };
});
EN

回答 1

Stack Overflow用户

回答已采纳

发布于 2015-12-22 18:46:49

这个CancelAddPersonTest函数是错误的:

代码语言:javascript
复制
 AddPersonCancel: addPersonCancel.CancelAddPersonTest(personTabPage, addPersonPage, person),

此调用发生在构建对象文本时,此时没有运行任何操作(您仍在创建将定义测试结构的对象文字),因此您传递的所有变量都是空的,并且始终是空的。

最简单的解决方案是尽早创建一个对象,然后将其传递给CancelAddPersonTest,而不是单个变量:

代码语言:javascript
复制
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中使用该对象的属性,就像您现在试图使用这些参数一样,事情会按照您的要求进行。

票数 1
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/34420199

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档