Skip to content

Commit

Permalink
webdriver: Merge pull request #26 from Ms2ger/cleanup
Browse files Browse the repository at this point in the history
Various cleanup.

Source-Repo: https://github.com/mozilla/webdriver-rust
Source-Revision: 338dcf0716188d3fa89ba2062bb4cf14db660e22

--HG--
extra : subtree_source : http%3A//tristan.corp.lon2.mozilla.com%3A8000
extra : subtree_revision : 153d50bc115a597a019b517a87953cb12bceec92
  • Loading branch information
Ms2ger committed Apr 4, 2016
1 parent c21a98c commit 8ad0f25
Show file tree
Hide file tree
Showing 6 changed files with 22 additions and 24 deletions.
1 change: 0 additions & 1 deletion testing/webdriver/Cargo.toml
Original file line number Diff line number Diff line change
Expand Up @@ -11,5 +11,4 @@ license = "MPL-2.0"
log = "0.3.5"
regex = "0.1.47"
rustc-serialize = "0.3.16"
uuid = "0.1.18"
hyper = {version = "0.8", default-features = false}
19 changes: 8 additions & 11 deletions testing/webdriver/src/command.rs
Original file line number Diff line number Diff line change
Expand Up @@ -94,15 +94,11 @@ impl <U: WebDriverExtensionRoute> WebDriverMessage<U> {
let body_data = if requires_body {
debug!("Got request body {}", body);
match Json::from_str(body) {
Ok(x) => {
match x {
Json::Object(_) => x,
_ => return Err(WebDriverError::new(ErrorStatus::InvalidArgument,
"Body was not a json object"))
}
},
Ok(x @ Json::Object(_)) => x,
Ok(_) => return Err(WebDriverError::new(ErrorStatus::InvalidArgument,
"Body was not a json object")),
Err(_) => return Err(WebDriverError::new(ErrorStatus::InvalidArgument,
&format!("Failed to decode request body as json: {}", body)[..]))
format!("Failed to decode request body as json: {}", body)))
}
} else {
Json::Null
Expand Down Expand Up @@ -316,7 +312,6 @@ impl <U: WebDriverExtensionRoute> WebDriverMessage<U> {

impl <U:WebDriverExtensionRoute> ToJson for WebDriverMessage<U> {
fn to_json(&self) -> Json {
let mut data = BTreeMap::new();
let parameters = match self.command {
WebDriverCommand::NewSession |
WebDriverCommand::DeleteSession | WebDriverCommand::GetCurrentUrl |
Expand Down Expand Up @@ -353,8 +348,10 @@ impl <U:WebDriverExtensionRoute> ToJson for WebDriverMessage<U> {
WebDriverCommand::SendAlertText(ref x) => Some(x.to_json()),
WebDriverCommand::Extension(ref x) => x.parameters_json(),
};
if parameters.is_some() {
data.insert("parameters".to_string(), parameters.unwrap());

let mut data = BTreeMap::new();
if let Some(parameters) = parameters {
data.insert("parameters".to_string(), parameters);
}
Json::Object(data)
}
Expand Down
2 changes: 1 addition & 1 deletion testing/webdriver/src/common.rs
Original file line number Diff line number Diff line change
Expand Up @@ -186,7 +186,7 @@ impl LocatorStrategy {
"partial link text" => Ok(LocatorStrategy::PartialLinkText),
"xpath" => Ok(LocatorStrategy::XPath),
x => Err(WebDriverError::new(ErrorStatus::InvalidArgument,
&format!("Unknown locator strategy {}", x)[..]))
format!("Unknown locator strategy {}", x)))
}
}
}
Expand Down
16 changes: 9 additions & 7 deletions testing/webdriver/src/error.rs
Original file line number Diff line number Diff line change
@@ -1,5 +1,6 @@
use hyper::status::StatusCode;
use rustc_serialize::json::{Json, ToJson, ParserError, DecoderError};
use std::borrow::Cow;
use std::collections::BTreeMap;
use std::convert::From;
use std::error::Error;
Expand Down Expand Up @@ -99,7 +100,7 @@ pub type WebDriverResult<T> = Result<T, WebDriverError>;
#[derive(Debug)]
pub struct WebDriverError {
pub error: ErrorStatus,
pub message: String,
pub message: Cow<'static, str>,
delete_session: bool
}

Expand All @@ -110,10 +111,12 @@ impl fmt::Display for WebDriverError {
}

impl WebDriverError {
pub fn new(error: ErrorStatus, message: &str) -> WebDriverError {
pub fn new<S>(error: ErrorStatus, message: S) -> WebDriverError
where S: Into<Cow<'static, str>>
{
WebDriverError {
error: error,
message: message.to_string(),
message: message.into(),
delete_session: false
}
}
Expand Down Expand Up @@ -161,21 +164,20 @@ impl Error for WebDriverError {
impl From<ParserError> for WebDriverError {
fn from(err: ParserError) -> WebDriverError {
WebDriverError::new(ErrorStatus::UnknownError,
err.description())
err.description().to_string())
}
}

impl From<IoError> for WebDriverError {
fn from(err: IoError) -> WebDriverError {
WebDriverError::new(ErrorStatus::UnknownError,
err.description())
err.description().to_string())
}
}

impl From<DecoderError> for WebDriverError {
fn from(err: DecoderError) -> WebDriverError {
WebDriverError::new(ErrorStatus::UnknownError,
&format!(
"Could not decode json string:\n{}", err.description())[..])
format!("Could not decode json string:\n{}", err.description()))
}
}
2 changes: 1 addition & 1 deletion testing/webdriver/src/httpapi.rs
Original file line number Diff line number Diff line change
Expand Up @@ -228,6 +228,6 @@ impl <U: WebDriverExtensionRoute> WebDriverHttpApi<U> {
}
}
Err(WebDriverError::new(error,
&format!("{} {} did not match a known command", method, path)[..]))
format!("{} {} did not match a known command", method, path)))
}
}
6 changes: 3 additions & 3 deletions testing/webdriver/src/server.rs
Original file line number Diff line number Diff line change
Expand Up @@ -104,9 +104,9 @@ impl <T: WebDriverHandler<U>,
if existing_session.id != *msg_session_id {
Err(WebDriverError::new(
ErrorStatus::InvalidSessionId,
&format!("Got unexpected session id {} expected {}",
msg_session_id,
existing_session.id)[..]))
format!("Got unexpected session id {} expected {}",
msg_session_id,
existing_session.id)))
} else {
Ok(())
}
Expand Down

0 comments on commit 8ad0f25

Please sign in to comment.