aboutsummaryrefslogtreecommitdiff
path: root/node_modules/selenium-webdriver/test/logging_test.js
diff options
context:
space:
mode:
authorFlorian Dold <florian.dold@gmail.com>2016-11-03 01:33:53 +0100
committerFlorian Dold <florian.dold@gmail.com>2016-11-03 01:33:53 +0100
commitd1291f67551c58168af43698a359cb5ddfd266b0 (patch)
tree55a13ed29fe1915e3f42f1b1b7038dafa2e975a7 /node_modules/selenium-webdriver/test/logging_test.js
parentd0a0695fb5d34996850723f7d4b1b59c3df909c2 (diff)
node_modules
Diffstat (limited to 'node_modules/selenium-webdriver/test/logging_test.js')
-rw-r--r--node_modules/selenium-webdriver/test/logging_test.js169
1 files changed, 169 insertions, 0 deletions
diff --git a/node_modules/selenium-webdriver/test/logging_test.js b/node_modules/selenium-webdriver/test/logging_test.js
new file mode 100644
index 000000000..fd88daa72
--- /dev/null
+++ b/node_modules/selenium-webdriver/test/logging_test.js
@@ -0,0 +1,169 @@
+// 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('');
+ }
+});