All Downloads are FREE. Search and download functionalities are using the official Maven repository.

org.openqa.selenium.logging.LoggingPreferences Maven / Gradle / Ivy

Go to download

Selenium automates browsers. That's it! What you do with that power is entirely up to you.

There is a newer version: 4.26.0
Show newest version
// 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.

package org.openqa.selenium.logging;

import java.io.Serializable;
import java.util.HashMap;
import java.util.HashSet;
import java.util.Map;
import java.util.Set;
import java.util.TreeMap;
import java.util.logging.Level;
import org.openqa.selenium.Beta;

/**
 * Represents the logging preferences.
 *
 * 

Sample usage: DesiredCapabilities caps = DesiredCapabilities.firefox(); LoggingPreferences * logs = new LoggingPreferences(); logs.enable(LogType.DRIVER, Level.INFO); * caps.setCapability(CapabilityType.LOGGING_PREFS, logs); * *

WebDriver driver = new FirefoxDriver(caps); */ public class LoggingPreferences implements Serializable { private static final long serialVersionUID = 6708028456766320675L; // Mapping the {@link LogType} to {@link Level} private final Map prefs = new HashMap<>(); /** * Enables logging for the given log type at the specified level and above. * * @param logType String the logType. Can be any of {@link LogType}. * @param level {@link Level} the level. */ public void enable(String logType, Level level) { prefs.put(logType, level); } /** * @return the set of log types for which logging has been enabled. */ public Set getEnabledLogTypes() { return new HashSet<>(prefs.keySet()); } /** * @param logType The log type. * @return the {@link Level} for the given {@link LogType} if enabled. Otherwise returns {@link * Level#OFF}. */ public Level getLevel(String logType) { return prefs.get(logType) == null ? Level.OFF : prefs.get(logType); } /** * Adds the given logging preferences giving them precedence over existing preferences. * * @param prefs The logging preferences to add. * @return A references to this object. */ public LoggingPreferences addPreferences(LoggingPreferences prefs) { if (prefs == null) { return this; } for (String logType : prefs.getEnabledLogTypes()) { enable(logType, prefs.getLevel(logType)); } return this; } @Override public int hashCode() { return prefs.hashCode(); } @Override public boolean equals(Object o) { if (this == o) { return true; } if (!(o instanceof LoggingPreferences)) { return false; } LoggingPreferences that = (LoggingPreferences) o; return prefs.equals(that.prefs); } @Beta public Map toJson() { TreeMap converted = new TreeMap<>(); for (String logType : getEnabledLogTypes()) { converted.put(logType, LogLevelMapping.getName(getLevel(logType))); } return converted; } }





© 2015 - 2024 Weber Informatics LLC | Privacy Policy