mirror of
https://github.com/servo/servo.git
synced 2025-08-07 06:25:32 +01:00
Send WillNavigate earlier during navigation startup (#37778)
The will-navigate message tells the devtools client to expect a navigation for a browsing context. This makes the network monitor clear any previous entries and show the requests for the new page that is loaded. In order to support this correctly, we need to send the navigation notification from the constellation instead of the script thread, otherwise we silently ignore navigations triggered by the browser URL bar. Testing: Ran servo in devtools mode , now the requests appear for new loaded page Fixes: https://github.com/servo/servo/issues/37334 --------- Signed-off-by: Uthman Yahaya Baba <uthmanyahayababa@gmail.com>
This commit is contained in:
parent
864c877be5
commit
2ad5b24225
13 changed files with 197 additions and 112 deletions
|
@ -11,7 +11,7 @@ use std::sync::atomic::{AtomicUsize, Ordering};
|
|||
use std::sync::{Arc, Mutex, Weak};
|
||||
use std::time::{Duration, SystemTime};
|
||||
|
||||
use base::id::TEST_PIPELINE_ID;
|
||||
use base::id::{TEST_PIPELINE_ID, TEST_WEBVIEW_ID};
|
||||
use content_security_policy as csp;
|
||||
use crossbeam_channel::{Sender, unbounded};
|
||||
use devtools_traits::{HttpRequest as DevtoolsHttpRequest, HttpResponse as DevtoolsHttpResponse};
|
||||
|
@ -66,7 +66,7 @@ fn test_fetch_response_is_not_network_error() {
|
|||
};
|
||||
let (server, url) = make_server(handler);
|
||||
|
||||
let request = RequestBuilder::new(None, url.clone(), Referrer::NoReferrer)
|
||||
let request = RequestBuilder::new(Some(TEST_WEBVIEW_ID), url.clone(), Referrer::NoReferrer)
|
||||
.origin(url.origin())
|
||||
.build();
|
||||
let fetch_response = fetch(request, None);
|
||||
|
@ -80,7 +80,7 @@ fn test_fetch_response_is_not_network_error() {
|
|||
#[test]
|
||||
fn test_fetch_on_bad_port_is_network_error() {
|
||||
let url = ServoUrl::parse("http://www.example.org:6667").unwrap();
|
||||
let request = RequestBuilder::new(None, url.clone(), Referrer::NoReferrer)
|
||||
let request = RequestBuilder::new(Some(TEST_WEBVIEW_ID), url.clone(), Referrer::NoReferrer)
|
||||
.origin(url.origin())
|
||||
.build();
|
||||
let fetch_response = fetch(request, None);
|
||||
|
@ -102,7 +102,7 @@ fn test_fetch_response_body_matches_const_message() {
|
|||
};
|
||||
let (server, url) = make_server(handler);
|
||||
|
||||
let request = RequestBuilder::new(None, url.clone(), Referrer::NoReferrer)
|
||||
let request = RequestBuilder::new(Some(TEST_WEBVIEW_ID), url.clone(), Referrer::NoReferrer)
|
||||
.origin(url.origin())
|
||||
.build();
|
||||
let fetch_response = fetch(request, None);
|
||||
|
@ -122,7 +122,7 @@ fn test_fetch_response_body_matches_const_message() {
|
|||
#[test]
|
||||
fn test_fetch_aboutblank() {
|
||||
let url = ServoUrl::parse("about:blank").unwrap();
|
||||
let request = RequestBuilder::new(None, url.clone(), Referrer::NoReferrer)
|
||||
let request = RequestBuilder::new(Some(TEST_WEBVIEW_ID), url.clone(), Referrer::NoReferrer)
|
||||
.origin(url.origin())
|
||||
.build();
|
||||
|
||||
|
@ -188,7 +188,7 @@ fn test_fetch_blob() {
|
|||
);
|
||||
let url = ServoUrl::parse(&format!("blob:{}{}", origin.as_str(), id.simple())).unwrap();
|
||||
|
||||
let request = RequestBuilder::new(None, url.clone(), Referrer::NoReferrer)
|
||||
let request = RequestBuilder::new(Some(TEST_WEBVIEW_ID), url.clone(), Referrer::NoReferrer)
|
||||
.origin(origin.origin())
|
||||
.build();
|
||||
|
||||
|
@ -230,7 +230,7 @@ fn test_file() {
|
|||
.unwrap();
|
||||
let url = ServoUrl::from_file_path(path.clone()).unwrap();
|
||||
|
||||
let request = RequestBuilder::new(None, url.clone(), Referrer::NoReferrer)
|
||||
let request = RequestBuilder::new(Some(TEST_WEBVIEW_ID), url.clone(), Referrer::NoReferrer)
|
||||
.origin(url.origin())
|
||||
.build();
|
||||
|
||||
|
@ -273,7 +273,7 @@ fn test_file() {
|
|||
#[test]
|
||||
fn test_fetch_ftp() {
|
||||
let url = ServoUrl::parse("ftp://not-supported").unwrap();
|
||||
let request = RequestBuilder::new(None, url.clone(), Referrer::NoReferrer)
|
||||
let request = RequestBuilder::new(Some(TEST_WEBVIEW_ID), url.clone(), Referrer::NoReferrer)
|
||||
.origin(url.origin())
|
||||
.build();
|
||||
let fetch_response = fetch(request, None);
|
||||
|
@ -283,7 +283,7 @@ fn test_fetch_ftp() {
|
|||
#[test]
|
||||
fn test_fetch_bogus_scheme() {
|
||||
let url = ServoUrl::parse("bogus://whatever").unwrap();
|
||||
let request = RequestBuilder::new(None, url.clone(), Referrer::NoReferrer)
|
||||
let request = RequestBuilder::new(Some(TEST_WEBVIEW_ID), url.clone(), Referrer::NoReferrer)
|
||||
.origin(url.origin())
|
||||
.build();
|
||||
let fetch_response = fetch(request, None);
|
||||
|
@ -338,7 +338,12 @@ fn test_cors_preflight_fetch() {
|
|||
let (server, url) = make_server(handler);
|
||||
|
||||
let target_url = url.clone().join("a.html").unwrap();
|
||||
let mut request = RequestBuilder::new(None, url, Referrer::ReferrerUrl(target_url)).build();
|
||||
let mut request = RequestBuilder::new(
|
||||
Some(TEST_WEBVIEW_ID),
|
||||
url,
|
||||
Referrer::ReferrerUrl(target_url),
|
||||
)
|
||||
.build();
|
||||
request.referrer_policy = ReferrerPolicy::Origin;
|
||||
request.use_cors_preflight = true;
|
||||
request.mode = RequestMode::CorsMode;
|
||||
|
@ -395,7 +400,7 @@ fn test_cors_preflight_cache_fetch() {
|
|||
};
|
||||
let (server, url) = make_server(handler);
|
||||
|
||||
let mut request = RequestBuilder::new(None, url, Referrer::NoReferrer).build();
|
||||
let mut request = RequestBuilder::new(Some(TEST_WEBVIEW_ID), url, Referrer::NoReferrer).build();
|
||||
request.use_cors_preflight = true;
|
||||
request.mode = RequestMode::CorsMode;
|
||||
let wrapped_request0 = request.clone();
|
||||
|
@ -464,7 +469,7 @@ fn test_cors_preflight_fetch_network_error() {
|
|||
};
|
||||
let (server, url) = make_server(handler);
|
||||
|
||||
let mut request = RequestBuilder::new(None, url, Referrer::NoReferrer).build();
|
||||
let mut request = RequestBuilder::new(Some(TEST_WEBVIEW_ID), url, Referrer::NoReferrer).build();
|
||||
request.method = Method::from_bytes(b"CHICKEN").unwrap();
|
||||
request.use_cors_preflight = true;
|
||||
request.mode = RequestMode::CorsMode;
|
||||
|
@ -493,7 +498,7 @@ fn test_fetch_response_is_basic_filtered() {
|
|||
};
|
||||
let (server, url) = make_server(handler);
|
||||
|
||||
let request = RequestBuilder::new(None, url.clone(), Referrer::NoReferrer)
|
||||
let request = RequestBuilder::new(Some(TEST_WEBVIEW_ID), url.clone(), Referrer::NoReferrer)
|
||||
.origin(url.origin())
|
||||
.build();
|
||||
let fetch_response = fetch(request, None);
|
||||
|
@ -560,7 +565,7 @@ fn test_fetch_response_is_cors_filtered() {
|
|||
let (server, url) = make_server(handler);
|
||||
|
||||
// an origin mis-match will stop it from defaulting to a basic filtered response
|
||||
let mut request = RequestBuilder::new(None, url, Referrer::NoReferrer).build();
|
||||
let mut request = RequestBuilder::new(Some(TEST_WEBVIEW_ID), url, Referrer::NoReferrer).build();
|
||||
request.mode = RequestMode::CorsMode;
|
||||
let fetch_response = fetch(request, None);
|
||||
let _ = server.close();
|
||||
|
@ -596,7 +601,7 @@ fn test_fetch_response_is_opaque_filtered() {
|
|||
let (server, url) = make_server(handler);
|
||||
|
||||
// an origin mis-match will fall through to an Opaque filtered response
|
||||
let request = RequestBuilder::new(None, url, Referrer::NoReferrer).build();
|
||||
let request = RequestBuilder::new(Some(TEST_WEBVIEW_ID), url, Referrer::NoReferrer).build();
|
||||
let fetch_response = fetch(request, None);
|
||||
let _ = server.close();
|
||||
|
||||
|
@ -644,7 +649,7 @@ fn test_fetch_response_is_opaque_redirect_filtered() {
|
|||
|
||||
let (server, url) = make_server(handler);
|
||||
|
||||
let mut request = RequestBuilder::new(None, url.clone(), Referrer::NoReferrer)
|
||||
let mut request = RequestBuilder::new(Some(TEST_WEBVIEW_ID), url.clone(), Referrer::NoReferrer)
|
||||
.origin(url.origin())
|
||||
.build();
|
||||
request.redirect_mode = RedirectMode::Manual;
|
||||
|
@ -680,9 +685,10 @@ fn test_fetch_with_local_urls_only() {
|
|||
let (server, server_url) = make_server(handler);
|
||||
|
||||
let do_fetch = |url: ServoUrl| {
|
||||
let mut request = RequestBuilder::new(None, url.clone(), Referrer::NoReferrer)
|
||||
.origin(url.origin())
|
||||
.build();
|
||||
let mut request =
|
||||
RequestBuilder::new(Some(TEST_WEBVIEW_ID), url.clone(), Referrer::NoReferrer)
|
||||
.origin(url.origin())
|
||||
.build();
|
||||
|
||||
// Set the flag.
|
||||
request.local_urls_only = true;
|
||||
|
@ -748,7 +754,7 @@ fn test_fetch_with_hsts() {
|
|||
HstsEntry::new("localhost".to_owned(), IncludeSubdomains::NotIncluded, None).unwrap(),
|
||||
);
|
||||
}
|
||||
let mut request = RequestBuilder::new(None, url.clone(), Referrer::NoReferrer)
|
||||
let mut request = RequestBuilder::new(Some(TEST_WEBVIEW_ID), url.clone(), Referrer::NoReferrer)
|
||||
.origin(url.origin())
|
||||
.build();
|
||||
// Set the flag.
|
||||
|
@ -802,7 +808,7 @@ fn test_load_adds_host_to_hsts_list_when_url_is_https() {
|
|||
context.state.override_manager.add_override(certificate);
|
||||
}
|
||||
|
||||
let request = RequestBuilder::new(None, url.clone(), Referrer::NoReferrer)
|
||||
let request = RequestBuilder::new(Some(TEST_WEBVIEW_ID), url.clone(), Referrer::NoReferrer)
|
||||
.method(Method::GET)
|
||||
.body(None)
|
||||
.destination(Destination::Document)
|
||||
|
@ -862,7 +868,7 @@ fn test_fetch_self_signed() {
|
|||
protocols: Arc::new(ProtocolRegistry::default()),
|
||||
};
|
||||
|
||||
let request = RequestBuilder::new(None, url.clone(), Referrer::NoReferrer)
|
||||
let request = RequestBuilder::new(Some(TEST_WEBVIEW_ID), url.clone(), Referrer::NoReferrer)
|
||||
.method(Method::GET)
|
||||
.body(None)
|
||||
.destination(Destination::Document)
|
||||
|
@ -883,7 +889,7 @@ fn test_fetch_self_signed() {
|
|||
context.state.override_manager.add_override(certificate);
|
||||
}
|
||||
|
||||
let request = RequestBuilder::new(None, url.clone(), Referrer::NoReferrer)
|
||||
let request = RequestBuilder::new(Some(TEST_WEBVIEW_ID), url.clone(), Referrer::NoReferrer)
|
||||
.method(Method::GET)
|
||||
.body(None)
|
||||
.destination(Destination::Document)
|
||||
|
@ -908,7 +914,7 @@ fn test_fetch_with_sri_network_error() {
|
|||
};
|
||||
let (server, url) = make_server(handler);
|
||||
|
||||
let mut request = RequestBuilder::new(None, url.clone(), Referrer::NoReferrer)
|
||||
let mut request = RequestBuilder::new(Some(TEST_WEBVIEW_ID), url.clone(), Referrer::NoReferrer)
|
||||
.origin(url.origin())
|
||||
.build();
|
||||
// To calulate hash use :
|
||||
|
@ -934,7 +940,7 @@ fn test_fetch_with_sri_sucess() {
|
|||
};
|
||||
let (server, url) = make_server(handler);
|
||||
|
||||
let mut request = RequestBuilder::new(None, url.clone(), Referrer::NoReferrer)
|
||||
let mut request = RequestBuilder::new(Some(TEST_WEBVIEW_ID), url.clone(), Referrer::NoReferrer)
|
||||
.origin(url.origin())
|
||||
.build();
|
||||
// To calulate hash use :
|
||||
|
@ -976,7 +982,7 @@ fn test_fetch_blocked_nosniff() {
|
|||
|
||||
let (server, url) = make_server(handler);
|
||||
|
||||
let request = RequestBuilder::new(None, url.clone(), Referrer::NoReferrer)
|
||||
let request = RequestBuilder::new(Some(TEST_WEBVIEW_ID), url.clone(), Referrer::NoReferrer)
|
||||
.origin(url.origin())
|
||||
.destination(destination)
|
||||
.build();
|
||||
|
@ -1023,7 +1029,7 @@ fn setup_server_and_fetch(message: &'static [u8], redirect_cap: u32) -> Response
|
|||
|
||||
let (server, url) = make_server(handler);
|
||||
|
||||
let request = RequestBuilder::new(None, url.clone(), Referrer::NoReferrer)
|
||||
let request = RequestBuilder::new(Some(TEST_WEBVIEW_ID), url.clone(), Referrer::NoReferrer)
|
||||
.origin(url.origin())
|
||||
.build();
|
||||
let fetch_response = fetch(request, None);
|
||||
|
@ -1113,7 +1119,7 @@ fn test_fetch_redirect_updates_method_runner(
|
|||
|
||||
let (server, url) = crate::make_server(handler);
|
||||
|
||||
let request = RequestBuilder::new(None, url.clone(), Referrer::NoReferrer)
|
||||
let request = RequestBuilder::new(Some(TEST_WEBVIEW_ID), url.clone(), Referrer::NoReferrer)
|
||||
.origin(url.origin())
|
||||
.method(method)
|
||||
.build();
|
||||
|
@ -1198,7 +1204,7 @@ fn test_fetch_async_returns_complete_response() {
|
|||
};
|
||||
let (server, url) = make_server(handler);
|
||||
|
||||
let request = RequestBuilder::new(None, url.clone(), Referrer::NoReferrer)
|
||||
let request = RequestBuilder::new(Some(TEST_WEBVIEW_ID), url.clone(), Referrer::NoReferrer)
|
||||
.origin(url.origin())
|
||||
.build();
|
||||
let fetch_response = fetch(request, None);
|
||||
|
@ -1218,7 +1224,7 @@ fn test_opaque_filtered_fetch_async_returns_complete_response() {
|
|||
let (server, url) = make_server(handler);
|
||||
|
||||
// an origin mis-match will fall through to an Opaque filtered response
|
||||
let request = RequestBuilder::new(None, url, Referrer::NoReferrer).build();
|
||||
let request = RequestBuilder::new(Some(TEST_WEBVIEW_ID), url, Referrer::NoReferrer).build();
|
||||
let fetch_response = fetch(request, None);
|
||||
|
||||
let _ = server.close();
|
||||
|
@ -1252,7 +1258,7 @@ fn test_opaque_redirect_filtered_fetch_async_returns_complete_response() {
|
|||
};
|
||||
|
||||
let (server, url) = make_server(handler);
|
||||
let request = RequestBuilder::new(None, url.clone(), Referrer::NoReferrer)
|
||||
let request = RequestBuilder::new(Some(TEST_WEBVIEW_ID), url.clone(), Referrer::NoReferrer)
|
||||
.origin(url.origin())
|
||||
.redirect_mode(RedirectMode::Manual)
|
||||
.build();
|
||||
|
@ -1277,7 +1283,7 @@ fn test_fetch_with_devtools() {
|
|||
|
||||
let (server, url) = make_server(handler);
|
||||
|
||||
let request = RequestBuilder::new(None, url.clone(), Referrer::NoReferrer)
|
||||
let request = RequestBuilder::new(Some(TEST_WEBVIEW_ID), url.clone(), Referrer::NoReferrer)
|
||||
.origin(url.origin())
|
||||
.redirect_mode(RedirectMode::Manual)
|
||||
.pipeline_id(Some(TEST_PIPELINE_ID))
|
||||
|
@ -1334,6 +1340,7 @@ fn test_fetch_with_devtools() {
|
|||
connect_time: devhttprequest.connect_time,
|
||||
send_time: devhttprequest.send_time,
|
||||
is_xhr: true,
|
||||
browsing_context_id: TEST_WEBVIEW_ID.0,
|
||||
};
|
||||
|
||||
let content = "Yay!";
|
||||
|
@ -1350,6 +1357,7 @@ fn test_fetch_with_devtools() {
|
|||
status: HttpStatus::default(),
|
||||
body: None,
|
||||
pipeline_id: TEST_PIPELINE_ID,
|
||||
browsing_context_id: TEST_WEBVIEW_ID.0,
|
||||
};
|
||||
|
||||
assert_eq!(devhttprequest, httprequest);
|
||||
|
@ -1417,7 +1425,7 @@ fn test_fetch_request_intercepted() {
|
|||
};
|
||||
|
||||
let url = ServoUrl::parse("http://www.example.org").unwrap();
|
||||
let request = RequestBuilder::new(None, url.clone(), Referrer::NoReferrer)
|
||||
let request = RequestBuilder::new(Some(TEST_WEBVIEW_ID), url.clone(), Referrer::NoReferrer)
|
||||
.origin(url.origin())
|
||||
.build();
|
||||
let response = fetch_with_context(request, &mut context);
|
||||
|
|
Loading…
Add table
Add a link
Reference in a new issue