[−][src]Crate thirtyfour
Selenium client for working with W3C-compatible WebDriver implmentations.
NOTE: This project is still WIP and not yet ready for production.
The API is roughly modeled after the python selenium library.
Synchronous and asynchronous APIs are provided (see examples below).
The following examples assume you have a selenium server running at localhost:4444.
i.e.
ⓘThis example is not tested
java -jar selenium-server-standalone-3.141.59.jar
Async example:
use std::thread; use std::time::Duration; use thirtyfour::error::WebDriverResult; use thirtyfour::{By, WebDriver, common::keys::TypingData}; use tokio; #[tokio::main] async fn main() { webtest().await.expect("Something went wrong"); } async fn webtest() -> WebDriverResult<()> { let caps = serde_json::json!({ "browserName": "chrome", "version": "", "platform": "any" }); let driver = WebDriver::new("http://localhost:4444/wd/hub", caps).await?; // Navigate to https://wikipedia.org. driver.get("https://wikipedia.org").await?; let elem_form = driver.find_element(By::Id("search-form")).await?; // Find element from element. let elem_text = elem_form.find_element(By::Id("searchInput")).await?; // Type in the search terms. elem_text.send_keys(TypingData::from("selenium")).await?; // Click the search button. let elem_button = elem_form.find_element(By::Css("button[type='submit']")).await?; elem_button.click().await?; // Look for header to implicitly wait for the page to load. driver.find_element(By::ClassName("firstHeading")).await?; assert_eq!(driver.title().await?, "Selenium - Wikipedia"); Ok(()) }
Sync example:
use std::thread; use std::time::Duration; use thirtyfour::error::WebDriverResult; use thirtyfour::{By, sync::WebDriver, common::keys::TypingData}; fn main() { webtest().expect("Something went wrong"); } fn webtest() -> WebDriverResult<()> { let caps = serde_json::json!({ "browserName": "chrome", "version": "", "platform": "any" }); let driver = WebDriver::new("http://localhost:4444/wd/hub", caps)?; // Navigate to https://wikipedia.org. driver.get("https://wikipedia.org")?; let elem_form = driver.find_element(By::Id("search-form"))?; // Find element from element. let elem_text = elem_form.find_element(By::Id("searchInput"))?; // Type in the search terms. elem_text.send_keys(TypingData::from("selenium"))?; // Click the search button. let elem_button = elem_form.find_element(By::Css("button[type='submit']"))?; elem_button.click()?; // Look for header to implicitly wait for the page to load. driver.find_element(By::ClassName("firstHeading"))?; assert_eq!(driver.title()?, "Selenium - Wikipedia"); Ok(()) }
Re-exports
pub use common::command::By; |
pub use common::cookie::Cookie; |
pub use common::types::*; |
Modules
action_chain | |
common | |
error | |
sync |
Structs
RemoteConnectionAsync | Asynchronous remote connection with the Remote WebDriver server. |
WebDriver | The WebDriver struct encapsulates an async Selenium WebDriver browser session. For the async driver, see sync::WebDriver. |
WebElement | The WebElement struct encapsulates a single element on a page. |