mirror of
https://github.com/servo/servo.git
synced 2025-06-21 15:49:04 +01:00
Introduce service-worker mode
This commit is contained in:
parent
6342a4b455
commit
6adc653083
6 changed files with 85 additions and 71 deletions
|
@ -34,7 +34,7 @@ use msg::constellation_msg::PipelineId;
|
||||||
use net_traits::{CookieSource, FetchMetadata, NetworkError, ReferrerPolicy};
|
use net_traits::{CookieSource, FetchMetadata, NetworkError, ReferrerPolicy};
|
||||||
use net_traits::request::{CacheMode, CredentialsMode, Destination, Origin};
|
use net_traits::request::{CacheMode, CredentialsMode, Destination, Origin};
|
||||||
use net_traits::request::{RedirectMode, Referrer, Request, RequestMode};
|
use net_traits::request::{RedirectMode, Referrer, Request, RequestMode};
|
||||||
use net_traits::request::{ResponseTainting, Type};
|
use net_traits::request::{ResponseTainting, ServiceWorkersMode, Type};
|
||||||
use net_traits::response::{HttpsState, Response, ResponseBody, ResponseType};
|
use net_traits::response::{HttpsState, Response, ResponseBody, ResponseType};
|
||||||
use resource_thread::AuthCache;
|
use resource_thread::AuthCache;
|
||||||
use servo_url::{ImmutableOrigin, ServoUrl};
|
use servo_url::{ImmutableOrigin, ServoUrl};
|
||||||
|
@ -521,15 +521,29 @@ pub fn http_fetch(request: &mut Request,
|
||||||
// nothing to do, since actual_response is a function on response
|
// nothing to do, since actual_response is a function on response
|
||||||
|
|
||||||
// Step 3
|
// Step 3
|
||||||
if !request.skip_service_worker && !request.is_service_worker_global_scope {
|
if request.service_workers_mode != ServiceWorkersMode::None {
|
||||||
// Substep 1
|
// Substep 1
|
||||||
|
if request.service_workers_mode == ServiceWorkersMode::All {
|
||||||
// TODO (handle fetch unimplemented)
|
// TODO (handle fetch unimplemented)
|
||||||
|
}
|
||||||
|
|
||||||
if let Some(ref res) = response {
|
|
||||||
// Substep 2
|
// Substep 2
|
||||||
// nothing to do, since actual_response is a function on response
|
if response.is_none() && request.is_subresource_request() && match request.origin {
|
||||||
|
Origin::Origin(ref origin) if *origin == request.url().origin() => true,
|
||||||
|
_ => false,
|
||||||
|
} {
|
||||||
|
// TODO (handle foreign fetch unimplemented)
|
||||||
|
}
|
||||||
|
|
||||||
// Substep 3
|
// Substep 3
|
||||||
|
if let Some(ref res) = response {
|
||||||
|
// Subsubstep 1
|
||||||
|
// TODO: transmit body for request
|
||||||
|
|
||||||
|
// Subsubstep 2
|
||||||
|
// nothing to do, since actual_response is a function on response
|
||||||
|
|
||||||
|
// Subsubstep 3
|
||||||
if (res.response_type == ResponseType::Opaque &&
|
if (res.response_type == ResponseType::Opaque &&
|
||||||
request.mode != RequestMode::NoCors) ||
|
request.mode != RequestMode::NoCors) ||
|
||||||
(res.response_type == ResponseType::OpaqueRedirect &&
|
(res.response_type == ResponseType::OpaqueRedirect &&
|
||||||
|
@ -539,7 +553,7 @@ pub fn http_fetch(request: &mut Request,
|
||||||
return Response::network_error(NetworkError::Internal("Request failed".into()));
|
return Response::network_error(NetworkError::Internal("Request failed".into()));
|
||||||
}
|
}
|
||||||
|
|
||||||
// Substep 4
|
// Subsubstep 4
|
||||||
// TODO: set response's CSP list on actual_response
|
// TODO: set response's CSP list on actual_response
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -576,7 +590,9 @@ pub fn http_fetch(request: &mut Request,
|
||||||
}
|
}
|
||||||
|
|
||||||
// Substep 2
|
// Substep 2
|
||||||
request.skip_service_worker = true;
|
if request.redirect_mode == RedirectMode::Follow {
|
||||||
|
request.service_workers_mode = ServiceWorkersMode::Foreign;
|
||||||
|
}
|
||||||
|
|
||||||
// Substep 3
|
// Substep 3
|
||||||
let mut fetch_result = http_network_or_cache_fetch(
|
let mut fetch_result = http_network_or_cache_fetch(
|
||||||
|
@ -1238,8 +1254,7 @@ fn cors_preflight_fetch(request: &Request,
|
||||||
context: &FetchContext)
|
context: &FetchContext)
|
||||||
-> Response {
|
-> Response {
|
||||||
// Step 1
|
// Step 1
|
||||||
let mut preflight = Request::new(request.current_url(), Some(request.origin.clone()),
|
let mut preflight = Request::new(request.current_url(), Some(request.origin.clone()), request.pipeline_id);
|
||||||
request.is_service_worker_global_scope, request.pipeline_id);
|
|
||||||
preflight.method = Method::Options;
|
preflight.method = Method::Options;
|
||||||
preflight.initiator = request.initiator.clone();
|
preflight.initiator = request.initiator.clone();
|
||||||
preflight.type_ = request.type_.clone();
|
preflight.type_ = request.type_.clone();
|
||||||
|
|
|
@ -97,6 +97,14 @@ pub enum CacheMode {
|
||||||
OnlyIfCached,
|
OnlyIfCached,
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/// [Service-workers mode](https://fetch.spec.whatwg.org/#request-service-workers-mode)
|
||||||
|
#[derive(Copy, Clone, PartialEq, Serialize, Deserialize, HeapSizeOf)]
|
||||||
|
pub enum ServiceWorkersMode {
|
||||||
|
All,
|
||||||
|
Foreign,
|
||||||
|
None,
|
||||||
|
}
|
||||||
|
|
||||||
/// [Redirect mode](https://fetch.spec.whatwg.org/#concept-request-redirect-mode)
|
/// [Redirect mode](https://fetch.spec.whatwg.org/#concept-request-redirect-mode)
|
||||||
#[derive(Copy, Clone, PartialEq, Serialize, Deserialize, HeapSizeOf)]
|
#[derive(Copy, Clone, PartialEq, Serialize, Deserialize, HeapSizeOf)]
|
||||||
pub enum RedirectMode {
|
pub enum RedirectMode {
|
||||||
|
@ -140,6 +148,7 @@ pub struct RequestInit {
|
||||||
pub headers: Headers,
|
pub headers: Headers,
|
||||||
pub unsafe_request: bool,
|
pub unsafe_request: bool,
|
||||||
pub body: Option<Vec<u8>>,
|
pub body: Option<Vec<u8>>,
|
||||||
|
pub service_workers_mode: ServiceWorkersMode,
|
||||||
// TODO: client object
|
// TODO: client object
|
||||||
pub type_: Type,
|
pub type_: Type,
|
||||||
pub destination: Destination,
|
pub destination: Destination,
|
||||||
|
@ -170,6 +179,7 @@ impl Default for RequestInit {
|
||||||
headers: Headers::new(),
|
headers: Headers::new(),
|
||||||
unsafe_request: false,
|
unsafe_request: false,
|
||||||
body: None,
|
body: None,
|
||||||
|
service_workers_mode: ServiceWorkersMode::All,
|
||||||
type_: Type::None,
|
type_: Type::None,
|
||||||
destination: Destination::None,
|
destination: Destination::None,
|
||||||
synchronous: false,
|
synchronous: false,
|
||||||
|
@ -208,12 +218,12 @@ pub struct Request {
|
||||||
/// https://fetch.spec.whatwg.org/#concept-request-body
|
/// https://fetch.spec.whatwg.org/#concept-request-body
|
||||||
pub body: Option<Vec<u8>>,
|
pub body: Option<Vec<u8>>,
|
||||||
// TODO: client object
|
// TODO: client object
|
||||||
pub is_service_worker_global_scope: bool,
|
|
||||||
pub window: Window,
|
pub window: Window,
|
||||||
// TODO: target browsing context
|
// TODO: target browsing context
|
||||||
/// https://fetch.spec.whatwg.org/#request-keepalive-flag
|
/// https://fetch.spec.whatwg.org/#request-keepalive-flag
|
||||||
pub keep_alive: bool,
|
pub keep_alive: bool,
|
||||||
pub skip_service_worker: bool,
|
// https://fetch.spec.whatwg.org/#request-service-workers-mode
|
||||||
|
pub service_workers_mode: ServiceWorkersMode,
|
||||||
/// https://fetch.spec.whatwg.org/#concept-request-initiator
|
/// https://fetch.spec.whatwg.org/#concept-request-initiator
|
||||||
pub initiator: Initiator,
|
pub initiator: Initiator,
|
||||||
/// https://fetch.spec.whatwg.org/#concept-request-type
|
/// https://fetch.spec.whatwg.org/#concept-request-type
|
||||||
|
@ -257,7 +267,6 @@ pub struct Request {
|
||||||
impl Request {
|
impl Request {
|
||||||
pub fn new(url: ServoUrl,
|
pub fn new(url: ServoUrl,
|
||||||
origin: Option<Origin>,
|
origin: Option<Origin>,
|
||||||
is_service_worker_global_scope: bool,
|
|
||||||
pipeline_id: Option<PipelineId>)
|
pipeline_id: Option<PipelineId>)
|
||||||
-> Request {
|
-> Request {
|
||||||
Request {
|
Request {
|
||||||
|
@ -267,10 +276,9 @@ impl Request {
|
||||||
headers: Headers::new(),
|
headers: Headers::new(),
|
||||||
unsafe_request: false,
|
unsafe_request: false,
|
||||||
body: None,
|
body: None,
|
||||||
is_service_worker_global_scope: is_service_worker_global_scope,
|
|
||||||
window: Window::Client,
|
window: Window::Client,
|
||||||
keep_alive: false,
|
keep_alive: false,
|
||||||
skip_service_worker: false,
|
service_workers_mode: ServiceWorkersMode::All,
|
||||||
initiator: Initiator::None,
|
initiator: Initiator::None,
|
||||||
type_: Type::None,
|
type_: Type::None,
|
||||||
destination: Destination::None,
|
destination: Destination::None,
|
||||||
|
@ -295,12 +303,12 @@ impl Request {
|
||||||
pub fn from_init(init: RequestInit) -> Request {
|
pub fn from_init(init: RequestInit) -> Request {
|
||||||
let mut req = Request::new(init.url.clone(),
|
let mut req = Request::new(init.url.clone(),
|
||||||
Some(Origin::Origin(init.origin.origin())),
|
Some(Origin::Origin(init.origin.origin())),
|
||||||
false,
|
|
||||||
init.pipeline_id);
|
init.pipeline_id);
|
||||||
req.method = init.method;
|
req.method = init.method;
|
||||||
req.headers = init.headers;
|
req.headers = init.headers;
|
||||||
req.unsafe_request = init.unsafe_request;
|
req.unsafe_request = init.unsafe_request;
|
||||||
req.body = init.body;
|
req.body = init.body;
|
||||||
|
req.service_workers_mode = init.service_workers_mode;
|
||||||
req.type_ = init.type_;
|
req.type_ = init.type_;
|
||||||
req.destination = init.destination;
|
req.destination = init.destination;
|
||||||
req.synchronous = init.synchronous;
|
req.synchronous = init.synchronous;
|
||||||
|
|
|
@ -55,14 +55,11 @@ pub struct Request {
|
||||||
|
|
||||||
impl Request {
|
impl Request {
|
||||||
fn new_inherited(global: &GlobalScope,
|
fn new_inherited(global: &GlobalScope,
|
||||||
url: ServoUrl,
|
url: ServoUrl) -> Request {
|
||||||
is_service_worker_global_scope: bool) -> Request {
|
|
||||||
Request {
|
Request {
|
||||||
reflector_: Reflector::new(),
|
reflector_: Reflector::new(),
|
||||||
request: DOMRefCell::new(
|
request: DOMRefCell::new(
|
||||||
net_request_from_global(global,
|
net_request_from_global(global, url)),
|
||||||
url,
|
|
||||||
is_service_worker_global_scope)),
|
|
||||||
body_used: Cell::new(false),
|
body_used: Cell::new(false),
|
||||||
headers: Default::default(),
|
headers: Default::default(),
|
||||||
mime_type: DOMRefCell::new("".to_string().into_bytes()),
|
mime_type: DOMRefCell::new("".to_string().into_bytes()),
|
||||||
|
@ -71,11 +68,9 @@ impl Request {
|
||||||
}
|
}
|
||||||
|
|
||||||
pub fn new(global: &GlobalScope,
|
pub fn new(global: &GlobalScope,
|
||||||
url: ServoUrl,
|
url: ServoUrl) -> Root<Request> {
|
||||||
is_service_worker_global_scope: bool) -> Root<Request> {
|
|
||||||
reflect_dom_object(box Request::new_inherited(global,
|
reflect_dom_object(box Request::new_inherited(global,
|
||||||
url,
|
url),
|
||||||
is_service_worker_global_scope),
|
|
||||||
global, RequestBinding::Wrap)
|
global, RequestBinding::Wrap)
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -111,9 +106,7 @@ impl Request {
|
||||||
return Err(Error::Type("Url includes credentials".to_string()))
|
return Err(Error::Type("Url includes credentials".to_string()))
|
||||||
}
|
}
|
||||||
// Step 5.4
|
// Step 5.4
|
||||||
temporary_request = net_request_from_global(global,
|
temporary_request = net_request_from_global(global, url);
|
||||||
url,
|
|
||||||
false);
|
|
||||||
// Step 5.5
|
// Step 5.5
|
||||||
fallback_mode = Some(NetTraitsRequestMode::CorsMode);
|
fallback_mode = Some(NetTraitsRequestMode::CorsMode);
|
||||||
// Step 5.6
|
// Step 5.6
|
||||||
|
@ -152,9 +145,7 @@ impl Request {
|
||||||
|
|
||||||
// Step 12
|
// Step 12
|
||||||
let mut request: NetTraitsRequest;
|
let mut request: NetTraitsRequest;
|
||||||
request = net_request_from_global(global,
|
request = net_request_from_global(global, temporary_request.current_url());
|
||||||
temporary_request.current_url(),
|
|
||||||
false);
|
|
||||||
request.method = temporary_request.method;
|
request.method = temporary_request.method;
|
||||||
request.headers = temporary_request.headers.clone();
|
request.headers = temporary_request.headers.clone();
|
||||||
request.unsafe_request = true;
|
request.unsafe_request = true;
|
||||||
|
@ -293,9 +284,7 @@ impl Request {
|
||||||
}
|
}
|
||||||
|
|
||||||
// Step 26
|
// Step 26
|
||||||
let r = Request::from_net_request(global,
|
let r = Request::from_net_request(global, request);
|
||||||
false,
|
|
||||||
request);
|
|
||||||
r.headers.or_init(|| Headers::for_request(&r.global()));
|
r.headers.or_init(|| Headers::for_request(&r.global()));
|
||||||
|
|
||||||
// Step 27
|
// Step 27
|
||||||
|
@ -421,11 +410,9 @@ impl Request {
|
||||||
|
|
||||||
impl Request {
|
impl Request {
|
||||||
fn from_net_request(global: &GlobalScope,
|
fn from_net_request(global: &GlobalScope,
|
||||||
is_service_worker_global_scope: bool,
|
|
||||||
net_request: NetTraitsRequest) -> Root<Request> {
|
net_request: NetTraitsRequest) -> Root<Request> {
|
||||||
let r = Request::new(global,
|
let r = Request::new(global,
|
||||||
net_request.current_url(),
|
net_request.current_url());
|
||||||
is_service_worker_global_scope);
|
|
||||||
*r.request.borrow_mut() = net_request;
|
*r.request.borrow_mut() = net_request;
|
||||||
r
|
r
|
||||||
}
|
}
|
||||||
|
@ -433,11 +420,10 @@ impl Request {
|
||||||
fn clone_from(r: &Request) -> Fallible<Root<Request>> {
|
fn clone_from(r: &Request) -> Fallible<Root<Request>> {
|
||||||
let req = r.request.borrow();
|
let req = r.request.borrow();
|
||||||
let url = req.url();
|
let url = req.url();
|
||||||
let is_service_worker_global_scope = req.is_service_worker_global_scope;
|
|
||||||
let body_used = r.body_used.get();
|
let body_used = r.body_used.get();
|
||||||
let mime_type = r.mime_type.borrow().clone();
|
let mime_type = r.mime_type.borrow().clone();
|
||||||
let headers_guard = r.Headers().get_guard();
|
let headers_guard = r.Headers().get_guard();
|
||||||
let r_clone = Request::new(&r.global(), url, is_service_worker_global_scope);
|
let r_clone = Request::new(&r.global(), url);
|
||||||
r_clone.request.borrow_mut().pipeline_id = req.pipeline_id;
|
r_clone.request.borrow_mut().pipeline_id = req.pipeline_id;
|
||||||
{
|
{
|
||||||
let mut borrowed_r_request = r_clone.request.borrow_mut();
|
let mut borrowed_r_request = r_clone.request.borrow_mut();
|
||||||
|
@ -457,13 +443,11 @@ impl Request {
|
||||||
}
|
}
|
||||||
|
|
||||||
fn net_request_from_global(global: &GlobalScope,
|
fn net_request_from_global(global: &GlobalScope,
|
||||||
url: ServoUrl,
|
url: ServoUrl) -> NetTraitsRequest {
|
||||||
is_service_worker_global_scope: bool) -> NetTraitsRequest {
|
|
||||||
let origin = Origin::Origin(global.get_url().origin());
|
let origin = Origin::Origin(global.get_url().origin());
|
||||||
let pipeline_id = global.pipeline_id();
|
let pipeline_id = global.pipeline_id();
|
||||||
NetTraitsRequest::new(url,
|
NetTraitsRequest::new(url,
|
||||||
Some(origin),
|
Some(origin),
|
||||||
is_service_worker_global_scope,
|
|
||||||
Some(pipeline_id))
|
Some(pipeline_id))
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -7,6 +7,7 @@ use dom::bindings::codegen::Bindings::RequestBinding::RequestInit;
|
||||||
use dom::bindings::codegen::Bindings::ResponseBinding::ResponseBinding::ResponseMethods;
|
use dom::bindings::codegen::Bindings::ResponseBinding::ResponseBinding::ResponseMethods;
|
||||||
use dom::bindings::codegen::Bindings::ResponseBinding::ResponseType as DOMResponseType;
|
use dom::bindings::codegen::Bindings::ResponseBinding::ResponseType as DOMResponseType;
|
||||||
use dom::bindings::error::Error;
|
use dom::bindings::error::Error;
|
||||||
|
use dom::bindings::inheritance::Castable;
|
||||||
use dom::bindings::js::Root;
|
use dom::bindings::js::Root;
|
||||||
use dom::bindings::refcounted::{Trusted, TrustedPromise};
|
use dom::bindings::refcounted::{Trusted, TrustedPromise};
|
||||||
use dom::bindings::reflector::DomObject;
|
use dom::bindings::reflector::DomObject;
|
||||||
|
@ -16,13 +17,14 @@ use dom::headers::Guard;
|
||||||
use dom::promise::Promise;
|
use dom::promise::Promise;
|
||||||
use dom::request::Request;
|
use dom::request::Request;
|
||||||
use dom::response::Response;
|
use dom::response::Response;
|
||||||
|
use dom::serviceworkerglobalscope::ServiceWorkerGlobalScope;
|
||||||
use ipc_channel::ipc;
|
use ipc_channel::ipc;
|
||||||
use ipc_channel::router::ROUTER;
|
use ipc_channel::router::ROUTER;
|
||||||
use js::jsapi::JSAutoCompartment;
|
use js::jsapi::JSAutoCompartment;
|
||||||
use net_traits::{FetchResponseListener, NetworkError};
|
use net_traits::{FetchResponseListener, NetworkError};
|
||||||
use net_traits::{FilteredMetadata, FetchMetadata, Metadata};
|
use net_traits::{FilteredMetadata, FetchMetadata, Metadata};
|
||||||
use net_traits::CoreResourceMsg::Fetch as NetTraitsFetch;
|
use net_traits::CoreResourceMsg::Fetch as NetTraitsFetch;
|
||||||
use net_traits::request::Request as NetTraitsRequest;
|
use net_traits::request::{Request as NetTraitsRequest, ServiceWorkersMode};
|
||||||
use net_traits::request::RequestInit as NetTraitsRequestInit;
|
use net_traits::request::RequestInit as NetTraitsRequestInit;
|
||||||
use network_listener::{NetworkListener, PreInvoke};
|
use network_listener::{NetworkListener, PreInvoke};
|
||||||
use servo_url::ServoUrl;
|
use servo_url::ServoUrl;
|
||||||
|
@ -83,12 +85,17 @@ pub fn Fetch(global: &GlobalScope, input: RequestInfo, init: RootedTraceableBox<
|
||||||
},
|
},
|
||||||
Ok(r) => r.get_request(),
|
Ok(r) => r.get_request(),
|
||||||
};
|
};
|
||||||
let request_init = request_init_from_request(request);
|
let mut request_init = request_init_from_request(request);
|
||||||
|
|
||||||
// Step 3
|
// Step 3
|
||||||
response.Headers().set_guard(Guard::Immutable);
|
if global.downcast::<ServiceWorkerGlobalScope>().is_some() {
|
||||||
|
request_init.service_workers_mode = ServiceWorkersMode::Foreign;
|
||||||
|
}
|
||||||
|
|
||||||
// Step 4
|
// Step 4
|
||||||
|
response.Headers().set_guard(Guard::Immutable);
|
||||||
|
|
||||||
|
// Step 5
|
||||||
let (action_sender, action_receiver) = ipc::channel().unwrap();
|
let (action_sender, action_receiver) = ipc::channel().unwrap();
|
||||||
let fetch_context = Arc::new(Mutex::new(FetchContext {
|
let fetch_context = Arc::new(Mutex::new(FetchContext {
|
||||||
fetch_promise: Some(TrustedPromise::new(promise.clone())),
|
fetch_promise: Some(TrustedPromise::new(promise.clone())),
|
||||||
|
|
|
@ -19,7 +19,7 @@ fn assert_parse(url: &'static str,
|
||||||
data: Option<&[u8]>) {
|
data: Option<&[u8]>) {
|
||||||
let url = ServoUrl::parse(url).unwrap();
|
let url = ServoUrl::parse(url).unwrap();
|
||||||
let origin = Origin::Origin(url.origin());
|
let origin = Origin::Origin(url.origin());
|
||||||
let mut request = Request::new(url, Some(origin), false, None);
|
let mut request = Request::new(url, Some(origin), None);
|
||||||
|
|
||||||
let response = fetch(&mut request, None);
|
let response = fetch(&mut request, None);
|
||||||
|
|
||||||
|
|
|
@ -55,7 +55,7 @@ fn test_fetch_response_is_not_network_error() {
|
||||||
let (mut server, url) = make_server(handler);
|
let (mut server, url) = make_server(handler);
|
||||||
|
|
||||||
let origin = Origin::Origin(url.origin());
|
let origin = Origin::Origin(url.origin());
|
||||||
let mut request = Request::new(url, Some(origin), false, None);
|
let mut request = Request::new(url, Some(origin), None);
|
||||||
request.referrer = Referrer::NoReferrer;
|
request.referrer = Referrer::NoReferrer;
|
||||||
let fetch_response = fetch(&mut request, None);
|
let fetch_response = fetch(&mut request, None);
|
||||||
let _ = server.close();
|
let _ = server.close();
|
||||||
|
@ -69,7 +69,7 @@ fn test_fetch_response_is_not_network_error() {
|
||||||
fn test_fetch_on_bad_port_is_network_error() {
|
fn test_fetch_on_bad_port_is_network_error() {
|
||||||
let url = ServoUrl::parse("http://www.example.org:6667").unwrap();
|
let url = ServoUrl::parse("http://www.example.org:6667").unwrap();
|
||||||
let origin = Origin::Origin(url.origin());
|
let origin = Origin::Origin(url.origin());
|
||||||
let mut request = Request::new(url, Some(origin), false, None);
|
let mut request = Request::new(url, Some(origin), None);
|
||||||
request.referrer = Referrer::NoReferrer;
|
request.referrer = Referrer::NoReferrer;
|
||||||
let fetch_response = fetch(&mut request, None);
|
let fetch_response = fetch(&mut request, None);
|
||||||
assert!(fetch_response.is_network_error());
|
assert!(fetch_response.is_network_error());
|
||||||
|
@ -86,7 +86,7 @@ fn test_fetch_response_body_matches_const_message() {
|
||||||
let (mut server, url) = make_server(handler);
|
let (mut server, url) = make_server(handler);
|
||||||
|
|
||||||
let origin = Origin::Origin(url.origin());
|
let origin = Origin::Origin(url.origin());
|
||||||
let mut request = Request::new(url, Some(origin), false, None);
|
let mut request = Request::new(url, Some(origin), None);
|
||||||
request.referrer = Referrer::NoReferrer;
|
request.referrer = Referrer::NoReferrer;
|
||||||
let fetch_response = fetch(&mut request, None);
|
let fetch_response = fetch(&mut request, None);
|
||||||
let _ = server.close();
|
let _ = server.close();
|
||||||
|
@ -106,7 +106,7 @@ fn test_fetch_response_body_matches_const_message() {
|
||||||
fn test_fetch_aboutblank() {
|
fn test_fetch_aboutblank() {
|
||||||
let url = ServoUrl::parse("about:blank").unwrap();
|
let url = ServoUrl::parse("about:blank").unwrap();
|
||||||
let origin = Origin::Origin(url.origin());
|
let origin = Origin::Origin(url.origin());
|
||||||
let mut request = Request::new(url, Some(origin), false, None);
|
let mut request = Request::new(url, Some(origin), None);
|
||||||
request.referrer = Referrer::NoReferrer;
|
request.referrer = Referrer::NoReferrer;
|
||||||
let fetch_response = fetch(&mut request, None);
|
let fetch_response = fetch(&mut request, None);
|
||||||
assert!(!fetch_response.is_network_error());
|
assert!(!fetch_response.is_network_error());
|
||||||
|
@ -136,7 +136,7 @@ fn test_fetch_blob() {
|
||||||
let url = ServoUrl::parse(&format!("blob:{}{}", origin.as_str(), id.simple())).unwrap();
|
let url = ServoUrl::parse(&format!("blob:{}{}", origin.as_str(), id.simple())).unwrap();
|
||||||
|
|
||||||
|
|
||||||
let mut request = Request::new(url, Some(Origin::Origin(origin.origin())), false, None);
|
let mut request = Request::new(url, Some(Origin::Origin(origin.origin())), None);
|
||||||
let fetch_response = fetch_with_context(&mut request, &context);
|
let fetch_response = fetch_with_context(&mut request, &context);
|
||||||
|
|
||||||
assert!(!fetch_response.is_network_error());
|
assert!(!fetch_response.is_network_error());
|
||||||
|
@ -160,7 +160,7 @@ fn test_fetch_file() {
|
||||||
|
|
||||||
let url = ServoUrl::from_file_path(path.clone()).unwrap();
|
let url = ServoUrl::from_file_path(path.clone()).unwrap();
|
||||||
let origin = Origin::Origin(url.origin());
|
let origin = Origin::Origin(url.origin());
|
||||||
let mut request = Request::new(url, Some(origin), false, None);
|
let mut request = Request::new(url, Some(origin), None);
|
||||||
|
|
||||||
let fetch_response = fetch(&mut request, None);
|
let fetch_response = fetch(&mut request, None);
|
||||||
assert!(!fetch_response.is_network_error());
|
assert!(!fetch_response.is_network_error());
|
||||||
|
@ -185,7 +185,7 @@ fn test_fetch_file() {
|
||||||
fn test_fetch_ftp() {
|
fn test_fetch_ftp() {
|
||||||
let url = ServoUrl::parse("ftp://not-supported").unwrap();
|
let url = ServoUrl::parse("ftp://not-supported").unwrap();
|
||||||
let origin = Origin::Origin(url.origin());
|
let origin = Origin::Origin(url.origin());
|
||||||
let mut request = Request::new(url, Some(origin), false, None);
|
let mut request = Request::new(url, Some(origin), None);
|
||||||
request.referrer = Referrer::NoReferrer;
|
request.referrer = Referrer::NoReferrer;
|
||||||
let fetch_response = fetch(&mut request, None);
|
let fetch_response = fetch(&mut request, None);
|
||||||
assert!(fetch_response.is_network_error());
|
assert!(fetch_response.is_network_error());
|
||||||
|
@ -195,7 +195,7 @@ fn test_fetch_ftp() {
|
||||||
fn test_fetch_bogus_scheme() {
|
fn test_fetch_bogus_scheme() {
|
||||||
let url = ServoUrl::parse("bogus://whatever").unwrap();
|
let url = ServoUrl::parse("bogus://whatever").unwrap();
|
||||||
let origin = Origin::Origin(url.origin());
|
let origin = Origin::Origin(url.origin());
|
||||||
let mut request = Request::new(url, Some(origin), false, None);
|
let mut request = Request::new(url, Some(origin), None);
|
||||||
request.referrer = Referrer::NoReferrer;
|
request.referrer = Referrer::NoReferrer;
|
||||||
let fetch_response = fetch(&mut request, None);
|
let fetch_response = fetch(&mut request, None);
|
||||||
assert!(fetch_response.is_network_error());
|
assert!(fetch_response.is_network_error());
|
||||||
|
@ -223,7 +223,7 @@ fn test_cors_preflight_fetch() {
|
||||||
let target_url = url.clone().join("a.html").unwrap();
|
let target_url = url.clone().join("a.html").unwrap();
|
||||||
|
|
||||||
let origin = Origin::Origin(ImmutableOrigin::new_opaque());
|
let origin = Origin::Origin(ImmutableOrigin::new_opaque());
|
||||||
let mut request = Request::new(url.clone(), Some(origin), false, None);
|
let mut request = Request::new(url.clone(), Some(origin), None);
|
||||||
request.referrer = Referrer::ReferrerUrl(target_url);
|
request.referrer = Referrer::ReferrerUrl(target_url);
|
||||||
request.referrer_policy = Some(ReferrerPolicy::Origin);
|
request.referrer_policy = Some(ReferrerPolicy::Origin);
|
||||||
request.use_cors_preflight = true;
|
request.use_cors_preflight = true;
|
||||||
|
@ -260,7 +260,7 @@ fn test_cors_preflight_cache_fetch() {
|
||||||
let (mut server, url) = make_server(handler);
|
let (mut server, url) = make_server(handler);
|
||||||
|
|
||||||
let origin = Origin::Origin(ImmutableOrigin::new_opaque());
|
let origin = Origin::Origin(ImmutableOrigin::new_opaque());
|
||||||
let mut request = Request::new(url.clone(), Some(origin.clone()), false, None);
|
let mut request = Request::new(url.clone(), Some(origin.clone()), None);
|
||||||
request.referrer = Referrer::NoReferrer;
|
request.referrer = Referrer::NoReferrer;
|
||||||
request.use_cors_preflight = true;
|
request.use_cors_preflight = true;
|
||||||
request.mode = RequestMode::CorsMode;
|
request.mode = RequestMode::CorsMode;
|
||||||
|
@ -309,7 +309,7 @@ fn test_cors_preflight_fetch_network_error() {
|
||||||
let (mut server, url) = make_server(handler);
|
let (mut server, url) = make_server(handler);
|
||||||
|
|
||||||
let origin = Origin::Origin(ImmutableOrigin::new_opaque());
|
let origin = Origin::Origin(ImmutableOrigin::new_opaque());
|
||||||
let mut request = Request::new(url, Some(origin), false, None);
|
let mut request = Request::new(url, Some(origin), None);
|
||||||
request.method = Method::Extension("CHICKEN".to_owned());
|
request.method = Method::Extension("CHICKEN".to_owned());
|
||||||
request.referrer = Referrer::NoReferrer;
|
request.referrer = Referrer::NoReferrer;
|
||||||
request.use_cors_preflight = true;
|
request.use_cors_preflight = true;
|
||||||
|
@ -333,7 +333,7 @@ fn test_fetch_response_is_basic_filtered() {
|
||||||
let (mut server, url) = make_server(handler);
|
let (mut server, url) = make_server(handler);
|
||||||
|
|
||||||
let origin = Origin::Origin(url.origin());
|
let origin = Origin::Origin(url.origin());
|
||||||
let mut request = Request::new(url, Some(origin), false, None);
|
let mut request = Request::new(url, Some(origin), None);
|
||||||
request.referrer = Referrer::NoReferrer;
|
request.referrer = Referrer::NoReferrer;
|
||||||
let fetch_response = fetch(&mut request, None);
|
let fetch_response = fetch(&mut request, None);
|
||||||
let _ = server.close();
|
let _ = server.close();
|
||||||
|
@ -378,7 +378,7 @@ fn test_fetch_response_is_cors_filtered() {
|
||||||
|
|
||||||
// an origin mis-match will stop it from defaulting to a basic filtered response
|
// an origin mis-match will stop it from defaulting to a basic filtered response
|
||||||
let origin = Origin::Origin(ImmutableOrigin::new_opaque());
|
let origin = Origin::Origin(ImmutableOrigin::new_opaque());
|
||||||
let mut request = Request::new(url, Some(origin), false, None);
|
let mut request = Request::new(url, Some(origin), None);
|
||||||
request.referrer = Referrer::NoReferrer;
|
request.referrer = Referrer::NoReferrer;
|
||||||
request.mode = RequestMode::CorsMode;
|
request.mode = RequestMode::CorsMode;
|
||||||
let fetch_response = fetch(&mut request, None);
|
let fetch_response = fetch(&mut request, None);
|
||||||
|
@ -410,7 +410,7 @@ fn test_fetch_response_is_opaque_filtered() {
|
||||||
|
|
||||||
// an origin mis-match will fall through to an Opaque filtered response
|
// an origin mis-match will fall through to an Opaque filtered response
|
||||||
let origin = Origin::Origin(ImmutableOrigin::new_opaque());
|
let origin = Origin::Origin(ImmutableOrigin::new_opaque());
|
||||||
let mut request = Request::new(url, Some(origin), false, None);
|
let mut request = Request::new(url, Some(origin), None);
|
||||||
request.referrer = Referrer::NoReferrer;
|
request.referrer = Referrer::NoReferrer;
|
||||||
let fetch_response = fetch(&mut request, None);
|
let fetch_response = fetch(&mut request, None);
|
||||||
let _ = server.close();
|
let _ = server.close();
|
||||||
|
@ -457,7 +457,7 @@ fn test_fetch_response_is_opaque_redirect_filtered() {
|
||||||
let (mut server, url) = make_server(handler);
|
let (mut server, url) = make_server(handler);
|
||||||
|
|
||||||
let origin = Origin::Origin(url.origin());
|
let origin = Origin::Origin(url.origin());
|
||||||
let mut request = Request::new(url, Some(origin), false, None);
|
let mut request = Request::new(url, Some(origin), None);
|
||||||
request.referrer = Referrer::NoReferrer;
|
request.referrer = Referrer::NoReferrer;
|
||||||
request.redirect_mode = RedirectMode::Manual;
|
request.redirect_mode = RedirectMode::Manual;
|
||||||
let fetch_response = fetch(&mut request, None);
|
let fetch_response = fetch(&mut request, None);
|
||||||
|
@ -491,7 +491,7 @@ fn test_fetch_with_local_urls_only() {
|
||||||
|
|
||||||
let do_fetch = |url: ServoUrl| {
|
let do_fetch = |url: ServoUrl| {
|
||||||
let origin = Origin::Origin(url.origin());
|
let origin = Origin::Origin(url.origin());
|
||||||
let mut request = Request::new(url, Some(origin), false, None);
|
let mut request = Request::new(url, Some(origin), None);
|
||||||
request.referrer = Referrer::NoReferrer;
|
request.referrer = Referrer::NoReferrer;
|
||||||
|
|
||||||
// Set the flag.
|
// Set the flag.
|
||||||
|
@ -548,7 +548,7 @@ fn test_fetch_with_hsts() {
|
||||||
let url_string = format!("http://localhost:{}", server.socket.port());
|
let url_string = format!("http://localhost:{}", server.socket.port());
|
||||||
let url = ServoUrl::parse(&url_string).unwrap();
|
let url = ServoUrl::parse(&url_string).unwrap();
|
||||||
let origin = Origin::Origin(url.origin());
|
let origin = Origin::Origin(url.origin());
|
||||||
let mut request = Request::new(url, Some(origin), false, None);
|
let mut request = Request::new(url, Some(origin), None);
|
||||||
request.referrer = Referrer::NoReferrer;
|
request.referrer = Referrer::NoReferrer;
|
||||||
// Set the flag.
|
// Set the flag.
|
||||||
request.local_urls_only = false;
|
request.local_urls_only = false;
|
||||||
|
@ -567,7 +567,7 @@ fn test_fetch_with_sri_network_error() {
|
||||||
let (mut server, url) = make_server(handler);
|
let (mut server, url) = make_server(handler);
|
||||||
|
|
||||||
let origin = Origin::Origin(url.origin());
|
let origin = Origin::Origin(url.origin());
|
||||||
let mut request = Request::new(url, Some(origin), false, None);
|
let mut request = Request::new(url, Some(origin), None);
|
||||||
request.referrer = Referrer::NoReferrer;
|
request.referrer = Referrer::NoReferrer;
|
||||||
// To calulate hash use :
|
// To calulate hash use :
|
||||||
// echo -n "alert('Hello, Network Error');" | openssl dgst -sha384 -binary | openssl base64 -A
|
// echo -n "alert('Hello, Network Error');" | openssl dgst -sha384 -binary | openssl base64 -A
|
||||||
|
@ -591,7 +591,7 @@ fn test_fetch_with_sri_sucess() {
|
||||||
let (mut server, url) = make_server(handler);
|
let (mut server, url) = make_server(handler);
|
||||||
|
|
||||||
let origin = Origin::Origin(url.origin());
|
let origin = Origin::Origin(url.origin());
|
||||||
let mut request = Request::new(url, Some(origin), false, None);
|
let mut request = Request::new(url, Some(origin), None);
|
||||||
request.referrer = Referrer::NoReferrer;
|
request.referrer = Referrer::NoReferrer;
|
||||||
// To calulate hash use :
|
// To calulate hash use :
|
||||||
// echo -n "alert('Hello, Network Error');" | openssl dgst -sha384 -binary | openssl base64 -A
|
// echo -n "alert('Hello, Network Error');" | openssl dgst -sha384 -binary | openssl base64 -A
|
||||||
|
@ -630,7 +630,7 @@ fn test_fetch_blocked_nosniff() {
|
||||||
let (mut server, url) = make_server(handler);
|
let (mut server, url) = make_server(handler);
|
||||||
|
|
||||||
let origin = Origin::Origin(url.origin());
|
let origin = Origin::Origin(url.origin());
|
||||||
let mut request = Request::new(url, Some(origin), false, None);
|
let mut request = Request::new(url, Some(origin), None);
|
||||||
request.type_ = request_type;
|
request.type_ = request_type;
|
||||||
let fetch_response = fetch(&mut request, None);
|
let fetch_response = fetch(&mut request, None);
|
||||||
let _ = server.close();
|
let _ = server.close();
|
||||||
|
@ -672,7 +672,7 @@ fn setup_server_and_fetch(message: &'static [u8], redirect_cap: u32) -> Response
|
||||||
let (mut server, url) = make_server(handler);
|
let (mut server, url) = make_server(handler);
|
||||||
|
|
||||||
let origin = Origin::Origin(url.origin());
|
let origin = Origin::Origin(url.origin());
|
||||||
let mut request = Request::new(url, Some(origin), false, None);
|
let mut request = Request::new(url, Some(origin), None);
|
||||||
request.referrer = Referrer::NoReferrer;
|
request.referrer = Referrer::NoReferrer;
|
||||||
let fetch_response = fetch(&mut request, None);
|
let fetch_response = fetch(&mut request, None);
|
||||||
let _ = server.close();
|
let _ = server.close();
|
||||||
|
@ -755,7 +755,7 @@ fn test_fetch_redirect_updates_method_runner(tx: Sender<bool>, status_code: Stat
|
||||||
let (mut server, url) = make_server(handler);
|
let (mut server, url) = make_server(handler);
|
||||||
|
|
||||||
let origin = Origin::Origin(url.origin());
|
let origin = Origin::Origin(url.origin());
|
||||||
let mut request = Request::new(url, Some(origin), false, None);
|
let mut request = Request::new(url, Some(origin), None);
|
||||||
request.referrer = Referrer::NoReferrer;
|
request.referrer = Referrer::NoReferrer;
|
||||||
request.method = method;
|
request.method = method;
|
||||||
|
|
||||||
|
@ -830,7 +830,7 @@ fn test_fetch_async_returns_complete_response() {
|
||||||
let (mut server, url) = make_server(handler);
|
let (mut server, url) = make_server(handler);
|
||||||
|
|
||||||
let origin = Origin::Origin(url.origin());
|
let origin = Origin::Origin(url.origin());
|
||||||
let mut request = Request::new(url, Some(origin), false, None);
|
let mut request = Request::new(url, Some(origin), None);
|
||||||
request.referrer = Referrer::NoReferrer;
|
request.referrer = Referrer::NoReferrer;
|
||||||
|
|
||||||
let fetch_response = fetch(&mut request, None);
|
let fetch_response = fetch(&mut request, None);
|
||||||
|
@ -849,7 +849,7 @@ fn test_opaque_filtered_fetch_async_returns_complete_response() {
|
||||||
|
|
||||||
// an origin mis-match will fall through to an Opaque filtered response
|
// an origin mis-match will fall through to an Opaque filtered response
|
||||||
let origin = Origin::Origin(ImmutableOrigin::new_opaque());
|
let origin = Origin::Origin(ImmutableOrigin::new_opaque());
|
||||||
let mut request = Request::new(url, Some(origin), false, None);
|
let mut request = Request::new(url, Some(origin), None);
|
||||||
request.referrer = Referrer::NoReferrer;
|
request.referrer = Referrer::NoReferrer;
|
||||||
|
|
||||||
let fetch_response = fetch(&mut request, None);
|
let fetch_response = fetch(&mut request, None);
|
||||||
|
@ -884,7 +884,7 @@ fn test_opaque_redirect_filtered_fetch_async_returns_complete_response() {
|
||||||
let (mut server, url) = make_server(handler);
|
let (mut server, url) = make_server(handler);
|
||||||
|
|
||||||
let origin = Origin::Origin(url.origin());
|
let origin = Origin::Origin(url.origin());
|
||||||
let mut request = Request::new(url, Some(origin), false, None);
|
let mut request = Request::new(url, Some(origin), None);
|
||||||
request.referrer = Referrer::NoReferrer;
|
request.referrer = Referrer::NoReferrer;
|
||||||
request.redirect_mode = RedirectMode::Manual;
|
request.redirect_mode = RedirectMode::Manual;
|
||||||
|
|
||||||
|
@ -906,7 +906,7 @@ fn test_fetch_with_devtools() {
|
||||||
let (mut server, url) = make_server(handler);
|
let (mut server, url) = make_server(handler);
|
||||||
|
|
||||||
let origin = Origin::Origin(url.origin());
|
let origin = Origin::Origin(url.origin());
|
||||||
let mut request = Request::new(url.clone(), Some(origin), false, Some(TEST_PIPELINE_ID));
|
let mut request = Request::new(url.clone(), Some(origin), Some(TEST_PIPELINE_ID));
|
||||||
request.referrer = Referrer::NoReferrer;
|
request.referrer = Referrer::NoReferrer;
|
||||||
|
|
||||||
let (devtools_chan, devtools_port) = channel::<DevtoolsControlMsg>();
|
let (devtools_chan, devtools_port) = channel::<DevtoolsControlMsg>();
|
||||||
|
|
Loading…
Add table
Add a link
Reference in a new issue