mirror of
https://github.com/servo/servo.git
synced 2025-07-23 07:13:52 +01:00
implemented secure_connection_start
This commit is contained in:
parent
cf725fc3f5
commit
bd0c0b65ba
3 changed files with 18 additions and 2 deletions
|
@ -408,6 +408,17 @@ fn obtain_response(
|
||||||
)
|
)
|
||||||
.body(request_body.clone().into());
|
.body(request_body.clone().into());
|
||||||
|
|
||||||
|
// TODO: We currently don't know when the handhhake before the connection is done
|
||||||
|
// so our best bet would be to set `secure_connection_start` here when we are currently
|
||||||
|
// fetching on a HTTPS url.
|
||||||
|
if url.scheme() == "https" {
|
||||||
|
context
|
||||||
|
.timing
|
||||||
|
.lock()
|
||||||
|
.unwrap()
|
||||||
|
.set_attribute(ResourceAttribute::SecureConnectionStart);
|
||||||
|
}
|
||||||
|
|
||||||
let mut request = match request {
|
let mut request = match request {
|
||||||
Ok(request) => request,
|
Ok(request) => request,
|
||||||
Err(e) => return Box::new(future::result(Err(NetworkError::from_http_error(&e)))),
|
Err(e) => return Box::new(future::result(Err(NetworkError::from_http_error(&e)))),
|
||||||
|
|
|
@ -466,6 +466,7 @@ pub struct ResourceFetchTiming {
|
||||||
/// Number of redirects until final resource (currently limited to 20)
|
/// Number of redirects until final resource (currently limited to 20)
|
||||||
pub redirect_count: u16,
|
pub redirect_count: u16,
|
||||||
pub request_start: u64,
|
pub request_start: u64,
|
||||||
|
pub secure_connection_start: u64,
|
||||||
pub response_start: u64,
|
pub response_start: u64,
|
||||||
pub fetch_start: u64,
|
pub fetch_start: u64,
|
||||||
pub response_end: u64,
|
pub response_end: u64,
|
||||||
|
@ -496,6 +497,7 @@ pub enum ResourceAttribute {
|
||||||
FetchStart,
|
FetchStart,
|
||||||
ConnectStart(u64),
|
ConnectStart(u64),
|
||||||
ConnectEnd(u64),
|
ConnectEnd(u64),
|
||||||
|
SecureConnectionStart,
|
||||||
ResponseEnd,
|
ResponseEnd,
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -514,6 +516,7 @@ impl ResourceFetchTiming {
|
||||||
timing_check_passed: true,
|
timing_check_passed: true,
|
||||||
domain_lookup_start: 0,
|
domain_lookup_start: 0,
|
||||||
redirect_count: 0,
|
redirect_count: 0,
|
||||||
|
secure_connection_start: 0,
|
||||||
request_start: 0,
|
request_start: 0,
|
||||||
response_start: 0,
|
response_start: 0,
|
||||||
fetch_start: 0,
|
fetch_start: 0,
|
||||||
|
@ -555,6 +558,9 @@ impl ResourceFetchTiming {
|
||||||
ResourceAttribute::FetchStart => self.fetch_start = precise_time_ns(),
|
ResourceAttribute::FetchStart => self.fetch_start = precise_time_ns(),
|
||||||
ResourceAttribute::ConnectStart(val) => self.connect_start = val,
|
ResourceAttribute::ConnectStart(val) => self.connect_start = val,
|
||||||
ResourceAttribute::ConnectEnd(val) => self.connect_end = val,
|
ResourceAttribute::ConnectEnd(val) => self.connect_end = val,
|
||||||
|
ResourceAttribute::SecureConnectionStart => {
|
||||||
|
self.secure_connection_start = precise_time_ns()
|
||||||
|
},
|
||||||
ResourceAttribute::ResponseEnd => self.response_end = precise_time_ns(),
|
ResourceAttribute::ResponseEnd => self.response_end = precise_time_ns(),
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -129,8 +129,7 @@ impl PerformanceResourceTiming {
|
||||||
domain_lookup_end: 0.,
|
domain_lookup_end: 0.,
|
||||||
connect_start: resource_timing.connect_start as f64,
|
connect_start: resource_timing.connect_start as f64,
|
||||||
connect_end: resource_timing.connect_end as f64,
|
connect_end: resource_timing.connect_end as f64,
|
||||||
// TODO (#21271)
|
secure_connection_start: resource_timing.secure_connection_start as f64,
|
||||||
secure_connection_start: 0.,
|
|
||||||
request_start: resource_timing.request_start as f64,
|
request_start: resource_timing.request_start as f64,
|
||||||
response_start: resource_timing.response_start as f64,
|
response_start: resource_timing.response_start as f64,
|
||||||
response_end: resource_timing.response_end as f64,
|
response_end: resource_timing.response_end as f64,
|
||||||
|
|
Loading…
Add table
Add a link
Reference in a new issue