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

org.openqa.selenium.ie.InternetExplorerDriver Maven / Gradle / Ivy

The 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.ie;

import org.openqa.selenium.Beta;
import org.openqa.selenium.Capabilities;
import org.openqa.selenium.Platform;
import org.openqa.selenium.WebDriverException;
import org.openqa.selenium.remote.FileDetector;
import org.openqa.selenium.remote.RemoteWebDriver;
import org.openqa.selenium.remote.RemoteWebDriverBuilder;
import org.openqa.selenium.remote.http.ClientConfig;
import org.openqa.selenium.remote.service.DriverCommandExecutor;
import org.openqa.selenium.remote.service.DriverFinder;

public class InternetExplorerDriver extends RemoteWebDriver {

  /** Capability that defines whether to ignore the browser zoom level or not. */
  public static final String IGNORE_ZOOM_SETTING = "ignoreZoomSetting";

  /**
   * Capability that defines to use whether to use native or javascript events during operations.
   *
   * @deprecated Non W3C compliant
   */
  @Deprecated public static final String NATIVE_EVENTS = "nativeEvents";

  /** Capability that defines the initial URL to be used when IE is launched. */
  public static final String INITIAL_BROWSER_URL = "initialBrowserUrl";

  /** Capability that defines how elements are scrolled into view in the InternetExplorerDriver. */
  public static final String ELEMENT_SCROLL_BEHAVIOR = "elementScrollBehavior";

  /** Capability that defines to use or not cleanup of element cache on document loading. */
  public static final String ENABLE_ELEMENT_CACHE_CLEANUP = "enableElementCacheCleanup";

  /** Capability that defines timeout in milliseconds for attaching to new browser window. */
  public static final String BROWSER_ATTACH_TIMEOUT = "browserAttachTimeout";

  /**
   * Capability that defines to ignore browser protected mode settings during starting by
   * IEDriverServer.
   *
   * 

Setting this capability will make your tests unstable and hard to debug. */ public static final String INTRODUCE_FLAKINESS_BY_IGNORING_SECURITY_DOMAINS = "ignoreProtectedModeSettings"; /** Capability that defines to use persistent hovering or not. */ public static final String ENABLE_PERSISTENT_HOVERING = "enablePersistentHover"; /** Capability that defines to focus to browser window or not before operation. */ public static final String REQUIRE_WINDOW_FOCUS = "requireWindowFocus"; /** Capability that defines launch API of IE used by IEDriverServer. */ public static final String FORCE_CREATE_PROCESS = "ie.forceCreateProcessApi"; /** * Capability that defines to clean or not browser cache before launching IE by IEDriverServer. */ public static final String IE_ENSURE_CLEAN_SESSION = "ie.ensureCleanSession"; /** * Capability that defines setting the proxy information for a single IE process without affecting * the proxy settings of other instances of IE. */ public static final String IE_USE_PER_PROCESS_PROXY = "ie.usePerProcessProxy"; /** Capability that defines used IE CLI switches when {@link #FORCE_CREATE_PROCESS} is enabled. */ public static final String IE_SWITCHES = "ie.browserCommandLineSwitches"; public InternetExplorerDriver() { this( InternetExplorerDriverService.createDefaultService(), new InternetExplorerOptions(), ClientConfig.defaultConfig()); } public InternetExplorerDriver(InternetExplorerOptions options) { this( InternetExplorerDriverService.createDefaultService(), options, ClientConfig.defaultConfig()); } public InternetExplorerDriver(InternetExplorerDriverService service) { this(service, new InternetExplorerOptions(), ClientConfig.defaultConfig()); } public InternetExplorerDriver( InternetExplorerDriverService service, InternetExplorerOptions options) { this(service, options, ClientConfig.defaultConfig()); } /** * Creates a new InternetExplorerDriver instance with the specified options. The {@code service} * will be started along with the driver, and shutdown upon calling {@link #quit()}. * * @param service The service to use. * @param options The options required from InternetExplorerDriver. */ public InternetExplorerDriver( InternetExplorerDriverService service, InternetExplorerOptions options, ClientConfig clientConfig) { if (options == null) { options = new InternetExplorerOptions(); } if (service == null) { service = InternetExplorerDriverService.createDefaultService(); } service.setExecutable(new DriverFinder(service, options).getDriverPath()); if (clientConfig == null) { clientConfig = ClientConfig.defaultConfig(); } run(service, options, clientConfig); } @Beta public static RemoteWebDriverBuilder builder() { return RemoteWebDriver.builder().oneOf(new InternetExplorerOptions()); } private void run( InternetExplorerDriverService service, Capabilities capabilities, ClientConfig clientConfig) { assertOnWindows(); setCommandExecutor(new DriverCommandExecutor(service, clientConfig)); startSession(capabilities); } @Override public void setFileDetector(FileDetector detector) { throw new WebDriverException( "Setting the file detector only works on remote webdriver instances obtained " + "via RemoteWebDriver"); } protected void assertOnWindows() { Platform current = Platform.getCurrent(); if (!current.is(Platform.WINDOWS)) { throw new WebDriverException( String.format( "You appear to be running %s. The IE driver only runs on Windows.", current)); } } }





© 2015 - 2025 Weber Informatics LLC | Privacy Policy