在实习测试套件

时间:2015-12-22 16:23:04

标签: javascript node.js testing intern

我有一个非常大的测试套件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();
      }
    };
  };
});

1 个答案:

答案 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中使用该对象的属性,因为您现在尝试使用这些参数,并且可以按照您的意愿使用。