创建一个循环运行的测试

时间:2016-05-18 16:48:13

标签: javascript typescript automated-tests nightwatch.js

我有这个代码并且运行正常,但是我希望它在循环中运行,这样它将计算它在class="socal"中有多少个元素,然后测试每个链接。

module.exports = {
    'Unitel Fitness - click' : function (browser) {
    browser
        .url('http://m.unitel.ao/fit/')
        .execute('scrollIntoView(alignToBottom)')
        .waitForElementVisible('.socal>span:nth-child(1) a', 6000)

        .moveToElement('.socal>span:nth-child(1) a', 3, 3)
        .pause(6000)
        .click(".socal>span:nth-child(1) a")
        .pause(6000)
        .keys(['\uE006'])

        .window_handles(function (result) {
            var handle = result.value[1];
            browser.switchWindow(handle);
            browser.pause(1000);
            //browser.assert.urlContains('facebook');
            browser.closeWindow();
        })
        .end();
    }
};

我为此升级了代码,但仍然没有完全按照我的意愿行事。 结果如下:(我试过给了更多时间)

链接数:执行前4 i val:执行前1 i val:执行前2 i val:执行前3 i val:4?在等待元素< .socal> span:nth-​​child(“+ i +”)a>时超时存在8000毫秒。 - 期望“可见”但得到:未找到

module.exports = {
                'Social links' : function (browser) {
        browser
            .url('http://m.unitel.ao/fit/')
            .execute(function(){
                        return document.querySelectorAll(".socal>span").length;
                    },

            function(links) {
                total_links = links.value;

                console.log("Number of links: " + total_links);

                for (var i = 1; i <= total_links; i++) {
                    console.log("i val before execute: " + i);

                    browser.execute('scrollIntoView(alignToBottom)');
                    //browser.waitForElementVisible('.socal>span:nth-child("+ i +") a', 8000);

                    //call back function
                    browser.waitForElementVisible('.socal>span:nth-child("+ i +") a', 5000, function() {

                    browser.moveToElement('.socal>span:nth-child("+ i +") a', 3, 3);
                    browser.pause(8000);
                    browser.click(".socal>span:nth-child("+ i +") a");
                    browser.pause(6000);
                    browser.keys(['\uE006']);

                    browser.window_handles(function (result) {
                        var handle = result.value[1];
                        browser.switchWindow(handle);
                        browser.pause(8000);
                        //browser.assert.urlContains('facebook');
                        browser.closeWindow();
                    })
                        });
                }
            })

               // .end();
            }
};

1 个答案:

答案 0 :(得分:0)

为什么循环何时可以获得一个集合并使用.length?它的性能也更高。

client.getEls(classSel, function(collection) {      
            return collection.length;
});