我使用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文本并在测试中进一步使用?
答案 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(){ });
});
});
})