如何在nodejs soda中生成动态断言

时间:2013-04-27 02:42:33

标签: selenium selenium-webdriver selenium-rc selenium-ide soda

我使用soda脚本在nodejs中为selenium提供了以下代码。

如果您在下面看到我的脚本,请查找verifyData() 针对固定列值进行行测试。我想动态生成这些断言,只有行号会变化,列总是会相同,如何实现这一点。我可以将行号传递给这个方法。

第二件事,如果你看到断言我使用了function(),我们可以在这里捕获err / assertfail吗?

var browser = soda.createClient({
.....
});

browser 
    .chain
    .session()  
    .setSpeed(speed)
    .setTimeout(2000)
    .open('/')
    .and(login('dev@dev.com', 'x1212GQsdtpS'))
    .and(verifyData())
    .end(function(err){
        console.log('error');

    });

function login(user, pass) {
  return function(browser) {
    browser
    .click('css=a#loginButton')
    .type('css=input.input-medium.email',user)
    .type('css=input.input.pwd',pass)
    .clickAndWait('css=a.btn.login')
    .assertTextPresent('Clients',function(){ console.log('logged in ok')})
  }
}


function verifyData() {
  return function(browser) {
    browser
    //Row 1 testing
    .assertText('css=div.keyYears table tbody tr:nth-child(1) td:nth-child(3)','some text',function(){ console.log('looks good')})
    .assertText('css=div.keyYears table tbody tr:nth-child(1) td:nth-child(5)','some text')
    .assertText('css=div.keyYears table tbody tr:nth-child(1) td:nth-child(6)','some text')
    .assertText('css=div.keyYears table tbody tr:nth-child(1) td:nth-child(7)','some text')
    //Row 2 testing
    .assertText('css=div.keyYears table tbody tr:nth-child(2) td:nth-child(3)','some text1',function(){ console.log('looks good')})
    .assertText('css=div.keyYears table tbody tr:nth-child(2) td:nth-child(5)','some text1')
    .assertText('css=div.keyYears table tbody tr:nth-child(2) td:nth-child(6)','some text1')
    .assertText('css=div.keyYears table tbody tr:nth-child(2) td:nth-child(7)','some text1')

  }
}

1 个答案:

答案 0 :(得分:0)

我得到了解决方案,我们必须做以下事情:

browser
  .chain
  .setSpeed(200)
  .session()
  .open('/')
  .click("id=save")
  .focus(editor)
  .and(function (browser) {
    for (var i = 0; i < 10; i++) {
      browser.keyDown(editor, '\\40')
    }
  })
  ...