storeEval编号没问题,但是文本 - 失败

时间:2013-07-21 12:08:40

标签: selenium

我使用soda selenium进行集成测试。 以下代码有效:

我保存了元素的高度,然后在测试中使用它:

var soda = require('soda')
    , assert = require('assert');
var browser = soda.createClient({
    host: 'localhost'
    , port: 4444
    , url: 'http://jquery.com'
    , browser: 'firefox'
});
browser.session(function(err){
    browser.open('/', function(err, body, res){
        browser.storeEval("window.jQuery('.logo').height();", "height", function(err, body, res){
            browser.getEval('${height}',function(err,val){
                if(err !== null) throw err
                console.log(val) //------ it outputs 66 in console, so it works well
                browser.testComplete(function(){ });
            });
        });
    });
})

当我尝试获取元素window.jQuery('h2.logo').text();的文本时,它失败了:

var soda = require('soda')
    , assert = require('assert');
var browser = soda.createClient({
    host: 'localhost'
    , port: 4444
    , url: 'http://jquery.com'
    , browser: 'firefox'
});
browser.session(function(err){
    browser.open('/', function(err, body, res){
        browser.storeEval("window.jQuery('h2.logo').text();", "text", function(err, body, res){
            browser.getEval('${text}',function(err,val){
                if(err !== null) throw err
                console.log(val) // ------------------------- null
                browser.testComplete(function(){ });
            });
        });
    });
})

它在控制台中打印null。所以h2文本为null但是当我在浏览器控制台上检查它时会打印:

window.jQuery('h2.logo').text()
"jQuery"

那么如何存储h2文本并在测试中进一步使用?

1 个答案:

答案 0 :(得分:1)

Thanx,Slanec。 getText对我有用:

var soda = require('soda')
    , assert = require('assert');
var browser = soda.createClient({
    host: 'localhost'
    , port: 4444
    , url: 'http://jquery.com'
    , browser: 'firefox'
});
browser.session(function(err){
    browser.open('/', function(err, body, res){
        browser.getText('css=h2.logo',function(err,val){
            if(err !== null) throw err
            console.log(val) //------------------- jQuery
            browser.testComplete(function(){ });
        });
    });
})