Skip to content

Commit

Permalink
ensure documents drop when a pipeline exits
Browse files Browse the repository at this point in the history
  • Loading branch information
gterzian committed Aug 27, 2019
1 parent 66e5ad0 commit 344684a
Show file tree
Hide file tree
Showing 2 changed files with 15 additions and 4 deletions.
18 changes: 14 additions & 4 deletions components/script/dom/window.rs
Expand Up @@ -872,10 +872,19 @@ impl WindowMethods for Window {
// https://dvcs.w3.org/hg/webperf/raw-file/tip/specs/
// NavigationTiming/Overview.html#sec-window.performance-attribute
fn Performance(&self) -> DomRoot<Performance> {
self.performance.or_init(|| {
let global_scope = self.upcast::<GlobalScope>();
Performance::new(global_scope, self.navigation_start_precise.get())
})
match self.current_state.get() {
WindowState::Alive => self.performance.or_init(|| {
let global_scope = self.upcast::<GlobalScope>();
Performance::new(global_scope, self.navigation_start_precise.get())
}),
WindowState::Zombie => {
// Don't store in Zombie state,
// as clear_js_runtime has already been called,
// and we won't have another opportunity to drop it.
let global_scope = self.upcast::<GlobalScope>();
Performance::new(global_scope, self.navigation_start_precise.get())
},
}
}

// https://html.spec.whatwg.org/multipage/#globaleventhandlers
Expand Down Expand Up @@ -1299,6 +1308,7 @@ impl Window {
self.current_state.set(WindowState::Zombie);
*self.js_runtime.borrow_mut() = None;
self.window_proxy.set(None);
self.performance.set(None);
self.ignore_all_events();
}

Expand Down
@@ -1,4 +1,5 @@
[blob.https.html]
expected: CRASH
[Cross-Origin-Embedder-Policy and blob: URL from https://web-platform.test:8443 in subframe via subframe]
expected: FAIL

Expand Down

0 comments on commit 344684a

Please sign in to comment.