如果浏览器中禁用了 javascript(使用 noscript
),我们的一个内部应用程序(用 angularjs 编写)会出现一个特殊的错误框,类似于 stackoverflow 上的错误框:
我正在尝试为其编写自动化测试,但遇到了困难。
我们正在使用 protractor
,但我很确定这不是关于它的。这是 Protractor 配置文件:
'use strict';
var helper = require('./helper.js');
exports.config = {
seleniumAddress: 'http://localhost:4444/wd/hub',
baseUrl: 'http://localhost:9001',
capabilities: helper.getFirefoxProfile(),
framework: 'jasmine',
allScriptsTimeout: 20000,
jasmineNodeOpts: {
showColors: true,
isVerbose: true,
includeStackTrace: true
}
};
哪里helper.js
是:
var q = require('q');
var FirefoxProfile = require('firefox-profile');
exports.getFirefoxProfile = function() {
var deferred = q.defer();
var firefoxProfile = new FirefoxProfile();
firefoxProfile.setPreference("javascript.enabled", false);
firefoxProfile.encoded(function(encodedProfile) {
var capabilities = {
'browserName': 'firefox',
'firefox_profile' : encodedProfile,
'specs': [
'*.spec.js'
]
};
deferred.resolve(capabilities);
});
return deferred.promise;
};
如您所见,我们正在设置 javascript.enabled
firefox 偏好 false
如果您手动打开 about:config
,这已被证明有效在 Firefox 中,将其更改为 false
- 你会看到 noscript
的内容部分。
但是,当我运行测试时,出现以下错误:
Exception thrown org.openqa.selenium.WebDriverException: waiting for evaluate.js load failed
这是 complete traceback .
仅供引用, Selenium 2.44.0
和火狐 33.1.1
被使用。
据我所知(借助提出的几点 here ),禁用 javascript 会杀死 javascript webdriver 本身。是真的吗?如果是,我有哪些选择或解决方法?
注意事项:
对于 chrome,过去可以通过
--disable-javascript
command-line argument 禁用 javascript , 但是 not anymore.这会导致第 0 号解决方法 - 将 chrome 降级到支持命令行标志的旧版本 - 这将是一个未经测试的计划 B
设置
javascript.enabled=false
firefox 首选项适用于 python selenium 绑定(bind):from selenium import webdriver profile = webdriver.FirefoxProfile() profile.set_preference('javascript.enabled', False) driver = webdriver.Firefox(firefox_profile=profile) driver.get('https://my_internal_url.com') # no errors and I can assert the error is present
我乐于接受任何建议,并可以为您提供任何其他信息。
最佳答案
这是实际发生的事情。
后来查了protractor
和selenium js webdriver的源码,发现问题的关键不在js webdriver或者protractor
,而是在我测试的编写方式。
有一个名为 ignoreSynchronization
的设置默认情况下为 false
:
/**
* If true, Protractor will not attempt to synchronize with the page before
* performing actions. This can be harmful because Protractor will not wait
* until $timeouts and $http calls have been processed, which can cause
* tests to become flaky. This should be used only when necessary, such as
* when a page continuously polls an API using $timeout.
*
* @type {boolean}
*/
this.ignoreSynchronization = false;
而且我没有将它设置为 true
,这使得 protractor
尝试与页面同步并执行客户端脚本,这 evaluate.js
负责。
解决方案是如此简单,我无法想象 - 只需将 ignoreSynchronization
设置为 true
即可解决问题:
'use strict';
require('jasmine-expect');
describe('Disabled Javascript', function () {
beforeEach(function () {
browser.ignoreSynchronization = true;
browser.get('index.html');
});
it('should show disabled js', function () {
var element = browser.findElement(by.tagName('noscript'));
expect(element.getText()).toEqual('Please enable Javascript and try again.');
});
});
希望这对将来的人有所帮助。
关于javascript - 禁用 JavaScript 的 Selenium WebDriver 测试,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/27099250/