From e6cdfddea6c8435a6147ccc11967cb027a965a97 Mon Sep 17 00:00:00 2001 From: Josh Matthews Date: Tue, 14 Jul 2020 12:16:34 -0400 Subject: [PATCH] dom: Hide debugging extension methods behind a pref. --- components/config/prefs.rs | 3 +++ components/script/dom/webidls/Window.webidl | 3 +++ resources/prefs.json | 1 + resources/user-agent-js/00.example.js | 1 + .../meta-layout-2020/mozilla/media_query_list_gc.html.ini | 1 + .../wpt/mozilla/meta-layout-2020/mozilla/prototypes.html.ini | 1 + .../wpt/mozilla/meta-layout-2020/mozilla/trace_null.html.ini | 1 + .../meta-layout-2020/mozilla/transitionend_safety.html.ini | 1 + tests/wpt/mozilla/meta-layout-2020/mozilla/weakref.html.ini | 5 ++--- tests/wpt/mozilla/meta/mozilla/media_query_list_gc.html.ini | 1 + tests/wpt/mozilla/meta/mozilla/prototypes.html.ini | 1 + tests/wpt/mozilla/meta/mozilla/trace_null.html.ini | 1 + tests/wpt/mozilla/meta/mozilla/transitionend_safety.html.ini | 1 + tests/wpt/mozilla/meta/mozilla/weakref.html.ini | 2 +- 14 files changed, 19 insertions(+), 4 deletions(-) create mode 100644 tests/wpt/mozilla/meta-layout-2020/mozilla/media_query_list_gc.html.ini create mode 100644 tests/wpt/mozilla/meta-layout-2020/mozilla/prototypes.html.ini create mode 100644 tests/wpt/mozilla/meta-layout-2020/mozilla/trace_null.html.ini create mode 100644 tests/wpt/mozilla/meta-layout-2020/mozilla/transitionend_safety.html.ini create mode 100644 tests/wpt/mozilla/meta/mozilla/media_query_list_gc.html.ini create mode 100644 tests/wpt/mozilla/meta/mozilla/prototypes.html.ini create mode 100644 tests/wpt/mozilla/meta/mozilla/trace_null.html.ini create mode 100644 tests/wpt/mozilla/meta/mozilla/transitionend_safety.html.ini diff --git a/components/config/prefs.rs b/components/config/prefs.rs index bf78d8d584d..36b35c3447f 100644 --- a/components/config/prefs.rs +++ b/components/config/prefs.rs @@ -187,6 +187,9 @@ mod gen { enabled: bool, timeout_seconds: i64, }, + servo_helpers: { + enabled: bool, + }, servoparser: { async_html_tokenizer: { enabled: bool, diff --git a/components/script/dom/webidls/Window.webidl b/components/script/dom/webidls/Window.webidl index 71f03a2e1f4..80a8d31595a 100644 --- a/components/script/dom/webidls/Window.webidl +++ b/components/script/dom/webidls/Window.webidl @@ -136,8 +136,11 @@ partial interface Window { // Proprietary extensions. partial interface Window { + [Pref="dom.servo_helpers.enabled"] void debug(DOMString arg); + [Pref="dom.servo_helpers.enabled"] void gc(); + [Pref="dom.servo_helpers.enabled"] void trap(); }; diff --git a/resources/prefs.json b/resources/prefs.json index 0b219f7966a..d05504d5f43 100644 --- a/resources/prefs.json +++ b/resources/prefs.json @@ -19,6 +19,7 @@ "dom.permissions.testing.allowed_in_nonsecure_contexts": false, "dom.serviceworker.enabled": false, "dom.serviceworker.timeout_seconds": 60, + "dom.servo_helpers.enabled": false, "dom.servoparser.async_html_tokenizer.enabled": false, "dom.shadowdom.enabled": false, "dom.svg.enabled": false, diff --git a/resources/user-agent-js/00.example.js b/resources/user-agent-js/00.example.js index c024b0f6a48..168f3d6254c 100644 --- a/resources/user-agent-js/00.example.js +++ b/resources/user-agent-js/00.example.js @@ -3,3 +3,4 @@ // Files are sorted alphabetically. When committing polyfills // order them with numbers, e.g. `01.innerhtml.js` will be executed before // `05.jquery.js` +onunhandledrejection = (e) => console.error("xxxjdm error: " + JSON.stringify(e.reason)); diff --git a/tests/wpt/mozilla/meta-layout-2020/mozilla/media_query_list_gc.html.ini b/tests/wpt/mozilla/meta-layout-2020/mozilla/media_query_list_gc.html.ini new file mode 100644 index 00000000000..e30744b586d --- /dev/null +++ b/tests/wpt/mozilla/meta-layout-2020/mozilla/media_query_list_gc.html.ini @@ -0,0 +1 @@ +prefs: ["dom.servo_helpers.enabled:true"] diff --git a/tests/wpt/mozilla/meta-layout-2020/mozilla/prototypes.html.ini b/tests/wpt/mozilla/meta-layout-2020/mozilla/prototypes.html.ini new file mode 100644 index 00000000000..e30744b586d --- /dev/null +++ b/tests/wpt/mozilla/meta-layout-2020/mozilla/prototypes.html.ini @@ -0,0 +1 @@ +prefs: ["dom.servo_helpers.enabled:true"] diff --git a/tests/wpt/mozilla/meta-layout-2020/mozilla/trace_null.html.ini b/tests/wpt/mozilla/meta-layout-2020/mozilla/trace_null.html.ini new file mode 100644 index 00000000000..e30744b586d --- /dev/null +++ b/tests/wpt/mozilla/meta-layout-2020/mozilla/trace_null.html.ini @@ -0,0 +1 @@ +prefs: ["dom.servo_helpers.enabled:true"] diff --git a/tests/wpt/mozilla/meta-layout-2020/mozilla/transitionend_safety.html.ini b/tests/wpt/mozilla/meta-layout-2020/mozilla/transitionend_safety.html.ini new file mode 100644 index 00000000000..e30744b586d --- /dev/null +++ b/tests/wpt/mozilla/meta-layout-2020/mozilla/transitionend_safety.html.ini @@ -0,0 +1 @@ +prefs: ["dom.servo_helpers.enabled:true"] diff --git a/tests/wpt/mozilla/meta-layout-2020/mozilla/weakref.html.ini b/tests/wpt/mozilla/meta-layout-2020/mozilla/weakref.html.ini index f0fc027e023..8faf1a9b047 100644 --- a/tests/wpt/mozilla/meta-layout-2020/mozilla/weakref.html.ini +++ b/tests/wpt/mozilla/meta-layout-2020/mozilla/weakref.html.ini @@ -1,4 +1,3 @@ [weakref.html] - [Weak references work] - expected: FAIL - + type: testharness + prefs: ["dom.testbinding.enabled:true", "dom.servo_helpers.enabled:true"] diff --git a/tests/wpt/mozilla/meta/mozilla/media_query_list_gc.html.ini b/tests/wpt/mozilla/meta/mozilla/media_query_list_gc.html.ini new file mode 100644 index 00000000000..e30744b586d --- /dev/null +++ b/tests/wpt/mozilla/meta/mozilla/media_query_list_gc.html.ini @@ -0,0 +1 @@ +prefs: ["dom.servo_helpers.enabled:true"] diff --git a/tests/wpt/mozilla/meta/mozilla/prototypes.html.ini b/tests/wpt/mozilla/meta/mozilla/prototypes.html.ini new file mode 100644 index 00000000000..e30744b586d --- /dev/null +++ b/tests/wpt/mozilla/meta/mozilla/prototypes.html.ini @@ -0,0 +1 @@ +prefs: ["dom.servo_helpers.enabled:true"] diff --git a/tests/wpt/mozilla/meta/mozilla/trace_null.html.ini b/tests/wpt/mozilla/meta/mozilla/trace_null.html.ini new file mode 100644 index 00000000000..e30744b586d --- /dev/null +++ b/tests/wpt/mozilla/meta/mozilla/trace_null.html.ini @@ -0,0 +1 @@ +prefs: ["dom.servo_helpers.enabled:true"] diff --git a/tests/wpt/mozilla/meta/mozilla/transitionend_safety.html.ini b/tests/wpt/mozilla/meta/mozilla/transitionend_safety.html.ini new file mode 100644 index 00000000000..e30744b586d --- /dev/null +++ b/tests/wpt/mozilla/meta/mozilla/transitionend_safety.html.ini @@ -0,0 +1 @@ +prefs: ["dom.servo_helpers.enabled:true"] diff --git a/tests/wpt/mozilla/meta/mozilla/weakref.html.ini b/tests/wpt/mozilla/meta/mozilla/weakref.html.ini index 3c694147814..8faf1a9b047 100644 --- a/tests/wpt/mozilla/meta/mozilla/weakref.html.ini +++ b/tests/wpt/mozilla/meta/mozilla/weakref.html.ini @@ -1,3 +1,3 @@ [weakref.html] type: testharness - prefs: [dom.testbinding.enabled:true] + prefs: ["dom.testbinding.enabled:true", "dom.servo_helpers.enabled:true"]