aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorMs2ger <Ms2ger@gmail.com>2016-11-08 14:42:04 +0100
committerMs2ger <Ms2ger@gmail.com>2016-11-08 16:15:22 +0100
commit00e23a4c57110c50b579c063b7afb815f61724cb (patch)
tree91039b09964195ebbab67bf1800abe17a472f0d3
parent9b1e153b3103b63985b63d759a907ee69701a1e8 (diff)
downloadservo-00e23a4c57110c50b579c063b7afb815f61724cb.tar.gz
servo-00e23a4c57110c50b579c063b7afb815f61724cb.zip
Rewrite test_redirected_request_to_devtools.
-rw-r--r--tests/unit/net/http_loader.rs58
1 files changed, 29 insertions, 29 deletions
diff --git a/tests/unit/net/http_loader.rs b/tests/unit/net/http_loader.rs
index 8a9880d70f1..47ac4acfc27 100644
--- a/tests/unit/net/http_loader.rs
+++ b/tests/unit/net/http_loader.rs
@@ -575,47 +575,47 @@ fn test_request_and_response_message_from_devtool_without_pipeline_id() {
#[test]
fn test_redirected_request_to_devtools() {
- struct Factory;
-
- impl HttpRequestFactory for Factory {
- type R = MockRequest;
-
- fn create(&self, url: Url, method: Method, _: Headers) -> Result<MockRequest, LoadError> {
- if url.domain().unwrap() == "mozilla.com" {
- assert_eq!(Method::Post, method);
- Ok(MockRequest::new(ResponseType::Redirect("http://mozilla.org".to_owned())))
- } else {
- assert_eq!(Method::Get, method);
- Ok(MockRequest::new(ResponseType::Text(<[_]>::to_vec("Yay!".as_bytes()))))
- }
- }
- }
-
- let url = Url::parse("http://mozilla.com").unwrap();
- let mut load_data = LoadData::new(LoadContext::Browsing, url.clone(), &HttpTest);
-
- load_data.method = Method::Post;
+ let post_handler = move |request: HyperRequest, response: HyperResponse| {
+ assert_eq!(request.method, Method::Get);
+ response.send(b"Yay!").unwrap();
+ };
+ let (mut post_server, post_url) = make_server(post_handler);
+
+ let post_redirect_url = post_url.clone();
+ let pre_handler = move |request: HyperRequest, mut response: HyperResponse| {
+ assert_eq!(request.method, Method::Post);
+ response.headers_mut().set(Location(post_redirect_url.to_string()));
+ *response.status_mut() = StatusCode::MovedPermanently;
+ response.send(b"").unwrap();
+ };
+ let (mut pre_server, pre_url) = make_server(pre_handler);
- let http_state = HttpState::new();
- let ui_provider = TestProvider::new();
- let (devtools_chan, devtools_port) = mpsc::channel::<DevtoolsControlMsg>();
+ let request = Request::from_init(RequestInit {
+ url: pre_url.clone(),
+ method: Method::Post,
+ destination: Destination::Document,
+ origin: pre_url.clone(),
+ pipeline_id: Some(TEST_PIPELINE_ID),
+ .. RequestInit::default()
+ });
+ let (devtools_chan, devtools_port) = mpsc::channel();
+ let response = fetch_sync(request, Some(devtools_chan));
- let _ = load(&load_data, &ui_provider, &http_state, Some(devtools_chan), &Factory,
- DEFAULT_USER_AGENT.into(), &CancellationListener::new(None), None);
+ let _ = pre_server.close();
+ let _ = post_server.close();
let devhttprequest = expect_devtools_http_request(&devtools_port);
let devhttpresponse = expect_devtools_http_response(&devtools_port);
assert!(devhttprequest.method == Method::Post);
- assert!(devhttprequest.url == url);
- assert!(devhttpresponse.status == Some((301, "Moved Permanently".as_bytes().to_vec())));
+ assert!(devhttprequest.url == pre_url);
+ assert!(devhttpresponse.status == Some((301, b"Moved Permanently".to_vec())));
let devhttprequest = expect_devtools_http_request(&devtools_port);
let devhttpresponse = expect_devtools_http_response(&devtools_port);
- let url = Url::parse("http://mozilla.org").unwrap();
assert!(devhttprequest.method == Method::Get);
- assert!(devhttprequest.url == url);
+ assert!(devhttprequest.url == post_url);
assert!(devhttpresponse.status == Some((200, b"OK".to_vec())));
}