Node中的量角器:如何命令我的测试同步运行?

时间:2015-06-11 22:29:47

标签: node.js selenium jasmine protractor

我想知道如何执行多个"描述"同步顺序的块?

describe('Go To Home Page', function () {  
    browser.ignoreSynchronization = true;
    it("Url should be on Login Page", function ()  {
        browser.get(HomePageUrl).then(function () {
            browser.wait(urlChanged(loginPageUrl), 2000).then(
                function (newurl){
                    var url = browser.getCurrentUrl().then(function (url) {
                        expect(url).tobe(loginPageUrl);
                        //I know I'm at Login page url... how do I kick off next test?                 
                    });                     
                }
            )          
        });
    });
}); 

此测试转到主页,然后如果将其重定向到“登录”页面,我想使用新的Describe块执行所有登录测试。问题是,如果我将下一个Describe块放在与第一个相同的级别,则节点并行执行所有这些块。

我不想进入回调 - 地狱......我认为上面的代码已经过深了。

1 个答案:

答案 0 :(得分:5)

Jasmine对此表示Asyncronous support

describe('Go To Home Page', function () {  
    browser.ignoreSynchronization = true;
    it("Url should be on Login Page", function (done)  {
        browser.get(HomePageUrl).then(function () {
            browser.wait(urlChanged(loginPageUrl), 2000).then(
                function (newurl){
                    var url = browser.getCurrentUrl().then(function (url) {
                        expect(url).tobe(loginPageUrl);
                        done();      
                    });                     
                }
            )          
        });
    });

   it("next", function ()  {
      //will start this block after previous done callback has been called
   });
}); 

PS Promises可以而且应该在一行中链接以避免嵌套:

it("Url should be on Login Page", function (done)  {
    browser
        .get(HomePageUrl)
        .then(function () {
            return browser.wait(urlChanged(loginPageUrl), 2000);
        })
        .then(function () {
            return browser.getCurrentUrl();
        })
        .then(function (currentUrl){
            expect(currentUrl).tobe(loginPageUrl);
            done();         
        });
});