From 0668c6a8e7344d10386a1128fe6b0e18bd4fea11 Mon Sep 17 00:00:00 2001 From: Boni Garcia Date: Tue, 19 Sep 2023 16:16:35 +0200 Subject: [PATCH 01/33] [rust] Automated Edge management (macOS) (#11681) --- rust/src/edge.rs | 245 ++++++++++++++++++++++++++++++++++++++++++++++- 1 file changed, 240 insertions(+), 5 deletions(-) diff --git a/rust/src/edge.rs b/rust/src/edge.rs index 26ac93d2da7f1..eb1f87ce13299 100644 --- a/rust/src/edge.rs +++ b/rust/src/edge.rs @@ -17,20 +17,22 @@ use crate::config::ManagerConfig; use reqwest::Client; +use serde::{Deserialize, Serialize}; use std::collections::HashMap; use std::error::Error; use std::path::PathBuf; use crate::config::ARCH::{ARM64, X32}; use crate::config::OS::{LINUX, MACOS, WINDOWS}; -use crate::downloads::read_version_from_link; +use crate::downloads::{parse_json_from_url, read_version_from_link}; use crate::files::{compose_driver_path_in_cache, BrowserPath}; use crate::metadata::{ create_driver_metadata, get_driver_version_from_metadata, get_metadata, write_metadata, }; use crate::{ - create_http_client, Logger, SeleniumManager, BETA, DASH_DASH_VERSION, DEV, NIGHTLY, - OFFLINE_REQUEST_ERR_MSG, REG_VERSION_ARG, STABLE, + create_browser_metadata, create_http_client, download_to_tmp_folder, + get_browser_version_from_metadata, path_buf_to_string, uncompress, Logger, SeleniumManager, + BETA, DASH_DASH_VERSION, DEV, NIGHTLY, OFFLINE_REQUEST_ERR_MSG, REG_VERSION_ARG, STABLE, }; pub const EDGE_NAMES: &[&str] = &["edge", "msedge", "microsoftedge"]; @@ -38,6 +40,12 @@ pub const EDGEDRIVER_NAME: &str = "msedgedriver"; const DRIVER_URL: &str = "https://msedgedriver.azureedge.net/"; const LATEST_STABLE: &str = "LATEST_STABLE"; const LATEST_RELEASE: &str = "LATEST_RELEASE"; +const BROWSER_URL: &str = "https://edgeupdates.microsoft.com/api/products"; +const EDGE_MACOS_APP_NAME: &str = "Microsoft Edge.app/Contents/MacOS/Microsoft Edge"; +const EDGE_BETA_MACOS_APP_NAME: &str = "Microsoft Edge Beta.app/Contents/MacOS/Microsoft Edge Beta"; +const EDGE_DEV_MACOS_APP_NAME: &str = "Microsoft Edge Dev.app/Contents/MacOS/Microsoft Edge Dev"; +const EDGE_CANARY_MACOS_APP_NAME: &str = + "Microsoft Edge Canary.app/Contents/MacOS/Microsoft Edge Canary"; pub struct EdgeManager { pub browser_name: &'static str, @@ -45,6 +53,7 @@ pub struct EdgeManager { pub config: ManagerConfig, pub http_client: Client, pub log: Logger, + pub browser_url: Option, } impl EdgeManager { @@ -60,8 +69,33 @@ impl EdgeManager { http_client: create_http_client(default_timeout, default_proxy)?, config, log: Logger::new(), + browser_url: None, })) } + + // TODO check + fn get_browser_url(&self) -> Result> { + let browser_url = self.browser_url.clone(); + Ok(browser_url.unwrap_or_default()) + } + + fn get_browser_binary_path_in_cache(&self) -> Result> { + let browser_in_cache = self.get_browser_path_in_cache()?; + if MACOS.is(self.get_os()) { + let macos_app_name = if self.is_browser_version_beta() { + EDGE_BETA_MACOS_APP_NAME + } else if self.is_browser_version_dev() { + EDGE_DEV_MACOS_APP_NAME + } else if self.is_browser_version_nightly() { + EDGE_CANARY_MACOS_APP_NAME + } else { + EDGE_MACOS_APP_NAME + }; + Ok(browser_in_cache.join(macos_app_name)) + } else { + Ok(browser_in_cache.join(self.get_browser_name_with_extension())) + } + } } impl SeleniumManager for EdgeManager { @@ -264,8 +298,95 @@ impl SeleniumManager for EdgeManager { self.log = log; } + // TODO check fn download_browser(&mut self) -> Result, Box> { - Ok(None) + let browser_version; + let browser_name = self.browser_name; + let mut metadata = get_metadata(self.get_logger(), self.get_cache_path()?); + let major_browser_version = self.get_major_browser_version(); + + // Browser version is checked in the local metadata + match get_browser_version_from_metadata( + &metadata.browsers, + browser_name, + &major_browser_version, + ) { + Some(version) => { + self.get_logger().trace(format!( + "Browser with valid TTL. Getting {} version from metadata", + browser_name + )); + browser_version = version; + self.set_browser_version(browser_version.clone()); + } + _ => { + // If not in metadata, discover version using Mozilla online metadata + if self.is_browser_version_stable() || self.is_browser_version_empty() { + browser_version = self.request_latest_browser_version_from_online()?; + } else { + browser_version = self.request_fixed_browser_version_from_online()?; + } + self.set_browser_version(browser_version.clone()); + + let browser_ttl = self.get_ttl(); + if browser_ttl > 0 + && !self.is_browser_version_empty() + && !self.is_browser_version_stable() + { + metadata.browsers.push(create_browser_metadata( + browser_name, + &major_browser_version, + &browser_version, + browser_ttl, + )); + write_metadata(&metadata, self.get_logger(), self.get_cache_path()?); + } + } + } + self.get_logger().debug(format!( + "Required browser: {} {}", + browser_name, browser_version + )); + + // Checking if browser version is in the cache + let browser_binary_path = self.get_browser_binary_path_in_cache()?; + if browser_binary_path.exists() { + self.get_logger().debug(format!( + "{} {} already in the cache", + browser_name, browser_version + )); + } else { + // If browser is not in the cache, download it + let browser_url = self.get_browser_url()?; + self.get_logger().debug(format!( + "Downloading {} {} from {}", + self.get_browser_name(), + self.get_browser_version(), + browser_url + )); + let (_tmp_folder, driver_zip_file) = + download_to_tmp_folder(self.get_http_client(), browser_url, self.get_logger())?; + + let major_browser_version_int = self + .get_major_browser_version() + .parse::() + .unwrap_or_default(); + uncompress( + &driver_zip_file, + &self.get_browser_path_in_cache()?, + self.get_logger(), + self.get_os(), + None, + None, + Some(major_browser_version_int), + )?; + } + if browser_binary_path.exists() { + self.set_browser_path(path_buf_to_string(browser_binary_path.clone())); + Ok(Some(browser_binary_path)) + } else { + Ok(None) + } } fn get_platform_label(&self) -> &str { @@ -290,11 +411,125 @@ impl SeleniumManager for EdgeManager { } } + // TODO check fn request_latest_browser_version_from_online(&mut self) -> Result> { - self.unavailable_download() + let browser_version = self.get_browser_version(); + let edge_updates_url = if browser_version.is_empty() { + BROWSER_URL.to_string() + } else { + format!("{}?view=enterprise", BROWSER_URL) + }; + let edge_products = parse_json_from_url::>( + self.get_http_client(), + edge_updates_url.clone(), + )?; + + let edge_channel = if self.is_browser_version_beta() { + "Beta" + } else if self.is_browser_version_dev() { + "Dev" + } else if self.is_browser_version_nightly() { + "Canary" + } else { + "Stable" + }; + let products: Vec<&EdgeProduct> = edge_products + .iter() + .filter(|p| p.product.eq_ignore_ascii_case(edge_channel)) + .collect(); + self.get_logger().trace(format!("Products: {:?}", products)); + + let os = self.get_os(); + let arch = self.get_arch(); + let arch_label = if WINDOWS.is(os) { + if ARM64.is(arch) { + "arm64" + } else if X32.is(arch) { + "x86" + } else { + "x64" + } + } else if MACOS.is(os) { + "universal" + } else { + "x64" + }; + let releases: Vec<&Release> = products + .first() + .unwrap() + .releases + .iter() + .filter(|r| r.architecture.eq_ignore_ascii_case(arch_label)) + .collect(); + self.get_logger().trace(format!("Releases: {:?}", releases)); + + let package_label = if WINDOWS.is(os) { + "msi" + } else if MACOS.is(os) { + "pkg" + } else { + "deb" + }; + let release = releases.first().unwrap(); + let artifacts: Vec<&Artifact> = release + .artifacts + .iter() + .filter(|a| a.artifact_name.eq_ignore_ascii_case(package_label)) + .collect(); + self.get_logger() + .trace(format!("Artifacts: {:?}", artifacts)); + + let artifact = artifacts.first().unwrap(); + let browser_version = release.product_version.clone(); + self.browser_url = Some(artifact.location.clone()); + + Ok(browser_version) } + // TODO fn request_fixed_browser_version_from_online(&mut self) -> Result> { self.unavailable_download() } } + +#[derive(Serialize, Deserialize, Debug)] +pub struct EdgeProduct { + #[serde(rename = "Product")] + pub product: String, + #[serde(rename = "Releases")] + pub releases: Vec, +} + +#[derive(Serialize, Deserialize, Debug)] +pub struct Release { + #[serde(rename = "ReleaseId")] + pub release_id: u32, + #[serde(rename = "Platform")] + pub platform: String, + #[serde(rename = "Architecture")] + pub architecture: String, + #[serde(rename = "CVEs")] + pub cves: Vec, + #[serde(rename = "ProductVersion")] + pub product_version: String, + #[serde(rename = "Artifacts")] + pub artifacts: Vec, + #[serde(rename = "PublishedTime")] + pub published_time: String, + #[serde(rename = "ExpectedExpiryDate")] + pub expected_expiry_date: String, +} + +#[derive(Serialize, Deserialize, Debug)] +pub struct Artifact { + #[serde(rename = "ArtifactName")] + pub artifact_name: String, + #[serde(rename = "Location")] + pub location: String, + #[serde(rename = "Hash")] + pub hash: String, + #[serde(rename = "HashAlgorithm")] + pub hash_algorithm: String, + #[serde(rename = "SizeInBytes")] + pub size_in_bytes: u32, +} From 9a5ae46b1771da6df7eb7945ce0f16db041ec0d9 Mon Sep 17 00:00:00 2001 From: Boni Garcia Date: Tue, 19 Sep 2023 16:42:55 +0200 Subject: [PATCH 02/33] [rust] Check also unstable versions for Edge management --- rust/src/edge.rs | 10 ++++++---- 1 file changed, 6 insertions(+), 4 deletions(-) diff --git a/rust/src/edge.rs b/rust/src/edge.rs index eb1f87ce13299..6ba34c35b33e9 100644 --- a/rust/src/edge.rs +++ b/rust/src/edge.rs @@ -414,7 +414,7 @@ impl SeleniumManager for EdgeManager { // TODO check fn request_latest_browser_version_from_online(&mut self) -> Result> { let browser_version = self.get_browser_version(); - let edge_updates_url = if browser_version.is_empty() { + let edge_updates_url = if browser_version.is_empty() || self.is_browser_version_unstable() { BROWSER_URL.to_string() } else { format!("{}?view=enterprise", BROWSER_URL) @@ -459,7 +459,10 @@ impl SeleniumManager for EdgeManager { .unwrap() .releases .iter() - .filter(|r| r.architecture.eq_ignore_ascii_case(arch_label)) + .filter(|r| { + r.platform.eq_ignore_ascii_case(os) + && r.architecture.eq_ignore_ascii_case(arch_label) + }) .collect(); self.get_logger().trace(format!("Releases: {:?}", releases)); @@ -486,9 +489,8 @@ impl SeleniumManager for EdgeManager { Ok(browser_version) } - // TODO fn request_fixed_browser_version_from_online(&mut self) -> Result> { - self.unavailable_download() + self.request_latest_browser_version_from_online() } } From 501ffe6b0d589fd22de4d98506293dc87ef7bee7 Mon Sep 17 00:00:00 2001 From: Boni Garcia Date: Tue, 19 Sep 2023 17:07:16 +0200 Subject: [PATCH 03/33] [rust] Include logic to check fixed versions of Edge --- rust/src/edge.rs | 31 +++++++++++++++++++++++++++---- rust/src/firefox.rs | 3 +-- rust/src/lib.rs | 1 + 3 files changed, 29 insertions(+), 6 deletions(-) diff --git a/rust/src/edge.rs b/rust/src/edge.rs index 6ba34c35b33e9..8221acfa5caab 100644 --- a/rust/src/edge.rs +++ b/rust/src/edge.rs @@ -30,9 +30,10 @@ use crate::metadata::{ create_driver_metadata, get_driver_version_from_metadata, get_metadata, write_metadata, }; use crate::{ - create_browser_metadata, create_http_client, download_to_tmp_folder, + create_browser_metadata, create_http_client, download_to_tmp_folder, format_two_args, get_browser_version_from_metadata, path_buf_to_string, uncompress, Logger, SeleniumManager, - BETA, DASH_DASH_VERSION, DEV, NIGHTLY, OFFLINE_REQUEST_ERR_MSG, REG_VERSION_ARG, STABLE, + BETA, DASH_DASH_VERSION, DEV, NIGHTLY, OFFLINE_REQUEST_ERR_MSG, ONLINE_DISCOVERY_ERROR_MESSAGE, + REG_VERSION_ARG, STABLE, }; pub const EDGE_NAMES: &[&str] = &["edge", "msedge", "microsoftedge"]; @@ -413,12 +414,16 @@ impl SeleniumManager for EdgeManager { // TODO check fn request_latest_browser_version_from_online(&mut self) -> Result> { + let browser_name = self.browser_name; let browser_version = self.get_browser_version(); let edge_updates_url = if browser_version.is_empty() || self.is_browser_version_unstable() { BROWSER_URL.to_string() } else { format!("{}?view=enterprise", BROWSER_URL) }; + self.get_logger() + .debug(format!("Checking Edge releases on {}", edge_updates_url)); + let edge_products = parse_json_from_url::>( self.get_http_client(), edge_updates_url.clone(), @@ -441,7 +446,9 @@ impl SeleniumManager for EdgeManager { let os = self.get_os(); let arch = self.get_arch(); + let os_label; let arch_label = if WINDOWS.is(os) { + os_label = "Windows"; if ARM64.is(arch) { "arm64" } else if X32.is(arch) { @@ -450,8 +457,10 @@ impl SeleniumManager for EdgeManager { "x64" } } else if MACOS.is(os) { + os_label = "MacOS"; "universal" } else { + os_label = "Linux"; "x64" }; let releases: Vec<&Release> = products @@ -460,8 +469,14 @@ impl SeleniumManager for EdgeManager { .releases .iter() .filter(|r| { - r.platform.eq_ignore_ascii_case(os) - && r.architecture.eq_ignore_ascii_case(arch_label) + let os_arch = r.platform.eq_ignore_ascii_case(os_label) + && r.architecture.eq_ignore_ascii_case(arch_label); + if !browser_version.is_empty() && !self.is_browser_version_unstable() { + let browser_version_label = format!("{}.", browser_version); + os_arch && r.product_version.starts_with(&browser_version_label) + } else { + os_arch + } }) .collect(); self.get_logger().trace(format!("Releases: {:?}", releases)); @@ -473,6 +488,14 @@ impl SeleniumManager for EdgeManager { } else { "deb" }; + if releases.is_empty() { + return Err(format_two_args( + ONLINE_DISCOVERY_ERROR_MESSAGE, + browser_name, + self.get_browser_version(), + ) + .into()); + } let release = releases.first().unwrap(); let artifacts: Vec<&Artifact> = release .artifacts diff --git a/rust/src/firefox.rs b/rust/src/firefox.rs index 276ecde8bb6f6..bb637562ee2af 100644 --- a/rust/src/firefox.rs +++ b/rust/src/firefox.rs @@ -35,7 +35,7 @@ use crate::{ create_browser_metadata, create_http_client, download_to_tmp_folder, format_three_args, format_two_args, get_browser_version_from_metadata, path_to_string, uncompress, Logger, SeleniumManager, BETA, CANARY, DASH_VERSION, DEV, NIGHTLY, OFFLINE_REQUEST_ERR_MSG, - REG_CURRENT_VERSION_ARG, STABLE, + ONLINE_DISCOVERY_ERROR_MESSAGE, REG_CURRENT_VERSION_ARG, STABLE, }; pub const FIREFOX_NAME: &str = "firefox"; @@ -61,7 +61,6 @@ const FIREFOX_NIGHTLY_VOLUME: &str = r#"Firefox\ Nightly"#; const MIN_DOWNLOADABLE_FIREFOX_VERSION_WIN: i32 = 13; const MIN_DOWNLOADABLE_FIREFOX_VERSION_MAC: i32 = 4; const MIN_DOWNLOADABLE_FIREFOX_VERSION_LINUX: i32 = 4; -const ONLINE_DISCOVERY_ERROR_MESSAGE: &str = "Unable to discover {} {} in online repository"; const UNAVAILABLE_DOWNLOAD_ERROR_MESSAGE: &str = "{} {} not available for downloading (minimum version: {})"; diff --git a/rust/src/lib.rs b/rust/src/lib.rs index 7684a43f477b4..d1078a07b4a53 100644 --- a/rust/src/lib.rs +++ b/rust/src/lib.rs @@ -102,6 +102,7 @@ pub const SNAPSHOT: &str = "SNAPSHOT"; pub const OFFLINE_REQUEST_ERR_MSG: &str = "Unable to discover proper {} version in offline mode"; pub const OFFLINE_DOWNLOAD_ERR_MSG: &str = "Unable to download {} in offline mode"; pub const UNAVAILABLE_DOWNLOAD_ERR_MSG: &str = "{} not available for downloading"; +pub const ONLINE_DISCOVERY_ERROR_MESSAGE: &str = "Unable to discover {} {} in online repository"; pub const UNC_PREFIX: &str = r#"\\?\"#; pub trait SeleniumManager { From b0d03e9b94146a4d5c491b639a81dd756eccd12c Mon Sep 17 00:00:00 2001 From: Boni Garcia Date: Tue, 19 Sep 2023 17:43:22 +0200 Subject: [PATCH 04/33] [rust] Include additional log messages --- rust/src/edge.rs | 27 ++++++++++++++++++--------- 1 file changed, 18 insertions(+), 9 deletions(-) diff --git a/rust/src/edge.rs b/rust/src/edge.rs index 8221acfa5caab..07f9b4e1fd0e8 100644 --- a/rust/src/edge.rs +++ b/rust/src/edge.rs @@ -32,8 +32,8 @@ use crate::metadata::{ use crate::{ create_browser_metadata, create_http_client, download_to_tmp_folder, format_two_args, get_browser_version_from_metadata, path_buf_to_string, uncompress, Logger, SeleniumManager, - BETA, DASH_DASH_VERSION, DEV, NIGHTLY, OFFLINE_REQUEST_ERR_MSG, ONLINE_DISCOVERY_ERROR_MESSAGE, - REG_VERSION_ARG, STABLE, + BETA, CANARY, DASH_DASH_VERSION, DEV, NIGHTLY, OFFLINE_REQUEST_ERR_MSG, + ONLINE_DISCOVERY_ERROR_MESSAGE, REG_VERSION_ARG, STABLE, }; pub const EDGE_NAMES: &[&str] = &["edge", "msedge", "microsoftedge"]; @@ -80,14 +80,19 @@ impl EdgeManager { Ok(browser_url.unwrap_or_default()) } - fn get_browser_binary_path_in_cache(&self) -> Result> { + fn get_browser_binary_path_in_cache( + &self, + original_browser_version: &str, + ) -> Result> { let browser_in_cache = self.get_browser_path_in_cache()?; if MACOS.is(self.get_os()) { - let macos_app_name = if self.is_browser_version_beta() { + let macos_app_name = if original_browser_version.eq_ignore_ascii_case(BETA) { EDGE_BETA_MACOS_APP_NAME - } else if self.is_browser_version_dev() { + } else if original_browser_version.eq_ignore_ascii_case(DEV) { EDGE_DEV_MACOS_APP_NAME - } else if self.is_browser_version_nightly() { + } else if original_browser_version.eq_ignore_ascii_case(NIGHTLY) + || original_browser_version.eq_ignore_ascii_case(CANARY) + { EDGE_CANARY_MACOS_APP_NAME } else { EDGE_MACOS_APP_NAME @@ -303,6 +308,7 @@ impl SeleniumManager for EdgeManager { fn download_browser(&mut self) -> Result, Box> { let browser_version; let browser_name = self.browser_name; + let original_browser_version = self.get_config().browser_version.clone(); let mut metadata = get_metadata(self.get_logger(), self.get_cache_path()?); let major_browser_version = self.get_major_browser_version(); @@ -350,7 +356,8 @@ impl SeleniumManager for EdgeManager { )); // Checking if browser version is in the cache - let browser_binary_path = self.get_browser_binary_path_in_cache()?; + let browser_binary_path = + self.get_browser_binary_path_in_cache(&original_browser_version)?; if browser_binary_path.exists() { self.get_logger().debug(format!( "{} {} already in the cache", @@ -421,8 +428,10 @@ impl SeleniumManager for EdgeManager { } else { format!("{}?view=enterprise", BROWSER_URL) }; - self.get_logger() - .debug(format!("Checking Edge releases on {}", edge_updates_url)); + self.get_logger().debug(format!( + "Checking {} releases on {}", + browser_name, edge_updates_url + )); let edge_products = parse_json_from_url::>( self.get_http_client(), From b277e8cf4a5ab0a0d65fad8bf0c0abd449409200 Mon Sep 17 00:00:00 2001 From: Boni Garcia Date: Tue, 19 Sep 2023 18:28:42 +0200 Subject: [PATCH 05/33] [rust] Get browser url again if empty --- rust/src/edge.rs | 8 +++++--- 1 file changed, 5 insertions(+), 3 deletions(-) diff --git a/rust/src/edge.rs b/rust/src/edge.rs index 07f9b4e1fd0e8..8c44aa7bdbd3f 100644 --- a/rust/src/edge.rs +++ b/rust/src/edge.rs @@ -75,9 +75,11 @@ impl EdgeManager { } // TODO check - fn get_browser_url(&self) -> Result> { - let browser_url = self.browser_url.clone(); - Ok(browser_url.unwrap_or_default()) + fn get_browser_url(&mut self) -> Result> { + if self.browser_url.is_none() { + self.request_latest_browser_version_from_online()?; + } + Ok(self.browser_url.clone().unwrap()) } fn get_browser_binary_path_in_cache( From 1d1a905b7e664b5d0896c55fea9c4b0855e005d5 Mon Sep 17 00:00:00 2001 From: Boni Garcia Date: Wed, 20 Sep 2023 18:15:12 +0200 Subject: [PATCH 06/33] [rust] Include logic for stable label --- rust/src/edge.rs | 17 +++++++++++------ 1 file changed, 11 insertions(+), 6 deletions(-) diff --git a/rust/src/edge.rs b/rust/src/edge.rs index 8c44aa7bdbd3f..2fd637ee2cefc 100644 --- a/rust/src/edge.rs +++ b/rust/src/edge.rs @@ -425,10 +425,13 @@ impl SeleniumManager for EdgeManager { fn request_latest_browser_version_from_online(&mut self) -> Result> { let browser_name = self.browser_name; let browser_version = self.get_browser_version(); - let edge_updates_url = if browser_version.is_empty() || self.is_browser_version_unstable() { - BROWSER_URL.to_string() - } else { + let is_fixed_browser_version = !self.is_browser_version_empty() + && !self.is_browser_version_stable() + && !self.is_browser_version_unstable(); + let edge_updates_url = if is_fixed_browser_version { format!("{}?view=enterprise", BROWSER_URL) + } else { + BROWSER_URL.to_string() }; self.get_logger().debug(format!( "Checking {} releases on {}", @@ -440,14 +443,16 @@ impl SeleniumManager for EdgeManager { edge_updates_url.clone(), )?; - let edge_channel = if self.is_browser_version_beta() { + let edge_channel = if self.is_browser_version_empty() || self.is_browser_version_stable() { + "Stable" + } else if self.is_browser_version_beta() { "Beta" } else if self.is_browser_version_dev() { "Dev" } else if self.is_browser_version_nightly() { "Canary" } else { - "Stable" + return Err(format!("Incorrect {} version: {}", browser_name, browser_version).into()); }; let products: Vec<&EdgeProduct> = edge_products .iter() @@ -482,7 +487,7 @@ impl SeleniumManager for EdgeManager { .filter(|r| { let os_arch = r.platform.eq_ignore_ascii_case(os_label) && r.architecture.eq_ignore_ascii_case(arch_label); - if !browser_version.is_empty() && !self.is_browser_version_unstable() { + if is_fixed_browser_version { let browser_version_label = format!("{}.", browser_version); os_arch && r.product_version.starts_with(&browser_version_label) } else { From 64b282a89d15bfdc427db1edd356e100430bb550 Mon Sep 17 00:00:00 2001 From: Boni Garcia Date: Sun, 24 Sep 2023 19:16:11 +0200 Subject: [PATCH 07/33] [rust] Automated Edge management (Linux) (#11681 and #11683) --- rust/Cargo.lock | 62 ++++++++++++++++++++++++++++++++++++++++++++++- rust/Cargo.toml | 1 + rust/src/edge.rs | 35 ++++++++++++++++++-------- rust/src/files.rs | 33 +++++++++++++++++++++++++ 4 files changed, 120 insertions(+), 11 deletions(-) diff --git a/rust/Cargo.lock b/rust/Cargo.lock index 27bbb73d5360b..f1cf6b94a6b64 100644 --- a/rust/Cargo.lock +++ b/rust/Cargo.lock @@ -98,6 +98,18 @@ dependencies = [ "windows-sys 0.48.0", ] +[[package]] +name = "ar" +version = "0.9.0" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "d67af77d68a931ecd5cbd8a3b5987d63a1d1d1278f7f6a60ae33db485cdebb69" + +[[package]] +name = "arrayvec" +version = "0.7.4" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "96d30a06541fbafbc7f82ed10c06164cfbd2c401138f6addd8404629c4b16711" + [[package]] name = "assert_cmd" version = "2.0.12" @@ -393,6 +405,24 @@ dependencies = [ "typenum", ] +[[package]] +name = "debpkg" +version = "0.6.0" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "7ffffa9a03449467cfac11c9a4260556f477de22a935bb5e9475153de323c337" +dependencies = [ + "ar", + "arrayvec", + "bzip2", + "flate2", + "indexmap 1.9.2", + "infer 0.8.1", + "log", + "tar", + "xz2", + "zstd", +] + [[package]] name = "difflib" version = "0.4.0" @@ -868,6 +898,15 @@ dependencies = [ "hashbrown 0.14.0", ] +[[package]] +name = "infer" +version = "0.8.1" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "e035cede526e0b21d5adffc9fa0eb4ef5d6026fe9c5b0bfe8084b9472b587a55" +dependencies = [ + "cfb", +] + [[package]] name = "infer" version = "0.15.0" @@ -990,6 +1029,17 @@ dependencies = [ "byteorder", ] +[[package]] +name = "lzma-sys" +version = "0.1.20" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "5fda04ab3764e6cde78b9974eec4f779acaba7c4e84b36eca3cf77c581b85d27" +dependencies = [ + "cc", + "libc", + "pkg-config", +] + [[package]] name = "memchr" version = "2.5.0" @@ -1445,11 +1495,12 @@ dependencies = [ "assert_cmd", "bzip2", "clap", + "debpkg", "directories", "env_logger", "exitcode", "flate2", - "infer", + "infer 0.15.0", "is_executable", "log", "regex", @@ -2233,6 +2284,15 @@ dependencies = [ "libc", ] +[[package]] +name = "xz2" +version = "0.1.7" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "388c44dc09d76f1536602ead6d325eb532f5c122f17782bd57fb47baeeb767e2" +dependencies = [ + "lzma-sys", +] + [[package]] name = "zip" version = "0.6.6" diff --git a/rust/Cargo.toml b/rust/Cargo.toml index b6dcf3d853af7..1fe680ee5a0a4 100644 --- a/rust/Cargo.toml +++ b/rust/Cargo.toml @@ -32,6 +32,7 @@ toml = "0.7.6" bzip2 = "0.4.4" sevenz-rust = "0.5.2" walkdir = "2.4.0" +debpkg = "0.6.0" [dev-dependencies] assert_cmd = "2.0.12" diff --git a/rust/src/edge.rs b/rust/src/edge.rs index 2fd637ee2cefc..9e634c4a34d54 100644 --- a/rust/src/edge.rs +++ b/rust/src/edge.rs @@ -31,9 +31,9 @@ use crate::metadata::{ }; use crate::{ create_browser_metadata, create_http_client, download_to_tmp_folder, format_two_args, - get_browser_version_from_metadata, path_buf_to_string, uncompress, Logger, SeleniumManager, - BETA, CANARY, DASH_DASH_VERSION, DEV, NIGHTLY, OFFLINE_REQUEST_ERR_MSG, - ONLINE_DISCOVERY_ERROR_MESSAGE, REG_VERSION_ARG, STABLE, + get_binary_extension, get_browser_version_from_metadata, path_buf_to_string, uncompress, + Logger, SeleniumManager, BETA, CANARY, DASH_DASH_VERSION, DEV, NIGHTLY, + OFFLINE_REQUEST_ERR_MSG, ONLINE_DISCOVERY_ERROR_MESSAGE, REG_VERSION_ARG, STABLE, }; pub const EDGE_NAMES: &[&str] = &["edge", "msedge", "microsoftedge"]; @@ -42,6 +42,7 @@ const DRIVER_URL: &str = "https://msedgedriver.azureedge.net/"; const LATEST_STABLE: &str = "LATEST_STABLE"; const LATEST_RELEASE: &str = "LATEST_RELEASE"; const BROWSER_URL: &str = "https://edgeupdates.microsoft.com/api/products"; +const EDGE_WINDOWS_AND_LINUX_APP_NAME: &str = "msedge"; const EDGE_MACOS_APP_NAME: &str = "Microsoft Edge.app/Contents/MacOS/Microsoft Edge"; const EDGE_BETA_MACOS_APP_NAME: &str = "Microsoft Edge Beta.app/Contents/MacOS/Microsoft Edge Beta"; const EDGE_DEV_MACOS_APP_NAME: &str = "Microsoft Edge Dev.app/Contents/MacOS/Microsoft Edge Dev"; @@ -74,7 +75,6 @@ impl EdgeManager { })) } - // TODO check fn get_browser_url(&mut self) -> Result> { if self.browser_url.is_none() { self.request_latest_browser_version_from_online()?; @@ -101,7 +101,11 @@ impl EdgeManager { }; Ok(browser_in_cache.join(macos_app_name)) } else { - Ok(browser_in_cache.join(self.get_browser_name_with_extension())) + Ok(browser_in_cache.join(format!( + "{}{}", + EDGE_WINDOWS_AND_LINUX_APP_NAME, + get_binary_extension(self.get_os()) + ))) } } } @@ -381,13 +385,26 @@ impl SeleniumManager for EdgeManager { .get_major_browser_version() .parse::() .unwrap_or_default(); + + // TODO check + let extract_label = if original_browser_version.eq_ignore_ascii_case(BETA) { + Some("msedge-beta") + } else if original_browser_version.eq_ignore_ascii_case(DEV) { + Some("msedge-dev") + } else if original_browser_version.eq_ignore_ascii_case(NIGHTLY) + || original_browser_version.eq_ignore_ascii_case(CANARY) + { + Some("msedge-canary") + } else { + Some("msedge") + }; uncompress( &driver_zip_file, &self.get_browser_path_in_cache()?, self.get_logger(), self.get_os(), None, - None, + extract_label, Some(major_browser_version_int), )?; } @@ -443,16 +460,14 @@ impl SeleniumManager for EdgeManager { edge_updates_url.clone(), )?; - let edge_channel = if self.is_browser_version_empty() || self.is_browser_version_stable() { - "Stable" - } else if self.is_browser_version_beta() { + let edge_channel = if self.is_browser_version_beta() { "Beta" } else if self.is_browser_version_dev() { "Dev" } else if self.is_browser_version_nightly() { "Canary" } else { - return Err(format!("Incorrect {} version: {}", browser_name, browser_version).into()); + "Stable" }; let products: Vec<&EdgeProduct> = edge_products .iter() diff --git a/rust/src/files.rs b/rust/src/files.rs index 06fb9b4bd290a..94dd492271f57 100644 --- a/rust/src/files.rs +++ b/rust/src/files.rs @@ -49,6 +49,7 @@ const BZ2: &str = "bz2"; const PKG: &str = "pkg"; const DMG: &str = "dmg"; const EXE: &str = "exe"; +const DEB: &str = "deb"; const SEVEN_ZIP_HEADER: &[u8; 6] = b"7z\xBC\xAF\x27\x1C"; const UNCOMPRESS_MACOS_ERR_MSG: &str = "{} files are only supported in macOS"; @@ -136,6 +137,8 @@ pub fn uncompress( uncompress_dmg(compressed_file, target, log, os, volume.unwrap_or_default())? } else if extension.eq_ignore_ascii_case(EXE) { uncompress_sfx(compressed_file, target, log)? + } else if extension.eq_ignore_ascii_case(DEB) { + uncompress_deb(compressed_file, target, log, volume.unwrap_or_default())? } else if extension.eq_ignore_ascii_case(XML) || extension.eq_ignore_ascii_case(HTML) { log.debug(format!( "Wrong downloaded driver: {}", @@ -259,6 +262,36 @@ pub fn uncompress_dmg( Ok(()) } +pub fn uncompress_deb( + compressed_file: &str, + target: &Path, + log: &Logger, + label: &str, +) -> Result<(), Box> { + let zip_parent = Path::new(compressed_file).parent().unwrap(); + log.trace(format!( + "Extracting from {} to {}", + compressed_file, + zip_parent.display() + )); + + let deb_file = File::open(compressed_file)?; + let mut deb_pkg = debpkg::DebPkg::parse(deb_file)?; + deb_pkg.data()?.unpack(zip_parent)?; + + let zip_parent_str = path_buf_to_string(zip_parent.to_path_buf()); + let target_str = path_buf_to_string(target.to_path_buf()); + let opt_edge_str = format!(r#"{}\opt\microsoft\{}"#, zip_parent_str, label); + log.trace(format!( + "Moving extracted files and folders from {} to {}", + opt_edge_str, target_str + )); + create_parent_path_if_not_exists(target)?; + fs::rename(&opt_edge_str, &target_str)?; + + Ok(()) +} + pub fn untargz(compressed_file: &str, target: &Path, log: &Logger) -> Result<(), Box> { log.trace(format!( "Untargz {} to {}", From 1445faee820d7f288f53d002a825594b86ccc01a Mon Sep 17 00:00:00 2001 From: Boni Garcia Date: Sun, 24 Sep 2023 19:32:00 +0200 Subject: [PATCH 08/33] [rust] Fix paths used to extract edge --- rust/src/files.rs | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/rust/src/files.rs b/rust/src/files.rs index 94dd492271f57..385be51616a7e 100644 --- a/rust/src/files.rs +++ b/rust/src/files.rs @@ -281,7 +281,7 @@ pub fn uncompress_deb( let zip_parent_str = path_buf_to_string(zip_parent.to_path_buf()); let target_str = path_buf_to_string(target.to_path_buf()); - let opt_edge_str = format!(r#"{}\opt\microsoft\{}"#, zip_parent_str, label); + let opt_edge_str = format!("{}/opt/microsoft/{}", zip_parent_str, label); log.trace(format!( "Moving extracted files and folders from {} to {}", opt_edge_str, target_str From 72ad82c409ff74f297381934eb31028d51fa097f Mon Sep 17 00:00:00 2001 From: Boni Garcia Date: Wed, 27 Sep 2023 16:53:11 +0200 Subject: [PATCH 09/33] [rust] Clean extract label and fix searched version --- rust/src/edge.rs | 13 ++++++------- 1 file changed, 6 insertions(+), 7 deletions(-) diff --git a/rust/src/edge.rs b/rust/src/edge.rs index 9e634c4a34d54..7ce136563fa5e 100644 --- a/rust/src/edge.rs +++ b/rust/src/edge.rs @@ -388,15 +388,15 @@ impl SeleniumManager for EdgeManager { // TODO check let extract_label = if original_browser_version.eq_ignore_ascii_case(BETA) { - Some("msedge-beta") + "msedge-beta" } else if original_browser_version.eq_ignore_ascii_case(DEV) { - Some("msedge-dev") + "msedge-dev" } else if original_browser_version.eq_ignore_ascii_case(NIGHTLY) || original_browser_version.eq_ignore_ascii_case(CANARY) { - Some("msedge-canary") + "msedge-canary" } else { - Some("msedge") + "msedge" }; uncompress( &driver_zip_file, @@ -404,7 +404,7 @@ impl SeleniumManager for EdgeManager { self.get_logger(), self.get_os(), None, - extract_label, + Some(extract_label), Some(major_browser_version_int), )?; } @@ -503,8 +503,7 @@ impl SeleniumManager for EdgeManager { let os_arch = r.platform.eq_ignore_ascii_case(os_label) && r.architecture.eq_ignore_ascii_case(arch_label); if is_fixed_browser_version { - let browser_version_label = format!("{}.", browser_version); - os_arch && r.product_version.starts_with(&browser_version_label) + os_arch && r.product_version.starts_with(&browser_version) } else { os_arch } From 12f9dab917263588755fee9bf207a91432cc0d02 Mon Sep 17 00:00:00 2001 From: Boni Garcia Date: Thu, 28 Sep 2023 11:21:18 +0200 Subject: [PATCH 10/33] [rust] Refactor logic for downloading browsers in a common function --- rust/src/chrome.rs | 168 ++++++---------------- rust/src/edge.rs | 205 ++++++++------------------- rust/src/firefox.rs | 315 ++++++++++++++++-------------------------- rust/src/grid.rs | 26 +++- rust/src/iexplorer.rs | 26 +++- rust/src/lib.rs | 157 +++++++++++++++++++-- rust/src/safari.rs | 26 +++- rust/src/safaritp.rs | 26 +++- 8 files changed, 450 insertions(+), 499 deletions(-) diff --git a/rust/src/chrome.rs b/rust/src/chrome.rs index 80601856e41c5..c65319a7291e3 100644 --- a/rust/src/chrome.rs +++ b/rust/src/chrome.rs @@ -32,9 +32,8 @@ use crate::metadata::{ create_driver_metadata, get_driver_version_from_metadata, get_metadata, write_metadata, }; use crate::{ - create_browser_metadata, create_http_client, download_to_tmp_folder, format_three_args, - get_browser_version_from_metadata, uncompress, SeleniumManager, BETA, DASH_DASH_VERSION, DEV, - NIGHTLY, OFFLINE_REQUEST_ERR_MSG, REG_VERSION_ARG, STABLE, + create_http_client, format_three_args, SeleniumManager, BETA, DASH_DASH_VERSION, DEV, NIGHTLY, + OFFLINE_REQUEST_ERR_MSG, REG_VERSION_ARG, STABLE, UNAVAILABLE_DOWNLOAD_WITH_VERSION_ERR_MSG, }; pub const CHROME_NAME: &str = "chrome"; @@ -48,8 +47,6 @@ const CFT_MACOS_APP_NAME: &str = "Google Chrome for Testing.app/Contents/MacOS/Google Chrome for Testing"; const MIN_CHROME_VERSION_CFT: i32 = 113; const MIN_CHROMEDRIVER_VERSION_CFT: i32 = 115; -const UNAVAILABLE_CFT_ERROR_MESSAGE: &str = - "{} {} not available for download in Chrome for Testing (minimum version: {})"; pub struct ChromeManager { pub browser_name: &'static str, @@ -173,7 +170,7 @@ impl ChromeManager { .collect(); if filtered_versions.is_empty() { return Err(format_three_args( - UNAVAILABLE_CFT_ERROR_MESSAGE, + UNAVAILABLE_DOWNLOAD_WITH_VERSION_ERR_MSG, self.get_driver_name(), &version_for_filtering, &MIN_CHROMEDRIVER_VERSION_CFT.to_string(), @@ -195,15 +192,6 @@ impl ChromeManager { Ok(driver_version.version.to_string()) } - - fn get_browser_binary_path_in_cache(&self) -> Result> { - let browser_in_cache = self.get_browser_path_in_cache()?; - if MACOS.is(self.get_os()) { - Ok(browser_in_cache.join(CFT_MACOS_APP_NAME)) - } else { - Ok(browser_in_cache.join(self.get_browser_name_with_extension())) - } - } } impl SeleniumManager for ChromeManager { @@ -410,118 +398,6 @@ impl SeleniumManager for ChromeManager { self.log = log; } - fn download_browser(&mut self) -> Result, Box> { - let browser_version; - let browser_name = self.browser_name; - let cache_path = self.get_cache_path()?; - let mut metadata = get_metadata(self.get_logger(), &cache_path); - let major_browser_version = self.get_major_browser_version(); - let major_browser_version_int = major_browser_version.parse::().unwrap_or_default(); - - // Browser version should be available in the CfT endpoints (>= 113) - if !self.is_browser_version_unstable() - && !self.is_browser_version_stable() - && !self.is_browser_version_empty() - && major_browser_version_int < MIN_CHROME_VERSION_CFT - { - return Err(format_three_args( - UNAVAILABLE_CFT_ERROR_MESSAGE, - browser_name, - &major_browser_version, - &MIN_CHROME_VERSION_CFT.to_string(), - ) - .into()); - } - - // Browser version is checked in the local metadata - match get_browser_version_from_metadata( - &metadata.browsers, - browser_name, - &major_browser_version, - ) { - Some(version) => { - self.get_logger().trace(format!( - "Browser with valid TTL. Getting {} version from metadata", - browser_name - )); - browser_version = version; - self.set_browser_version(browser_version.clone()); - } - _ => { - // If not in metadata, discover version using Chrome for Testing (CfT) endpoints - if self.is_browser_version_stable() || self.is_browser_version_empty() { - browser_version = self.request_latest_browser_version_from_online()?; - } else { - browser_version = self.request_fixed_browser_version_from_online()?; - } - self.set_browser_version(browser_version.clone()); - - let browser_ttl = self.get_ttl(); - if browser_ttl > 0 - && !self.is_browser_version_empty() - && !self.is_browser_version_stable() - { - metadata.browsers.push(create_browser_metadata( - browser_name, - &major_browser_version, - &browser_version, - browser_ttl, - )); - write_metadata(&metadata, self.get_logger(), cache_path); - } - } - } - self.get_logger().debug(format!( - "Required browser: {} {}", - browser_name, browser_version - )); - - // Checking if browser version is in the cache - let browser_binary_path = self.get_browser_binary_path_in_cache()?; - if browser_binary_path.exists() { - self.get_logger().debug(format!( - "{} {} already in the cache", - browser_name, browser_version - )); - } else { - // If browser is not in the cache, download it - let browser_url = if let Some(url) = self.browser_url.clone() { - url - } else { - if self.is_browser_version_stable() || self.is_browser_version_empty() { - self.request_latest_browser_version_from_online()?; - } else { - self.request_fixed_browser_version_from_online()?; - } - self.browser_url.clone().unwrap() - }; - self.get_logger().debug(format!( - "Downloading {} {} from {}", - self.get_browser_name(), - self.get_browser_version(), - browser_url - )); - let (_tmp_folder, driver_zip_file) = - download_to_tmp_folder(self.get_http_client(), browser_url, self.get_logger())?; - - uncompress( - &driver_zip_file, - &self.get_browser_path_in_cache()?, - self.get_logger(), - self.get_os(), - None, - None, - None, - )?; - } - if browser_binary_path.exists() { - self.set_browser_path(path_to_string(&browser_binary_path)); - Ok(Some(browser_binary_path)) - } else { - Ok(None) - } - } - fn get_platform_label(&self) -> &str { let os = self.get_os(); let arch = self.get_arch(); @@ -611,7 +487,7 @@ impl SeleniumManager for ChromeManager { .collect(); if filtered_versions.is_empty() { return Err(format_three_args( - UNAVAILABLE_CFT_ERROR_MESSAGE, + UNAVAILABLE_DOWNLOAD_WITH_VERSION_ERR_MSG, browser_name, &major_browser_version, &MIN_CHROME_VERSION_CFT.to_string(), @@ -630,6 +506,42 @@ impl SeleniumManager for ChromeManager { Ok(last_browser.version.to_string()) } } + + fn get_min_browser_version_for_download(&self) -> Result> { + Ok(MIN_CHROME_VERSION_CFT) + } + + fn get_browser_binary_path(&self, _browser_version: &str) -> Result> { + let browser_in_cache = self.get_browser_path_in_cache()?; + if MACOS.is(self.get_os()) { + Ok(browser_in_cache.join(CFT_MACOS_APP_NAME)) + } else { + Ok(browser_in_cache.join(self.get_browser_name_with_extension())) + } + } + + fn get_browser_url_for_download( + &mut self, + _browser_version: &str, + ) -> Result> { + if let Some(browser_url) = self.browser_url.clone() { + Ok(browser_url) + } else { + if self.is_browser_version_stable() || self.is_browser_version_empty() { + self.request_latest_browser_version_from_online()?; + } else { + self.request_fixed_browser_version_from_online()?; + } + Ok(self.browser_url.clone().unwrap()) + } + } + + fn get_browser_label_for_download( + &self, + _browser_version: &str, + ) -> Result, Box> { + Ok(None) + } } #[derive(Serialize, Deserialize)] diff --git a/rust/src/edge.rs b/rust/src/edge.rs index 7ce136563fa5e..91032a69627a9 100644 --- a/rust/src/edge.rs +++ b/rust/src/edge.rs @@ -30,10 +30,9 @@ use crate::metadata::{ create_driver_metadata, get_driver_version_from_metadata, get_metadata, write_metadata, }; use crate::{ - create_browser_metadata, create_http_client, download_to_tmp_folder, format_two_args, - get_binary_extension, get_browser_version_from_metadata, path_buf_to_string, uncompress, - Logger, SeleniumManager, BETA, CANARY, DASH_DASH_VERSION, DEV, NIGHTLY, - OFFLINE_REQUEST_ERR_MSG, ONLINE_DISCOVERY_ERROR_MESSAGE, REG_VERSION_ARG, STABLE, + create_http_client, format_two_args, get_binary_extension, Logger, SeleniumManager, BETA, + DASH_DASH_VERSION, DEV, NIGHTLY, OFFLINE_REQUEST_ERR_MSG, ONLINE_DISCOVERY_ERROR_MESSAGE, + REG_VERSION_ARG, STABLE, }; pub const EDGE_NAMES: &[&str] = &["edge", "msedge", "microsoftedge"]; @@ -42,6 +41,7 @@ const DRIVER_URL: &str = "https://msedgedriver.azureedge.net/"; const LATEST_STABLE: &str = "LATEST_STABLE"; const LATEST_RELEASE: &str = "LATEST_RELEASE"; const BROWSER_URL: &str = "https://edgeupdates.microsoft.com/api/products"; +const MIN_EDGE_VERSION_DOWNLOAD: i32 = 113; const EDGE_WINDOWS_AND_LINUX_APP_NAME: &str = "msedge"; const EDGE_MACOS_APP_NAME: &str = "Microsoft Edge.app/Contents/MacOS/Microsoft Edge"; const EDGE_BETA_MACOS_APP_NAME: &str = "Microsoft Edge Beta.app/Contents/MacOS/Microsoft Edge Beta"; @@ -74,40 +74,6 @@ impl EdgeManager { browser_url: None, })) } - - fn get_browser_url(&mut self) -> Result> { - if self.browser_url.is_none() { - self.request_latest_browser_version_from_online()?; - } - Ok(self.browser_url.clone().unwrap()) - } - - fn get_browser_binary_path_in_cache( - &self, - original_browser_version: &str, - ) -> Result> { - let browser_in_cache = self.get_browser_path_in_cache()?; - if MACOS.is(self.get_os()) { - let macos_app_name = if original_browser_version.eq_ignore_ascii_case(BETA) { - EDGE_BETA_MACOS_APP_NAME - } else if original_browser_version.eq_ignore_ascii_case(DEV) { - EDGE_DEV_MACOS_APP_NAME - } else if original_browser_version.eq_ignore_ascii_case(NIGHTLY) - || original_browser_version.eq_ignore_ascii_case(CANARY) - { - EDGE_CANARY_MACOS_APP_NAME - } else { - EDGE_MACOS_APP_NAME - }; - Ok(browser_in_cache.join(macos_app_name)) - } else { - Ok(browser_in_cache.join(format!( - "{}{}", - EDGE_WINDOWS_AND_LINUX_APP_NAME, - get_binary_extension(self.get_os()) - ))) - } - } } impl SeleniumManager for EdgeManager { @@ -310,112 +276,6 @@ impl SeleniumManager for EdgeManager { self.log = log; } - // TODO check - fn download_browser(&mut self) -> Result, Box> { - let browser_version; - let browser_name = self.browser_name; - let original_browser_version = self.get_config().browser_version.clone(); - let mut metadata = get_metadata(self.get_logger(), self.get_cache_path()?); - let major_browser_version = self.get_major_browser_version(); - - // Browser version is checked in the local metadata - match get_browser_version_from_metadata( - &metadata.browsers, - browser_name, - &major_browser_version, - ) { - Some(version) => { - self.get_logger().trace(format!( - "Browser with valid TTL. Getting {} version from metadata", - browser_name - )); - browser_version = version; - self.set_browser_version(browser_version.clone()); - } - _ => { - // If not in metadata, discover version using Mozilla online metadata - if self.is_browser_version_stable() || self.is_browser_version_empty() { - browser_version = self.request_latest_browser_version_from_online()?; - } else { - browser_version = self.request_fixed_browser_version_from_online()?; - } - self.set_browser_version(browser_version.clone()); - - let browser_ttl = self.get_ttl(); - if browser_ttl > 0 - && !self.is_browser_version_empty() - && !self.is_browser_version_stable() - { - metadata.browsers.push(create_browser_metadata( - browser_name, - &major_browser_version, - &browser_version, - browser_ttl, - )); - write_metadata(&metadata, self.get_logger(), self.get_cache_path()?); - } - } - } - self.get_logger().debug(format!( - "Required browser: {} {}", - browser_name, browser_version - )); - - // Checking if browser version is in the cache - let browser_binary_path = - self.get_browser_binary_path_in_cache(&original_browser_version)?; - if browser_binary_path.exists() { - self.get_logger().debug(format!( - "{} {} already in the cache", - browser_name, browser_version - )); - } else { - // If browser is not in the cache, download it - let browser_url = self.get_browser_url()?; - self.get_logger().debug(format!( - "Downloading {} {} from {}", - self.get_browser_name(), - self.get_browser_version(), - browser_url - )); - let (_tmp_folder, driver_zip_file) = - download_to_tmp_folder(self.get_http_client(), browser_url, self.get_logger())?; - - let major_browser_version_int = self - .get_major_browser_version() - .parse::() - .unwrap_or_default(); - - // TODO check - let extract_label = if original_browser_version.eq_ignore_ascii_case(BETA) { - "msedge-beta" - } else if original_browser_version.eq_ignore_ascii_case(DEV) { - "msedge-dev" - } else if original_browser_version.eq_ignore_ascii_case(NIGHTLY) - || original_browser_version.eq_ignore_ascii_case(CANARY) - { - "msedge-canary" - } else { - "msedge" - }; - uncompress( - &driver_zip_file, - &self.get_browser_path_in_cache()?, - self.get_logger(), - self.get_os(), - None, - Some(extract_label), - Some(major_browser_version_int), - )?; - } - if browser_binary_path.exists() { - self.set_browser_path(path_buf_to_string(browser_binary_path.clone())); - Ok(Some(browser_binary_path)) - } else { - Ok(None) - } - } - fn get_platform_label(&self) -> &str { let os = self.get_os(); let arch = self.get_arch(); @@ -438,7 +298,6 @@ impl SeleniumManager for EdgeManager { } } - // TODO check fn request_latest_browser_version_from_online(&mut self) -> Result> { let browser_name = self.browser_name; let browser_version = self.get_browser_version(); @@ -457,7 +316,7 @@ impl SeleniumManager for EdgeManager { let edge_products = parse_json_from_url::>( self.get_http_client(), - edge_updates_url.clone(), + edge_updates_url, )?; let edge_channel = if self.is_browser_version_beta() { @@ -503,7 +362,7 @@ impl SeleniumManager for EdgeManager { let os_arch = r.platform.eq_ignore_ascii_case(os_label) && r.architecture.eq_ignore_ascii_case(arch_label); if is_fixed_browser_version { - os_arch && r.product_version.starts_with(&browser_version) + os_arch && r.product_version.starts_with(browser_version) } else { os_arch } @@ -545,6 +404,58 @@ impl SeleniumManager for EdgeManager { fn request_fixed_browser_version_from_online(&mut self) -> Result> { self.request_latest_browser_version_from_online() } + + fn get_min_browser_version_for_download(&self) -> Result> { + Ok(MIN_EDGE_VERSION_DOWNLOAD) + } + + fn get_browser_binary_path(&self, browser_version: &str) -> Result> { + let browser_in_cache = self.get_browser_path_in_cache()?; + if MACOS.is(self.get_os()) { + let macos_app_name = if self.is_beta(browser_version) { + EDGE_BETA_MACOS_APP_NAME + } else if self.is_dev(browser_version) { + EDGE_DEV_MACOS_APP_NAME + } else if self.is_nightly(browser_version) { + EDGE_CANARY_MACOS_APP_NAME + } else { + EDGE_MACOS_APP_NAME + }; + Ok(browser_in_cache.join(macos_app_name)) + } else { + Ok(browser_in_cache.join(format!( + "{}{}", + EDGE_WINDOWS_AND_LINUX_APP_NAME, + get_binary_extension(self.get_os()) + ))) + } + } + + fn get_browser_url_for_download( + &mut self, + _browser_version: &str, + ) -> Result> { + if self.browser_url.is_none() { + self.request_latest_browser_version_from_online()?; + } + Ok(self.browser_url.clone().unwrap()) + } + + fn get_browser_label_for_download( + &self, + browser_version: &str, + ) -> Result, Box> { + let browser_label = if self.is_beta(browser_version) { + "msedge-beta" + } else if self.is_dev(browser_version) { + "msedge-dev" + } else if self.is_nightly(browser_version) { + "msedge-canary" + } else { + "msedge" + }; + Ok(Some(browser_label)) + } } #[derive(Serialize, Deserialize, Debug)] diff --git a/rust/src/firefox.rs b/rust/src/firefox.rs index bb637562ee2af..a2a1b6d6b0fc2 100644 --- a/rust/src/firefox.rs +++ b/rust/src/firefox.rs @@ -32,10 +32,9 @@ use crate::metadata::{ create_driver_metadata, get_driver_version_from_metadata, get_metadata, write_metadata, }; use crate::{ - create_browser_metadata, create_http_client, download_to_tmp_folder, format_three_args, - format_two_args, get_browser_version_from_metadata, path_to_string, uncompress, Logger, - SeleniumManager, BETA, CANARY, DASH_VERSION, DEV, NIGHTLY, OFFLINE_REQUEST_ERR_MSG, - ONLINE_DISCOVERY_ERROR_MESSAGE, REG_CURRENT_VERSION_ARG, STABLE, + create_http_client, format_three_args, format_two_args, Logger, SeleniumManager, BETA, + DASH_VERSION, DEV, NIGHTLY, OFFLINE_REQUEST_ERR_MSG, ONLINE_DISCOVERY_ERROR_MESSAGE, + REG_CURRENT_VERSION_ARG, STABLE, }; pub const FIREFOX_NAME: &str = "firefox"; @@ -113,94 +112,6 @@ impl FirefoxManager { .map(|v| v.to_string()) .collect()) } - - fn get_browser_url( - &mut self, - is_browser_version_nightly: bool, - ) -> Result> { - let arch = self.get_arch(); - let os = self.get_os(); - let platform_label; - let artifact_name; - let artifact_extension; - let major_browser_version = self - .get_major_browser_version() - .parse::() - .unwrap_or_default(); - - if WINDOWS.is(os) { - artifact_name = "Firefox%20Setup%20"; - artifact_extension = "exe"; - // Before Firefox 42, only Windows 32 was supported - if X32.is(arch) || major_browser_version < 42 { - platform_label = "win32"; - } else if ARM64.is(arch) { - platform_label = "win-aarch64"; - } else { - platform_label = "win64"; - } - } else if MACOS.is(os) { - artifact_name = "Firefox%20"; - // Before Firefox 68, only DMG was released - if major_browser_version < 68 { - artifact_extension = "dmg"; - } else { - artifact_extension = "pkg"; - } - if is_browser_version_nightly { - platform_label = "osx"; - } else { - platform_label = "mac"; - } - } else { - // Linux - artifact_name = "firefox-"; - artifact_extension = "tar.bz2"; - if X32.is(arch) { - platform_label = "linux-i686"; - } else if is_browser_version_nightly { - platform_label = "linux64"; - } else { - platform_label = "linux-x86_64"; - } - } - - // A possible future improvement is to allow downloading language-specific releases - let language = FIREFOX_DEFAULT_LANG; - if is_browser_version_nightly { - Ok(format_two_args( - FIREFOX_NIGHTLY_URL, - platform_label, - language, - )) - } else { - let browser_version = self.get_browser_version(); - Ok(format!( - "{}{}/{}/{}/{}{}.{}", - BROWSER_URL, - browser_version, - platform_label, - language, - artifact_name, - browser_version, - artifact_extension - )) - } - } - - fn get_browser_binary_path_in_cache(&self) -> Result> { - let browser_in_cache = self.get_browser_path_in_cache()?; - if MACOS.is(self.get_os()) { - let macos_app_name = if self.is_browser_version_nightly() { - FIREFOX_NIGHTLY_MACOS_APP_NAME - } else { - FIREFOX_MACOS_APP_NAME - }; - Ok(browser_in_cache.join(macos_app_name)) - } else { - Ok(browser_in_cache.join(self.get_browser_name_with_extension())) - } - } } impl SeleniumManager for FirefoxManager { @@ -383,105 +294,6 @@ impl SeleniumManager for FirefoxManager { self.log = log; } - fn download_browser(&mut self) -> Result, Box> { - let browser_version; - let browser_name = self.browser_name; - let original_browser_version = self.get_config().browser_version.clone(); - let cache_path = self.get_cache_path()?; - let mut metadata = get_metadata(self.get_logger(), &cache_path); - let major_browser_version = self.get_major_browser_version(); - let is_browser_version_nightly = original_browser_version.eq_ignore_ascii_case(NIGHTLY) - || original_browser_version.eq_ignore_ascii_case(CANARY); - - // Browser version is checked in the local metadata - match get_browser_version_from_metadata( - &metadata.browsers, - browser_name, - &major_browser_version, - ) { - Some(version) => { - self.get_logger().trace(format!( - "Browser with valid TTL. Getting {} version from metadata", - browser_name - )); - browser_version = version; - self.set_browser_version(browser_version.clone()); - } - _ => { - // If not in metadata, discover version using Mozilla online metadata - if self.is_browser_version_stable() || self.is_browser_version_empty() { - browser_version = self.request_latest_browser_version_from_online()?; - } else { - browser_version = self.request_fixed_browser_version_from_online()?; - } - self.set_browser_version(browser_version.clone()); - - let browser_ttl = self.get_ttl(); - if browser_ttl > 0 - && !self.is_browser_version_empty() - && !self.is_browser_version_stable() - { - metadata.browsers.push(create_browser_metadata( - browser_name, - &major_browser_version, - &browser_version, - browser_ttl, - )); - write_metadata(&metadata, self.get_logger(), cache_path); - } - } - } - self.get_logger().debug(format!( - "Required browser: {} {}", - browser_name, browser_version - )); - - // Checking if browser version is in the cache - let browser_binary_path = self.get_browser_binary_path_in_cache()?; - if browser_binary_path.exists() { - self.get_logger().debug(format!( - "{} {} already in the cache", - browser_name, browser_version - )); - } else { - // If browser is not in the cache, download it - let browser_url = self.get_browser_url(is_browser_version_nightly)?; - self.get_logger().debug(format!( - "Downloading {} {} from {}", - self.get_browser_name(), - self.get_browser_version(), - browser_url - )); - let (_tmp_folder, driver_zip_file) = - download_to_tmp_folder(self.get_http_client(), browser_url, self.get_logger())?; - - let major_browser_version_int = self - .get_major_browser_version() - .parse::() - .unwrap_or_default(); - let volume = if is_browser_version_nightly { - FIREFOX_NIGHTLY_VOLUME - } else { - FIREFOX_VOLUME - }; - uncompress( - &driver_zip_file, - &self.get_browser_path_in_cache()?, - self.get_logger(), - self.get_os(), - None, - Some(volume), - Some(major_browser_version_int), - )?; - } - if browser_binary_path.exists() { - self.set_browser_path(path_to_string(&browser_binary_path)); - Ok(Some(browser_binary_path)) - } else { - Ok(None) - } - } - fn get_platform_label(&self) -> &str { let driver_version = self.get_driver_version(); let os = self.get_os(); @@ -559,19 +371,12 @@ impl SeleniumManager for FirefoxManager { .unwrap(); Ok(browser_version.to_string()) } else { - let os = self.get_os(); let major_browser_version = self .get_major_browser_version() .parse::() .unwrap_or_default(); - let min_downloadable_version = if WINDOWS.is(os) { - MIN_DOWNLOADABLE_FIREFOX_VERSION_WIN - } else if MACOS.is(os) { - MIN_DOWNLOADABLE_FIREFOX_VERSION_MAC - } else { - MIN_DOWNLOADABLE_FIREFOX_VERSION_LINUX - }; + let min_downloadable_version = self.get_min_browser_version_for_download()?; if major_browser_version < min_downloadable_version { return Err(format_three_args( UNAVAILABLE_DOWNLOAD_ERROR_MESSAGE, @@ -614,6 +419,118 @@ impl SeleniumManager for FirefoxManager { .into()) } } + + fn get_min_browser_version_for_download(&self) -> Result> { + let os = self.get_os(); + let min_browser_version_for_download = if WINDOWS.is(os) { + MIN_DOWNLOADABLE_FIREFOX_VERSION_WIN + } else if MACOS.is(os) { + MIN_DOWNLOADABLE_FIREFOX_VERSION_MAC + } else { + MIN_DOWNLOADABLE_FIREFOX_VERSION_LINUX + }; + Ok(min_browser_version_for_download) + } + + fn get_browser_binary_path(&self, _browser_version: &str) -> Result> { + let browser_in_cache = self.get_browser_path_in_cache()?; + if MACOS.is(self.get_os()) { + let macos_app_name = if self.is_browser_version_nightly() { + FIREFOX_NIGHTLY_MACOS_APP_NAME + } else { + FIREFOX_MACOS_APP_NAME + }; + Ok(browser_in_cache.join(macos_app_name)) + } else { + Ok(browser_in_cache.join(self.get_browser_name_with_extension())) + } + } + + fn get_browser_url_for_download( + &mut self, + browser_version: &str, + ) -> Result> { + let arch = self.get_arch(); + let os = self.get_os(); + let platform_label; + let artifact_name; + let artifact_extension; + let major_browser_version = self + .get_major_browser_version() + .parse::() + .unwrap_or_default(); + + if WINDOWS.is(os) { + artifact_name = "Firefox%20Setup%20"; + artifact_extension = "exe"; + // Before Firefox 42, only Windows 32 was supported + if X32.is(arch) || major_browser_version < 42 { + platform_label = "win32"; + } else if ARM64.is(arch) { + platform_label = "win-aarch64"; + } else { + platform_label = "win64"; + } + } else if MACOS.is(os) { + artifact_name = "Firefox%20"; + // Before Firefox 68, only DMG was released + if major_browser_version < 68 { + artifact_extension = "dmg"; + } else { + artifact_extension = "pkg"; + } + if self.is_nightly(browser_version) { + platform_label = "osx"; + } else { + platform_label = "mac"; + } + } else { + // Linux + artifact_name = "firefox-"; + artifact_extension = "tar.bz2"; + if X32.is(arch) { + platform_label = "linux-i686"; + } else if self.is_nightly(browser_version) { + platform_label = "linux64"; + } else { + platform_label = "linux-x86_64"; + } + } + + // A possible future improvement is to allow downloading language-specific releases + let language = FIREFOX_DEFAULT_LANG; + if self.is_nightly(browser_version) { + Ok(format_two_args( + FIREFOX_NIGHTLY_URL, + platform_label, + language, + )) + } else { + let browser_version = self.get_browser_version(); + Ok(format!( + "{}{}/{}/{}/{}{}.{}", + BROWSER_URL, + browser_version, + platform_label, + language, + artifact_name, + browser_version, + artifact_extension + )) + } + } + + fn get_browser_label_for_download( + &self, + browser_version: &str, + ) -> Result, Box> { + let browser_label = if self.is_nightly(browser_version) { + FIREFOX_NIGHTLY_VOLUME + } else { + FIREFOX_VOLUME + }; + Ok(Some(browser_label)) + } } #[cfg(test)] diff --git a/rust/src/grid.rs b/rust/src/grid.rs index 295cc9ba3ae57..b5b8675999915 100644 --- a/rust/src/grid.rs +++ b/rust/src/grid.rs @@ -220,10 +220,6 @@ impl SeleniumManager for GridManager { self.log = log; } - fn download_browser(&mut self) -> Result, Box> { - Ok(None) - } - fn get_platform_label(&self) -> &str { "" } @@ -235,4 +231,26 @@ impl SeleniumManager for GridManager { fn request_fixed_browser_version_from_online(&mut self) -> Result> { self.unavailable_download() } + + fn get_min_browser_version_for_download(&self) -> Result> { + self.unavailable_download() + } + + fn get_browser_binary_path(&self, _browser_version: &str) -> Result> { + self.unavailable_download() + } + + fn get_browser_url_for_download( + &mut self, + _browser_version: &str, + ) -> Result> { + self.unavailable_download() + } + + fn get_browser_label_for_download( + &self, + _browser_version: &str, + ) -> Result, Box> { + self.unavailable_download() + } } diff --git a/rust/src/iexplorer.rs b/rust/src/iexplorer.rs index 829ac849b1e99..0f174a7cdc87c 100644 --- a/rust/src/iexplorer.rs +++ b/rust/src/iexplorer.rs @@ -225,10 +225,6 @@ impl SeleniumManager for IExplorerManager { self.log = log; } - fn download_browser(&mut self) -> Result, Box> { - Ok(None) - } - fn get_platform_label(&self) -> &str { "win32" } @@ -240,4 +236,26 @@ impl SeleniumManager for IExplorerManager { fn request_fixed_browser_version_from_online(&mut self) -> Result> { self.unavailable_download() } + + fn get_min_browser_version_for_download(&self) -> Result> { + self.unavailable_download() + } + + fn get_browser_binary_path(&self, _browser_version: &str) -> Result> { + self.unavailable_download() + } + + fn get_browser_url_for_download( + &mut self, + _browser_version: &str, + ) -> Result> { + self.unavailable_download() + } + + fn get_browser_label_for_download( + &self, + _browser_version: &str, + ) -> Result, Box> { + self.unavailable_download() + } } diff --git a/rust/src/lib.rs b/rust/src/lib.rs index d1078a07b4a53..17f6a7411b602 100644 --- a/rust/src/lib.rs +++ b/rust/src/lib.rs @@ -101,7 +101,9 @@ pub const ESCAPE_COMMAND: &str = "printf %q \"{}\""; pub const SNAPSHOT: &str = "SNAPSHOT"; pub const OFFLINE_REQUEST_ERR_MSG: &str = "Unable to discover proper {} version in offline mode"; pub const OFFLINE_DOWNLOAD_ERR_MSG: &str = "Unable to download {} in offline mode"; -pub const UNAVAILABLE_DOWNLOAD_ERR_MSG: &str = "{} not available for downloading"; +pub const UNAVAILABLE_DOWNLOAD_ERR_MSG: &str = "{} not available for download"; +pub const UNAVAILABLE_DOWNLOAD_WITH_VERSION_ERR_MSG: &str = + "{} {} not available for download (minimum version: {})"; pub const ONLINE_DISCOVERY_ERROR_MESSAGE: &str = "Unable to discover {} {} in online repository"; pub const UNC_PREFIX: &str = r#"\\?\"#; @@ -140,14 +142,26 @@ pub trait SeleniumManager { fn set_logger(&mut self, log: Logger); - fn download_browser(&mut self) -> Result, Box>; - fn get_platform_label(&self) -> &str; fn request_latest_browser_version_from_online(&mut self) -> Result>; fn request_fixed_browser_version_from_online(&mut self) -> Result>; + fn get_min_browser_version_for_download(&self) -> Result>; + + fn get_browser_binary_path(&self, browser_version: &str) -> Result>; + + fn get_browser_url_for_download( + &mut self, + browser_version: &str, + ) -> Result>; + + fn get_browser_label_for_download( + &self, + _browser_version: &str, + ) -> Result, Box>; + // ---------------------------------------------------------- // Shared functions // ---------------------------------------------------------- @@ -182,6 +196,117 @@ pub trait SeleniumManager { } } + fn download_browser(&mut self) -> Result, Box> { + let browser_version; + let original_browser_version = self.get_config().browser_version.clone(); + let mut metadata = get_metadata(self.get_logger(), self.get_cache_path()?); + let major_browser_version = self.get_major_browser_version(); + let major_browser_version_int = major_browser_version.parse::().unwrap_or_default(); + + // Browser version should be available for download + let min_browser_version_for_download = self.get_min_browser_version_for_download()?; + if !self.is_browser_version_unstable() + && !self.is_browser_version_stable() + && !self.is_browser_version_empty() + && major_browser_version_int < min_browser_version_for_download + { + return Err(format_three_args( + UNAVAILABLE_DOWNLOAD_WITH_VERSION_ERR_MSG, + self.get_browser_name(), + &major_browser_version, + &min_browser_version_for_download.to_string(), + ) + .into()); + } + + // Browser version is checked in the local metadata + match get_browser_version_from_metadata( + &metadata.browsers, + self.get_browser_name(), + &major_browser_version, + ) { + Some(version) => { + self.get_logger().trace(format!( + "Browser with valid TTL. Getting {} version from metadata", + self.get_browser_name() + )); + browser_version = version; + self.set_browser_version(browser_version.clone()); + } + _ => { + // If not in metadata, discover version using Mozilla online metadata + if self.is_browser_version_stable() || self.is_browser_version_empty() { + browser_version = self.request_latest_browser_version_from_online()?; + } else { + browser_version = self.request_fixed_browser_version_from_online()?; + } + self.set_browser_version(browser_version.clone()); + + let browser_ttl = self.get_ttl(); + if browser_ttl > 0 + && !self.is_browser_version_empty() + && !self.is_browser_version_stable() + { + metadata.browsers.push(create_browser_metadata( + self.get_browser_name(), + &major_browser_version, + &browser_version, + browser_ttl, + )); + write_metadata(&metadata, self.get_logger(), self.get_cache_path()?); + } + } + } + self.get_logger().debug(format!( + "Required browser: {} {}", + self.get_browser_name(), + browser_version + )); + + // Checking if browser version is in the cache + let browser_binary_path = self.get_browser_binary_path(&original_browser_version)?; + if browser_binary_path.exists() { + self.get_logger().debug(format!( + "{} {} already in the cache", + self.get_browser_name(), + browser_version + )); + } else { + // If browser is not in the cache, download it + let browser_url = self.get_browser_url_for_download(&original_browser_version)?; + self.get_logger().debug(format!( + "Downloading {} {} from {}", + self.get_browser_name(), + self.get_browser_version(), + browser_url + )); + let (_tmp_folder, driver_zip_file) = + download_to_tmp_folder(self.get_http_client(), browser_url, self.get_logger())?; + + let major_browser_version_int = self + .get_major_browser_version() + .parse::() + .unwrap_or_default(); + let browser_label_for_download = + self.get_browser_label_for_download(&original_browser_version)?; + uncompress( + &driver_zip_file, + &self.get_browser_path_in_cache()?, + self.get_logger(), + self.get_os(), + None, + browser_label_for_download, + Some(major_browser_version_int), + )?; + } + if browser_binary_path.exists() { + self.set_browser_path(path_buf_to_string(browser_binary_path.clone())); + Ok(Some(browser_binary_path)) + } else { + Ok(None) + } + } + fn detect_browser_path(&mut self) -> Option { let mut browser_version = self.get_browser_version(); if browser_version.eq_ignore_ascii_case(CANARY) { @@ -334,7 +459,7 @@ pub trait SeleniumManager { && !major_browser_version.eq(&discovered_major_browser_version) { self.get_logger().debug(format!( - "Discovered online {} version ({}) different to specified browser version ({})", + "Discovered {} version ({}) different to specified browser version ({})", self.get_browser_name(), discovered_major_browser_version, major_browser_version, @@ -478,15 +603,26 @@ pub trait SeleniumManager { } fn is_browser_version_beta(&self) -> bool { - self.get_browser_version().eq_ignore_ascii_case(BETA) + self.is_beta(self.get_browser_version()) + } + + fn is_beta(&self, browser_version: &str) -> bool { + browser_version.eq_ignore_ascii_case(BETA) } fn is_browser_version_dev(&self) -> bool { - self.get_browser_version().eq_ignore_ascii_case(DEV) + self.is_dev(self.get_browser_version()) + } + + fn is_dev(&self, browser_version: &str) -> bool { + browser_version.eq_ignore_ascii_case(DEV) } fn is_browser_version_nightly(&self) -> bool { - let browser_version = self.get_browser_version(); + self.is_nightly(self.get_browser_version()) + } + + fn is_nightly(&self, browser_version: &str) -> bool { browser_version.eq_ignore_ascii_case(NIGHTLY) || browser_version.eq_ignore_ascii_case(CANARY) } @@ -739,7 +875,7 @@ pub trait SeleniumManager { self.set_browser_version(browser_version.clone()); } _ => { - // If not in metadata, discover version using Chrome for Testing (CfT) endpoints + // If not in metadata, discover version using online endpoints browser_version = if major_browser_version.is_empty() || self.is_browser_version_stable() { self.request_latest_browser_version_from_online()? @@ -863,7 +999,10 @@ pub trait SeleniumManager { } } - fn unavailable_download(&mut self) -> Result> { + fn unavailable_download(&self) -> Result> + where + Self: Sized, + { Err(format_one_arg(UNAVAILABLE_DOWNLOAD_ERR_MSG, self.get_browser_name()).into()) } diff --git a/rust/src/safari.rs b/rust/src/safari.rs index 13687d5ccd5bf..0133c644a50ae 100644 --- a/rust/src/safari.rs +++ b/rust/src/safari.rs @@ -118,10 +118,6 @@ impl SeleniumManager for SafariManager { self.log = log; } - fn download_browser(&mut self) -> Result, Box> { - Ok(None) - } - fn get_platform_label(&self) -> &str { "" } @@ -133,4 +129,26 @@ impl SeleniumManager for SafariManager { fn request_fixed_browser_version_from_online(&mut self) -> Result> { self.unavailable_download() } + + fn get_min_browser_version_for_download(&self) -> Result> { + self.unavailable_download() + } + + fn get_browser_binary_path(&self, _browser_version: &str) -> Result> { + self.unavailable_download() + } + + fn get_browser_url_for_download( + &mut self, + _browser_version: &str, + ) -> Result> { + self.unavailable_download() + } + + fn get_browser_label_for_download( + &self, + _browser_version: &str, + ) -> Result, Box> { + self.unavailable_download() + } } diff --git a/rust/src/safaritp.rs b/rust/src/safaritp.rs index a3beed8a795c2..fad5ba1e5830f 100644 --- a/rust/src/safaritp.rs +++ b/rust/src/safaritp.rs @@ -126,10 +126,6 @@ impl SeleniumManager for SafariTPManager { self.log = log; } - fn download_browser(&mut self) -> Result, Box> { - Ok(None) - } - fn get_platform_label(&self) -> &str { "" } @@ -141,4 +137,26 @@ impl SeleniumManager for SafariTPManager { fn request_fixed_browser_version_from_online(&mut self) -> Result> { self.unavailable_download() } + + fn get_min_browser_version_for_download(&self) -> Result> { + self.unavailable_download() + } + + fn get_browser_binary_path(&self, _browser_version: &str) -> Result> { + self.unavailable_download() + } + + fn get_browser_url_for_download( + &mut self, + _browser_version: &str, + ) -> Result> { + self.unavailable_download() + } + + fn get_browser_label_for_download( + &self, + _browser_version: &str, + ) -> Result, Box> { + self.unavailable_download() + } } From 21c23a9fc7bf0cdb8196a6d022739a2dd6ccb53a Mon Sep 17 00:00:00 2001 From: Boni Garcia Date: Thu, 28 Sep 2023 12:49:05 +0200 Subject: [PATCH 11/33] [rust] Install Edge in Windows through the MSI installer --- rust/src/chrome.rs | 12 ++++++--- rust/src/edge.rs | 50 ++++++++++++++++++++++++++----------- rust/src/files.rs | 24 ++++++++++++++++-- rust/src/firefox.rs | 5 +++- rust/src/grid.rs | 5 +++- rust/src/iexplorer.rs | 5 +++- rust/src/lib.rs | 58 +++++++++++++++++++++++++++++-------------- rust/src/safari.rs | 5 +++- rust/src/safaritp.rs | 5 +++- 9 files changed, 126 insertions(+), 43 deletions(-) diff --git a/rust/src/chrome.rs b/rust/src/chrome.rs index c65319a7291e3..c4a2a8ee9f9dc 100644 --- a/rust/src/chrome.rs +++ b/rust/src/chrome.rs @@ -33,7 +33,8 @@ use crate::metadata::{ }; use crate::{ create_http_client, format_three_args, SeleniumManager, BETA, DASH_DASH_VERSION, DEV, NIGHTLY, - OFFLINE_REQUEST_ERR_MSG, REG_VERSION_ARG, STABLE, UNAVAILABLE_DOWNLOAD_WITH_VERSION_ERR_MSG, + OFFLINE_REQUEST_ERR_MSG, REG_VERSION_ARG, STABLE, + UNAVAILABLE_DOWNLOAD_WITH_MIN_VERSION_ERR_MSG, }; pub const CHROME_NAME: &str = "chrome"; @@ -170,7 +171,7 @@ impl ChromeManager { .collect(); if filtered_versions.is_empty() { return Err(format_three_args( - UNAVAILABLE_DOWNLOAD_WITH_VERSION_ERR_MSG, + UNAVAILABLE_DOWNLOAD_WITH_MIN_VERSION_ERR_MSG, self.get_driver_name(), &version_for_filtering, &MIN_CHROMEDRIVER_VERSION_CFT.to_string(), @@ -487,7 +488,7 @@ impl SeleniumManager for ChromeManager { .collect(); if filtered_versions.is_empty() { return Err(format_three_args( - UNAVAILABLE_DOWNLOAD_WITH_VERSION_ERR_MSG, + UNAVAILABLE_DOWNLOAD_WITH_MIN_VERSION_ERR_MSG, browser_name, &major_browser_version, &MIN_CHROME_VERSION_CFT.to_string(), @@ -511,7 +512,10 @@ impl SeleniumManager for ChromeManager { Ok(MIN_CHROME_VERSION_CFT) } - fn get_browser_binary_path(&self, _browser_version: &str) -> Result> { + fn get_browser_binary_path( + &mut self, + _browser_version: &str, + ) -> Result> { let browser_in_cache = self.get_browser_path_in_cache()?; if MACOS.is(self.get_os()) { Ok(browser_in_cache.join(CFT_MACOS_APP_NAME)) diff --git a/rust/src/edge.rs b/rust/src/edge.rs index 91032a69627a9..a00ffbfca37e4 100644 --- a/rust/src/edge.rs +++ b/rust/src/edge.rs @@ -19,8 +19,9 @@ use crate::config::ManagerConfig; use reqwest::Client; use serde::{Deserialize, Serialize}; use std::collections::HashMap; +use std::env; use std::error::Error; -use std::path::PathBuf; +use std::path::{Path, PathBuf}; use crate::config::ARCH::{ARM64, X32}; use crate::config::OS::{LINUX, MACOS, WINDOWS}; @@ -30,8 +31,8 @@ use crate::metadata::{ create_driver_metadata, get_driver_version_from_metadata, get_metadata, write_metadata, }; use crate::{ - create_http_client, format_two_args, get_binary_extension, Logger, SeleniumManager, BETA, - DASH_DASH_VERSION, DEV, NIGHTLY, OFFLINE_REQUEST_ERR_MSG, ONLINE_DISCOVERY_ERROR_MESSAGE, + create_http_client, get_binary_extension, path_buf_to_string, Logger, SeleniumManager, BETA, + DASH_DASH_VERSION, DEV, ENV_PROGRAM_FILES_X86, NIGHTLY, OFFLINE_REQUEST_ERR_MSG, REG_VERSION_ARG, STABLE, }; @@ -314,10 +315,8 @@ impl SeleniumManager for EdgeManager { browser_name, edge_updates_url )); - let edge_products = parse_json_from_url::>( - self.get_http_client(), - edge_updates_url, - )?; + let edge_products = + parse_json_from_url::>(self.get_http_client(), edge_updates_url)?; let edge_channel = if self.is_browser_version_beta() { "Beta" @@ -353,6 +352,10 @@ impl SeleniumManager for EdgeManager { os_label = "Linux"; "x64" }; + if products.is_empty() { + return self.unavailable_download(); + } + let releases: Vec<&Release> = products .first() .unwrap() @@ -378,13 +381,9 @@ impl SeleniumManager for EdgeManager { "deb" }; if releases.is_empty() { - return Err(format_two_args( - ONLINE_DISCOVERY_ERROR_MESSAGE, - browser_name, - self.get_browser_version(), - ) - .into()); + return self.unavailable_download(); } + let release = releases.first().unwrap(); let artifacts: Vec<&Artifact> = release .artifacts @@ -394,6 +393,9 @@ impl SeleniumManager for EdgeManager { self.get_logger() .trace(format!("Artifacts: {:?}", artifacts)); + if artifacts.is_empty() { + return self.unavailable_download(); + } let artifact = artifacts.first().unwrap(); let browser_version = release.product_version.clone(); self.browser_url = Some(artifact.location.clone()); @@ -409,7 +411,10 @@ impl SeleniumManager for EdgeManager { Ok(MIN_EDGE_VERSION_DOWNLOAD) } - fn get_browser_binary_path(&self, browser_version: &str) -> Result> { + fn get_browser_binary_path( + &mut self, + browser_version: &str, + ) -> Result> { let browser_in_cache = self.get_browser_path_in_cache()?; if MACOS.is(self.get_os()) { let macos_app_name = if self.is_beta(browser_version) { @@ -422,6 +427,23 @@ impl SeleniumManager for EdgeManager { EDGE_MACOS_APP_NAME }; Ok(browser_in_cache.join(macos_app_name)) + } else if WINDOWS.is(self.get_os()) { + let browser_path = if self.is_unstable(browser_version) { + self.get_browser_path_from_version(browser_version) + .to_string() + } else { + format!( + r#"Microsoft\Edge\Application\{}\msedge.exe"#, + self.get_browser_version() + ) + }; + let mut full_browser_path = Path::new(&browser_path).to_path_buf(); + if WINDOWS.is(self.get_os()) { + let env_value = env::var(ENV_PROGRAM_FILES_X86).unwrap_or_default(); + let parent_path = Path::new(&env_value); + full_browser_path = parent_path.join(&browser_path); + } + Ok((&path_buf_to_string(full_browser_path)).into()) } else { Ok(browser_in_cache.join(format!( "{}{}", diff --git a/rust/src/files.rs b/rust/src/files.rs index 385be51616a7e..bd7159001b727 100644 --- a/rust/src/files.rs +++ b/rust/src/files.rs @@ -35,8 +35,8 @@ use zip::ZipArchive; use crate::config::OS::WINDOWS; use crate::{ format_one_arg, format_three_args, format_two_args, run_shell_command_by_os, Command, Logger, - CP_VOLUME_COMMAND, HDIUTIL_ATTACH_COMMAND, HDIUTIL_DETACH_COMMAND, MACOS, MV_PAYLOAD_COMMAND, - MV_PAYLOAD_OLD_VERSIONS_COMMAND, PKGUTIL_COMMAND, + CP_VOLUME_COMMAND, HDIUTIL_ATTACH_COMMAND, HDIUTIL_DETACH_COMMAND, MACOS, + MSIEXEC_INSTALL_COMMAND, MV_PAYLOAD_COMMAND, MV_PAYLOAD_OLD_VERSIONS_COMMAND, PKGUTIL_COMMAND, }; pub const PARSE_ERROR: &str = "Wrong browser/driver version"; @@ -50,6 +50,7 @@ const PKG: &str = "pkg"; const DMG: &str = "dmg"; const EXE: &str = "exe"; const DEB: &str = "deb"; +const MSI: &str = "msi"; const SEVEN_ZIP_HEADER: &[u8; 6] = b"7z\xBC\xAF\x27\x1C"; const UNCOMPRESS_MACOS_ERR_MSG: &str = "{} files are only supported in macOS"; @@ -139,6 +140,8 @@ pub fn uncompress( uncompress_sfx(compressed_file, target, log)? } else if extension.eq_ignore_ascii_case(DEB) { uncompress_deb(compressed_file, target, log, volume.unwrap_or_default())? + } else if extension.eq_ignore_ascii_case(MSI) { + install_msi(compressed_file, log, os)? } else if extension.eq_ignore_ascii_case(XML) || extension.eq_ignore_ascii_case(HTML) { log.debug(format!( "Wrong downloaded driver: {}", @@ -292,6 +295,23 @@ pub fn uncompress_deb( Ok(()) } +pub fn install_msi(msi_file: &str, log: &Logger, os: &str) -> Result<(), Box> { + let msi_file_name = Path::new(msi_file) + .file_name() + .unwrap_or_default() + .to_os_string(); + log.debug(format!( + "Installing {}", + msi_file_name.to_str().unwrap_or_default() + )); + + let command = Command::new_single(format_one_arg(MSIEXEC_INSTALL_COMMAND, msi_file)); + log.trace(format!("Running command: {}", command.display())); + run_shell_command_by_os(os, command)?; + + Ok(()) +} + pub fn untargz(compressed_file: &str, target: &Path, log: &Logger) -> Result<(), Box> { log.trace(format!( "Untargz {} to {}", diff --git a/rust/src/firefox.rs b/rust/src/firefox.rs index a2a1b6d6b0fc2..37cd64a7a565c 100644 --- a/rust/src/firefox.rs +++ b/rust/src/firefox.rs @@ -432,7 +432,10 @@ impl SeleniumManager for FirefoxManager { Ok(min_browser_version_for_download) } - fn get_browser_binary_path(&self, _browser_version: &str) -> Result> { + fn get_browser_binary_path( + &mut self, + _browser_version: &str, + ) -> Result> { let browser_in_cache = self.get_browser_path_in_cache()?; if MACOS.is(self.get_os()) { let macos_app_name = if self.is_browser_version_nightly() { diff --git a/rust/src/grid.rs b/rust/src/grid.rs index b5b8675999915..c26cd49902592 100644 --- a/rust/src/grid.rs +++ b/rust/src/grid.rs @@ -236,7 +236,10 @@ impl SeleniumManager for GridManager { self.unavailable_download() } - fn get_browser_binary_path(&self, _browser_version: &str) -> Result> { + fn get_browser_binary_path( + &mut self, + _browser_version: &str, + ) -> Result> { self.unavailable_download() } diff --git a/rust/src/iexplorer.rs b/rust/src/iexplorer.rs index 0f174a7cdc87c..26a6f2b03a769 100644 --- a/rust/src/iexplorer.rs +++ b/rust/src/iexplorer.rs @@ -241,7 +241,10 @@ impl SeleniumManager for IExplorerManager { self.unavailable_download() } - fn get_browser_binary_path(&self, _browser_version: &str) -> Result> { + fn get_browser_binary_path( + &mut self, + _browser_version: &str, + ) -> Result> { self.unavailable_download() } diff --git a/rust/src/lib.rs b/rust/src/lib.rs index 17f6a7411b602..c43c478e580a2 100644 --- a/rust/src/lib.rs +++ b/rust/src/lib.rs @@ -81,6 +81,7 @@ pub const HDIUTIL_DETACH_COMMAND: &str = "hdiutil detach /Volumes/{}"; pub const CP_VOLUME_COMMAND: &str = "cp -R /Volumes/{}/{}.app {}"; pub const MV_PAYLOAD_COMMAND: &str = "mv {}/*{}/Payload/*.app {}"; pub const MV_PAYLOAD_OLD_VERSIONS_COMMAND: &str = "mv {}/Payload/*.app {}"; +pub const MSIEXEC_INSTALL_COMMAND: &str = "start /wait msiexec /i {} /qn ALLOWDOWNGRADE=1"; pub const DASH_VERSION: &str = "{}{}{} -v"; pub const DASH_DASH_VERSION: &str = "{}{}{} --version"; pub const DOUBLE_QUOTE: &str = "\""; @@ -101,8 +102,8 @@ pub const ESCAPE_COMMAND: &str = "printf %q \"{}\""; pub const SNAPSHOT: &str = "SNAPSHOT"; pub const OFFLINE_REQUEST_ERR_MSG: &str = "Unable to discover proper {} version in offline mode"; pub const OFFLINE_DOWNLOAD_ERR_MSG: &str = "Unable to download {} in offline mode"; -pub const UNAVAILABLE_DOWNLOAD_ERR_MSG: &str = "{} not available for download"; -pub const UNAVAILABLE_DOWNLOAD_WITH_VERSION_ERR_MSG: &str = +pub const UNAVAILABLE_DOWNLOAD_ERR_MSG: &str = "{}{} not available for download"; +pub const UNAVAILABLE_DOWNLOAD_WITH_MIN_VERSION_ERR_MSG: &str = "{} {} not available for download (minimum version: {})"; pub const ONLINE_DISCOVERY_ERROR_MESSAGE: &str = "Unable to discover {} {} in online repository"; pub const UNC_PREFIX: &str = r#"\\?\"#; @@ -150,7 +151,8 @@ pub trait SeleniumManager { fn get_min_browser_version_for_download(&self) -> Result>; - fn get_browser_binary_path(&self, browser_version: &str) -> Result>; + fn get_browser_binary_path(&mut self, browser_version: &str) + -> Result>; fn get_browser_url_for_download( &mut self, @@ -211,7 +213,7 @@ pub trait SeleniumManager { && major_browser_version_int < min_browser_version_for_download { return Err(format_three_args( - UNAVAILABLE_DOWNLOAD_WITH_VERSION_ERR_MSG, + UNAVAILABLE_DOWNLOAD_WITH_MIN_VERSION_ERR_MSG, self.get_browser_name(), &major_browser_version, &min_browser_version_for_download.to_string(), @@ -265,14 +267,14 @@ pub trait SeleniumManager { // Checking if browser version is in the cache let browser_binary_path = self.get_browser_binary_path(&original_browser_version)?; - if browser_binary_path.exists() { + if browser_binary_path.exists() && !self.is_edge() { self.get_logger().debug(format!( - "{} {} already in the cache", + "{} {} already exists", self.get_browser_name(), browser_version )); } else { - // If browser is not in the cache, download it + // If browser is not available, download it let browser_url = self.get_browser_url_for_download(&original_browser_version)?; self.get_logger().debug(format!( "Downloading {} {} from {}", @@ -307,22 +309,24 @@ pub trait SeleniumManager { } } - fn detect_browser_path(&mut self) -> Option { - let mut browser_version = self.get_browser_version(); + fn get_browser_path_from_version(&self, mut browser_version: &str) -> &str { if browser_version.eq_ignore_ascii_case(CANARY) { browser_version = NIGHTLY; - } else if !self.is_browser_version_unstable() { + } else if !self.is_unstable(browser_version) { browser_version = STABLE; } - - let browser_path = self - .get_browser_path_map() + self.get_browser_path_map() .get(&BrowserPath::new( str_to_os(self.get_os()).unwrap(), browser_version, )) .cloned() - .unwrap_or_default(); + .unwrap_or_default() + } + + fn detect_browser_path(&mut self) -> Option { + let browser_version = self.get_browser_version(); + let browser_path = self.get_browser_path_from_version(browser_version); let mut full_browser_path = Path::new(browser_path).to_path_buf(); if WINDOWS.is(self.get_os()) { @@ -484,7 +488,7 @@ pub trait SeleniumManager { let browser_path = self.download_browser()?; if browser_path.is_some() { self.get_logger().debug(format!( - "{} {} has been downloaded at {}", + "{} {} is available at {}", self.get_browser_name(), self.get_browser_version(), browser_path.unwrap().display() @@ -602,6 +606,10 @@ pub trait SeleniumManager { self.get_browser_name().contains(FIREFOX_NAME) } + fn is_edge(&self) -> bool { + self.get_browser_name().eq(EDGE_NAMES[0]) + } + fn is_browser_version_beta(&self) -> bool { self.is_beta(self.get_browser_version()) } @@ -627,14 +635,17 @@ pub trait SeleniumManager { || browser_version.eq_ignore_ascii_case(CANARY) } - fn is_browser_version_unstable(&self) -> bool { - let browser_version = self.get_browser_version(); + fn is_unstable(&self, browser_version: &str) -> bool { browser_version.eq_ignore_ascii_case(BETA) || browser_version.eq_ignore_ascii_case(DEV) || browser_version.eq_ignore_ascii_case(NIGHTLY) || browser_version.eq_ignore_ascii_case(CANARY) } + fn is_browser_version_unstable(&self) -> bool { + self.is_unstable(self.get_browser_version()) + } + fn is_browser_version_empty(&self) -> bool { self.get_browser_version().is_empty() } @@ -1003,7 +1014,18 @@ pub trait SeleniumManager { where Self: Sized, { - Err(format_one_arg(UNAVAILABLE_DOWNLOAD_ERR_MSG, self.get_browser_name()).into()) + let browser_version = self.get_browser_version(); + let browser_version_label = if browser_version.is_empty() { + "".to_string() + } else { + format!(" {}", browser_version) + }; + Err(format_two_args( + UNAVAILABLE_DOWNLOAD_ERR_MSG, + self.get_browser_name(), + &browser_version_label, + ) + .into()) } // ---------------------------------------------------------- diff --git a/rust/src/safari.rs b/rust/src/safari.rs index 0133c644a50ae..8e9c8e5e93ea7 100644 --- a/rust/src/safari.rs +++ b/rust/src/safari.rs @@ -134,7 +134,10 @@ impl SeleniumManager for SafariManager { self.unavailable_download() } - fn get_browser_binary_path(&self, _browser_version: &str) -> Result> { + fn get_browser_binary_path( + &mut self, + _browser_version: &str, + ) -> Result> { self.unavailable_download() } diff --git a/rust/src/safaritp.rs b/rust/src/safaritp.rs index fad5ba1e5830f..9e4df969ebb6d 100644 --- a/rust/src/safaritp.rs +++ b/rust/src/safaritp.rs @@ -142,7 +142,10 @@ impl SeleniumManager for SafariTPManager { self.unavailable_download() } - fn get_browser_binary_path(&self, _browser_version: &str) -> Result> { + fn get_browser_binary_path( + &mut self, + _browser_version: &str, + ) -> Result> { self.unavailable_download() } From a55c408c7ccbef05682cd02f4caf12744539b63e Mon Sep 17 00:00:00 2001 From: Boni Garcia Date: Thu, 28 Sep 2023 16:53:15 +0200 Subject: [PATCH 12/33] [rust] Check admin permissions in Windows before downloading MSI installer --- rust/src/lib.rs | 22 ++++++++++++++++++++++ 1 file changed, 22 insertions(+) diff --git a/rust/src/lib.rs b/rust/src/lib.rs index c43c478e580a2..a0dd249971ccd 100644 --- a/rust/src/lib.rs +++ b/rust/src/lib.rs @@ -82,6 +82,7 @@ pub const CP_VOLUME_COMMAND: &str = "cp -R /Volumes/{}/{}.app {}"; pub const MV_PAYLOAD_COMMAND: &str = "mv {}/*{}/Payload/*.app {}"; pub const MV_PAYLOAD_OLD_VERSIONS_COMMAND: &str = "mv {}/Payload/*.app {}"; pub const MSIEXEC_INSTALL_COMMAND: &str = "start /wait msiexec /i {} /qn ALLOWDOWNGRADE=1"; +pub const WINDOWS_CHECK_ADMIN_COMMAND: &str = "net session"; pub const DASH_VERSION: &str = "{}{}{} -v"; pub const DASH_DASH_VERSION: &str = "{}{}{} --version"; pub const DOUBLE_QUOTE: &str = "\""; @@ -105,6 +106,8 @@ pub const OFFLINE_DOWNLOAD_ERR_MSG: &str = "Unable to download {} in offline mod pub const UNAVAILABLE_DOWNLOAD_ERR_MSG: &str = "{}{} not available for download"; pub const UNAVAILABLE_DOWNLOAD_WITH_MIN_VERSION_ERR_MSG: &str = "{} {} not available for download (minimum version: {})"; +pub const NOT_ADMIN_FOR_EDGE_INSTALLER_ERR_MSG: &str = + "{} can only be installed in Windows with administrator permissions"; pub const ONLINE_DISCOVERY_ERROR_MESSAGE: &str = "Unable to discover {} {} in online repository"; pub const UNC_PREFIX: &str = r#"\\?\"#; @@ -199,6 +202,14 @@ pub trait SeleniumManager { } fn download_browser(&mut self) -> Result, Box> { + if WINDOWS.is(self.get_os()) && self.is_edge() && !self.is_windows_admin() { + return Err(format_one_arg( + NOT_ADMIN_FOR_EDGE_INSTALLER_ERR_MSG, + self.get_browser_name(), + ) + .into()); + } + let browser_version; let original_browser_version = self.get_config().browser_version.clone(); let mut metadata = get_metadata(self.get_logger(), self.get_cache_path()?); @@ -590,6 +601,17 @@ pub trait SeleniumManager { } } + fn is_windows_admin(&self) -> bool { + let os = self.get_os(); + if WINDOWS.is(os) { + let command = Command::new_single(WINDOWS_CHECK_ADMIN_COMMAND.to_string()); + let output = run_shell_command_by_os(os, command).unwrap_or_default(); + !output.is_empty() && !output.contains("error") + } else { + false + } + } + fn is_safari(&self) -> bool { self.get_browser_name().contains(SAFARI_NAME) } From b5b58b819659eb3dd57027a917ab8de01b18ba7c Mon Sep 17 00:00:00 2001 From: Boni Garcia Date: Thu, 28 Sep 2023 17:04:34 +0200 Subject: [PATCH 13/33] [rust] Include tests for managing Edge --- rust/src/lib.rs | 9 +++++++-- rust/tests/browser_download_tests.rs | 11 +++++++++-- 2 files changed, 16 insertions(+), 4 deletions(-) diff --git a/rust/src/lib.rs b/rust/src/lib.rs index a0dd249971ccd..5ce0567c94131 100644 --- a/rust/src/lib.rs +++ b/rust/src/lib.rs @@ -495,7 +495,12 @@ pub trait SeleniumManager { } } - if download_browser && !self.is_avoid_browser_download() { + if download_browser + && !self.is_avoid_browser_download() + && !self.is_iexplorer() + && !self.is_grid() + && !self.is_safari() + { let browser_path = self.download_browser()?; if browser_path.is_some() { self.get_logger().debug(format!( @@ -504,7 +509,7 @@ pub trait SeleniumManager { self.get_browser_version(), browser_path.unwrap().display() )); - } else if !self.is_iexplorer() && !self.is_grid() { + } else if !self.is_iexplorer() && !self.is_grid() && !self.is_safari() { return Err(format!( "{}{} cannot be downloaded", self.get_browser_name(), diff --git a/rust/tests/browser_download_tests.rs b/rust/tests/browser_download_tests.rs index be8daad88d951..404d6b29cb8ab 100644 --- a/rust/tests/browser_download_tests.rs +++ b/rust/tests/browser_download_tests.rs @@ -16,6 +16,7 @@ // under the License. use assert_cmd::Command; +use std::env::consts::OS; use crate::common::{assert_browser, assert_driver}; use rstest::rstest; @@ -25,6 +26,7 @@ mod common; #[rstest] #[case("chrome")] #[case("firefox")] +#[case("edge")] fn browser_latest_download_test(#[case] browser: String) { let mut cmd = Command::new(env!("CARGO_BIN_EXE_selenium-manager")); cmd.args([ @@ -40,7 +42,9 @@ fn browser_latest_download_test(#[case] browser: String) { .code(0); assert_driver(&mut cmd); - assert_browser(&mut cmd); + if !OS.eq("windows") { + assert_browser(&mut cmd); + } } #[rstest] @@ -48,6 +52,7 @@ fn browser_latest_download_test(#[case] browser: String) { #[case("chrome", "beta")] #[case("firefox", "116")] #[case("firefox", "beta")] +#[case("edge", "beta")] fn browser_version_download_test(#[case] browser: String, #[case] browser_version: String) { let mut cmd = Command::new(env!("CARGO_BIN_EXE_selenium-manager")); cmd.args([ @@ -64,5 +69,7 @@ fn browser_version_download_test(#[case] browser: String, #[case] browser_versio .code(0); assert_driver(&mut cmd); - assert_browser(&mut cmd); + if !OS.eq("windows") { + assert_browser(&mut cmd); + } } From 6f35235a838de25cb6399c893de9433321132a11 Mon Sep 17 00:00:00 2001 From: Boni Garcia Date: Thu, 28 Sep 2023 18:35:48 +0200 Subject: [PATCH 14/33] [rust] Use browser version in functions for requesting online repos --- rust/src/chrome.rs | 16 +++++++++++----- rust/src/edge.rs | 29 +++++++++++++++++------------ rust/src/firefox.rs | 10 ++++++++-- rust/src/grid.rs | 10 ++++++++-- rust/src/iexplorer.rs | 10 ++++++++-- rust/src/lib.rs | 35 ++++++++++++++++++++++++++--------- rust/src/safari.rs | 10 ++++++++-- rust/src/safaritp.rs | 10 ++++++++-- 8 files changed, 94 insertions(+), 36 deletions(-) diff --git a/rust/src/chrome.rs b/rust/src/chrome.rs index c4a2a8ee9f9dc..72602214078bd 100644 --- a/rust/src/chrome.rs +++ b/rust/src/chrome.rs @@ -419,7 +419,10 @@ impl SeleniumManager for ChromeManager { } } - fn request_latest_browser_version_from_online(&mut self) -> Result> { + fn request_latest_browser_version_from_online( + &mut self, + _browser_version: &str, + ) -> Result> { let browser_name = self.browser_name; self.get_logger().trace(format!( "Using Chrome for Testing (CfT) endpoints to find out latest stable {} version", @@ -447,7 +450,10 @@ impl SeleniumManager for ChromeManager { Ok(browser_version) } - fn request_fixed_browser_version_from_online(&mut self) -> Result> { + fn request_fixed_browser_version_from_online( + &mut self, + _browser_version: &str, + ) -> Result> { let browser_name = self.browser_name; let mut browser_version = self.get_browser_version().to_string(); let major_browser_version = self.get_major_browser_version(); @@ -526,15 +532,15 @@ impl SeleniumManager for ChromeManager { fn get_browser_url_for_download( &mut self, - _browser_version: &str, + browser_version: &str, ) -> Result> { if let Some(browser_url) = self.browser_url.clone() { Ok(browser_url) } else { if self.is_browser_version_stable() || self.is_browser_version_empty() { - self.request_latest_browser_version_from_online()?; + self.request_latest_browser_version_from_online(browser_version)?; } else { - self.request_fixed_browser_version_from_online()?; + self.request_fixed_browser_version_from_online(browser_version)?; } Ok(self.browser_url.clone().unwrap()) } diff --git a/rust/src/edge.rs b/rust/src/edge.rs index a00ffbfca37e4..3ac3e3f37e702 100644 --- a/rust/src/edge.rs +++ b/rust/src/edge.rs @@ -299,12 +299,14 @@ impl SeleniumManager for EdgeManager { } } - fn request_latest_browser_version_from_online(&mut self) -> Result> { + fn request_latest_browser_version_from_online( + &mut self, + browser_version: &str, + ) -> Result> { let browser_name = self.browser_name; - let browser_version = self.get_browser_version(); - let is_fixed_browser_version = !self.is_browser_version_empty() - && !self.is_browser_version_stable() - && !self.is_browser_version_unstable(); + let is_fixed_browser_version = !self.is_empty(browser_version) + && !self.is_stable(browser_version) + && !self.is_unstable(browser_version); let edge_updates_url = if is_fixed_browser_version { format!("{}?view=enterprise", BROWSER_URL) } else { @@ -318,11 +320,11 @@ impl SeleniumManager for EdgeManager { let edge_products = parse_json_from_url::>(self.get_http_client(), edge_updates_url)?; - let edge_channel = if self.is_browser_version_beta() { + let edge_channel = if self.is_beta(browser_version) { "Beta" - } else if self.is_browser_version_dev() { + } else if self.is_dev(browser_version) { "Dev" - } else if self.is_browser_version_nightly() { + } else if self.is_nightly(browser_version) { "Canary" } else { "Stable" @@ -403,8 +405,11 @@ impl SeleniumManager for EdgeManager { Ok(browser_version) } - fn request_fixed_browser_version_from_online(&mut self) -> Result> { - self.request_latest_browser_version_from_online() + fn request_fixed_browser_version_from_online( + &mut self, + browser_version: &str, + ) -> Result> { + self.request_latest_browser_version_from_online(browser_version) } fn get_min_browser_version_for_download(&self) -> Result> { @@ -455,10 +460,10 @@ impl SeleniumManager for EdgeManager { fn get_browser_url_for_download( &mut self, - _browser_version: &str, + browser_version: &str, ) -> Result> { if self.browser_url.is_none() { - self.request_latest_browser_version_from_online()?; + self.request_latest_browser_version_from_online(browser_version)?; } Ok(self.browser_url.clone().unwrap()) } diff --git a/rust/src/firefox.rs b/rust/src/firefox.rs index 37cd64a7a565c..20d631a06b07d 100644 --- a/rust/src/firefox.rs +++ b/rust/src/firefox.rs @@ -326,7 +326,10 @@ impl SeleniumManager for FirefoxManager { } } - fn request_latest_browser_version_from_online(&mut self) -> Result> { + fn request_latest_browser_version_from_online( + &mut self, + _browser_version: &str, + ) -> Result> { let browser_name = self.browser_name; self.get_logger().trace(format!( "Using Firefox endpoints to find out latest stable {} version", @@ -345,7 +348,10 @@ impl SeleniumManager for FirefoxManager { Ok(browser_version.to_string()) } - fn request_fixed_browser_version_from_online(&mut self) -> Result> { + fn request_fixed_browser_version_from_online( + &mut self, + _browser_version: &str, + ) -> Result> { let browser_name = self.browser_name; let browser_version = self.get_browser_version().to_string(); self.get_logger().trace(format!( diff --git a/rust/src/grid.rs b/rust/src/grid.rs index c26cd49902592..13a48db68cfb1 100644 --- a/rust/src/grid.rs +++ b/rust/src/grid.rs @@ -224,11 +224,17 @@ impl SeleniumManager for GridManager { "" } - fn request_latest_browser_version_from_online(&mut self) -> Result> { + fn request_latest_browser_version_from_online( + &mut self, + _browser_version: &str, + ) -> Result> { self.unavailable_download() } - fn request_fixed_browser_version_from_online(&mut self) -> Result> { + fn request_fixed_browser_version_from_online( + &mut self, + _browser_version: &str, + ) -> Result> { self.unavailable_download() } diff --git a/rust/src/iexplorer.rs b/rust/src/iexplorer.rs index 26a6f2b03a769..f764f2d094b6b 100644 --- a/rust/src/iexplorer.rs +++ b/rust/src/iexplorer.rs @@ -229,11 +229,17 @@ impl SeleniumManager for IExplorerManager { "win32" } - fn request_latest_browser_version_from_online(&mut self) -> Result> { + fn request_latest_browser_version_from_online( + &mut self, + _browser_version: &str, + ) -> Result> { self.unavailable_download() } - fn request_fixed_browser_version_from_online(&mut self) -> Result> { + fn request_fixed_browser_version_from_online( + &mut self, + _browser_version: &str, + ) -> Result> { self.unavailable_download() } diff --git a/rust/src/lib.rs b/rust/src/lib.rs index 5ce0567c94131..da080f423dc97 100644 --- a/rust/src/lib.rs +++ b/rust/src/lib.rs @@ -148,9 +148,15 @@ pub trait SeleniumManager { fn get_platform_label(&self) -> &str; - fn request_latest_browser_version_from_online(&mut self) -> Result>; + fn request_latest_browser_version_from_online( + &mut self, + browser_version: &str, + ) -> Result>; - fn request_fixed_browser_version_from_online(&mut self) -> Result>; + fn request_fixed_browser_version_from_online( + &mut self, + browser_version: &str, + ) -> Result>; fn get_min_browser_version_for_download(&self) -> Result>; @@ -247,11 +253,13 @@ pub trait SeleniumManager { self.set_browser_version(browser_version.clone()); } _ => { - // If not in metadata, discover version using Mozilla online metadata + // If not in metadata, discover version using online metadata if self.is_browser_version_stable() || self.is_browser_version_empty() { - browser_version = self.request_latest_browser_version_from_online()?; + browser_version = + self.request_latest_browser_version_from_online(&original_browser_version)?; } else { - browser_version = self.request_fixed_browser_version_from_online()?; + browser_version = + self.request_fixed_browser_version_from_online(&original_browser_version)?; } self.set_browser_version(browser_version.clone()); @@ -673,12 +681,20 @@ pub trait SeleniumManager { self.is_unstable(self.get_browser_version()) } + fn is_empty(&self, browser_version: &str) -> bool { + browser_version.is_empty() + } + fn is_browser_version_empty(&self) -> bool { - self.get_browser_version().is_empty() + self.is_empty(self.get_browser_version()) + } + + fn is_stable(&self, browser_version: &str) -> bool { + browser_version.eq_ignore_ascii_case(STABLE) } fn is_browser_version_stable(&self) -> bool { - self.get_browser_version().eq_ignore_ascii_case(STABLE) + self.is_stable(self.get_browser_version()) } fn setup(&mut self) -> Result> { @@ -894,6 +910,7 @@ pub trait SeleniumManager { browser_name: &str, ) -> Result, Box> { let browser_version; + let original_browser_version = self.get_config().browser_version.clone(); let major_browser_version = self.get_major_browser_version(); let cache_path = self.get_cache_path()?; let mut metadata = get_metadata(self.get_logger(), &cache_path); @@ -916,9 +933,9 @@ pub trait SeleniumManager { // If not in metadata, discover version using online endpoints browser_version = if major_browser_version.is_empty() || self.is_browser_version_stable() { - self.request_latest_browser_version_from_online()? + self.request_latest_browser_version_from_online(&original_browser_version)? } else { - self.request_fixed_browser_version_from_online()? + self.request_fixed_browser_version_from_online(&original_browser_version)? }; let browser_ttl = self.get_ttl(); diff --git a/rust/src/safari.rs b/rust/src/safari.rs index 8e9c8e5e93ea7..0ce03828363a4 100644 --- a/rust/src/safari.rs +++ b/rust/src/safari.rs @@ -122,11 +122,17 @@ impl SeleniumManager for SafariManager { "" } - fn request_latest_browser_version_from_online(&mut self) -> Result> { + fn request_latest_browser_version_from_online( + &mut self, + _browser_version: &str, + ) -> Result> { self.unavailable_download() } - fn request_fixed_browser_version_from_online(&mut self) -> Result> { + fn request_fixed_browser_version_from_online( + &mut self, + _browser_version: &str, + ) -> Result> { self.unavailable_download() } diff --git a/rust/src/safaritp.rs b/rust/src/safaritp.rs index 9e4df969ebb6d..5bfee0a9d5ad3 100644 --- a/rust/src/safaritp.rs +++ b/rust/src/safaritp.rs @@ -130,11 +130,17 @@ impl SeleniumManager for SafariTPManager { "" } - fn request_latest_browser_version_from_online(&mut self) -> Result> { + fn request_latest_browser_version_from_online( + &mut self, + _browser_version: &str, + ) -> Result> { self.unavailable_download() } - fn request_fixed_browser_version_from_online(&mut self) -> Result> { + fn request_fixed_browser_version_from_online( + &mut self, + _browser_version: &str, + ) -> Result> { self.unavailable_download() } From 8f47db3c412f06f7af4898a406a58c79460b8724 Mon Sep 17 00:00:00 2001 From: Boni Garcia Date: Fri, 29 Sep 2023 10:21:35 +0200 Subject: [PATCH 15/33] [rust] Refactor common logic when unavailable download or discovery --- rust/src/edge.rs | 6 +++--- rust/src/firefox.rs | 17 +++-------------- rust/src/lib.rs | 16 +++++++++++++++- 3 files changed, 21 insertions(+), 18 deletions(-) diff --git a/rust/src/edge.rs b/rust/src/edge.rs index 3ac3e3f37e702..478685ca9d554 100644 --- a/rust/src/edge.rs +++ b/rust/src/edge.rs @@ -355,7 +355,7 @@ impl SeleniumManager for EdgeManager { "x64" }; if products.is_empty() { - return self.unavailable_download(); + return self.unavailable_discovery(); } let releases: Vec<&Release> = products @@ -383,7 +383,7 @@ impl SeleniumManager for EdgeManager { "deb" }; if releases.is_empty() { - return self.unavailable_download(); + return self.unavailable_discovery(); } let release = releases.first().unwrap(); @@ -396,7 +396,7 @@ impl SeleniumManager for EdgeManager { .trace(format!("Artifacts: {:?}", artifacts)); if artifacts.is_empty() { - return self.unavailable_download(); + return self.unavailable_discovery(); } let artifact = artifacts.first().unwrap(); let browser_version = release.product_version.clone(); diff --git a/rust/src/firefox.rs b/rust/src/firefox.rs index 20d631a06b07d..d79340f742c3c 100644 --- a/rust/src/firefox.rs +++ b/rust/src/firefox.rs @@ -33,8 +33,7 @@ use crate::metadata::{ }; use crate::{ create_http_client, format_three_args, format_two_args, Logger, SeleniumManager, BETA, - DASH_VERSION, DEV, NIGHTLY, OFFLINE_REQUEST_ERR_MSG, ONLINE_DISCOVERY_ERROR_MESSAGE, - REG_CURRENT_VERSION_ARG, STABLE, + DASH_VERSION, DEV, NIGHTLY, OFFLINE_REQUEST_ERR_MSG, REG_CURRENT_VERSION_ARG, STABLE, }; pub const FIREFOX_NAME: &str = "firefox"; @@ -399,12 +398,7 @@ impl SeleniumManager for FirefoxManager { firefox_versions = self.request_versions_from_online(FIREFOX_HISTORY_DEV_ENDPOINT)?; if firefox_versions.is_empty() { - return Err(format_two_args( - ONLINE_DISCOVERY_ERROR_MESSAGE, - browser_name, - self.get_browser_version(), - ) - .into()); + return self.unavailable_discovery(); } } @@ -417,12 +411,7 @@ impl SeleniumManager for FirefoxManager { return Ok(version.to_string()); } } - Err(format_two_args( - ONLINE_DISCOVERY_ERROR_MESSAGE, - browser_name, - self.get_browser_version(), - ) - .into()) + self.unavailable_discovery() } } diff --git a/rust/src/lib.rs b/rust/src/lib.rs index da080f423dc97..058869901a006 100644 --- a/rust/src/lib.rs +++ b/rust/src/lib.rs @@ -1055,6 +1055,20 @@ pub trait SeleniumManager { } fn unavailable_download(&self) -> Result> + where + Self: Sized, + { + self.throw_error_message(UNAVAILABLE_DOWNLOAD_ERR_MSG) + } + + fn unavailable_discovery(&self) -> Result> + where + Self: Sized, + { + self.throw_error_message(ONLINE_DISCOVERY_ERROR_MESSAGE) + } + + fn throw_error_message(&self, error_message: &str) -> Result> where Self: Sized, { @@ -1065,7 +1079,7 @@ pub trait SeleniumManager { format!(" {}", browser_version) }; Err(format_two_args( - UNAVAILABLE_DOWNLOAD_ERR_MSG, + error_message, self.get_browser_name(), &browser_version_label, ) From baa4651734d2dd9883a84c31b7e021b6a9ab196e Mon Sep 17 00:00:00 2001 From: Boni Garcia Date: Fri, 29 Sep 2023 12:15:42 +0200 Subject: [PATCH 16/33] [rust] Improve a couple of logging messages --- rust/src/lib.rs | 7 ++++++- 1 file changed, 6 insertions(+), 1 deletion(-) diff --git a/rust/src/lib.rs b/rust/src/lib.rs index 058869901a006..487a6b06d5c3e 100644 --- a/rust/src/lib.rs +++ b/rust/src/lib.rs @@ -108,7 +108,7 @@ pub const UNAVAILABLE_DOWNLOAD_WITH_MIN_VERSION_ERR_MSG: &str = "{} {} not available for download (minimum version: {})"; pub const NOT_ADMIN_FOR_EDGE_INSTALLER_ERR_MSG: &str = "{} can only be installed in Windows with administrator permissions"; -pub const ONLINE_DISCOVERY_ERROR_MESSAGE: &str = "Unable to discover {} {} in online repository"; +pub const ONLINE_DISCOVERY_ERROR_MESSAGE: &str = "Unable to discover {}{} in online repository"; pub const UNC_PREFIX: &str = r#"\\?\"#; pub trait SeleniumManager { @@ -324,6 +324,11 @@ pub trait SeleniumManager { self.set_browser_path(path_buf_to_string(browser_binary_path.clone())); Ok(Some(browser_binary_path)) } else { + self.get_logger().warn(format!( + "Expected {} path does not exists: {}", + self.get_browser_name(), + browser_binary_path.display() + )); Ok(None) } } From 90bbf8e4cfa3471213e916427a2fe10d4c1454e1 Mon Sep 17 00:00:00 2001 From: Boni Garcia Date: Fri, 29 Sep 2023 12:21:36 +0200 Subject: [PATCH 17/33] [rust] Fix condition checking Firefox nightly in mac --- rust/src/firefox.rs | 4 ++-- 1 file changed, 2 insertions(+), 2 deletions(-) diff --git a/rust/src/firefox.rs b/rust/src/firefox.rs index d79340f742c3c..4a7be91fd8284 100644 --- a/rust/src/firefox.rs +++ b/rust/src/firefox.rs @@ -429,11 +429,11 @@ impl SeleniumManager for FirefoxManager { fn get_browser_binary_path( &mut self, - _browser_version: &str, + browser_version: &str, ) -> Result> { let browser_in_cache = self.get_browser_path_in_cache()?; if MACOS.is(self.get_os()) { - let macos_app_name = if self.is_browser_version_nightly() { + let macos_app_name = if self.is_nightly(browser_version) { FIREFOX_NIGHTLY_MACOS_APP_NAME } else { FIREFOX_MACOS_APP_NAME From 329abdf68c047bbdc7dd599112564efe8750aa8a Mon Sep 17 00:00:00 2001 From: Boni Garcia Date: Fri, 29 Sep 2023 12:56:53 +0200 Subject: [PATCH 18/33] [rust] Update cargo bazel lock fil --- rust/Cargo.Bazel.lock | 306 +++++++++++++++++++++++++++++++++++++++++- 1 file changed, 305 insertions(+), 1 deletion(-) diff --git a/rust/Cargo.Bazel.lock b/rust/Cargo.Bazel.lock index 58046d9a2e4db..8188b66f1681c 100644 --- a/rust/Cargo.Bazel.lock +++ b/rust/Cargo.Bazel.lock @@ -1,5 +1,5 @@ { - "checksum": "495be0038fd3bd2826baeb0433f22c042c1b03eeeb117631135bc6339799addf", + "checksum": "7bb62c0cb24820374fb08c7eb1d2c1661ceb1a296f8cf2cad91579a7d2687eaf", "crates": { "addr2line 0.19.0": { "name": "addr2line", @@ -478,6 +478,73 @@ }, "license": "MIT OR Apache-2.0" }, + "ar 0.9.0": { + "name": "ar", + "version": "0.9.0", + "repository": { + "Http": { + "url": "https://crates.io/api/v1/crates/ar/0.9.0/download", + "sha256": "d67af77d68a931ecd5cbd8a3b5987d63a1d1d1278f7f6a60ae33db485cdebb69" + } + }, + "targets": [ + { + "Library": { + "crate_name": "ar", + "crate_root": "src/lib.rs", + "srcs": [ + "**/*.rs" + ] + } + } + ], + "library_target_name": "ar", + "common_attrs": { + "compile_data_glob": [ + "**" + ], + "edition": "2015", + "version": "0.9.0" + }, + "license": "MIT" + }, + "arrayvec 0.7.4": { + "name": "arrayvec", + "version": "0.7.4", + "repository": { + "Http": { + "url": "https://crates.io/api/v1/crates/arrayvec/0.7.4/download", + "sha256": "96d30a06541fbafbc7f82ed10c06164cfbd2c401138f6addd8404629c4b16711" + } + }, + "targets": [ + { + "Library": { + "crate_name": "arrayvec", + "crate_root": "src/lib.rs", + "srcs": [ + "**/*.rs" + ] + } + } + ], + "library_target_name": "arrayvec", + "common_attrs": { + "compile_data_glob": [ + "**" + ], + "crate_features": { + "common": [ + "default", + "std" + ], + "selects": {} + }, + "edition": "2018", + "version": "0.7.4" + }, + "license": "MIT OR Apache-2.0" + }, "assert_cmd 2.0.12": { "name": "assert_cmd", "version": "2.0.12", @@ -2021,6 +2088,81 @@ }, "license": "MIT OR Apache-2.0" }, + "debpkg 0.6.0": { + "name": "debpkg", + "version": "0.6.0", + "repository": { + "Http": { + "url": "https://crates.io/api/v1/crates/debpkg/0.6.0/download", + "sha256": "7ffffa9a03449467cfac11c9a4260556f477de22a935bb5e9475153de323c337" + } + }, + "targets": [ + { + "Library": { + "crate_name": "debpkg", + "crate_root": "src/lib.rs", + "srcs": [ + "**/*.rs" + ] + } + } + ], + "library_target_name": "debpkg", + "common_attrs": { + "compile_data_glob": [ + "**" + ], + "deps": { + "common": [ + { + "id": "ar 0.9.0", + "target": "ar" + }, + { + "id": "arrayvec 0.7.4", + "target": "arrayvec" + }, + { + "id": "bzip2 0.4.4", + "target": "bzip2" + }, + { + "id": "flate2 1.0.27", + "target": "flate2" + }, + { + "id": "indexmap 1.9.2", + "target": "indexmap" + }, + { + "id": "infer 0.8.1", + "target": "infer" + }, + { + "id": "log 0.4.20", + "target": "log" + }, + { + "id": "tar 0.4.40", + "target": "tar" + }, + { + "id": "xz2 0.1.7", + "target": "xz2" + }, + { + "id": "zstd 0.11.2+zstd.1.5.2", + "target": "zstd" + } + ], + "selects": {} + }, + "edition": "2018", + "version": "0.6.0" + }, + "license": "MIT" + }, "difflib 0.4.0": { "name": "difflib", "version": "0.4.0", @@ -4647,6 +4789,54 @@ }, "license": "MIT" }, + "infer 0.8.1": { + "name": "infer", + "version": "0.8.1", + "repository": { + "Http": { + "url": "https://crates.io/api/v1/crates/infer/0.8.1/download", + "sha256": "e035cede526e0b21d5adffc9fa0eb4ef5d6026fe9c5b0bfe8084b9472b587a55" + } + }, + "targets": [ + { + "Library": { + "crate_name": "infer", + "crate_root": "src/lib.rs", + "srcs": [ + "**/*.rs" + ] + } + } + ], + "library_target_name": "infer", + "common_attrs": { + "compile_data_glob": [ + "**" + ], + "crate_features": { + "common": [ + "alloc", + "cfb", + "default", + "std" + ], + "selects": {} + }, + "deps": { + "common": [ + { + "id": "cfb 0.7.3", + "target": "cfb" + } + ], + "selects": {} + }, + "edition": "2018", + "version": "0.8.1" + }, + "license": "MIT" + }, "inout 0.1.3": { "name": "inout", "version": "0.1.3", @@ -5280,6 +5470,77 @@ }, "license": "Apache-2.0" }, + "lzma-sys 0.1.20": { + "name": "lzma-sys", + "version": "0.1.20", + "repository": { + "Http": { + "url": "https://crates.io/api/v1/crates/lzma-sys/0.1.20/download", + "sha256": "5fda04ab3764e6cde78b9974eec4f779acaba7c4e84b36eca3cf77c581b85d27" + } + }, + "targets": [ + { + "Library": { + "crate_name": "lzma_sys", + "crate_root": "src/lib.rs", + "srcs": [ + "**/*.rs" + ] + } + }, + { + "BuildScript": { + "crate_name": "build_script_build", + "crate_root": "build.rs", + "srcs": [ + "**/*.rs" + ] + } + } + ], + "library_target_name": "lzma_sys", + "common_attrs": { + "compile_data_glob": [ + "**" + ], + "deps": { + "common": [ + { + "id": "libc 0.2.147", + "target": "libc" + }, + { + "id": "lzma-sys 0.1.20", + "target": "build_script_build" + } + ], + "selects": {} + }, + "edition": "2018", + "version": "0.1.20" + }, + "build_script_attrs": { + "data_glob": [ + "**" + ], + "deps": { + "common": [ + { + "id": "cc 1.0.79", + "target": "cc" + }, + { + "id": "pkg-config 0.3.26", + "target": "pkg_config" + } + ], + "selects": {} + }, + "links": "lzma" + }, + "license": "MIT/Apache-2.0" + }, "memchr 2.5.0": { "name": "memchr", "version": "2.5.0", @@ -7750,6 +8011,10 @@ "id": "clap 4.3.23", "target": "clap" }, + { + "id": "debpkg 0.6.0", + "target": "debpkg" + }, { "id": "directories 5.0.1", "target": "directories" @@ -12349,6 +12614,45 @@ }, "license": "MIT/Apache-2.0" }, + "xz2 0.1.7": { + "name": "xz2", + "version": "0.1.7", + "repository": { + "Http": { + "url": "https://crates.io/api/v1/crates/xz2/0.1.7/download", + "sha256": "388c44dc09d76f1536602ead6d325eb532f5c122f17782bd57fb47baeeb767e2" + } + }, + "targets": [ + { + "Library": { + "crate_name": "xz2", + "crate_root": "src/lib.rs", + "srcs": [ + "**/*.rs" + ] + } + } + ], + "library_target_name": "xz2", + "common_attrs": { + "compile_data_glob": [ + "**" + ], + "deps": { + "common": [ + { + "id": "lzma-sys 0.1.20", + "target": "lzma_sys" + } + ], + "selects": {} + }, + "edition": "2018", + "version": "0.1.7" + }, + "license": "MIT/Apache-2.0" + }, "zip 0.6.6": { "name": "zip", "version": "0.6.6", From a508aacc61023ba5ec7faf310aee743e0272a926 Mon Sep 17 00:00:00 2001 From: Boni Garcia Date: Fri, 29 Sep 2023 14:43:13 +0200 Subject: [PATCH 19/33] [rust] Ensure empty parent path before moving files --- rust/src/files.rs | 12 ++++++++---- rust/src/lib.rs | 6 +++--- 2 files changed, 11 insertions(+), 7 deletions(-) diff --git a/rust/src/files.rs b/rust/src/files.rs index bd7159001b727..159a8b2726f90 100644 --- a/rust/src/files.rs +++ b/rust/src/files.rs @@ -69,9 +69,13 @@ impl BrowserPath { } } -pub fn create_parent_path_if_not_exists(path: &Path) -> Result<(), Box> { +pub fn create_empty_parent_path_if_not_exists(path: &Path) -> Result<(), Box> { if let Some(p) = path.parent() { create_path_if_not_exists(p)?; + if p.to_path_buf().read_dir()?.next().is_some() { + // If not empty + fs::remove_dir_all(p).and_then(|_| fs::create_dir(p))?; + } } Ok(()) } @@ -183,7 +187,7 @@ pub fn uncompress_sfx( "Moving extracted files and folders from {} to {}", core_str, target_str )); - create_parent_path_if_not_exists(target)?; + create_empty_parent_path_if_not_exists(target)?; fs::rename(&core_str, &target_str)?; Ok(()) @@ -289,7 +293,7 @@ pub fn uncompress_deb( "Moving extracted files and folders from {} to {}", opt_edge_str, target_str )); - create_parent_path_if_not_exists(target)?; + create_empty_parent_path_if_not_exists(target)?; fs::rename(&opt_edge_str, &target_str)?; Ok(()) @@ -402,7 +406,7 @@ pub fn unzip( fs::create_dir_all(&tmp_path)?; } else { let target_path = tmp_path.join(path.clone()); - create_parent_path_if_not_exists(target_path.as_path())?; + create_empty_parent_path_if_not_exists(target_path.as_path())?; let mut outfile = File::create(&target_path)?; // Set permissions in Unix-like systems diff --git a/rust/src/lib.rs b/rust/src/lib.rs index 487a6b06d5c3e..1112c9c20c85d 100644 --- a/rust/src/lib.rs +++ b/rust/src/lib.rs @@ -18,8 +18,8 @@ use crate::chrome::{ChromeManager, CHROMEDRIVER_NAME, CHROME_NAME}; use crate::edge::{EdgeManager, EDGEDRIVER_NAME, EDGE_NAMES}; use crate::files::{ - create_parent_path_if_not_exists, create_path_if_not_exists, default_cache_folder, - get_binary_extension, path_to_string, + create_empty_parent_path_if_not_exists, create_path_if_not_exists, default_cache_folder, + get_binary_extension, path_buf_to_string, }; use crate::firefox::{FirefoxManager, FIREFOX_NAME, GECKODRIVER_NAME}; use crate::iexplorer::{IExplorerManager, IEDRIVER_NAME, IE_NAMES}; @@ -190,7 +190,7 @@ pub trait SeleniumManager { if self.is_grid() { let driver_path_in_cache = self.get_driver_path_in_cache()?; - create_parent_path_if_not_exists(&driver_path_in_cache)?; + create_empty_parent_path_if_not_exists(&driver_path_in_cache)?; Ok(fs::rename(driver_zip_file, driver_path_in_cache)?) } else { let driver_path_in_cache = self.get_driver_path_in_cache()?; From 1d71373a6eacfaec7d1c26bff03236017eb1a750 Mon Sep 17 00:00:00 2001 From: Boni Garcia Date: Fri, 29 Sep 2023 14:51:33 +0200 Subject: [PATCH 20/33] Revert "[rust] Ensure empty parent path before moving files" This reverts commit bdcf7e48b32b3b984748c1902c5089b27aed426a. --- rust/src/files.rs | 12 ++++-------- rust/src/lib.rs | 4 ++-- 2 files changed, 6 insertions(+), 10 deletions(-) diff --git a/rust/src/files.rs b/rust/src/files.rs index 159a8b2726f90..bd7159001b727 100644 --- a/rust/src/files.rs +++ b/rust/src/files.rs @@ -69,13 +69,9 @@ impl BrowserPath { } } -pub fn create_empty_parent_path_if_not_exists(path: &Path) -> Result<(), Box> { +pub fn create_parent_path_if_not_exists(path: &Path) -> Result<(), Box> { if let Some(p) = path.parent() { create_path_if_not_exists(p)?; - if p.to_path_buf().read_dir()?.next().is_some() { - // If not empty - fs::remove_dir_all(p).and_then(|_| fs::create_dir(p))?; - } } Ok(()) } @@ -187,7 +183,7 @@ pub fn uncompress_sfx( "Moving extracted files and folders from {} to {}", core_str, target_str )); - create_empty_parent_path_if_not_exists(target)?; + create_parent_path_if_not_exists(target)?; fs::rename(&core_str, &target_str)?; Ok(()) @@ -293,7 +289,7 @@ pub fn uncompress_deb( "Moving extracted files and folders from {} to {}", opt_edge_str, target_str )); - create_empty_parent_path_if_not_exists(target)?; + create_parent_path_if_not_exists(target)?; fs::rename(&opt_edge_str, &target_str)?; Ok(()) @@ -406,7 +402,7 @@ pub fn unzip( fs::create_dir_all(&tmp_path)?; } else { let target_path = tmp_path.join(path.clone()); - create_empty_parent_path_if_not_exists(target_path.as_path())?; + create_parent_path_if_not_exists(target_path.as_path())?; let mut outfile = File::create(&target_path)?; // Set permissions in Unix-like systems diff --git a/rust/src/lib.rs b/rust/src/lib.rs index 1112c9c20c85d..c97f523c08f13 100644 --- a/rust/src/lib.rs +++ b/rust/src/lib.rs @@ -18,7 +18,7 @@ use crate::chrome::{ChromeManager, CHROMEDRIVER_NAME, CHROME_NAME}; use crate::edge::{EdgeManager, EDGEDRIVER_NAME, EDGE_NAMES}; use crate::files::{ - create_empty_parent_path_if_not_exists, create_path_if_not_exists, default_cache_folder, + create_parent_path_if_not_exists, create_path_if_not_exists, default_cache_folder, get_binary_extension, path_buf_to_string, }; use crate::firefox::{FirefoxManager, FIREFOX_NAME, GECKODRIVER_NAME}; @@ -190,7 +190,7 @@ pub trait SeleniumManager { if self.is_grid() { let driver_path_in_cache = self.get_driver_path_in_cache()?; - create_empty_parent_path_if_not_exists(&driver_path_in_cache)?; + create_parent_path_if_not_exists(&driver_path_in_cache)?; Ok(fs::rename(driver_zip_file, driver_path_in_cache)?) } else { let driver_path_in_cache = self.get_driver_path_in_cache()?; From c7565bb67c942c703713b994bec4c33747745f06 Mon Sep 17 00:00:00 2001 From: Boni Garcia Date: Fri, 29 Sep 2023 15:00:11 +0200 Subject: [PATCH 21/33] [rust] Separate function to tnsure empty parent path before moving files --- rust/src/files.rs | 10 ++++++++-- rust/src/lib.rs | 4 ++-- 2 files changed, 10 insertions(+), 4 deletions(-) diff --git a/rust/src/files.rs b/rust/src/files.rs index bd7159001b727..f108486bc6e13 100644 --- a/rust/src/files.rs +++ b/rust/src/files.rs @@ -69,6 +69,12 @@ impl BrowserPath { } } +pub fn create_empty_parent_path_if_not_exists(path: &Path) -> Result<(), Box> { + create_parent_path_if_not_exists(path)?; + fs::remove_dir_all(path).and_then(|_| fs::create_dir(path))?; + Ok(()) +} + pub fn create_parent_path_if_not_exists(path: &Path) -> Result<(), Box> { if let Some(p) = path.parent() { create_path_if_not_exists(p)?; @@ -183,7 +189,7 @@ pub fn uncompress_sfx( "Moving extracted files and folders from {} to {}", core_str, target_str )); - create_parent_path_if_not_exists(target)?; + create_empty_parent_path_if_not_exists(target)?; fs::rename(&core_str, &target_str)?; Ok(()) @@ -289,7 +295,7 @@ pub fn uncompress_deb( "Moving extracted files and folders from {} to {}", opt_edge_str, target_str )); - create_parent_path_if_not_exists(target)?; + create_empty_parent_path_if_not_exists(target)?; fs::rename(&opt_edge_str, &target_str)?; Ok(()) diff --git a/rust/src/lib.rs b/rust/src/lib.rs index c97f523c08f13..1112c9c20c85d 100644 --- a/rust/src/lib.rs +++ b/rust/src/lib.rs @@ -18,7 +18,7 @@ use crate::chrome::{ChromeManager, CHROMEDRIVER_NAME, CHROME_NAME}; use crate::edge::{EdgeManager, EDGEDRIVER_NAME, EDGE_NAMES}; use crate::files::{ - create_parent_path_if_not_exists, create_path_if_not_exists, default_cache_folder, + create_empty_parent_path_if_not_exists, create_path_if_not_exists, default_cache_folder, get_binary_extension, path_buf_to_string, }; use crate::firefox::{FirefoxManager, FIREFOX_NAME, GECKODRIVER_NAME}; @@ -190,7 +190,7 @@ pub trait SeleniumManager { if self.is_grid() { let driver_path_in_cache = self.get_driver_path_in_cache()?; - create_parent_path_if_not_exists(&driver_path_in_cache)?; + create_empty_parent_path_if_not_exists(&driver_path_in_cache)?; Ok(fs::rename(driver_zip_file, driver_path_in_cache)?) } else { let driver_path_in_cache = self.get_driver_path_in_cache()?; From bb9f0d0bcfc37d5d4232b46e53942d53d4c9008f Mon Sep 17 00:00:00 2001 From: Boni Garcia Date: Fri, 29 Sep 2023 16:55:25 +0200 Subject: [PATCH 22/33] [rust] Revert function to create parent path in grid logic --- rust/src/lib.rs | 4 ++-- 1 file changed, 2 insertions(+), 2 deletions(-) diff --git a/rust/src/lib.rs b/rust/src/lib.rs index 1112c9c20c85d..c97f523c08f13 100644 --- a/rust/src/lib.rs +++ b/rust/src/lib.rs @@ -18,7 +18,7 @@ use crate::chrome::{ChromeManager, CHROMEDRIVER_NAME, CHROME_NAME}; use crate::edge::{EdgeManager, EDGEDRIVER_NAME, EDGE_NAMES}; use crate::files::{ - create_empty_parent_path_if_not_exists, create_path_if_not_exists, default_cache_folder, + create_parent_path_if_not_exists, create_path_if_not_exists, default_cache_folder, get_binary_extension, path_buf_to_string, }; use crate::firefox::{FirefoxManager, FIREFOX_NAME, GECKODRIVER_NAME}; @@ -190,7 +190,7 @@ pub trait SeleniumManager { if self.is_grid() { let driver_path_in_cache = self.get_driver_path_in_cache()?; - create_empty_parent_path_if_not_exists(&driver_path_in_cache)?; + create_parent_path_if_not_exists(&driver_path_in_cache)?; Ok(fs::rename(driver_zip_file, driver_path_in_cache)?) } else { let driver_path_in_cache = self.get_driver_path_in_cache()?; From 514b29f994cfdb5bc5eb0399dede8a7f14461e75 Mon Sep 17 00:00:00 2001 From: Boni Garcia Date: Sat, 30 Sep 2023 21:45:26 +0200 Subject: [PATCH 23/33] [rust] Fix logic to create empty parent path --- rust/src/files.rs | 6 ++++-- 1 file changed, 4 insertions(+), 2 deletions(-) diff --git a/rust/src/files.rs b/rust/src/files.rs index f108486bc6e13..70b84b5b928f1 100644 --- a/rust/src/files.rs +++ b/rust/src/files.rs @@ -70,8 +70,10 @@ impl BrowserPath { } pub fn create_empty_parent_path_if_not_exists(path: &Path) -> Result<(), Box> { - create_parent_path_if_not_exists(path)?; - fs::remove_dir_all(path).and_then(|_| fs::create_dir(path))?; + if let Some(p) = path.parent() { + create_path_if_not_exists(p)?; + fs::remove_dir_all(p).and_then(|_| fs::create_dir(p))?; + } Ok(()) } From 2cf7a079660269f4776aae96c8d612e64fe0e352 Mon Sep 17 00:00:00 2001 From: Boni Garcia Date: Fri, 6 Oct 2023 10:29:25 +0200 Subject: [PATCH 24/33] [rust] Fix problems after rebasing --- rust/src/chrome.rs | 2 +- rust/src/edge.rs | 4 ++-- rust/src/files.rs | 4 ++-- rust/src/lib.rs | 9 +++++---- 4 files changed, 10 insertions(+), 9 deletions(-) diff --git a/rust/src/chrome.rs b/rust/src/chrome.rs index 72602214078bd..28513dc21f290 100644 --- a/rust/src/chrome.rs +++ b/rust/src/chrome.rs @@ -26,7 +26,7 @@ use std::path::PathBuf; use crate::config::ARCH::{ARM64, X32}; use crate::config::OS::{LINUX, MACOS, WINDOWS}; use crate::downloads::{parse_json_from_url, read_version_from_link}; -use crate::files::{compose_driver_path_in_cache, path_to_string, BrowserPath}; +use crate::files::{compose_driver_path_in_cache, BrowserPath}; use crate::logger::Logger; use crate::metadata::{ create_driver_metadata, get_driver_version_from_metadata, get_metadata, write_metadata, diff --git a/rust/src/edge.rs b/rust/src/edge.rs index 478685ca9d554..4d4156fe292d7 100644 --- a/rust/src/edge.rs +++ b/rust/src/edge.rs @@ -31,7 +31,7 @@ use crate::metadata::{ create_driver_metadata, get_driver_version_from_metadata, get_metadata, write_metadata, }; use crate::{ - create_http_client, get_binary_extension, path_buf_to_string, Logger, SeleniumManager, BETA, + create_http_client, get_binary_extension, path_to_string, Logger, SeleniumManager, BETA, DASH_DASH_VERSION, DEV, ENV_PROGRAM_FILES_X86, NIGHTLY, OFFLINE_REQUEST_ERR_MSG, REG_VERSION_ARG, STABLE, }; @@ -448,7 +448,7 @@ impl SeleniumManager for EdgeManager { let parent_path = Path::new(&env_value); full_browser_path = parent_path.join(&browser_path); } - Ok((&path_buf_to_string(full_browser_path)).into()) + Ok((&path_to_string(&full_browser_path)).into()) } else { Ok(browser_in_cache.join(format!( "{}{}", diff --git a/rust/src/files.rs b/rust/src/files.rs index 70b84b5b928f1..2eff09e160ad6 100644 --- a/rust/src/files.rs +++ b/rust/src/files.rs @@ -290,8 +290,8 @@ pub fn uncompress_deb( let mut deb_pkg = debpkg::DebPkg::parse(deb_file)?; deb_pkg.data()?.unpack(zip_parent)?; - let zip_parent_str = path_buf_to_string(zip_parent.to_path_buf()); - let target_str = path_buf_to_string(target.to_path_buf()); + let zip_parent_str = path_to_string(zip_parent); + let target_str = path_to_string(target); let opt_edge_str = format!("{}/opt/microsoft/{}", zip_parent_str, label); log.trace(format!( "Moving extracted files and folders from {} to {}", diff --git a/rust/src/lib.rs b/rust/src/lib.rs index c97f523c08f13..373c759a0eb71 100644 --- a/rust/src/lib.rs +++ b/rust/src/lib.rs @@ -19,7 +19,7 @@ use crate::chrome::{ChromeManager, CHROMEDRIVER_NAME, CHROME_NAME}; use crate::edge::{EdgeManager, EDGEDRIVER_NAME, EDGE_NAMES}; use crate::files::{ create_parent_path_if_not_exists, create_path_if_not_exists, default_cache_folder, - get_binary_extension, path_buf_to_string, + get_binary_extension, path_to_string, }; use crate::firefox::{FirefoxManager, FIREFOX_NAME, GECKODRIVER_NAME}; use crate::iexplorer::{IExplorerManager, IEDRIVER_NAME, IE_NAMES}; @@ -218,7 +218,8 @@ pub trait SeleniumManager { let browser_version; let original_browser_version = self.get_config().browser_version.clone(); - let mut metadata = get_metadata(self.get_logger(), self.get_cache_path()?); + let cache_path = self.get_cache_path()?; + let mut metadata = get_metadata(self.get_logger(), &cache_path); let major_browser_version = self.get_major_browser_version(); let major_browser_version_int = major_browser_version.parse::().unwrap_or_default(); @@ -274,7 +275,7 @@ pub trait SeleniumManager { &browser_version, browser_ttl, )); - write_metadata(&metadata, self.get_logger(), self.get_cache_path()?); + write_metadata(&metadata, self.get_logger(), cache_path); } } } @@ -321,7 +322,7 @@ pub trait SeleniumManager { )?; } if browser_binary_path.exists() { - self.set_browser_path(path_buf_to_string(browser_binary_path.clone())); + self.set_browser_path(path_to_string(&browser_binary_path)); Ok(Some(browser_binary_path)) } else { self.get_logger().warn(format!( From efdc4f18982c4b065b719de38c0299ab5f37af34 Mon Sep 17 00:00:00 2001 From: titusfortner Date: Fri, 6 Oct 2023 08:09:02 -0500 Subject: [PATCH 25/33] [ci] try without reusing docker in the tests --- common/remote-build/BUILD.bazel | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/common/remote-build/BUILD.bazel b/common/remote-build/BUILD.bazel index 1010e1d5b3108..dd28b016acf8a 100755 --- a/common/remote-build/BUILD.bazel +++ b/common/remote-build/BUILD.bazel @@ -40,7 +40,7 @@ platform( exec_properties = { "container-image": "docker://docker.io/shs96c/selenium-remote-build@sha256:314b60a3c2b82f512c0f3fdba0aed8983f2b9bfdf2901a4f41511abdfd6dd74a", "OSFamily": "Linux", - "dockerReuse": "True", + "dockerReuse": "False", "dockerRunAsRoot": "False", "dockerUseEntrypoint": "True", "sandboxAllowed": "False", From 3f2835c05ffad7cc40346941a7d465ae20d579a3 Mon Sep 17 00:00:00 2001 From: titusfortner Date: Fri, 6 Oct 2023 10:23:35 -0500 Subject: [PATCH 26/33] [ci] run rbe with selenium manager in offline mode --- .github/workflows/bazel.yml | 1 + .github/workflows/ci-rbe.yml | 1 + common/remote-build/BUILD.bazel | 2 +- 3 files changed, 3 insertions(+), 1 deletion(-) diff --git a/.github/workflows/bazel.yml b/.github/workflows/bazel.yml index 9999a6d905124..ed08296071206 100644 --- a/.github/workflows/bazel.yml +++ b/.github/workflows/bazel.yml @@ -55,6 +55,7 @@ jobs: GITHUB_TOKEN: ${{ secrets.GITHUB_TOKEN }} SEL_M2_USER: ${{ secrets.SEL_M2_USER }} SEL_M2_PASS: ${{ secrets.SEL_M2_PASS }} + SE_OFFLINE: ${{ inputs.offline }} steps: - name: Checkout source tree uses: actions/checkout@v4 diff --git a/.github/workflows/ci-rbe.yml b/.github/workflows/ci-rbe.yml index 3b4c36d9212f2..650dd744093b7 100644 --- a/.github/workflows/ci-rbe.yml +++ b/.github/workflows/ci-rbe.yml @@ -22,6 +22,7 @@ jobs: with: # TODO: experiment with turning off caches name: All RBE tests + offline: true cache-key: rbe ruby-version: jruby-9.4.2.0 run: ./scripts/github-actions/ci-build.sh diff --git a/common/remote-build/BUILD.bazel b/common/remote-build/BUILD.bazel index dd28b016acf8a..1010e1d5b3108 100755 --- a/common/remote-build/BUILD.bazel +++ b/common/remote-build/BUILD.bazel @@ -40,7 +40,7 @@ platform( exec_properties = { "container-image": "docker://docker.io/shs96c/selenium-remote-build@sha256:314b60a3c2b82f512c0f3fdba0aed8983f2b9bfdf2901a4f41511abdfd6dd74a", "OSFamily": "Linux", - "dockerReuse": "False", + "dockerReuse": "True", "dockerRunAsRoot": "False", "dockerUseEntrypoint": "True", "sandboxAllowed": "False", From 9fe3e52b4461d9489b54e38fbd06f856e430c645 Mon Sep 17 00:00:00 2001 From: titusfortner Date: Fri, 6 Oct 2023 11:26:04 -0500 Subject: [PATCH 27/33] [ci] set the input the correct way --- .github/workflows/bazel.yml | 5 +++++ 1 file changed, 5 insertions(+) diff --git a/.github/workflows/bazel.yml b/.github/workflows/bazel.yml index ed08296071206..af783bca59e01 100644 --- a/.github/workflows/bazel.yml +++ b/.github/workflows/bazel.yml @@ -26,6 +26,11 @@ on: required: false type: string default: '' + offline: + description: Whether to set Selenium Manager to offline mode + required: false + type: string + default: '' cache-key: description: Bazel disk cache key required: false From a35754da826f64bbc69898aab5be74bb9ae2daeb Mon Sep 17 00:00:00 2001 From: titusfortner Date: Fri, 6 Oct 2023 14:55:44 -0500 Subject: [PATCH 28/33] try setting environment variable in bazelrc --- .bazelrc | 1 + .github/workflows/bazel.yml | 6 ------ .github/workflows/ci-rbe.yml | 1 - 3 files changed, 1 insertion(+), 7 deletions(-) diff --git a/.bazelrc b/.bazelrc index ea23ac61e3548..292b56664893b 100644 --- a/.bazelrc +++ b/.bazelrc @@ -119,6 +119,7 @@ test:remote --test_tag_filters=-edge,-safari,-remote build:remote --action_env=HOME=/home/dev build:remote --action_env=PATH=/bin:/usr/bin:/usr/local/bin test:remote --test_env=HOME=/home/dev +test:remote --test_env=SE_OFFLINE=true # Make sure we sniff credentials properly build:remote --credential_helper=%workspace%/scripts/credential-helper.sh diff --git a/.github/workflows/bazel.yml b/.github/workflows/bazel.yml index af783bca59e01..9999a6d905124 100644 --- a/.github/workflows/bazel.yml +++ b/.github/workflows/bazel.yml @@ -26,11 +26,6 @@ on: required: false type: string default: '' - offline: - description: Whether to set Selenium Manager to offline mode - required: false - type: string - default: '' cache-key: description: Bazel disk cache key required: false @@ -60,7 +55,6 @@ jobs: GITHUB_TOKEN: ${{ secrets.GITHUB_TOKEN }} SEL_M2_USER: ${{ secrets.SEL_M2_USER }} SEL_M2_PASS: ${{ secrets.SEL_M2_PASS }} - SE_OFFLINE: ${{ inputs.offline }} steps: - name: Checkout source tree uses: actions/checkout@v4 diff --git a/.github/workflows/ci-rbe.yml b/.github/workflows/ci-rbe.yml index 650dd744093b7..3b4c36d9212f2 100644 --- a/.github/workflows/ci-rbe.yml +++ b/.github/workflows/ci-rbe.yml @@ -22,7 +22,6 @@ jobs: with: # TODO: experiment with turning off caches name: All RBE tests - offline: true cache-key: rbe ruby-version: jruby-9.4.2.0 run: ./scripts/github-actions/ci-build.sh From 3fb7df212d741db8c8cb7f4b5c655504048b4ece Mon Sep 17 00:00:00 2001 From: titusfortner Date: Fri, 6 Oct 2023 18:40:56 -0500 Subject: [PATCH 29/33] turn off network on remote build --- .bazelrc | 1 + 1 file changed, 1 insertion(+) diff --git a/.bazelrc b/.bazelrc index 292b56664893b..291ec27f2f433 100644 --- a/.bazelrc +++ b/.bazelrc @@ -110,6 +110,7 @@ build:remote --host_cpu=k8 build:remote --disk_cache= +build:remote --sandbox_default_allow_network=false build:remote --incompatible_enable_cc_toolchain_resolution build:remote --action_env=BAZEL_DO_NOT_DETECT_CPP_TOOLCHAIN=1 test:remote --test_env=DISPLAY=:99.0 From 42cb176f4966652c68270da64a47d2ec43155dd4 Mon Sep 17 00:00:00 2001 From: titusfortner Date: Fri, 6 Oct 2023 18:41:42 -0500 Subject: [PATCH 30/33] try setting the env in build as well as test --- .bazelrc | 1 + 1 file changed, 1 insertion(+) diff --git a/.bazelrc b/.bazelrc index 291ec27f2f433..115d4fddd4519 100644 --- a/.bazelrc +++ b/.bazelrc @@ -119,6 +119,7 @@ test:remote --test_tag_filters=-edge,-safari,-remote # Env vars we can hard code build:remote --action_env=HOME=/home/dev build:remote --action_env=PATH=/bin:/usr/bin:/usr/local/bin +build:remote --action_env=SE_OFFLINE=true test:remote --test_env=HOME=/home/dev test:remote --test_env=SE_OFFLINE=true From cf27b9c58db877bb887ce0b3da1a534bba21a67e Mon Sep 17 00:00:00 2001 From: titusfortner Date: Fri, 6 Oct 2023 19:59:40 -0500 Subject: [PATCH 31/33] none of this worked --- .bazelrc | 3 --- 1 file changed, 3 deletions(-) diff --git a/.bazelrc b/.bazelrc index 115d4fddd4519..ea23ac61e3548 100644 --- a/.bazelrc +++ b/.bazelrc @@ -110,7 +110,6 @@ build:remote --host_cpu=k8 build:remote --disk_cache= -build:remote --sandbox_default_allow_network=false build:remote --incompatible_enable_cc_toolchain_resolution build:remote --action_env=BAZEL_DO_NOT_DETECT_CPP_TOOLCHAIN=1 test:remote --test_env=DISPLAY=:99.0 @@ -119,9 +118,7 @@ test:remote --test_tag_filters=-edge,-safari,-remote # Env vars we can hard code build:remote --action_env=HOME=/home/dev build:remote --action_env=PATH=/bin:/usr/bin:/usr/local/bin -build:remote --action_env=SE_OFFLINE=true test:remote --test_env=HOME=/home/dev -test:remote --test_env=SE_OFFLINE=true # Make sure we sniff credentials properly build:remote --credential_helper=%workspace%/scripts/credential-helper.sh From 5da0dc3114d825eae24762f291b567f544e35718 Mon Sep 17 00:00:00 2001 From: titusfortner Date: Fri, 6 Oct 2023 19:59:58 -0500 Subject: [PATCH 32/33] turn off selenium manager in test --- java/test/org/openqa/selenium/grid/router/StressTest.java | 1 - 1 file changed, 1 deletion(-) diff --git a/java/test/org/openqa/selenium/grid/router/StressTest.java b/java/test/org/openqa/selenium/grid/router/StressTest.java index 35b0c63a8a947..f66b8af355ee9 100644 --- a/java/test/org/openqa/selenium/grid/router/StressTest.java +++ b/java/test/org/openqa/selenium/grid/router/StressTest.java @@ -67,7 +67,6 @@ public void setupServers() { new TomlConfig( new StringReader( "[node]\n" - + "selenium-manager = true\n" + "driver-implementation = " + browser.displayName()))); tearDowns.add(deployment); From 5c3f06afaeb36411904b279fc8b69fffe528c803 Mon Sep 17 00:00:00 2001 From: titusfortner Date: Fri, 6 Oct 2023 20:23:34 -0500 Subject: [PATCH 33/33] fix linter issue --- java/test/org/openqa/selenium/grid/router/StressTest.java | 5 +---- 1 file changed, 1 insertion(+), 4 deletions(-) diff --git a/java/test/org/openqa/selenium/grid/router/StressTest.java b/java/test/org/openqa/selenium/grid/router/StressTest.java index f66b8af355ee9..a2c432229297f 100644 --- a/java/test/org/openqa/selenium/grid/router/StressTest.java +++ b/java/test/org/openqa/selenium/grid/router/StressTest.java @@ -65,10 +65,7 @@ public void setupServers() { DeploymentTypes.DISTRIBUTED.start( browser.getCapabilities(), new TomlConfig( - new StringReader( - "[node]\n" - + "driver-implementation = " - + browser.displayName()))); + new StringReader("[node]\n" + "driver-implementation = " + browser.displayName()))); tearDowns.add(deployment); server = deployment.getServer();