0.31.0
| ≥ 3.11 (3.14 Python)
diff --git a/marionette/Cargo.toml b/marionette/Cargo.toml
index 034560c..98a1cc9 100644
--- a/marionette/Cargo.toml
+++ b/marionette/Cargo.toml
@@ -1,6 +1,10 @@
[package]
name = "marionette"
version = "0.2.0"
+description = "Library implementing the client side of Gecko's Marionette remote automation protocol."
+keywords = ["mozilla", "firefox", "marionette", "webdriver"]
+repository = "https://hg.mozilla.org/mozilla-central/file/tip/testing/geckodriver/marionette"
+license = "MPL-2.0"
authors = ["Mozilla"]
edition = "2018"
diff --git a/src/browser.rs b/src/browser.rs
index 306bfe1..902f7f7 100644
--- a/src/browser.rs
+++ b/src/browser.rs
@@ -71,6 +71,7 @@ impl LocalBrowser {
options: FirefoxOptions,
marionette_port: u16,
jsdebugger: bool,
+ profile_root: Option<&Path>,
) -> WebDriverResult {
let binary = options.binary.ok_or_else(|| {
WebDriverError::new(
@@ -87,7 +88,7 @@ impl LocalBrowser {
let mut profile = match options.profile {
ProfileType::Named => None,
ProfileType::Path(x) => Some(x),
- ProfileType::Temporary => Some(Profile::new()?),
+ ProfileType::Temporary => Some(Profile::new(profile_root)?),
};
let (profile_path, prefs_backup) = if let Some(ref mut profile) = profile {
@@ -159,10 +160,12 @@ impl LocalBrowser {
}
}
self.process.kill()?;
+
// Restoring the prefs if the browser fails to stop perhaps doesn't work anyway
if let Some(prefs_backup) = self.prefs_backup {
prefs_backup.restore();
};
+
Ok(())
}
@@ -227,6 +230,7 @@ fn read_marionette_port(profile_path: &Path) -> Option {
pub(crate) struct RemoteBrowser {
handler: AndroidHandler,
marionette_port: u16,
+ prefs_backup: Option,
}
impl RemoteBrowser {
@@ -234,6 +238,7 @@ impl RemoteBrowser {
options: FirefoxOptions,
marionette_port: u16,
websocket_port: Option,
+ profile_root: Option<&Path>,
) -> WebDriverResult {
let android_options = options.android.unwrap();
@@ -248,10 +253,10 @@ impl RemoteBrowser {
));
}
ProfileType::Path(x) => (x, true),
- ProfileType::Temporary => (Profile::new()?, false),
+ ProfileType::Temporary => (Profile::new(profile_root)?, false),
};
- set_prefs(
+ let prefs_backup = set_prefs(
handler.marionette_target_port,
&mut profile,
is_custom_profile,
@@ -272,11 +277,18 @@ impl RemoteBrowser {
Ok(RemoteBrowser {
handler,
marionette_port,
+ prefs_backup,
})
}
fn close(self) -> WebDriverResult<()> {
self.handler.force_stop()?;
+
+ // Restoring the prefs if the browser fails to stop perhaps doesn't work anyway
+ if let Some(prefs_backup) = self.prefs_backup {
+ prefs_backup.restore();
+ };
+
Ok(())
}
@@ -398,7 +410,7 @@ mod tests {
// several regressions related to remote.log.level.
#[test]
fn test_remote_log_level() {
- let mut profile = Profile::new().unwrap();
+ let mut profile = Profile::new(None).unwrap();
set_prefs(2828, &mut profile, false, vec![], false).ok();
let user_prefs = profile.user_prefs().unwrap();
@@ -460,7 +472,7 @@ mod tests {
#[test]
fn test_pref_backup() {
- let mut profile = Profile::new().unwrap();
+ let mut profile = Profile::new(None).unwrap();
// Create some prefs in the profile
let initial_prefs = profile.user_prefs().unwrap();
diff --git a/src/capabilities.rs b/src/capabilities.rs
index 97e1e28..3654cc5 100644
--- a/src/capabilities.rs
+++ b/src/capabilities.rs
@@ -432,7 +432,10 @@ impl FirefoxOptions {
rv.env = FirefoxOptions::load_env(options)?;
rv.log = FirefoxOptions::load_log(options)?;
rv.prefs = FirefoxOptions::load_prefs(options)?;
- if let Some(profile) = FirefoxOptions::load_profile(options)? {
+ if let Some(profile) = FirefoxOptions::load_profile(
+ settings.profile_root.as_ref().map(|x| x.as_path()),
+ options,
+ )? {
rv.profile = ProfileType::Path(profile);
}
}
@@ -554,7 +557,10 @@ impl FirefoxOptions {
Ok(rv)
}
- fn load_profile(options: &Capabilities) -> WebDriverResult |