wallet-core/node_modules/selenium-webdriver/test/logging_test.js

170 lines
5.8 KiB
JavaScript
Raw Normal View History

2016-11-03 01:33:53 +01:00
// Licensed to the Software Freedom Conservancy (SFC) under one
// or more contributor license agreements. See the NOTICE file
// distributed with this work for additional information
// regarding copyright ownership. The SFC licenses this file
// to you under the Apache License, Version 2.0 (the
// "License"); you may not use this file except in compliance
// with the License. You may obtain a copy of the License at
//
// http://www.apache.org/licenses/LICENSE-2.0
//
// Unless required by applicable law or agreed to in writing,
// software distributed under the License is distributed on an
// "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY
// KIND, either express or implied. See the License for the
// specific language governing permissions and limitations
// under the License.
'use strict';
var Browser = require('..').Browser,
By = require('..').By,
logging = require('..').logging,
assert = require('../testing/assert'),
test = require('../lib/test');
test.suite(function(env) {
// Logging API has numerous issues with PhantomJS:
// - does not support adjusting log levels for type "browser".
// - does not return proper log level for "browser" messages.
// - does not delete logs after retrieval
// Logging API is not supported in IE.
// Logging API not supported in Marionette.
// Tests depend on opening data URLs, which is broken in Safari (issue 7586)
test.ignore(env.browsers(
Browser.PHANTOM_JS, Browser.IE, Browser.SAFARI, Browser.FIREFOX)).
describe('logging', function() {
var driver;
test.beforeEach(function() {
driver = null;
});
test.afterEach(function() {
if (driver) {
driver.quit();
}
});
test.it('can be disabled', function() {
var prefs = new logging.Preferences();
prefs.setLevel(logging.Type.BROWSER, logging.Level.OFF);
driver = env.builder()
.setLoggingPrefs(prefs)
.build();
driver.get(dataUrl(
'<!DOCTYPE html><script>',
'console.info("hello");',
'console.warn("this is a warning");',
'console.error("and this is an error");',
'</script>'));
driver.manage().logs().get(logging.Type.BROWSER).then(function(entries) {
assert(entries.length).equalTo(0);
});
});
// Firefox does not capture JS error console log messages.
test.ignore(env.browsers(Browser.FIREFOX, 'legacy-firefox')).
it('can be turned down', function() {
var prefs = new logging.Preferences();
prefs.setLevel(logging.Type.BROWSER, logging.Level.SEVERE);
driver = env.builder()
.setLoggingPrefs(prefs)
.build();
driver.get(dataUrl(
'<!DOCTYPE html><script>',
'console.info("hello");',
'console.warn("this is a warning");',
'console.error("and this is an error");',
'</script>'));
driver.manage().logs().get(logging.Type.BROWSER).then(function(entries) {
assert(entries.length).equalTo(1);
assert(entries[0].level.name).equalTo('SEVERE');
assert(entries[0].message).endsWith('and this is an error');
});
});
// Firefox does not capture JS error console log messages.
test.ignore(env.browsers(Browser.FIREFOX, 'legacy-firefox')).
it('can be made verbose', function() {
var prefs = new logging.Preferences();
prefs.setLevel(logging.Type.BROWSER, logging.Level.DEBUG);
driver = env.builder()
.setLoggingPrefs(prefs)
.build();
driver.get(dataUrl(
'<!DOCTYPE html><script>',
'console.debug("hello");',
'console.warn("this is a warning");',
'console.error("and this is an error");',
'</script>'));
driver.manage().logs().get(logging.Type.BROWSER).then(function(entries) {
assert(entries.length).equalTo(3);
assert(entries[0].level.name).equalTo('DEBUG');
assert(entries[0].message).endsWith('hello');
assert(entries[1].level.name).equalTo('WARNING');
assert(entries[1].message).endsWith('this is a warning');
assert(entries[2].level.name).equalTo('SEVERE');
assert(entries[2].message).endsWith('and this is an error');
});
});
// Firefox does not capture JS error console log messages.
test.ignore(env.browsers(Browser.FIREFOX, 'legacy-firefox')).
it('clears records after retrieval', function() {
var prefs = new logging.Preferences();
prefs.setLevel(logging.Type.BROWSER, logging.Level.DEBUG);
driver = env.builder()
.setLoggingPrefs(prefs)
.build();
driver.get(dataUrl(
'<!DOCTYPE html><script>',
'console.debug("hello");',
'console.warn("this is a warning");',
'console.error("and this is an error");',
'</script>'));
driver.manage().logs().get(logging.Type.BROWSER).then(function(entries) {
assert(entries.length).equalTo(3);
});
driver.manage().logs().get(logging.Type.BROWSER).then(function(entries) {
assert(entries.length).equalTo(0);
});
});
test.it('does not mix log types', function() {
var prefs = new logging.Preferences();
prefs.setLevel(logging.Type.BROWSER, logging.Level.DEBUG);
prefs.setLevel(logging.Type.DRIVER, logging.Level.SEVERE);
driver = env.builder()
.setLoggingPrefs(prefs)
.build();
driver.get(dataUrl(
'<!DOCTYPE html><script>',
'console.debug("hello");',
'console.warn("this is a warning");',
'console.error("and this is an error");',
'</script>'));
driver.manage().logs().get(logging.Type.DRIVER).then(function(entries) {
assert(entries.length).equalTo(0);
});
});
});
function dataUrl(var_args) {
return 'data:text/html,'
+ Array.prototype.slice.call(arguments, 0).join('');
}
});