Introdução ao ChromeDriver

Esta página documenta como começar a usar o ChromeDriver para testar seu site no computador (Windows/Mac/Linux). Você também pode ler Introdução ao Android ou Introdução ao ChromeOS.

Configuração

O ChromeDriver é um executável separado que o Selenium WebDriver usa para controlar o Chrome. Ele é mantido pela equipe do Chromium com a ajuda de colaboradores do WebDriver. Se você não conhece o Selenium WebDriver, confira o site do Selenium (link em inglês).

Siga estas etapas para configurar seus testes para execução com o ChromeDriver:

  • Verifique se o Chromium/Google Chrome está instalado em um local reconhecido
  • Faça o download do binário do ChromeDriver da sua plataforma na seção downloads deste site
  • Ajudar o WebDriver a encontrar o executável do ChromeDriver transferido por download

Qualquer uma destas etapas pode funcionar:

  1. inclua o local do ChromeDriver na variável de ambiente PATH
  2. (Somente Java) especifique o local usando a propriedade do sistema webdriver.chrome.driver (veja o exemplo abaixo)
  3. (somente Python) inclua o caminho para ChromeDriver ao instanciar webdriver.Chrome (veja o exemplo abaixo).

Exemplo de teste

Java:

import org.openqa.selenium.*;
import org.openqa.selenium.chrome.*;
import org.junit.Test;
public class GettingStarted {   
@Test   
public void testGoogleSearch() throws InterruptedException {
  // Optional. If not specified, WebDriver searches the PATH for chromedriver.
  // System.setProperty("webdriver.chrome.driver", "/path/to/chromedriver");
  // WebDriver driver = new ChromeDriver();
  driver.get("http://www.google.com/"); 
  Thread.sleep(5000);  // Let the user actually see something!
  WebElement searchBox = driver.findElement(By.name("q"));
  searchBox.sendKeys("ChromeDriver");
  searchBox.submit(); 
  Thread.sleep(5000);  // Let the user actually see something!
  driver.quit();  
 }
}

Python:

import time
from selenium import webdriver

driver = webdriver.Chrome('/path/to/chromedriver')  # Optional argument, if not specified will search path.
driver.get('http://www.google.com/');
time.sleep(5) # Let the user actually see something!
search_box = driver.find_element_by_name('q')
search_box.send_keys('ChromeDriver')
search_box.submit()
time.sleep(5) # Let the user actually see something!
driver.quit()

Controlar o ciclo de vida do ChromeDriver

A classe ChromeDriver inicia o processo do servidor ChromeDriver na criação e o encerra quando quit é chamado. Isso pode desperdiçar um tempo significativo de pacotes de teste grandes, em que uma instância do ChromeDriver é criada por teste. Há duas opções para resolver isso:

  1. Use o ChromeDriverService. Esse recurso está disponível na maioria dos idiomas e permite que você inicie ou pare o servidor do ChromeDriver por conta própria. Veja aqui um exemplo de Java (com JUnit 4):
import java.io.*;
import org.junit.*;
import org.openqa.selenium.*;
import org.openqa.selenium.chrome.*;
import org.openqa.selenium.remote.*;
public class GettingStartedWithService {
  private static ChromeDriverService service;
  private WebDriver driver;
  @BeforeClass
  public static void createAndStartService() throws IOException {
      service = new ChromeDriverService.Builder()
              .usingDriverExecutable(new File("/path/to/chromedriver"))
              .usingAnyFreePort()
              .build();
      service.start();
  }
  
  @AfterClass   
  public static void stopService() {
    service.stop();
  }

  @Before   
  public void createDriver() {
    driver = new RemoteWebDriver(service.getUrl(), new ChromeOptions());
  }

  @After   public void quitDriver() {
    driver.quit();
  }

  @Test   
  public void testGoogleSearch() {
    driver.get("http://www.google.com");
    // rest of the test...
  }
}

Python:

import time
from selenium import webdriver
from selenium.webdriver.chrome.service import Service
service = Service('/path/to/chromedriver')
service.start()
driver = webdriver.Remote(service.service_url)
driver.get('http://www.google.com/');
time.sleep(5) # Let the user actually see something!
driver.quit()
  1. Inicie o servidor ChromeDriver separadamente antes de executar os testes e conecte-se a ele usando o Remote WebDriver.

Terminal:

$ ./chromedriver
Starting ChromeDriver
76.0.3809.68 (...) on port 9515
...

Java:

import java.net.*;
import org.openqa.selenium.*;
import org.openqa.selenium.chrome.*;
import org.openqa.selenium.remote.*;  

public class GettingStartedRemote {

  public static void main(String[] args) throws MalformedURLException {
    WebDriver driver = new RemoteWebDriver(
        new URL("http://127.0.0.1:9515"),
        new ChromeOptions());
    driver.get("http://www.google.com");
    driver.quit();
  }
}