2017-07-19 39 views
1

对于新版本的产品,我决定尝试一种页面对象方法,而不是使用视图,可能我开始错误地使用它。Nightwatch:使用页面对象内的自定义命令

我们有一个简单地等待一个元素和点击(waitAndClick.js)的自定义命令:

exports.command = function(selector, callback) { 
    return this 
    .waitForElementPresent(selector, 30000) 
    .click(selector, callback); 
}; 

它完美的测试里面:

const {client} = require('nightwatch-cucumber'); 
const {defineSupportCode} = require('cucumber'); 

defineSupportCode(({Given, Then, When}) => { 
    Given(/^I enable Dashboard management$/,() => { 
     return client.waitAndClick('[id=enableManagement]'); 
    }); 
}); 

但是,当我试图在页面对象内使用它会抛出一个错误:

module.exports = { 
    url() { 
    return this.api.launchUrl; 
    }, 
    elements: { 
    username: '[name="_Nitro_Login_username"]', 
    password: '[name="_Nitro_Login_password"]', 
    enter_button: '[title="Enter"]' 
    }, 
    commands: [ 
    { 
     loginAs(username, password) { 
     return this.waitForElementVisible('@username', 50000) 
      .setValue('@username', username) 
      .setValue('@password', password) 
      .waitAndClick('@enter_button') 
      .waitForElementNotPresent('@enter_button', 50000); 
     } 
    } 
    ] 
}; 

我也尝试过使用.api.waitAndClic k('@ enter_button'),结果相同。

和错误消息:

Error while running click command: Provided locating strategy is not supported: [title="enter"]. It must be one of the following:

class name, css selector, id, name, link text, partial link text, tag name, xpath

at Object.exports.command (/Users/eaflor/dev/jive-next/test/ui/commands/waitAndClick.js:9:63) 

at Object.F.command (/Users/eaflor/dev/jive-next/node_modules/nightwatch/lib/core/api.js:274:31) 

at Object.commandFn (/Users/eaflor/dev/jive-next/node_modules/nightwatch/lib/core/api.js:287:24) 

at AsyncTree.runCommand (/Users/eaflor/dev/jive-next/node_modules/nightwatch/lib/core/queue.js:154:30) 

at AsyncTree.runChildNode (/Users/eaflor/dev/jive-next/node_modules/nightwatch/lib/core/queue.js:114:8) 

at AsyncTree.walkDown (/Users/eaflor/dev/jive-next/node_modules/nightwatch/lib/core/queue.js:80:10) 

at AsyncTree.walkUp (/Users/eaflor/dev/jive-next/node_modules/nightwatch/lib/core/queue.js:97:8) 

at AsyncTree.walkDown (/Users/eaflor/dev/jive-next/node_modules/nightwatch/lib/core/queue.js:90:12) 

at AsyncTree.traverse (/Users/eaflor/dev/jive-next/node_modules/nightwatch/lib/core/queue.js:73:8) 

at F.onCommandComplete (/Users/eaflor/dev/jive-next/node_modules/nightwatch/lib/core/queue.js:131:12) 

at F.g (events.js:291:16) 

at emitNone (events.js:86:13) 

at F.emit (events.js:185:7) 

at /Users/eaflor/dev/jive-next/node_modules/nightwatch/lib/api/client-commands/_locateStrategy.js:18:10 

at _combinedTickCallback (internal/process/next_tick.js:67:7) 

at process._tickCallback (internal/process/next_tick.js:98:9) 

Is it even possible to use custom commands inside the page object?

回答

1

我找到解决它的办法。为了在页面对象使用自定义命令你必须把它们写在类风格:http://nightwatchjs.org/guide#writing-custom-commands

这应该什么样子:

var util = require('util'); 
var events = require('events'); 

function waitAndClick() { 
    events.EventEmitter.call(this); 
} 

util.inherits(waitAndClick, events.EventEmitter); 

waitAndClick.prototype.command = function(selector) { 
    const api = this.client.api; 

    api 
      .waitForElementPresent(selector) 
      .click(selector,() => { 
       this.emit('complete'); 
      }) 
    ; 

    return this; 
}; 

module.exports = waitAndClick; 

希望它会帮助别人。

+0

感谢 - 只是出于兴趣 - 如果在pageObject命令中使用此自定义命令,我们是否返回调用此方法或Nightwatch API实例的pageObject? – GrayedFox

相关问题