diff --git a/.gitattributes b/.gitattributes index 74328c4..dfb4ad1 100644 --- a/.gitattributes +++ b/.gitattributes
@@ -1,2 +1,5 @@ # Stop Windows python license check presubmit errors by forcing LF checkout. *.py text eol=lf + +# Force LF checkout of the pins files to avoid transport_security_state_generator errors. +/net/http/*.pins text eol=lf
diff --git a/DEPS b/DEPS index 60b1c085..4d43ae3 100644 --- a/DEPS +++ b/DEPS
@@ -40,7 +40,7 @@ # Three lines of non-changing comments so that # the commit queue can handle CLs rolling Skia # and whatever else without interference from each other. - 'skia_revision': 'ec045b431211082563a4352ccf2c9d5b3765048e', + 'skia_revision': '8fe24272fa6d2fa9eb2458221ed9852d6ec16f56', # Three lines of non-changing comments so that # the commit queue can handle CLs rolling V8 # and whatever else without interference from each other. @@ -64,7 +64,7 @@ # Three lines of non-changing comments so that # the commit queue can handle CLs rolling PDFium # and whatever else without interference from each other. - 'pdfium_revision': 'f6f68c75ce54a5865fb19dcb075e7734f1639663', + 'pdfium_revision': 'b46ce4172ee8282a39997c175dff2bd8f187208f', # Three lines of non-changing comments so that # the commit queue can handle CLs rolling openmax_dl # and whatever else without interference from each other. @@ -96,7 +96,7 @@ # Three lines of non-changing comments so that # the commit queue can handle CLs rolling catapult # and whatever else without interference from each other. - 'catapult_revision': '1e3b1949cdcde84079ef3f0fa3f31610e2d1687d', + 'catapult_revision': '00b0c16c97088f5c06df9d3b27eaeb41f06173e5', # Three lines of non-changing comments so that # the commit queue can handle CLs rolling libFuzzer # and whatever else without interference from each other.
diff --git a/android_webview/browser/cookie_manager.cc b/android_webview/browser/cookie_manager.cc index cc09e6e..ae33e5a 100644 --- a/android_webview/browser/cookie_manager.cc +++ b/android_webview/browser/cookie_manager.cc
@@ -4,6 +4,8 @@ #include "android_webview/browser/cookie_manager.h" +#include <stdint.h> + #include <memory> #include <utility> #include <vector> @@ -206,7 +208,7 @@ void RemoveSessionCookiesHelper(BoolCallback callback); void RemoveAllCookiesHelper(BoolCallback callback); - void RemoveCookiesCompleted(BoolCallback callback, int num_deleted); + void RemoveCookiesCompleted(BoolCallback callback, uint32_t num_deleted); void FlushCookieStoreAsyncHelper(base::Closure complete); @@ -448,8 +450,8 @@ } void CookieManager::RemoveCookiesCompleted(BoolCallback callback, - int num_deleted) { - callback.Run(num_deleted > 0); + uint32_t num_deleted) { + callback.Run(num_deleted > 0u); } void CookieManager::RemoveAllCookies(
diff --git a/android_webview/browser/net/aw_cookie_store_wrapper.cc b/android_webview/browser/net/aw_cookie_store_wrapper.cc index 88b8a60..7a671e88 100644 --- a/android_webview/browser/net/aw_cookie_store_wrapper.cc +++ b/android_webview/browser/net/aw_cookie_store_wrapper.cc
@@ -294,7 +294,7 @@ DCHECK(client_task_runner_->RunsTasksInCurrentSequence()); PostTaskToCookieStoreTaskRunner( base::BindOnce(&DeleteCanonicalCookieAsyncOnCookieThread, cookie, - CreateWrappedCallback<int>(std::move(callback)))); + CreateWrappedCallback<uint32_t>(std::move(callback)))); } void AwCookieStoreWrapper::DeleteAllCreatedBetweenAsync( @@ -304,7 +304,7 @@ DCHECK(client_task_runner_->RunsTasksInCurrentSequence()); PostTaskToCookieStoreTaskRunner(base::BindOnce( &DeleteAllCreatedBetweenAsyncOnCookieThread, delete_begin, delete_end, - CreateWrappedCallback<int>(std::move(callback)))); + CreateWrappedCallback<uint32_t>(std::move(callback)))); } void AwCookieStoreWrapper::DeleteAllCreatedBetweenWithPredicateAsync( @@ -313,16 +313,17 @@ const CookiePredicate& predicate, DeleteCallback callback) { DCHECK(client_task_runner_->RunsTasksInCurrentSequence()); - PostTaskToCookieStoreTaskRunner(base::BindOnce( - &DeleteAllCreatedBetweenWithPredicateAsyncOnCookieThread, delete_begin, - delete_end, predicate, CreateWrappedCallback<int>(std::move(callback)))); + PostTaskToCookieStoreTaskRunner( + base::BindOnce(&DeleteAllCreatedBetweenWithPredicateAsyncOnCookieThread, + delete_begin, delete_end, predicate, + CreateWrappedCallback<uint32_t>(std::move(callback)))); } void AwCookieStoreWrapper::DeleteSessionCookiesAsync(DeleteCallback callback) { DCHECK(client_task_runner_->RunsTasksInCurrentSequence()); PostTaskToCookieStoreTaskRunner( base::BindOnce(&DeleteSessionCookiesAsyncOnCookieThread, - CreateWrappedCallback<int>(std::move(callback)))); + CreateWrappedCallback<uint32_t>(std::move(callback)))); } void AwCookieStoreWrapper::FlushStore(base::OnceClosure callback) {
diff --git a/android_webview/browser/net/aw_cookie_store_wrapper_unittest.cc b/android_webview/browser/net/aw_cookie_store_wrapper_unittest.cc index d856d24..a80d03b9 100644 --- a/android_webview/browser/net/aw_cookie_store_wrapper_unittest.cc +++ b/android_webview/browser/net/aw_cookie_store_wrapper_unittest.cc
@@ -4,6 +4,8 @@ #include "android_webview/browser/net/aw_cookie_store_wrapper.h" +#include <stdint.h> + #include <memory> #include "net/cookies/cookie_store.h" @@ -20,9 +22,9 @@ // Android Webview can run multiple tests without restarting the binary, // so have to delete any cookies the global store may have from an earlier // test. - net::ResultSavingCookieCallback<int> callback; + net::ResultSavingCookieCallback<uint32_t> callback; cookie_store->DeleteAllAsync( - base::Bind(&net::ResultSavingCookieCallback<int>::Run, + base::Bind(&net::ResultSavingCookieCallback<uint32_t>::Run, base::Unretained(&callback))); callback.WaitUntilDone();
diff --git a/ash/accelerators/accelerator_controller.cc b/ash/accelerators/accelerator_controller.cc index b5145db4..452df17 100644 --- a/ash/accelerators/accelerator_controller.cc +++ b/ash/accelerators/accelerator_controller.cc
@@ -378,7 +378,8 @@ // Search key. if (previous_accelerator.key_state() != ui::Accelerator::KeyState::PRESSED || - previous_accelerator.key_code() != ui::VKEY_LWIN) { + previous_accelerator.key_code() != ui::VKEY_LWIN || + previous_accelerator.interrupted_by_mouse_event()) { return false; }
diff --git a/ash/accelerators/accelerator_controller_unittest.cc b/ash/accelerators/accelerator_controller_unittest.cc index 6519ab0..dd96cae 100644 --- a/ash/accelerators/accelerator_controller_unittest.cc +++ b/ash/accelerators/accelerator_controller_unittest.cc
@@ -862,6 +862,15 @@ CreateReleaseAccelerator(ui::VKEY_BROWSER_SEARCH, ui::EF_NONE))); RunAllPendingInMessageLoop(); EXPECT_EQ(3u, test_app_list_presenter.toggle_count()); + + // When pressed key is interrupted by mouse, the AppList should not toggle. + EXPECT_FALSE( + ProcessInController(ui::Accelerator(ui::VKEY_LWIN, ui::EF_NONE))); + GetController()->accelerator_history()->InterruptCurrentAccelerator(); + EXPECT_FALSE(ProcessInController( + CreateReleaseAccelerator(ui::VKEY_LWIN, ui::EF_NONE))); + RunAllPendingInMessageLoop(); + EXPECT_EQ(3u, test_app_list_presenter.toggle_count()); } TEST_F(AcceleratorControllerTest, ImeGlobalAccelerators) {
diff --git a/ash/accelerators/accelerator_filter_unittest.cc b/ash/accelerators/accelerator_filter_unittest.cc index 603bbef..3b1897cb 100644 --- a/ash/accelerators/accelerator_filter_unittest.cc +++ b/ash/accelerators/accelerator_filter_unittest.cc
@@ -18,6 +18,8 @@ #include "ash/wm/window_state.h" #include "ash/wm/window_util.h" #include "testing/gtest/include/gtest/gtest.h" +#include "ui/app_list/presenter/app_list.h" +#include "ui/app_list/presenter/test/test_app_list_presenter.h" #include "ui/aura/client/aura_constants.h" #include "ui/aura/test/aura_test_base.h" #include "ui/aura/test/test_windows.h" @@ -185,5 +187,27 @@ EXPECT_FALSE(session_controller->IsScreenLocked()); } +TEST_F(AcceleratorFilterTest, ToggleAppListInterruptedByMouseEvent) { + ui::test::EventGenerator generator(Shell::GetPrimaryRootWindow()); + app_list::test::TestAppListPresenter test_app_list_presenter; + Shell::Get()->app_list()->SetAppListPresenter( + test_app_list_presenter.CreateInterfacePtrAndBind()); + EXPECT_EQ(0u, test_app_list_presenter.toggle_count()); + + // The AppList should toggle if no mouse event occurs between key press and + // key release. + generator.PressKey(ui::VKEY_LWIN, ui::EF_NONE); + generator.ReleaseKey(ui::VKEY_LWIN, ui::EF_NONE); + RunAllPendingInMessageLoop(); + EXPECT_EQ(1u, test_app_list_presenter.toggle_count()); + + // When pressed key is interrupted by mouse, the AppList should not toggle. + generator.PressKey(ui::VKEY_LWIN, ui::EF_NONE); + generator.ClickLeftButton(); + generator.ReleaseKey(ui::VKEY_LWIN, ui::EF_NONE); + RunAllPendingInMessageLoop(); + EXPECT_EQ(1u, test_app_list_presenter.toggle_count()); +} + } // namespace test } // namespace ash
diff --git a/ash/accelerators/accelerator_table.cc b/ash/accelerators/accelerator_table.cc index e3fc4d98..6d025f2 100644 --- a/ash/accelerators/accelerator_table.cc +++ b/ash/accelerators/accelerator_table.cc
@@ -161,6 +161,7 @@ // Voice Interaction shortcuts. {true, ui::VKEY_A, ui::EF_COMMAND_DOWN, START_VOICE_INTERACTION}, + {true, ui::VKEY_ASSISTANT, ui::EF_NONE, START_VOICE_INTERACTION}, // Temporary shortcut added for UX/PM exploration. // TODO(updowndota): Remove the temporary shortcut. {true, ui::VKEY_SPACE, ui::EF_COMMAND_DOWN, START_VOICE_INTERACTION},
diff --git a/ash/accelerators/accelerator_table_unittest.cc b/ash/accelerators/accelerator_table_unittest.cc index 2bee4f5..83c0de04 100644 --- a/ash/accelerators/accelerator_table_unittest.cc +++ b/ash/accelerators/accelerator_table_unittest.cc
@@ -15,12 +15,12 @@ namespace { -// The number of non-Search-based accelerators as of 2017-06-26. -constexpr int kNonSearchAcceleratorsNum = 92; -// The hash of non-Search-based accelerators as of 2017-06-26. +// The number of non-Search-based accelerators as of 2017-07-08. +constexpr int kNonSearchAcceleratorsNum = 93; +// The hash of non-Search-based accelerators as of 2017-07-08. // See HashAcceleratorData(). constexpr char kNonSearchAcceleratorsHash[] = - "c45246c981cba1fe2c6d0d3c494e1117"; + "b585642b182679454e0e924dffc92463"; struct Cmp { bool operator()(const AcceleratorData& lhs, const AcceleratorData& rhs) {
diff --git a/ash/laser/DEPS b/ash/laser/DEPS index 3ca145e0..89980df 100644 --- a/ash/laser/DEPS +++ b/ash/laser/DEPS
@@ -1,4 +1,5 @@ include_rules = [ "+cc", + "+components/viz/common/quads", "+gpu/command_buffer/client", ]
diff --git a/ash/laser/laser_pointer_view.cc b/ash/laser/laser_pointer_view.cc index 82ed189..73401bdd 100644 --- a/ash/laser/laser_pointer_view.cc +++ b/ash/laser/laser_pointer_view.cc
@@ -28,6 +28,7 @@ #include "cc/quads/texture_draw_quad.h" #include "cc/resources/texture_mailbox.h" #include "cc/resources/transferable_resource.h" +#include "components/viz/common/quads/resource_format.h" #include "gpu/command_buffer/client/context_support.h" #include "gpu/command_buffer/client/gles2_interface.h" #include "gpu/command_buffer/client/gpu_memory_buffer_manager.h" @@ -685,7 +686,7 @@ cc::TransferableResource transferable_resource; transferable_resource.id = next_resource_id_++; - transferable_resource.format = cc::RGBA_8888; + transferable_resource.format = viz::RGBA_8888; transferable_resource.filter = GL_LINEAR; transferable_resource.size = buffer_size; transferable_resource.mailbox_holder =
diff --git a/base/bind_unittest.nc b/base/bind_unittest.nc index 61835be..cfdd9e7 100644 --- a/base/bind_unittest.nc +++ b/base/bind_unittest.nc
@@ -194,6 +194,24 @@ Bind(&VoidPolymorphic1<HasRef*>, for_raw_ptr); } +#elif defined(NCTEST_NO_RVALUE_CONST_RAW_PTR_FOR_REFCOUNTED_TYPES) // [r"fatal error: static_assert failed \"A parameter is a refcounted type and needs scoped_refptr.\""] + +// Refcounted types should not be bound as a raw pointer. +void WontCompile() { + const HasRef for_raw_ptr; + Callback<void()> ref_count_as_raw_ptr = + Bind(&VoidPolymorphic1<const HasRef*>, &for_raw_ptr); +} + +#elif defined(NCTEST_NO_LVALUE_CONST_RAW_PTR_FOR_REFCOUNTED_TYPES) // [r"fatal error: static_assert failed \"A parameter is a refcounted type and needs scoped_refptr.\""] + +// Refcounted types should not be bound as a raw pointer. +void WontCompile() { + const HasRef* for_raw_ptr = nullptr; + Callback<void()> ref_count_as_raw_ptr = + Bind(&VoidPolymorphic1<const HasRef*>, for_raw_ptr); +} + #elif defined(NCTEST_WEAKPTR_BIND_MUST_RETURN_VOID) // [r"fatal error: static_assert failed \"weak_ptrs can only bind to methods without return values\""] // WeakPtrs cannot be bound to methods with return types.
diff --git a/base/memory/raw_scoped_refptr_mismatch_checker.h b/base/memory/raw_scoped_refptr_mismatch_checker.h index f480e07..0e74cb0b 100644 --- a/base/memory/raw_scoped_refptr_mismatch_checker.h +++ b/base/memory/raw_scoped_refptr_mismatch_checker.h
@@ -32,9 +32,11 @@ // Human readable translation: you needed to be a scoped_refptr if you are a // raw pointer type and are convertible to a RefCounted(Base|ThreadSafeBase) // type. - value = (std::is_pointer<T>::value && - (std::is_convertible<T, subtle::RefCountedBase*>::value || - std::is_convertible<T, subtle::RefCountedThreadSafeBase*>::value)) + value = + (std::is_pointer<T>::value && + (std::is_convertible<T, const subtle::RefCountedBase*>::value || + std::is_convertible<T, + const subtle::RefCountedThreadSafeBase*>::value)) }; };
diff --git a/base/test/test_suite.cc b/base/test/test_suite.cc index c9bfe9e..38f1f34 100644 --- a/base/test/test_suite.cc +++ b/base/test/test_suite.cc
@@ -135,8 +135,7 @@ Bind(&TestSuite::Run, Unretained(&test_suite))); } -TestSuite::TestSuite(int argc, char** argv) - : initialized_command_line_(false), created_feature_list_(false) { +TestSuite::TestSuite(int argc, char** argv) : initialized_command_line_(false) { PreInitialize(); InitializeFromCommandLine(argc, argv); // Logging must be initialized before any thread has a chance to call logging @@ -146,7 +145,7 @@ #if defined(OS_WIN) TestSuite::TestSuite(int argc, wchar_t** argv) - : initialized_command_line_(false), created_feature_list_(false) { + : initialized_command_line_(false) { PreInitialize(); InitializeFromCommandLine(argc, argv); // Logging must be initialized before any thread has a chance to call logging @@ -342,13 +341,10 @@ debug::WaitForDebugger(60, true); } #endif - // Set up a FeatureList instance, so that code using that API will not hit a - // an error that it's not set. If a FeatureList was created in this way (i.e. - // one didn't exist previously), it will be cleared in Shutdown() via - // ClearInstanceForTesting(). - created_feature_list_ = - FeatureList::InitializeInstance(std::string(), std::string()); + // an error that it's not set. It will be cleared automatically. + // TODO(chaopeng) Should load the actually features in command line here. + scoped_feature_list_.InitFromCommandLine(std::string(), std::string()); #if defined(OS_IOS) InitIOSTestMessageLoop(); @@ -412,10 +408,6 @@ void TestSuite::Shutdown() { base::debug::StopProfiling(); - - // Clear the FeatureList that was created by Initialize(). - if (created_feature_list_) - FeatureList::ClearInstanceForTesting(); } } // namespace base
diff --git a/base/test/test_suite.h b/base/test/test_suite.h index 82c746e..6d852baf 100644 --- a/base/test/test_suite.h +++ b/base/test/test_suite.h
@@ -15,6 +15,7 @@ #include "base/at_exit.h" #include "base/logging.h" #include "base/macros.h" +#include "base/test/scoped_feature_list.h" #include "base/test/trace_to_file.h" #include "build/build_config.h" @@ -88,7 +89,7 @@ bool initialized_command_line_; - bool created_feature_list_; + test::ScopedFeatureList scoped_feature_list_; XmlUnitTestResultPrinter* printer_ = nullptr;
diff --git a/build/toolchain/mac/BUILD.gn b/build/toolchain/mac/BUILD.gn index b417e76a..f89dd0d 100644 --- a/build/toolchain/mac/BUILD.gn +++ b/build/toolchain/mac/BUILD.gn
@@ -431,14 +431,17 @@ if (is_ios) { _sdk_name = ios_sdk_name _min_deployment_target = ios_deployment_target + _compress_pngs = "" } else { _sdk_name = mac_sdk_name _min_deployment_target = mac_deployment_target + _compress_pngs = " -c " } command = "$env_wrapper rm -f {{output}} && " + "TOOL_VERSION=${tool_versions.compile_xcassets} " + "python $_tool -p $_sdk_name -t $_min_deployment_target " + - "-T {{bundle_product_type}} -o {{output}} {{inputs}}" + "$_compress_pngs -T {{bundle_product_type}} -o {{output}} " + + "{{inputs}}" description = "COMPILE_XCASSETS {{output}}" pool = ":bundle_pool($default_toolchain)"
diff --git a/build/toolchain/mac/compile_xcassets.py b/build/toolchain/mac/compile_xcassets.py index 2c1a472..6b0f900 100644 --- a/build/toolchain/mac/compile_xcassets.py +++ b/build/toolchain/mac/compile_xcassets.py
@@ -23,10 +23,7 @@ """ # Pattern matching a section header in the output of actool. -SECTION_HEADER = re.compile('^/\\* ([a-z.]*) \\*/$') - -# Pattern matching an interesting message in the output of actool. -MESSAGE_PATTERN = re.compile('^([^:]*\.xcassets):.* (error|warning): .*$') +SECTION_HEADER = re.compile('^/\\* ([^ ]*) \\*/$') # Name of the section containing informational messages that can be ignored. NOTICE_SECTION = 'com.apple.actool.compilation-results' @@ -41,9 +38,8 @@ section. The function filter any lines that are not in com.apple.actool.errors or - com.apple.actool.document.warnings sections. For each messages, in those - sections, they are also filtered if they do not follow MESSAGE_PATTERN - pattern. + com.apple.actool.document.warnings sections (as spurious messages comes + before any section of the output). See crbug.com/730054 and crbug.com/739163 for some example messages that pollute the output of actool and cause flaky builds. @@ -70,22 +66,18 @@ if current_section != NOTICE_SECTION: filtered_output.append(line + '\n') continue - match = MESSAGE_PATTERN.search(line) - if match is not None: - if current_section == NOTICE_SECTION: - continue - - absolute_path = match.group(1) + if current_section and current_section != NOTICE_SECTION: + absolute_path = line.split(':')[0] relative_path = relative_paths.get(absolute_path, absolute_path) if absolute_path != relative_path: - line = line[:match.span(1)[0]] + relative_path + line[match.span(1)[1]:] + line = relative_path + line[len(absolute_path):] filtered_output.append(line + '\n') return ''.join(filtered_output) -def CompileAssetCatalog( - output, platform, product_type, min_deployment_target, inputs): +def CompileAssetCatalog(output, platform, product_type, min_deployment_target, + inputs, compress_pngs): """Compile the .xcassets bundles to an asset catalog using actool. Args: @@ -94,14 +86,17 @@ product_type: the bundle type min_deployment_target: minimum deployment target inputs: list of absolute paths to .xcassets bundles + compress_pngs: whether to enable compression of pngs """ command = [ 'xcrun', 'actool', '--output-format=human-readable-text', - '--compress-pngs', '--notices', '--warnings', '--errors', - '--platform', platform, '--minimum-deployment-target', - min_deployment_target, + '--notices', '--warnings', '--errors', '--platform', platform, + '--minimum-deployment-target', min_deployment_target, ] + if compress_pngs: + command.extend(['--compress-pngs']) + if product_type != '': command.extend(['--product-type', product_type]) @@ -153,6 +148,9 @@ '--output', '-o', required=True, help='path to the compiled assets catalog') parser.add_argument( + '--compress-pngs', '-c', action='store_true', default=False, + help='recompress PNGs while compiling assets catalog') + parser.add_argument( '--product-type', '-T', help='type of the containing bundle') parser.add_argument( @@ -171,7 +169,8 @@ args.platform, args.product_type, args.minimum_deployment_target, - args.inputs) + args.inputs, + args.compress_pngs) if __name__ == '__main__':
diff --git a/build/toolchain/mac/compile_xcassets_unittests.py b/build/toolchain/mac/compile_xcassets_unittests.py index 530d0c9..6fa41ab 100644 --- a/build/toolchain/mac/compile_xcassets_unittests.py +++ b/build/toolchain/mac/compile_xcassets_unittests.py
@@ -64,6 +64,63 @@ '/* com.apple.actool.compilation-results */\n', self.relative_paths)) + def testComplexError(self): + self.assertEquals( + '/* com.apple.actool.errors */\n' + ': error: Failed to find a suitable device for the type SimDeviceType ' + ': com.apple.dt.Xcode.IBSimDeviceType.iPad-2x with runtime SimRunt' + 'ime : 10.3.1 (14E8301) - com.apple.CoreSimulator.SimRuntime.iOS-1' + '0-3\n' + ' Failure Reason: Failed to create SimDeviceSet at path /Users/jane' + 'doe/Library/Developer/Xcode/UserData/IB Support/Simulator Devices' + '. You\'ll want to check the logs in ~/Library/Logs/CoreSimulator ' + 'to see why creating the SimDeviceSet failed.\n' + ' Underlying Errors:\n' + ' Description: Failed to initialize simulator device set.\n' + ' Failure Reason: Failed to subscribe to notifications from Cor' + 'eSimulatorService.\n' + ' Underlying Errors:\n' + ' Description: Error returned in reply to notification requ' + 'est: Connection invalid\n' + ' Failure Reason: Software caused connection abort\n', + compile_xcassets.FilterCompilerOutput( + '2017-07-07 10:37:27.367 ibtoold[88538:12553239] CoreSimulator det' + 'ected Xcode.app relocation or CoreSimulatorService version ch' + 'ange. Framework path (/Applications/Xcode.app/Contents/Devel' + 'oper/Library/PrivateFrameworks/CoreSimulator.framework) and v' + 'ersion (375.21) does not match existing job path (/Library/De' + 'veloper/PrivateFrameworks/CoreSimulator.framework/Versions/A/' + 'XPCServices/com.apple.CoreSimulator.CoreSimulatorService.xpc)' + ' and version (459.13). Attempting to remove the stale servic' + 'e in order to add the expected version.\n' + '2017-07-07 10:37:27.625 ibtoold[88538:12553256] CoreSimulatorServ' + 'ice connection interrupted. Resubscribing to notifications.\n' + '2017-07-07 10:37:27.632 ibtoold[88538:12553264] CoreSimulatorServ' + 'ice connection became invalid. Simulator services will no lo' + 'nger be available.\n' + '2017-07-07 10:37:27.642 ibtoold[88538:12553274] CoreSimulatorServ' + 'ice connection became invalid. Simulator services will no lo' + 'nger be available.\n' + '/* com.apple.actool.errors */\n' + ': error: Failed to find a suitable device for the type SimDeviceT' + 'ype : com.apple.dt.Xcode.IBSimDeviceType.iPad-2x with runtime' + ' SimRuntime : 10.3.1 (14E8301) - com.apple.CoreSimulator.SimR' + 'untime.iOS-10-3\n' + ' Failure Reason: Failed to create SimDeviceSet at path /Users/' + 'janedoe/Library/Developer/Xcode/UserData/IB Support/Simulator' + ' Devices. You\'ll want to check the logs in ~/Library/Logs/Co' + 'reSimulator to see why creating the SimDeviceSet failed.\n' + ' Underlying Errors:\n' + ' Description: Failed to initialize simulator device set.\n' + ' Failure Reason: Failed to subscribe to notifications from' + ' CoreSimulatorService.\n' + ' Underlying Errors:\n' + ' Description: Error returned in reply to notification ' + 'request: Connection invalid\n' + ' Failure Reason: Software caused connection abort\n' + '/* com.apple.actool.compilation-results */\n', + self.relative_paths)) + if __name__ == '__main__': unittest.main()
diff --git a/build/toolchain/toolchain.gni b/build/toolchain/toolchain.gni index 9a31c361..9ce2ad9 100644 --- a/build/toolchain/toolchain.gni +++ b/build/toolchain/toolchain.gni
@@ -42,6 +42,10 @@ # Currently disabled on LLD because of a bug (fixed upstream). # See https://crbug.com/716209. generate_linker_map = is_android && is_official_build + + # Use absolute file paths in the compiler diagnostics and __FILE__ macro + # if needed. + msvc_use_absolute_paths = false } if (generate_linker_map) {
diff --git a/build/toolchain/win/BUILD.gn b/build/toolchain/win/BUILD.gn index 296f829..90777eb 100644 --- a/build/toolchain/win/BUILD.gn +++ b/build/toolchain/win/BUILD.gn
@@ -135,6 +135,13 @@ sys_include_flags = "" } + clflags = "" + + # Pass /FC flag to the compiler if needed. + if (msvc_use_absolute_paths) { + clflags += "/FC " + } + tool("cc") { rspfile = "{{output}}.rsp" precompiled_header_type = "msvc" @@ -143,7 +150,7 @@ # Label names may have spaces in them so the pdbname must be quoted. The # source and output don't need to be quoted because GN knows they're a # full file name and will quote automatically when necessary. - command = "$env_wrapper$cl /nologo /showIncludes /FC @$rspfile /c {{source}} /Fo{{output}} /Fd\"$pdbname\"" + command = "$env_wrapper$cl /nologo /showIncludes ${clflags} @$rspfile /c {{source}} /Fo{{output}} /Fd\"$pdbname\"" depsformat = "msvc" description = "CC {{output}}" outputs = [ @@ -160,7 +167,7 @@ pdbname = "{{target_out_dir}}/{{label_name}}_cc.pdb" # See comment in CC tool about quoting. - command = "$env_wrapper$cl /nologo /showIncludes /FC @$rspfile /c {{source}} /Fo{{output}} /Fd\"$pdbname\"" + command = "$env_wrapper$cl /nologo /showIncludes ${clflags} @$rspfile /c {{source}} /Fo{{output}} /Fd\"$pdbname\"" depsformat = "msvc" description = "CXX {{output}}" outputs = [
diff --git a/cc/BUILD.gn b/cc/BUILD.gn index 8b0d79f..2fe2405 100644 --- a/cc/BUILD.gn +++ b/cc/BUILD.gn
@@ -289,13 +289,8 @@ "raster/zero_copy_raster_buffer_provider.h", "resources/memory_history.cc", "resources/memory_history.h", - "resources/platform_color.h", "resources/release_callback.h", "resources/resource.h", - "resources/resource_format.cc", - "resources/resource_format.h", - "resources/resource_format_utils.cc", - "resources/resource_format_utils.h", "resources/resource_pool.cc", "resources/resource_pool.h", "resources/resource_provider.cc", @@ -478,6 +473,7 @@ public_deps = [ "//cc/base", + "//components/viz/common", "//skia", ] deps = [ @@ -792,7 +788,6 @@ "raster/synchronous_task_graph_runner_unittest.cc", "raster/task_graph_work_queue_unittest.cc", "raster/texture_compressor_etc1_unittest.cc", - "resources/platform_color_unittest.cc", "resources/resource_pool_unittest.cc", "resources/resource_provider_unittest.cc", "resources/resource_util_unittest.cc", @@ -898,6 +893,7 @@ "//cc/surfaces", "//cc/surfaces:surface_id", "//cc/surfaces:surfaces", + "//components/viz/common", "//gpu", "//gpu:test_support", "//gpu/command_buffer/client:gles2_interface",
diff --git a/cc/DEPS b/cc/DEPS index 0701904..bf4ab29b 100644 --- a/cc/DEPS +++ b/cc/DEPS
@@ -1,4 +1,6 @@ include_rules = [ + "+components/viz/common/quads", + "+components/viz/common/resources", "+gpu/GLES2", "+gpu/command_buffer/client/context_support.h", "+gpu/command_buffer/client/gles2_interface.h",
diff --git a/cc/ipc/cc_param_traits_macros.h b/cc/ipc/cc_param_traits_macros.h index 019a16e1..7bb91782 100644 --- a/cc/ipc/cc_param_traits_macros.h +++ b/cc/ipc/cc_param_traits_macros.h
@@ -18,12 +18,12 @@ #include "cc/quads/texture_draw_quad.h" #include "cc/quads/tile_draw_quad.h" #include "cc/quads/yuv_video_draw_quad.h" -#include "cc/resources/resource_format.h" #include "cc/resources/returned_resource.h" #include "cc/resources/transferable_resource.h" #include "cc/surfaces/surface_id.h" #include "cc/surfaces/surface_info.h" #include "cc/surfaces/surface_sequence.h" +#include "components/viz/common/quads/resource_format.h" #include "ui/gfx/ipc/color/gfx_param_traits.h" #include "ui/gfx/ipc/gfx_param_traits.h" #include "ui/gfx/ipc/skia/gfx_skia_param_traits.h" @@ -35,7 +35,7 @@ IPC_ENUM_TRAITS_MAX_VALUE(cc::DrawQuad::Material, cc::DrawQuad::MATERIAL_LAST) IPC_ENUM_TRAITS_MAX_VALUE(cc::FilterOperation::FilterType, cc::FilterOperation::FILTER_TYPE_LAST) -IPC_ENUM_TRAITS_MAX_VALUE(cc::ResourceFormat, cc::RESOURCE_FORMAT_MAX) +IPC_ENUM_TRAITS_MAX_VALUE(viz::ResourceFormat, viz::RESOURCE_FORMAT_MAX) // TODO(fsamuel): This trait belongs with skia code. IPC_ENUM_TRAITS_MAX_VALUE(SkBlendMode, SkBlendMode::kLastMode)
diff --git a/cc/ipc/cc_param_traits_unittest.cc b/cc/ipc/cc_param_traits_unittest.cc index 41d6da45b..5da53a13 100644 --- a/cc/ipc/cc_param_traits_unittest.cc +++ b/cc/ipc/cc_param_traits_unittest.cc
@@ -592,7 +592,7 @@ TransferableResource arbitrary_resource1; arbitrary_resource1.id = 2178312; - arbitrary_resource1.format = cc::RGBA_8888; + arbitrary_resource1.format = viz::RGBA_8888; arbitrary_resource1.filter = 53; arbitrary_resource1.size = gfx::Size(37189, 123123); arbitrary_resource1.mailbox_holder.mailbox.SetName(arbitrary_mailbox1); @@ -606,7 +606,7 @@ TransferableResource arbitrary_resource2; arbitrary_resource2.id = 789132; - arbitrary_resource2.format = cc::RGBA_4444; + arbitrary_resource2.format = viz::RGBA_4444; arbitrary_resource2.filter = 47; arbitrary_resource2.size = gfx::Size(89123, 23789); arbitrary_resource2.mailbox_holder.mailbox.SetName(arbitrary_mailbox2);
diff --git a/cc/ipc/struct_traits_unittest.cc b/cc/ipc/struct_traits_unittest.cc index dc5d9cb..48f7269 100644 --- a/cc/ipc/struct_traits_unittest.cc +++ b/cc/ipc/struct_traits_unittest.cc
@@ -254,7 +254,7 @@ // TransferableResource constants. const uint32_t tr_id = 1337; - const ResourceFormat tr_format = ALPHA_8; + const viz::ResourceFormat tr_format = viz::ALPHA_8; const gfx::BufferFormat tr_buffer_format = gfx::BufferFormat::R_8; const uint32_t tr_filter = 1234; const gfx::Size tr_size(1234, 5678); @@ -1146,7 +1146,7 @@ TEST_F(StructTraitsTest, TransferableResource) { const uint32_t id = 1337; - const ResourceFormat format = ALPHA_8; + const viz::ResourceFormat format = viz::ALPHA_8; const uint32_t filter = 1234; const gfx::Size size(1234, 5678); const int8_t mailbox_name[GL_MAILBOX_SIZE_CHROMIUM] = {
diff --git a/cc/ipc/transferable_resource_struct_traits.cc b/cc/ipc/transferable_resource_struct_traits.cc index ea6c56d..60aedc8 100644 --- a/cc/ipc/transferable_resource_struct_traits.cc +++ b/cc/ipc/transferable_resource_struct_traits.cc
@@ -20,7 +20,7 @@ !data.ReadColorSpace(&out->color_space)) return false; out->id = data.id(); - out->format = static_cast<cc::ResourceFormat>(data.format()); + out->format = static_cast<viz::ResourceFormat>(data.format()); out->buffer_format = static_cast<gfx::BufferFormat>(data.buffer_format()); out->filter = data.filter(); out->read_lock_fences_enabled = data.read_lock_fences_enabled();
diff --git a/cc/layers/picture_layer_impl.cc b/cc/layers/picture_layer_impl.cc index 856f47c9..29c27a93 100644 --- a/cc/layers/picture_layer_impl.cc +++ b/cc/layers/picture_layer_impl.cc
@@ -256,7 +256,7 @@ render_pass->CreateAndAppendDrawQuad<PictureDrawQuad>(); quad->SetNew(shared_quad_state, geometry_rect, opaque_rect, visible_geometry_rect, texture_rect, texture_size, - nearest_neighbor_, RGBA_8888, quad_content_rect, + nearest_neighbor_, viz::RGBA_8888, quad_content_rect, max_contents_scale, raster_source_); ValidateQuadResources(quad); return;
diff --git a/cc/layers/texture_layer_impl.cc b/cc/layers/texture_layer_impl.cc index 4835c97d..a64b5e9 100644 --- a/cc/layers/texture_layer_impl.cc +++ b/cc/layers/texture_layer_impl.cc
@@ -13,11 +13,11 @@ #include "cc/output/output_surface.h" #include "cc/quads/solid_color_draw_quad.h" #include "cc/quads/texture_draw_quad.h" -#include "cc/resources/platform_color.h" #include "cc/resources/scoped_resource.h" #include "cc/resources/single_release_callback_impl.h" #include "cc/trees/layer_tree_impl.h" #include "cc/trees/occlusion.h" +#include "components/viz/common/resources/platform_color.h" namespace cc { @@ -122,7 +122,7 @@ std::vector<uint8_t> swizzled; uint8_t* pixels = texture_mailbox_.shared_bitmap()->pixels(); - if (!PlatformColor::SameComponentOrder(texture_copy_->format())) { + if (!viz::PlatformColor::SameComponentOrder(texture_copy_->format())) { // Swizzle colors. This is slow, but should be really uncommon. size_t bytes = texture_mailbox_.SharedMemorySizeInBytes(); swizzled.resize(bytes);
diff --git a/cc/output/direct_renderer.h b/cc/output/direct_renderer.h index 0c46c05e..d265657 100644 --- a/cc/output/direct_renderer.h +++ b/cc/output/direct_renderer.h
@@ -146,7 +146,7 @@ // Private interface implemented by subclasses for use by DirectRenderer. virtual bool CanPartialSwap() = 0; - virtual ResourceFormat BackbufferFormat() const = 0; + virtual viz::ResourceFormat BackbufferFormat() const = 0; virtual void BindFramebufferToOutputSurface() = 0; virtual bool BindFramebufferToTexture(const ScopedResource* resource) = 0; virtual void SetScissorTestRect(const gfx::Rect& scissor_rect) = 0;
diff --git a/cc/output/gl_renderer.cc b/cc/output/gl_renderer.cc index f42dfdb..29b67dc 100644 --- a/cc/output/gl_renderer.cc +++ b/cc/output/gl_renderer.cc
@@ -428,10 +428,10 @@ return context_provider->ContextCapabilities().post_sub_buffer; } -ResourceFormat GLRenderer::BackbufferFormat() const { +viz::ResourceFormat GLRenderer::BackbufferFormat() const { if (current_frame()->current_render_pass->color_space.IsHDR() && - resource_provider_->IsRenderBufferFormatSupported(RGBA_F16)) { - return RGBA_F16; + resource_provider_->IsRenderBufferFormatSupported(viz::RGBA_F16)) { + return viz::RGBA_F16; } return resource_provider_->best_texture_format(); } @@ -1057,7 +1057,7 @@ TileDrawQuad* tile_quad = &bypass->second; // RGBA_8888 and the gfx::ColorSpace() here are arbitrary and unused. Resource tile_resource(tile_quad->resource_id(), tile_quad->texture_size, - ResourceFormat::RGBA_8888, gfx::ColorSpace()); + viz::ResourceFormat::RGBA_8888, gfx::ColorSpace()); // The projection matrix used by GLRenderer has a flip. As tile texture // inputs are oriented opposite to framebuffer outputs, don't flip via // texture coords and let the projection matrix naturallyd o it. @@ -3406,7 +3406,8 @@ static_cast<uint32_t>(updated_dst_rect.height()), iosurface_multiple); *resource = overlay_resource_pool_->AcquireResource( - gfx::Size(iosurface_width, iosurface_height), ResourceFormat::RGBA_8888, + gfx::Size(iosurface_width, iosurface_height), + viz::ResourceFormat::RGBA_8888, current_frame()->current_render_pass->color_space); *new_bounds = gfx::RectF(updated_dst_rect.x(), updated_dst_rect.y(),
diff --git a/cc/output/gl_renderer.h b/cc/output/gl_renderer.h index ca853e3..05cd04b 100644 --- a/cc/output/gl_renderer.h +++ b/cc/output/gl_renderer.h
@@ -86,7 +86,7 @@ bool blend_enabled() const { return blend_shadow_; } bool CanPartialSwap() override; - ResourceFormat BackbufferFormat() const override; + viz::ResourceFormat BackbufferFormat() const override; void BindFramebufferToOutputSurface() override; bool BindFramebufferToTexture(const ScopedResource* resource) override; void SetScissorTestRect(const gfx::Rect& scissor_rect) override; @@ -187,8 +187,6 @@ const gfx::QuadF* clip_region); void DrawStreamVideoQuad(const StreamVideoDrawQuad* quad, const gfx::QuadF* clip_region); - void DrawTextureQuad(const TextureDrawQuad* quad, - const gfx::QuadF* clip_region); void EnqueueTextureQuad(const TextureDrawQuad* quad, const gfx::QuadF* clip_region); void FlushTextureQuadCache(BoundGeometry flush_binding); @@ -331,7 +329,7 @@ std::unique_ptr<ResourceProvider::ScopedWriteLockGL> current_framebuffer_lock_; // This is valid when current_framebuffer_lock_ is not null. - ResourceFormat current_framebuffer_format_; + viz::ResourceFormat current_framebuffer_format_; class SyncQuery; std::deque<std::unique_ptr<SyncQuery>> pending_sync_queries_;
diff --git a/cc/output/in_process_context_provider.cc b/cc/output/in_process_context_provider.cc index acadc43..cd53faa 100644 --- a/cc/output/in_process_context_provider.cc +++ b/cc/output/in_process_context_provider.cc
@@ -11,7 +11,7 @@ #include "base/memory/ptr_util.h" #include "base/single_thread_task_runner.h" #include "base/threading/thread_task_runner_handle.h" -#include "cc/resources/platform_color.h" +#include "components/viz/common/resources/platform_color.h" #include "gpu/GLES2/gl2extchromium.h" #include "gpu/command_buffer/client/gles2_implementation.h" #include "gpu/command_buffer/common/gles2_cmd_utils.h"
diff --git a/cc/output/renderer_pixeltest.cc b/cc/output/renderer_pixeltest.cc index 583e138..e2ebf56 100644 --- a/cc/output/renderer_pixeltest.cc +++ b/cc/output/renderer_pixeltest.cc
@@ -138,7 +138,7 @@ } } ResourceId resource = resource_provider->CreateResource( - rect.size(), ResourceProvider::TEXTURE_HINT_IMMUTABLE, RGBA_8888, + rect.size(), ResourceProvider::TEXTURE_HINT_IMMUTABLE, viz::RGBA_8888, gfx::ColorSpace()); resource_provider->CopyToResource( resource, reinterpret_cast<uint8_t*>(&pixels.front()), rect.size()); @@ -174,7 +174,7 @@ std::vector<uint32_t> pixels(num_pixels, pixel_color); ResourceId resource = resource_provider->CreateResource( - rect.size(), ResourceProvider::TEXTURE_HINT_IMMUTABLE, RGBA_8888, + rect.size(), ResourceProvider::TEXTURE_HINT_IMMUTABLE, viz::RGBA_8888, gfx::ColorSpace()); resource_provider->CopyToResource( resource, reinterpret_cast<uint8_t*>(&pixels.front()), rect.size()); @@ -553,7 +553,7 @@ rect.size(), ResourceProvider::TEXTURE_HINT_DEFAULT, resource_provider->YuvResourceFormat(8), gfx::ColorSpace()); ResourceId u_resource = resource_provider->CreateResource( - uv_tex_size, ResourceProvider::TEXTURE_HINT_DEFAULT, RGBA_8888, + uv_tex_size, ResourceProvider::TEXTURE_HINT_DEFAULT, viz::RGBA_8888, gfx::ColorSpace()); ResourceId v_resource = u_resource; ResourceId a_resource = 0; @@ -1056,8 +1056,8 @@ blue_quad->SetNew(this->front_quad_state_, this->quad_rect_, gfx::Rect(), this->quad_rect_, gfx::RectF(this->quad_rect_), - this->quad_rect_.size(), false, RGBA_8888, this->quad_rect_, - 1.f, blue_raster_source); + this->quad_rect_.size(), false, viz::RGBA_8888, + this->quad_rect_, 1.f, blue_raster_source); std::unique_ptr<FakeRecordingSource> green_recording = FakeRecordingSource::CreateFilledRecordingSource(this->quad_rect_.size()); @@ -1071,7 +1071,7 @@ this->render_pass_->template CreateAndAppendDrawQuad<PictureDrawQuad>(); green_quad->SetNew(this->back_quad_state_, this->quad_rect_, gfx::Rect(), this->quad_rect_, gfx::RectF(this->quad_rect_), - this->quad_rect_.size(), false, RGBA_8888, + this->quad_rect_.size(), false, viz::RGBA_8888, this->quad_rect_, 1.f, green_raster_source); SCOPED_TRACE("IntersectingPictureQuadsPass"); this->AppendBackgroundAndRunTest( @@ -2018,8 +2018,8 @@ } ResourceId mask_resource_id = this->resource_provider_->CreateResource( - mask_rect.size(), ResourceProvider::TEXTURE_HINT_IMMUTABLE, RGBA_8888, - gfx::ColorSpace()); + mask_rect.size(), ResourceProvider::TEXTURE_HINT_IMMUTABLE, + viz::RGBA_8888, gfx::ColorSpace()); this->resource_provider_->CopyToResource( mask_resource_id, reinterpret_cast<uint8_t*>(bitmap.getPixels()), @@ -2111,8 +2111,8 @@ } ResourceId mask_resource_id = this->resource_provider_->CreateResource( - mask_rect.size(), ResourceProvider::TEXTURE_HINT_IMMUTABLE, RGBA_8888, - gfx::ColorSpace()); + mask_rect.size(), ResourceProvider::TEXTURE_HINT_IMMUTABLE, + viz::RGBA_8888, gfx::ColorSpace()); this->resource_provider_->CopyToResource( mask_resource_id, reinterpret_cast<uint8_t*>(bitmap.getPixels()), @@ -2574,7 +2574,7 @@ TYPED_TEST(SoftwareRendererPixelTest, PictureDrawQuadIdentityScale) { gfx::Rect viewport(this->device_viewport_size_); // TODO(enne): the renderer should figure this out on its own. - ResourceFormat texture_format = RGBA_8888; + viz::ResourceFormat texture_format = viz::RGBA_8888; bool nearest_neighbor = false; int id = 1; @@ -2650,7 +2650,7 @@ // Not WithSkiaGPUBackend since that path currently requires tiles for opacity. TYPED_TEST(SoftwareRendererPixelTest, PictureDrawQuadOpacity) { gfx::Rect viewport(this->device_viewport_size_); - ResourceFormat texture_format = RGBA_8888; + viz::ResourceFormat texture_format = viz::RGBA_8888; bool nearest_neighbor = false; int id = 1; @@ -2738,7 +2738,7 @@ return; gfx::Rect viewport(this->device_viewport_size_); - ResourceFormat texture_format = RGBA_8888; + viz::ResourceFormat texture_format = viz::RGBA_8888; bool nearest_neighbor = false; int id = 1; @@ -2787,7 +2787,7 @@ // This disables filtering by setting |nearest_neighbor| on the PictureDrawQuad. TYPED_TEST(SoftwareRendererPixelTest, PictureDrawQuadNearestNeighbor) { gfx::Rect viewport(this->device_viewport_size_); - ResourceFormat texture_format = RGBA_8888; + viz::ResourceFormat texture_format = viz::RGBA_8888; bool nearest_neighbor = true; int id = 1; @@ -2847,7 +2847,7 @@ gfx::Size tile_size(2, 2); ResourceId resource = this->resource_provider_->CreateResource( - tile_size, ResourceProvider::TEXTURE_HINT_IMMUTABLE, RGBA_8888, + tile_size, ResourceProvider::TEXTURE_HINT_IMMUTABLE, viz::RGBA_8888, gfx::ColorSpace()); this->resource_provider_->CopyToResource( @@ -2892,7 +2892,7 @@ gfx::Size tile_size(2, 2); ResourceId resource = this->resource_provider_->CreateResource( - tile_size, ResourceProvider::TEXTURE_HINT_IMMUTABLE, RGBA_8888, + tile_size, ResourceProvider::TEXTURE_HINT_IMMUTABLE, viz::RGBA_8888, gfx::ColorSpace()); this->resource_provider_->CopyToResource( @@ -2940,7 +2940,7 @@ gfx::Size tile_size(2, 2); ResourceId resource = this->resource_provider_->CreateResource( - tile_size, ResourceProvider::TEXTURE_HINT_IMMUTABLE, RGBA_8888, + tile_size, ResourceProvider::TEXTURE_HINT_IMMUTABLE, viz::RGBA_8888, gfx::ColorSpace()); this->resource_provider_->CopyToResource( @@ -2975,7 +2975,7 @@ TYPED_TEST(SoftwareRendererPixelTest, PictureDrawQuadNonIdentityScale) { gfx::Rect viewport(this->device_viewport_size_); // TODO(enne): the renderer should figure this out on its own. - ResourceFormat texture_format = RGBA_8888; + viz::ResourceFormat texture_format = viz::RGBA_8888; bool nearest_neighbor = false; int id = 1; @@ -3301,8 +3301,8 @@ } ResourceId resource = this->resource_provider_->CreateResource( - mask_rect.size(), ResourceProvider::TEXTURE_HINT_IMMUTABLE, RGBA_8888, - gfx::ColorSpace()); + mask_rect.size(), ResourceProvider::TEXTURE_HINT_IMMUTABLE, + viz::RGBA_8888, gfx::ColorSpace()); this->resource_provider_->CopyToResource( resource, reinterpret_cast<uint8_t*>(bitmap.getPixels()), @@ -3480,7 +3480,7 @@ CreateTestSharedQuadState(gfx::Transform(), rect, pass.get()); ResourceId resource = resource_provider_->CreateResource( - rect.size(), ResourceProvider::TEXTURE_HINT_IMMUTABLE, RGBA_8888, + rect.size(), ResourceProvider::TEXTURE_HINT_IMMUTABLE, viz::RGBA_8888, src_color_space_); resource_provider_->CopyToResource(resource, input_colors.data(), rect.size());
diff --git a/cc/output/software_renderer.cc b/cc/output/software_renderer.cc index 6fc30a0..d6187b2 100644 --- a/cc/output/software_renderer.cc +++ b/cc/output/software_renderer.cc
@@ -66,7 +66,7 @@ return true; } -ResourceFormat SoftwareRenderer::BackbufferFormat() const { +viz::ResourceFormat SoftwareRenderer::BackbufferFormat() const { return resource_provider_->best_texture_format(); }
diff --git a/cc/output/software_renderer.h b/cc/output/software_renderer.h index 07e91027..3a077802 100644 --- a/cc/output/software_renderer.h +++ b/cc/output/software_renderer.h
@@ -37,7 +37,7 @@ protected: bool CanPartialSwap() override; - ResourceFormat BackbufferFormat() const override; + viz::ResourceFormat BackbufferFormat() const override; void BindFramebufferToOutputSurface() override; bool BindFramebufferToTexture(const ScopedResource* texture) override; void SetScissorTestRect(const gfx::Rect& scissor_rect) override;
diff --git a/cc/output/software_renderer_unittest.cc b/cc/output/software_renderer_unittest.cc index 19a68ca6..ec53b2d 100644 --- a/cc/output/software_renderer_unittest.cc +++ b/cc/output/software_renderer_unittest.cc
@@ -143,10 +143,10 @@ InitializeRenderer(base::WrapUnique(new SoftwareOutputDevice)); ResourceId resource_yellow = resource_provider()->CreateResource( - outer_size, ResourceProvider::TEXTURE_HINT_IMMUTABLE, RGBA_8888, + outer_size, ResourceProvider::TEXTURE_HINT_IMMUTABLE, viz::RGBA_8888, gfx::ColorSpace()); ResourceId resource_cyan = resource_provider()->CreateResource( - inner_size, ResourceProvider::TEXTURE_HINT_IMMUTABLE, RGBA_8888, + inner_size, ResourceProvider::TEXTURE_HINT_IMMUTABLE, viz::RGBA_8888, gfx::ColorSpace()); SkBitmap yellow_tile; @@ -209,7 +209,7 @@ InitializeRenderer(base::WrapUnique(new SoftwareOutputDevice)); ResourceId resource_cyan = resource_provider()->CreateResource( - tile_size, ResourceProvider::TEXTURE_HINT_IMMUTABLE, RGBA_8888, + tile_size, ResourceProvider::TEXTURE_HINT_IMMUTABLE, viz::RGBA_8888, gfx::ColorSpace()); SkBitmap cyan_tile; // The lowest five rows are yellow.
diff --git a/cc/paint/display_item_list.cc b/cc/paint/display_item_list.cc index 8945e5a..3fb69bb 100644 --- a/cc/paint/display_item_list.cc +++ b/cc/paint/display_item_list.cc
@@ -157,12 +157,7 @@ gfx::Rect bounds = rtree_.GetBounds(); DiscardableImageMap::ScopedMetadataGenerator generator( &image_map_, gfx::Size(bounds.right(), bounds.bottom())); - GatherDiscardableImages(generator.image_store()); -} - -void DisplayItemList::GatherDiscardableImages( - DiscardableImageStore* image_store) const { - image_store->GatherDiscardableImages(&paint_op_buffer_); + generator.image_store()->GatherDiscardableImages(&paint_op_buffer_); } void DisplayItemList::GetDiscardableImagesInRect( @@ -190,7 +185,6 @@ current_range_start_ = 0; in_paired_begin_count_ = 0; in_painting_ = false; - op_count_ = 0u; } sk_sp<PaintRecord> DisplayItemList::ReleaseAsRecord() {
diff --git a/cc/paint/display_item_list.h b/cc/paint/display_item_list.h index 1381336..46cc329 100644 --- a/cc/paint/display_item_list.h +++ b/cc/paint/display_item_list.h
@@ -126,7 +126,6 @@ gfx::Rect VisualRectForTesting(int index) { return visual_rects_[index]; } - void GatherDiscardableImages(DiscardableImageStore* image_store) const; const DiscardableImageMap& discardable_image_map_for_testing() const { return image_map_; } @@ -181,8 +180,6 @@ // nesting. bool in_painting_ = false; - size_t op_count_ = 0u; - friend class base::RefCountedThreadSafe<DisplayItemList>; FRIEND_TEST_ALL_PREFIXES(DisplayItemListTest, BytesUsed); DISALLOW_COPY_AND_ASSIGN(DisplayItemList);
diff --git a/cc/paint/paint_flags.h b/cc/paint/paint_flags.h index 940751c..2101c1aa 100644 --- a/cc/paint/paint_flags.h +++ b/cc/paint/paint_flags.h
@@ -176,7 +176,7 @@ return paint_.getShader()->isOpaque(); } - ALWAYS_INLINE void setShader(std::unique_ptr<PaintShader> shader) { + ALWAYS_INLINE void setShader(sk_sp<PaintShader> shader) { paint_.setShader(shader ? shader->sk_shader() : nullptr); } ALWAYS_INLINE SkPathEffect* getPathEffect() const {
diff --git a/cc/paint/paint_shader.cc b/cc/paint/paint_shader.cc index fb8bb25..19cf600 100644 --- a/cc/paint/paint_shader.cc +++ b/cc/paint/paint_shader.cc
@@ -10,42 +10,40 @@ namespace cc { -std::unique_ptr<PaintShader> PaintShader::MakeColor(SkColor color) { - return base::WrapUnique(new PaintShader(nullptr, color)); +sk_sp<PaintShader> PaintShader::MakeColor(SkColor color) { + return sk_sp<PaintShader>(new PaintShader(nullptr, color)); } -std::unique_ptr<PaintShader> PaintShader::MakeLinearGradient( - const SkPoint points[], - const SkColor colors[], - const SkScalar pos[], - int count, - SkShader::TileMode mode, - uint32_t flags, - const SkMatrix* local_matrix, - SkColor fallback_color) { - return base::WrapUnique( +sk_sp<PaintShader> PaintShader::MakeLinearGradient(const SkPoint points[], + const SkColor colors[], + const SkScalar pos[], + int count, + SkShader::TileMode mode, + uint32_t flags, + const SkMatrix* local_matrix, + SkColor fallback_color) { + return sk_sp<PaintShader>( new PaintShader(SkGradientShader::MakeLinear(points, colors, pos, count, mode, flags, local_matrix), fallback_color)); } -std::unique_ptr<PaintShader> PaintShader::MakeRadialGradient( - const SkPoint& center, - SkScalar radius, - const SkColor colors[], - const SkScalar pos[], - int color_count, - SkShader::TileMode mode, - uint32_t flags, - const SkMatrix* local_matrix, - SkColor fallback_color) { - return base::WrapUnique(new PaintShader( +sk_sp<PaintShader> PaintShader::MakeRadialGradient(const SkPoint& center, + SkScalar radius, + const SkColor colors[], + const SkScalar pos[], + int color_count, + SkShader::TileMode mode, + uint32_t flags, + const SkMatrix* local_matrix, + SkColor fallback_color) { + return sk_sp<PaintShader>(new PaintShader( SkGradientShader::MakeRadial(center, radius, colors, pos, color_count, mode, flags, local_matrix), fallback_color)); } -std::unique_ptr<PaintShader> PaintShader::MakeTwoPointConicalGradient( +sk_sp<PaintShader> PaintShader::MakeTwoPointConicalGradient( const SkPoint& start, SkScalar start_radius, const SkPoint& end, @@ -57,44 +55,41 @@ uint32_t flags, const SkMatrix* local_matrix, SkColor fallback_color) { - return base::WrapUnique( + return sk_sp<PaintShader>( new PaintShader(SkGradientShader::MakeTwoPointConical( start, start_radius, end, end_radius, colors, pos, color_count, mode, flags, local_matrix), fallback_color)); } -std::unique_ptr<PaintShader> PaintShader::MakeSweepGradient( - SkScalar cx, - SkScalar cy, - const SkColor colors[], - const SkScalar pos[], - int color_count, - uint32_t flags, - const SkMatrix* local_matrix, - SkColor fallback_color) { - return base::WrapUnique(new PaintShader( +sk_sp<PaintShader> PaintShader::MakeSweepGradient(SkScalar cx, + SkScalar cy, + const SkColor colors[], + const SkScalar pos[], + int color_count, + uint32_t flags, + const SkMatrix* local_matrix, + SkColor fallback_color) { + return sk_sp<PaintShader>(new PaintShader( SkGradientShader::MakeSweep(cx, cy, colors, pos, color_count, flags, local_matrix), fallback_color)); } -std::unique_ptr<PaintShader> PaintShader::MakeImage( - sk_sp<const SkImage> image, - SkShader::TileMode tx, - SkShader::TileMode ty, - const SkMatrix* local_matrix) { - return base::WrapUnique(new PaintShader( +sk_sp<PaintShader> PaintShader::MakeImage(sk_sp<const SkImage> image, + SkShader::TileMode tx, + SkShader::TileMode ty, + const SkMatrix* local_matrix) { + return sk_sp<PaintShader>(new PaintShader( image->makeShader(tx, ty, local_matrix), SK_ColorTRANSPARENT)); } -std::unique_ptr<PaintShader> PaintShader::MakePaintRecord( - sk_sp<PaintRecord> record, - const SkRect& tile, - SkShader::TileMode tx, - SkShader::TileMode ty, - const SkMatrix* local_matrix) { - return base::WrapUnique(new PaintShader( +sk_sp<PaintShader> PaintShader::MakePaintRecord(sk_sp<PaintRecord> record, + const SkRect& tile, + SkShader::TileMode tx, + SkShader::TileMode ty, + const SkMatrix* local_matrix) { + return sk_sp<PaintShader>(new PaintShader( SkShader::MakePictureShader(ToSkPicture(std::move(record), tile), tx, ty, local_matrix, nullptr), SK_ColorTRANSPARENT)); @@ -105,11 +100,7 @@ : SkShader::MakeColorShader(fallback_color)) { DCHECK(sk_shader_); } -PaintShader::PaintShader(const PaintShader& other) = default; -PaintShader::PaintShader(PaintShader&& other) = default; -PaintShader::~PaintShader() = default; -PaintShader& PaintShader::operator=(const PaintShader& other) = default; -PaintShader& PaintShader::operator=(PaintShader&& other) = default; +PaintShader::~PaintShader() = default; } // namespace cc
diff --git a/cc/paint/paint_shader.h b/cc/paint/paint_shader.h index 6fc1a46..6dd468c 100644 --- a/cc/paint/paint_shader.h +++ b/cc/paint/paint_shader.h
@@ -17,11 +17,11 @@ class PaintOpBuffer; using PaintRecord = PaintOpBuffer; -class CC_PAINT_EXPORT PaintShader { +class CC_PAINT_EXPORT PaintShader : public SkRefCnt { public: - static std::unique_ptr<PaintShader> MakeColor(SkColor color); + static sk_sp<PaintShader> MakeColor(SkColor color); - static std::unique_ptr<PaintShader> MakeLinearGradient( + static sk_sp<PaintShader> MakeLinearGradient( const SkPoint points[], const SkColor colors[], const SkScalar pos[], @@ -31,7 +31,7 @@ const SkMatrix* local_matrix = nullptr, SkColor fallback_color = SK_ColorTRANSPARENT); - static std::unique_ptr<PaintShader> MakeRadialGradient( + static sk_sp<PaintShader> MakeRadialGradient( const SkPoint& center, SkScalar radius, const SkColor colors[], @@ -42,7 +42,7 @@ const SkMatrix* local_matrix = nullptr, SkColor fallback_color = SK_ColorTRANSPARENT); - static std::unique_ptr<PaintShader> MakeTwoPointConicalGradient( + static sk_sp<PaintShader> MakeTwoPointConicalGradient( const SkPoint& start, SkScalar start_radius, const SkPoint& end, @@ -55,7 +55,7 @@ const SkMatrix* local_matrix = nullptr, SkColor fallback_color = SK_ColorTRANSPARENT); - static std::unique_ptr<PaintShader> MakeSweepGradient( + static sk_sp<PaintShader> MakeSweepGradient( SkScalar cx, SkScalar cy, const SkColor colors[], @@ -65,24 +65,18 @@ const SkMatrix* local_matrix = nullptr, SkColor fallback_color = SK_ColorTRANSPARENT); - static std::unique_ptr<PaintShader> MakeImage(sk_sp<const SkImage> image, - SkShader::TileMode tx, - SkShader::TileMode ty, - const SkMatrix* local_matrix); + static sk_sp<PaintShader> MakeImage(sk_sp<const SkImage> image, + SkShader::TileMode tx, + SkShader::TileMode ty, + const SkMatrix* local_matrix); - static std::unique_ptr<PaintShader> MakePaintRecord( - sk_sp<PaintRecord> record, - const SkRect& tile, - SkShader::TileMode tx, - SkShader::TileMode ty, - const SkMatrix* local_matrix); + static sk_sp<PaintShader> MakePaintRecord(sk_sp<PaintRecord> record, + const SkRect& tile, + SkShader::TileMode tx, + SkShader::TileMode ty, + const SkMatrix* local_matrix); - PaintShader(const PaintShader& other); - PaintShader(PaintShader&& other); - ~PaintShader(); - - PaintShader& operator=(const PaintShader& other); - PaintShader& operator=(PaintShader&& other); + ~PaintShader() override; const sk_sp<SkShader>& sk_shader() const { return sk_shader_; }
diff --git a/cc/quads/draw_quad_unittest.cc b/cc/quads/draw_quad_unittest.cc index b8f150b9..fafc1b2 100644 --- a/cc/quads/draw_quad_unittest.cc +++ b/cc/quads/draw_quad_unittest.cc
@@ -426,7 +426,7 @@ gfx::RectF tex_coord_rect(31.f, 12.f, 54.f, 20.f); gfx::Size texture_size(85, 32); bool nearest_neighbor = true; - ResourceFormat texture_format = RGBA_8888; + viz::ResourceFormat texture_format = viz::RGBA_8888; gfx::Rect content_rect(30, 40, 20, 30); float contents_scale = 3.141592f; scoped_refptr<RasterSource> raster_source = @@ -633,7 +633,7 @@ gfx::RectF tex_coord_rect(31.f, 12.f, 54.f, 20.f); gfx::Size texture_size(85, 32); bool nearest_neighbor = true; - ResourceFormat texture_format = RGBA_8888; + viz::ResourceFormat texture_format = viz::RGBA_8888; gfx::Rect content_rect(30, 40, 20, 30); float contents_scale = 3.141592f; scoped_refptr<RasterSource> raster_source =
diff --git a/cc/quads/picture_draw_quad.cc b/cc/quads/picture_draw_quad.cc index 14c0123..b0f1af27 100644 --- a/cc/quads/picture_draw_quad.cc +++ b/cc/quads/picture_draw_quad.cc
@@ -7,7 +7,7 @@ #include "base/trace_event/trace_event_argument.h" #include "base/values.h" #include "cc/base/math_util.h" -#include "cc/resources/platform_color.h" +#include "components/viz/common/resources/platform_color.h" namespace cc { @@ -26,19 +26,14 @@ const gfx::RectF& tex_coord_rect, const gfx::Size& texture_size, bool nearest_neighbor, - ResourceFormat texture_format, + viz::ResourceFormat texture_format, const gfx::Rect& content_rect, float contents_scale, scoped_refptr<RasterSource> raster_source) { ContentDrawQuadBase::SetNew( - shared_quad_state, - DrawQuad::PICTURE_CONTENT, - rect, - opaque_rect, - visible_rect, - tex_coord_rect, - texture_size, - !PlatformColor::SameComponentOrder(texture_format), + shared_quad_state, DrawQuad::PICTURE_CONTENT, rect, opaque_rect, + visible_rect, tex_coord_rect, texture_size, + !viz::PlatformColor::SameComponentOrder(texture_format), nearest_neighbor); this->content_rect = content_rect; this->contents_scale = contents_scale; @@ -54,21 +49,15 @@ const gfx::RectF& tex_coord_rect, const gfx::Size& texture_size, bool nearest_neighbor, - ResourceFormat texture_format, + viz::ResourceFormat texture_format, const gfx::Rect& content_rect, float contents_scale, scoped_refptr<RasterSource> raster_source) { - ContentDrawQuadBase::SetAll(shared_quad_state, - DrawQuad::PICTURE_CONTENT, - rect, - opaque_rect, - visible_rect, - needs_blending, - tex_coord_rect, - texture_size, - !PlatformColor::SameComponentOrder( - texture_format), - nearest_neighbor); + ContentDrawQuadBase::SetAll( + shared_quad_state, DrawQuad::PICTURE_CONTENT, rect, opaque_rect, + visible_rect, needs_blending, tex_coord_rect, texture_size, + !viz::PlatformColor::SameComponentOrder(texture_format), + nearest_neighbor); this->content_rect = content_rect; this->contents_scale = contents_scale; this->raster_source = raster_source;
diff --git a/cc/quads/picture_draw_quad.h b/cc/quads/picture_draw_quad.h index cb9f5a79..eefc9fba 100644 --- a/cc/quads/picture_draw_quad.h +++ b/cc/quads/picture_draw_quad.h
@@ -32,7 +32,7 @@ const gfx::RectF& tex_coord_rect, const gfx::Size& texture_size, bool nearest_neighbor, - ResourceFormat texture_format, + viz::ResourceFormat texture_format, const gfx::Rect& content_rect, float contents_scale, scoped_refptr<RasterSource> raster_source); @@ -45,7 +45,7 @@ const gfx::RectF& tex_coord_rect, const gfx::Size& texture_size, bool nearest_neighbor, - ResourceFormat texture_format, + viz::ResourceFormat texture_format, const gfx::Rect& content_rect, float contents_scale, scoped_refptr<RasterSource> raster_source); @@ -53,7 +53,7 @@ gfx::Rect content_rect; float contents_scale; scoped_refptr<RasterSource> raster_source; - ResourceFormat texture_format; + viz::ResourceFormat texture_format; static const PictureDrawQuad* MaterialCast(const DrawQuad* quad);
diff --git a/cc/raster/bitmap_raster_buffer_provider.cc b/cc/raster/bitmap_raster_buffer_provider.cc index b69531a..4abc5a7 100644 --- a/cc/raster/bitmap_raster_buffer_provider.cc +++ b/cc/raster/bitmap_raster_buffer_provider.cc
@@ -16,8 +16,8 @@ #include "base/trace_event/trace_event_argument.h" #include "cc/debug/traced_value.h" #include "cc/raster/raster_source.h" -#include "cc/resources/platform_color.h" #include "cc/resources/resource.h" +#include "components/viz/common/resources/platform_color.h" namespace cc { namespace { @@ -100,7 +100,7 @@ void BitmapRasterBufferProvider::Flush() {} -ResourceFormat BitmapRasterBufferProvider::GetResourceFormat( +viz::ResourceFormat BitmapRasterBufferProvider::GetResourceFormat( bool must_support_alpha) const { return resource_provider_->best_texture_format(); }
diff --git a/cc/raster/bitmap_raster_buffer_provider.h b/cc/raster/bitmap_raster_buffer_provider.h index 4f130136..267a079 100644 --- a/cc/raster/bitmap_raster_buffer_provider.h +++ b/cc/raster/bitmap_raster_buffer_provider.h
@@ -35,7 +35,7 @@ void ReleaseBufferForRaster(std::unique_ptr<RasterBuffer> buffer) override; void OrderingBarrier() override; void Flush() override; - ResourceFormat GetResourceFormat(bool must_support_alpha) const override; + viz::ResourceFormat GetResourceFormat(bool must_support_alpha) const override; bool IsResourceSwizzleRequired(bool must_support_alpha) const override; bool CanPartialRasterIntoProvidedResource() const override; bool IsResourceReadyToDraw(ResourceId id) const override;
diff --git a/cc/raster/gpu_raster_buffer_provider.cc b/cc/raster/gpu_raster_buffer_provider.cc index 1f2e8802..24947cf 100644 --- a/cc/raster/gpu_raster_buffer_provider.cc +++ b/cc/raster/gpu_raster_buffer_provider.cc
@@ -120,7 +120,7 @@ ResourceProvider* resource_provider, bool use_distance_field_text, int gpu_rasterization_msaa_sample_count, - ResourceFormat preferred_tile_format, + viz::ResourceFormat preferred_tile_format, bool async_worker_context_enabled) : compositor_context_provider_(compositor_context_provider), worker_context_provider_(worker_context_provider), @@ -185,7 +185,7 @@ } } -ResourceFormat GpuRasterBufferProvider::GetResourceFormat( +viz::ResourceFormat GpuRasterBufferProvider::GetResourceFormat( bool must_support_alpha) const { if (resource_provider_->IsRenderBufferFormatSupported( preferred_tile_format_) &&
diff --git a/cc/raster/gpu_raster_buffer_provider.h b/cc/raster/gpu_raster_buffer_provider.h index d699795..7c194d2 100644 --- a/cc/raster/gpu_raster_buffer_provider.h +++ b/cc/raster/gpu_raster_buffer_provider.h
@@ -22,7 +22,7 @@ ResourceProvider* resource_provider, bool use_distance_field_text, int gpu_rasterization_msaa_sample_count, - ResourceFormat preferred_tile_format, + viz::ResourceFormat preferred_tile_format, bool async_worker_context_enabled); ~GpuRasterBufferProvider() override; @@ -34,7 +34,7 @@ void ReleaseBufferForRaster(std::unique_ptr<RasterBuffer> buffer) override; void OrderingBarrier() override; void Flush() override; - ResourceFormat GetResourceFormat(bool must_support_alpha) const override; + viz::ResourceFormat GetResourceFormat(bool must_support_alpha) const override; bool IsResourceSwizzleRequired(bool must_support_alpha) const override; bool CanPartialRasterIntoProvidedResource() const override; bool IsResourceReadyToDraw(ResourceId id) const override; @@ -93,7 +93,7 @@ ResourceProvider* const resource_provider_; const bool use_distance_field_text_; const int msaa_sample_count_; - const ResourceFormat preferred_tile_format_; + const viz::ResourceFormat preferred_tile_format_; const bool async_worker_context_enabled_; std::set<RasterBufferImpl*> pending_raster_buffers_;
diff --git a/cc/raster/one_copy_raster_buffer_provider.cc b/cc/raster/one_copy_raster_buffer_provider.cc index f662e6c..2ff956c 100644 --- a/cc/raster/one_copy_raster_buffer_provider.cc +++ b/cc/raster/one_copy_raster_buffer_provider.cc
@@ -16,10 +16,10 @@ #include "base/trace_event/trace_event.h" #include "cc/base/histograms.h" #include "cc/base/math_util.h" -#include "cc/resources/platform_color.h" -#include "cc/resources/resource_format.h" #include "cc/resources/resource_util.h" #include "cc/resources/scoped_resource.h" +#include "components/viz/common/quads/resource_format.h" +#include "components/viz/common/resources/platform_color.h" #include "gpu/GLES2/gl2extchromium.h" #include "gpu/command_buffer/client/context_support.h" #include "gpu/command_buffer/client/gles2_interface.h" @@ -74,7 +74,7 @@ int max_copy_texture_chromium_size, bool use_partial_raster, int max_staging_buffer_usage_in_bytes, - ResourceFormat preferred_tile_format, + viz::ResourceFormat preferred_tile_format, bool async_worker_context_enabled) : compositor_context_provider_(compositor_context_provider), worker_context_provider_(worker_context_provider), @@ -150,7 +150,7 @@ } } -ResourceFormat OneCopyRasterBufferProvider::GetResourceFormat( +viz::ResourceFormat OneCopyRasterBufferProvider::GetResourceFormat( bool must_support_alpha) const { if (resource_provider_->IsTextureFormatSupported(preferred_tile_format_) && (DoesResourceFormatSupportAlpha(preferred_tile_format_) ||
diff --git a/cc/raster/one_copy_raster_buffer_provider.h b/cc/raster/one_copy_raster_buffer_provider.h index 581bc49..0ed3bf2 100644 --- a/cc/raster/one_copy_raster_buffer_provider.h +++ b/cc/raster/one_copy_raster_buffer_provider.h
@@ -27,7 +27,7 @@ int max_copy_texture_chromium_size, bool use_partial_raster, int max_staging_buffer_usage_in_bytes, - ResourceFormat preferred_tile_format, + viz::ResourceFormat preferred_tile_format, bool async_worker_context_enabled); ~OneCopyRasterBufferProvider() override; @@ -39,7 +39,7 @@ void ReleaseBufferForRaster(std::unique_ptr<RasterBuffer> buffer) override; void OrderingBarrier() override; void Flush() override; - ResourceFormat GetResourceFormat(bool must_support_alpha) const override; + viz::ResourceFormat GetResourceFormat(bool must_support_alpha) const override; bool IsResourceSwizzleRequired(bool must_support_alpha) const override; bool CanPartialRasterIntoProvidedResource() const override; bool IsResourceReadyToDraw(ResourceId id) const override; @@ -123,7 +123,7 @@ // Context lock must be acquired when accessing this member. int bytes_scheduled_since_last_flush_; - const ResourceFormat preferred_tile_format_; + const viz::ResourceFormat preferred_tile_format_; StagingBufferPool staging_pool_; const bool async_worker_context_enabled_;
diff --git a/cc/raster/raster_buffer_provider.cc b/cc/raster/raster_buffer_provider.cc index f3e2810..fc3ce57e 100644 --- a/cc/raster/raster_buffer_provider.cc +++ b/cc/raster/raster_buffer_provider.cc
@@ -9,8 +9,8 @@ #include "base/trace_event/trace_event.h" #include "cc/raster/raster_source.h" #include "cc/raster/texture_compressor.h" -#include "cc/resources/platform_color.h" -#include "cc/resources/resource_format_utils.h" +#include "components/viz/common/resources/platform_color.h" +#include "components/viz/common/resources/resource_format_utils.h" #include "third_party/skia/include/core/SkCanvas.h" #include "third_party/skia/include/core/SkMath.h" #include "third_party/skia/include/core/SkSurface.h" @@ -76,19 +76,19 @@ CHECK_LE(size, kMaxTotalSize); } -bool IsSupportedPlaybackToMemoryFormat(ResourceFormat format) { +bool IsSupportedPlaybackToMemoryFormat(viz::ResourceFormat format) { switch (format) { - case RGBA_4444: - case RGBA_8888: - case BGRA_8888: - case ETC1: + case viz::RGBA_4444: + case viz::RGBA_8888: + case viz::BGRA_8888: + case viz::ETC1: return true; - case ALPHA_8: - case LUMINANCE_8: - case RGB_565: - case RED_8: - case LUMINANCE_F16: - case RGBA_F16: + case viz::ALPHA_8: + case viz::LUMINANCE_8: + case viz::RGB_565: + case viz::RED_8: + case viz::LUMINANCE_F16: + case viz::RGBA_F16: return false; } NOTREACHED(); @@ -100,7 +100,7 @@ // static void RasterBufferProvider::PlaybackToMemory( void* memory, - ResourceFormat format, + viz::ResourceFormat format, const gfx::Size& size, size_t stride, const RasterSource* raster_source, @@ -130,9 +130,9 @@ DCHECK_GT(stride, 0u); switch (format) { - case RGBA_8888: - case BGRA_8888: - case RGBA_F16: { + case viz::RGBA_8888: + case viz::BGRA_8888: + case viz::RGBA_F16: { CheckValidRasterInfo(info, memory, stride); sk_sp<SkSurface> surface = SkSurface::MakeRasterDirect(info, memory, stride, &surface_props); @@ -142,8 +142,8 @@ transform, playback_settings); return; } - case RGBA_4444: - case ETC1: { + case viz::RGBA_4444: + case viz::ETC1: { sk_sp<SkSurface> surface = SkSurface::MakeRaster(info, &surface_props); // TODO(reveman): Improve partial raster support by reducing the size of // playback rect passed to PlaybackToCanvas. crbug.com/519070 @@ -151,7 +151,7 @@ canvas_bitmap_rect, canvas_bitmap_rect, transform, playback_settings); - if (format == ETC1) { + if (format == viz::ETC1) { TRACE_EVENT0("cc", "RasterBufferProvider::PlaybackToMemory::CompressETC1"); DCHECK_EQ(size.width() % 4, 0); @@ -174,11 +174,11 @@ } return; } - case ALPHA_8: - case LUMINANCE_8: - case RGB_565: - case RED_8: - case LUMINANCE_F16: + case viz::ALPHA_8: + case viz::LUMINANCE_8: + case viz::RGB_565: + case viz::RED_8: + case viz::LUMINANCE_F16: NOTREACHED(); return; } @@ -187,21 +187,21 @@ } bool RasterBufferProvider::ResourceFormatRequiresSwizzle( - ResourceFormat format) { + viz::ResourceFormat format) { switch (format) { - case RGBA_8888: - case BGRA_8888: - // Initialize resource using the preferred PlatformColor component + case viz::RGBA_8888: + case viz::BGRA_8888: + // Initialize resource using the preferred viz::PlatformColor component // order and swizzle in the shader instead of in software. - return !PlatformColor::SameComponentOrder(format); - case RGBA_4444: - case ETC1: - case ALPHA_8: - case LUMINANCE_8: - case RGB_565: - case RED_8: - case LUMINANCE_F16: - case RGBA_F16: + return !viz::PlatformColor::SameComponentOrder(format); + case viz::RGBA_4444: + case viz::ETC1: + case viz::ALPHA_8: + case viz::LUMINANCE_8: + case viz::RGB_565: + case viz::RED_8: + case viz::LUMINANCE_F16: + case viz::RGBA_F16: return false; } NOTREACHED();
diff --git a/cc/raster/raster_buffer_provider.h b/cc/raster/raster_buffer_provider.h index 6055ccd..31117c9 100644 --- a/cc/raster/raster_buffer_provider.h +++ b/cc/raster/raster_buffer_provider.h
@@ -11,8 +11,8 @@ #include "cc/raster/raster_source.h" #include "cc/raster/task_graph_runner.h" #include "cc/raster/tile_task.h" -#include "cc/resources/resource_format.h" #include "cc/resources/resource_provider.h" +#include "components/viz/common/quads/resource_format.h" #include "ui/gfx/geometry/rect.h" #include "ui/gfx/geometry/size.h" @@ -32,7 +32,7 @@ // already partially complete, and only the subrect needs to be played back. static void PlaybackToMemory( void* memory, - ResourceFormat format, + viz::ResourceFormat format, const gfx::Size& size, size_t stride, const RasterSource* raster_source, @@ -59,7 +59,8 @@ virtual void Flush() = 0; // Returns the format to use for the tiles. - virtual ResourceFormat GetResourceFormat(bool must_support_alpha) const = 0; + virtual viz::ResourceFormat GetResourceFormat( + bool must_support_alpha) const = 0; // Determine if the resource requires swizzling. virtual bool IsResourceSwizzleRequired(bool must_support_alpha) const = 0; @@ -87,7 +88,7 @@ protected: // Check if resource format matches output format. - static bool ResourceFormatRequiresSwizzle(ResourceFormat format); + static bool ResourceFormatRequiresSwizzle(viz::ResourceFormat format); }; } // namespace cc
diff --git a/cc/raster/raster_buffer_provider_perftest.cc b/cc/raster/raster_buffer_provider_perftest.cc index 4fdb265..7a6fc82 100644 --- a/cc/raster/raster_buffer_provider_perftest.cc +++ b/cc/raster/raster_buffer_provider_perftest.cc
@@ -18,7 +18,6 @@ #include "cc/raster/raster_buffer_provider.h" #include "cc/raster/synchronous_task_graph_runner.h" #include "cc/raster/zero_copy_raster_buffer_provider.h" -#include "cc/resources/platform_color.h" #include "cc/resources/resource_pool.h" #include "cc/resources/resource_provider.h" #include "cc/resources/scoped_resource.h" @@ -29,6 +28,7 @@ #include "cc/test/test_shared_bitmap_manager.h" #include "cc/test/test_web_graphics_context_3d.h" #include "cc/tiles/tile_task_manager.h" +#include "components/viz/common/resources/platform_color.h" #include "gpu/command_buffer/common/sync_token.h" #include "testing/gtest/include/gtest/gtest.h" #include "testing/perf/perf_test.h" @@ -245,7 +245,7 @@ auto resource = base::MakeUnique<ScopedResource>(resource_provider_.get()); resource->Allocate(size, ResourceProvider::TEXTURE_HINT_IMMUTABLE, - RGBA_8888, gfx::ColorSpace()); + viz::RGBA_8888, gfx::ColorSpace()); // No tile ids are given to support partial updates. std::unique_ptr<RasterBuffer> raster_buffer; @@ -326,7 +326,7 @@ case RASTER_BUFFER_PROVIDER_TYPE_ZERO_COPY: Create3dResourceProvider(); raster_buffer_provider_ = ZeroCopyRasterBufferProvider::Create( - resource_provider_.get(), PlatformColor::BestTextureFormat()); + resource_provider_.get(), viz::PlatformColor::BestTextureFormat()); break; case RASTER_BUFFER_PROVIDER_TYPE_ONE_COPY: Create3dResourceProvider(); @@ -334,15 +334,15 @@ task_runner_.get(), compositor_context_provider_.get(), worker_context_provider_.get(), resource_provider_.get(), std::numeric_limits<int>::max(), false, - std::numeric_limits<int>::max(), PlatformColor::BestTextureFormat(), - false); + std::numeric_limits<int>::max(), + viz::PlatformColor::BestTextureFormat(), false); break; case RASTER_BUFFER_PROVIDER_TYPE_GPU: Create3dResourceProvider(); raster_buffer_provider_ = base::MakeUnique<GpuRasterBufferProvider>( compositor_context_provider_.get(), worker_context_provider_.get(), resource_provider_.get(), false, 0, - PlatformColor::BestTextureFormat(), false); + viz::PlatformColor::BestTextureFormat(), false); break; case RASTER_BUFFER_PROVIDER_TYPE_BITMAP: CreateSoftwareResourceProvider();
diff --git a/cc/raster/raster_buffer_provider_unittest.cc b/cc/raster/raster_buffer_provider_unittest.cc index ea4cdff..737016dd 100644 --- a/cc/raster/raster_buffer_provider_unittest.cc +++ b/cc/raster/raster_buffer_provider_unittest.cc
@@ -25,7 +25,6 @@ #include "cc/raster/one_copy_raster_buffer_provider.h" #include "cc/raster/synchronous_task_graph_runner.h" #include "cc/raster/zero_copy_raster_buffer_provider.h" -#include "cc/resources/platform_color.h" #include "cc/resources/resource_pool.h" #include "cc/resources/resource_provider.h" #include "cc/resources/scoped_resource.h" @@ -36,6 +35,7 @@ #include "cc/test/test_shared_bitmap_manager.h" #include "cc/test/test_web_graphics_context_3d.h" #include "cc/tiles/tile_task_manager.h" +#include "components/viz/common/resources/platform_color.h" #include "gpu/GLES2/gl2extchromium.h" #include "testing/gtest/include/gtest/gtest.h" #include "ui/gfx/geometry/axis_transform2d.h" @@ -162,7 +162,7 @@ case RASTER_BUFFER_PROVIDER_TYPE_ZERO_COPY: Create3dResourceProvider(); raster_buffer_provider_ = ZeroCopyRasterBufferProvider::Create( - resource_provider_.get(), PlatformColor::BestTextureFormat()); + resource_provider_.get(), viz::PlatformColor::BestTextureFormat()); break; case RASTER_BUFFER_PROVIDER_TYPE_ONE_COPY: Create3dResourceProvider(); @@ -170,7 +170,7 @@ base::ThreadTaskRunnerHandle::Get().get(), context_provider_.get(), worker_context_provider_.get(), resource_provider_.get(), kMaxBytesPerCopyOperation, false, kMaxStagingBuffers, - PlatformColor::BestTextureFormat(), false); + viz::PlatformColor::BestTextureFormat(), false); break; case RASTER_BUFFER_PROVIDER_TYPE_ASYNC_ONE_COPY: Create3dResourceProvider(); @@ -178,21 +178,21 @@ base::ThreadTaskRunnerHandle::Get().get(), context_provider_.get(), worker_context_provider_.get(), resource_provider_.get(), kMaxBytesPerCopyOperation, false, kMaxStagingBuffers, - PlatformColor::BestTextureFormat(), true); + viz::PlatformColor::BestTextureFormat(), true); break; case RASTER_BUFFER_PROVIDER_TYPE_GPU: Create3dResourceProvider(); raster_buffer_provider_ = base::MakeUnique<GpuRasterBufferProvider>( context_provider_.get(), worker_context_provider_.get(), resource_provider_.get(), false, 0, - PlatformColor::BestTextureFormat(), false); + viz::PlatformColor::BestTextureFormat(), false); break; case RASTER_BUFFER_PROVIDER_TYPE_ASYNC_GPU: Create3dResourceProvider(); raster_buffer_provider_ = base::MakeUnique<GpuRasterBufferProvider>( context_provider_.get(), worker_context_provider_.get(), resource_provider_.get(), false, 0, - PlatformColor::BestTextureFormat(), true); + viz::PlatformColor::BestTextureFormat(), true); break; case RASTER_BUFFER_PROVIDER_TYPE_BITMAP: CreateSoftwareResourceProvider(); @@ -242,7 +242,7 @@ void AppendTask(unsigned id, const gfx::Size& size) { auto resource = base::MakeUnique<ScopedResource>(resource_provider_.get()); resource->Allocate(size, ResourceProvider::TEXTURE_HINT_IMMUTABLE, - RGBA_8888, gfx::ColorSpace()); + viz::RGBA_8888, gfx::ColorSpace()); // The raster buffer has no tile ids associated with it for partial update, // so doesn't need to provide a valid dirty rect. @@ -261,7 +261,7 @@ auto resource = base::MakeUnique<ScopedResource>(resource_provider_.get()); resource->Allocate(size, ResourceProvider::TEXTURE_HINT_IMMUTABLE, - RGBA_8888, gfx::ColorSpace()); + viz::RGBA_8888, gfx::ColorSpace()); std::unique_ptr<RasterBuffer> raster_buffer = raster_buffer_provider_->AcquireBufferForRaster(resource.get(), 0, 0);
diff --git a/cc/raster/raster_source_unittest.cc b/cc/raster/raster_source_unittest.cc index c75fcb8..d4c87821 100644 --- a/cc/raster/raster_source_unittest.cc +++ b/cc/raster/raster_source_unittest.cc
@@ -509,7 +509,7 @@ scoped_refptr<RasterSource> raster_source = recording_source->CreateRasterSource(can_use_lcd); SoftwareImageDecodeCache controller( - ResourceFormat::RGBA_8888, + viz::ResourceFormat::RGBA_8888, LayerTreeSettings().decoded_image_working_set_budget_bytes); raster_source->set_image_decode_cache(&controller);
diff --git a/cc/raster/staging_buffer_pool.cc b/cc/raster/staging_buffer_pool.cc index 450c740..69cd406 100644 --- a/cc/raster/staging_buffer_pool.cc +++ b/cc/raster/staging_buffer_pool.cc
@@ -61,7 +61,7 @@ } // namespace -StagingBuffer::StagingBuffer(const gfx::Size& size, ResourceFormat format) +StagingBuffer::StagingBuffer(const gfx::Size& size, viz::ResourceFormat format) : size(size), format(format), texture_id(0), @@ -91,7 +91,7 @@ } void StagingBuffer::OnMemoryDump(base::trace_event::ProcessMemoryDump* pmd, - ResourceFormat format, + viz::ResourceFormat format, bool in_free_list) const { if (!gpu_memory_buffer) return; @@ -215,7 +215,7 @@ } void StagingBufferPool::AddStagingBuffer(const StagingBuffer* staging_buffer, - ResourceFormat format) { + viz::ResourceFormat format) { lock_.AssertAcquired(); DCHECK(buffers_.find(staging_buffer) == buffers_.end());
diff --git a/cc/raster/staging_buffer_pool.h b/cc/raster/staging_buffer_pool.h index 32edc4f..0591cca 100644 --- a/cc/raster/staging_buffer_pool.h +++ b/cc/raster/staging_buffer_pool.h
@@ -31,16 +31,16 @@ class Resource; struct StagingBuffer { - StagingBuffer(const gfx::Size& size, ResourceFormat format); + StagingBuffer(const gfx::Size& size, viz::ResourceFormat format); ~StagingBuffer(); void DestroyGLResources(gpu::gles2::GLES2Interface* gl); void OnMemoryDump(base::trace_event::ProcessMemoryDump* pmd, - ResourceFormat format, + viz::ResourceFormat format, bool is_free) const; const gfx::Size size; - const ResourceFormat format; + const viz::ResourceFormat format; std::unique_ptr<gfx::GpuMemoryBuffer> gpu_memory_buffer; base::TimeTicks last_usage; unsigned texture_id; @@ -74,7 +74,7 @@ private: void AddStagingBuffer(const StagingBuffer* staging_buffer, - ResourceFormat format); + viz::ResourceFormat format); void RemoveStagingBuffer(const StagingBuffer* staging_buffer); void MarkStagingBufferAsFree(const StagingBuffer* staging_buffer); void MarkStagingBufferAsBusy(const StagingBuffer* staging_buffer);
diff --git a/cc/raster/zero_copy_raster_buffer_provider.cc b/cc/raster/zero_copy_raster_buffer_provider.cc index 9542fe4a..acb6b52 100644 --- a/cc/raster/zero_copy_raster_buffer_provider.cc +++ b/cc/raster/zero_copy_raster_buffer_provider.cc
@@ -14,8 +14,8 @@ #include "base/trace_event/trace_event.h" #include "base/trace_event/trace_event_argument.h" #include "cc/debug/traced_value.h" -#include "cc/resources/platform_color.h" #include "cc/resources/resource.h" +#include "components/viz/common/resources/platform_color.h" #include "ui/gfx/buffer_format_util.h" #include "ui/gfx/gpu_memory_buffer.h" @@ -68,7 +68,7 @@ // static std::unique_ptr<RasterBufferProvider> ZeroCopyRasterBufferProvider::Create( ResourceProvider* resource_provider, - ResourceFormat preferred_tile_format) { + viz::ResourceFormat preferred_tile_format) { return base::WrapUnique<RasterBufferProvider>( new ZeroCopyRasterBufferProvider(resource_provider, preferred_tile_format)); @@ -76,7 +76,7 @@ ZeroCopyRasterBufferProvider::ZeroCopyRasterBufferProvider( ResourceProvider* resource_provider, - ResourceFormat preferred_tile_format) + viz::ResourceFormat preferred_tile_format) : resource_provider_(resource_provider), preferred_tile_format_(preferred_tile_format) {} @@ -102,7 +102,7 @@ void ZeroCopyRasterBufferProvider::Flush() {} -ResourceFormat ZeroCopyRasterBufferProvider::GetResourceFormat( +viz::ResourceFormat ZeroCopyRasterBufferProvider::GetResourceFormat( bool must_support_alpha) const { if (resource_provider_->IsTextureFormatSupported(preferred_tile_format_) && (DoesResourceFormatSupportAlpha(preferred_tile_format_) ||
diff --git a/cc/raster/zero_copy_raster_buffer_provider.h b/cc/raster/zero_copy_raster_buffer_provider.h index 16f2c6bd..db6985d 100644 --- a/cc/raster/zero_copy_raster_buffer_provider.h +++ b/cc/raster/zero_copy_raster_buffer_provider.h
@@ -27,7 +27,7 @@ static std::unique_ptr<RasterBufferProvider> Create( ResourceProvider* resource_provider, - ResourceFormat preferred_tile_format); + viz::ResourceFormat preferred_tile_format); // Overridden from RasterBufferProvider: std::unique_ptr<RasterBuffer> AcquireBufferForRaster( @@ -37,7 +37,7 @@ void ReleaseBufferForRaster(std::unique_ptr<RasterBuffer> buffer) override; void OrderingBarrier() override; void Flush() override; - ResourceFormat GetResourceFormat(bool must_support_alpha) const override; + viz::ResourceFormat GetResourceFormat(bool must_support_alpha) const override; bool IsResourceSwizzleRequired(bool must_support_alpha) const override; bool CanPartialRasterIntoProvidedResource() const override; bool IsResourceReadyToDraw(ResourceId id) const override; @@ -49,14 +49,14 @@ protected: ZeroCopyRasterBufferProvider(ResourceProvider* resource_provider, - ResourceFormat preferred_tile_format); + viz::ResourceFormat preferred_tile_format); private: std::unique_ptr<base::trace_event::ConvertableToTraceFormat> StateAsValue() const; ResourceProvider* resource_provider_; - ResourceFormat preferred_tile_format_; + viz::ResourceFormat preferred_tile_format_; DISALLOW_COPY_AND_ASSIGN(ZeroCopyRasterBufferProvider); };
diff --git a/cc/resources/resource.h b/cc/resources/resource.h index 4dd483e..edae0cc 100644 --- a/cc/resources/resource.h +++ b/cc/resources/resource.h
@@ -16,21 +16,21 @@ class CC_EXPORT Resource { public: - Resource() : id_(0), format_(RGBA_8888) {} + Resource() : id_(0), format_(viz::RGBA_8888) {} Resource(unsigned id, const gfx::Size& size, - ResourceFormat format, + viz::ResourceFormat format, const gfx::ColorSpace& color_space) : id_(id), size_(size), format_(format), color_space_(color_space) {} ResourceId id() const { return id_; } const gfx::Size& size() const { return size_; } - ResourceFormat format() const { return format_; } + viz::ResourceFormat format() const { return format_; } const gfx::ColorSpace& color_space() const { return color_space_; } protected: void set_id(ResourceId id) { id_ = id; } - void set_dimensions(const gfx::Size& size, ResourceFormat format) { + void set_dimensions(const gfx::Size& size, viz::ResourceFormat format) { size_ = size; format_ = format; } @@ -41,7 +41,7 @@ private: ResourceId id_; gfx::Size size_; - ResourceFormat format_; + viz::ResourceFormat format_; gfx::ColorSpace color_space_; DISALLOW_COPY_AND_ASSIGN(Resource);
diff --git a/cc/resources/resource_format.h b/cc/resources/resource_format.h deleted file mode 100644 index 125a4ebf..0000000 --- a/cc/resources/resource_format.h +++ /dev/null
@@ -1,46 +0,0 @@ -// Copyright 2013 The Chromium Authors. All rights reserved. -// Use of this source code is governed by a BSD-style license that can be -// found in the LICENSE file. - -#ifndef CC_RESOURCES_RESOURCE_FORMAT_H_ -#define CC_RESOURCES_RESOURCE_FORMAT_H_ - -#include "base/logging.h" -#include "cc/cc_export.h" -#include "ui/gfx/buffer_types.h" - -// TODO(prashant.n): Including third_party/khronos/GLES2/gl2.h causes -// redefinition errors as macros/functions defined in it conflict with -// macros/functions defined in ui/gl/gl_bindings.h. (http://crbug.com/512833). -typedef unsigned int GLenum; - -namespace cc { - -// Keep in sync with arrays below. -enum ResourceFormat { - RGBA_8888, - RGBA_4444, - BGRA_8888, - ALPHA_8, - LUMINANCE_8, - RGB_565, - ETC1, - RED_8, - LUMINANCE_F16, - RGBA_F16, - RESOURCE_FORMAT_MAX = RGBA_F16, -}; - -CC_EXPORT int BitsPerPixel(ResourceFormat format); -CC_EXPORT GLenum GLDataType(ResourceFormat format); -CC_EXPORT GLenum GLDataFormat(ResourceFormat format); -CC_EXPORT GLenum GLInternalFormat(ResourceFormat format); -CC_EXPORT GLenum GLCopyTextureInternalFormat(ResourceFormat format); -CC_EXPORT gfx::BufferFormat BufferFormat(ResourceFormat format); - -bool IsResourceFormatCompressed(ResourceFormat format); -bool DoesResourceFormatSupportAlpha(ResourceFormat format); - -} // namespace cc - -#endif // CC_RESOURCES_RESOURCE_FORMAT_H_
diff --git a/cc/resources/resource_format_utils.cc b/cc/resources/resource_format_utils.cc deleted file mode 100644 index 8118160..0000000 --- a/cc/resources/resource_format_utils.cc +++ /dev/null
@@ -1,34 +0,0 @@ -// Copyright 2016 The Chromium Authors. All rights reserved. -// Use of this source code is governed by a BSD-style license that can be -// found in the LICENSE file. - -#include "cc/resources/resource_format_utils.h" - -namespace cc { - -SkColorType ResourceFormatToClosestSkColorType(ResourceFormat format) { - // Use kN32_SkColorType if there is no corresponding SkColorType. - switch (format) { - case RGBA_4444: - return kARGB_4444_SkColorType; - case RGBA_8888: - case BGRA_8888: - return kN32_SkColorType; - case ALPHA_8: - return kAlpha_8_SkColorType; - case RGB_565: - return kRGB_565_SkColorType; - case LUMINANCE_8: - return kGray_8_SkColorType; - case ETC1: - case RED_8: - case LUMINANCE_F16: - return kN32_SkColorType; - case RGBA_F16: - return kRGBA_F16_SkColorType; - } - NOTREACHED(); - return kN32_SkColorType; -} - -} // namespace cc
diff --git a/cc/resources/resource_format_utils.h b/cc/resources/resource_format_utils.h deleted file mode 100644 index 200c33c9b..0000000 --- a/cc/resources/resource_format_utils.h +++ /dev/null
@@ -1,17 +0,0 @@ -// Copyright 2016 The Chromium Authors. All rights reserved. -// Use of this source code is governed by a BSD-style license that can be -// found in the LICENSE file. - -#ifndef CC_RESOURCES_RESOURCE_FORMAT_UTILS_H_ -#define CC_RESOURCES_RESOURCE_FORMAT_UTILS_H_ - -#include "cc/resources/resource_format.h" -#include "third_party/skia/include/core/SkImageInfo.h" - -namespace cc { - -SkColorType ResourceFormatToClosestSkColorType(ResourceFormat format); - -} // namespace cc - -#endif // CC_RESOURCES_RESOURCE_FORMAT_UTILS_H_
diff --git a/cc/resources/resource_pool.cc b/cc/resources/resource_pool.cc index 5ad2f6a5..440af64 100644 --- a/cc/resources/resource_pool.cc +++ b/cc/resources/resource_pool.cc
@@ -142,7 +142,7 @@ } Resource* ResourcePool::ReuseResource(const gfx::Size& size, - ResourceFormat format, + viz::ResourceFormat format, const gfx::ColorSpace& color_space) { // Finding resources in |unused_resources_| from MRU to LRU direction, touches // LRU resources only if needed, which increases possibility of expiring more @@ -171,7 +171,7 @@ } Resource* ResourcePool::CreateResource(const gfx::Size& size, - ResourceFormat format, + viz::ResourceFormat format, const gfx::ColorSpace& color_space) { std::unique_ptr<PoolResource> pool_resource = PoolResource::Create(resource_provider_); @@ -203,7 +203,7 @@ } Resource* ResourcePool::AcquireResource(const gfx::Size& size, - ResourceFormat format, + viz::ResourceFormat format, const gfx::ColorSpace& color_space) { Resource* reused_resource = ReuseResource(size, format, color_space); if (reused_resource)
diff --git a/cc/resources/resource_pool.h b/cc/resources/resource_pool.h index 33291874..f1de3eb 100644 --- a/cc/resources/resource_pool.h +++ b/cc/resources/resource_pool.h
@@ -18,8 +18,8 @@ #include "base/trace_event/memory_dump_provider.h" #include "cc/cc_export.h" #include "cc/resources/resource.h" -#include "cc/resources/resource_format.h" #include "cc/resources/scoped_resource.h" +#include "components/viz/common/quads/resource_format.h" namespace cc { @@ -55,7 +55,7 @@ // Tries to reuse a resource. If none are available, makes a new one. Resource* AcquireResource(const gfx::Size& size, - ResourceFormat format, + viz::ResourceFormat format, const gfx::ColorSpace& color_space); // Tries to acquire the resource with |previous_content_id| for us in partial @@ -150,12 +150,12 @@ // Tries to reuse a resource. Returns |nullptr| if none are available. Resource* ReuseResource(const gfx::Size& size, - ResourceFormat format, + viz::ResourceFormat format, const gfx::ColorSpace& color_space); // Creates a new resource without trying to reuse an old one. Resource* CreateResource(const gfx::Size& size, - ResourceFormat format, + viz::ResourceFormat format, const gfx::ColorSpace& color_space); void DidFinishUsingResource(std::unique_ptr<PoolResource> resource);
diff --git a/cc/resources/resource_pool_unittest.cc b/cc/resources/resource_pool_unittest.cc index 34f7aca..a25ab1f 100644 --- a/cc/resources/resource_pool_unittest.cc +++ b/cc/resources/resource_pool_unittest.cc
@@ -49,7 +49,7 @@ TEST_F(ResourcePoolTest, AcquireRelease) { gfx::Size size(100, 100); - ResourceFormat format = RGBA_8888; + viz::ResourceFormat format = viz::RGBA_8888; gfx::ColorSpace color_space = gfx::ColorSpace::CreateSRGB(); Resource* resource = resource_pool_->AcquireResource(size, format, color_space); @@ -67,7 +67,7 @@ resource_pool_->SetResourceUsageLimits(bytes_limit, count_limit); gfx::Size size(100, 100); - ResourceFormat format = RGBA_8888; + viz::ResourceFormat format = viz::RGBA_8888; gfx::ColorSpace color_space = gfx::ColorSpace::CreateSRGB(); size_t resource_bytes = ResourceUtil::UncheckedSizeInBytes<size_t>(size, format); @@ -108,7 +108,7 @@ resource_pool_->SetResourceUsageLimits(bytes_limit, count_limit); gfx::Size size(100, 100); - ResourceFormat format = RGBA_8888; + viz::ResourceFormat format = viz::RGBA_8888; gfx::ColorSpace color_space1; gfx::ColorSpace color_space2 = gfx::ColorSpace::CreateSRGB(); @@ -124,8 +124,8 @@ EXPECT_EQ(1u, resource_provider_->num_resources()); // Different size/format should allocate new resource. - resource = resource_pool_->AcquireResource(gfx::Size(50, 50), LUMINANCE_8, - color_space1); + resource = resource_pool_->AcquireResource(gfx::Size(50, 50), + viz::LUMINANCE_8, color_space1); EXPECT_EQ(2u, resource_provider_->num_resources()); CheckAndReturnResource(resource); EXPECT_EQ(2u, resource_provider_->num_resources()); @@ -144,7 +144,7 @@ resource_pool_->SetResourceUsageLimits(bytes_limit, count_limit); gfx::Size size(100, 100); - ResourceFormat format = RGBA_8888; + viz::ResourceFormat format = viz::RGBA_8888; gfx::ColorSpace color_space = gfx::ColorSpace::CreateSRGB(); Resource* resource = @@ -171,7 +171,7 @@ resource_pool_->SetResourceUsageLimits(bytes_limit, count_limit); gfx::Size size(100, 100); - ResourceFormat format = RGBA_8888; + viz::ResourceFormat format = viz::RGBA_8888; gfx::ColorSpace color_space; Resource* resource = @@ -212,7 +212,7 @@ resource_pool_->SetResourceUsageLimits(bytes_limit, count_limit); gfx::Size size(100, 100); - ResourceFormat format = RGBA_8888; + viz::ResourceFormat format = viz::RGBA_8888; gfx::ColorSpace color_space; Resource* resource = @@ -249,7 +249,7 @@ TEST_F(ResourcePoolTest, UpdateContentId) { gfx::Size size(100, 100); - ResourceFormat format = RGBA_8888; + viz::ResourceFormat format = viz::RGBA_8888; gfx::ColorSpace color_space; uint64_t content_id = 42; uint64_t new_content_id = 43; @@ -273,7 +273,7 @@ TEST_F(ResourcePoolTest, UpdateContentIdAndInvalidatedRect) { gfx::Size size(100, 100); - ResourceFormat format = RGBA_8888; + viz::ResourceFormat format = viz::RGBA_8888; gfx::ColorSpace color_space; uint64_t content_ids[] = {42, 43, 44}; gfx::Rect invalidated_rect(20, 20, 10, 10); @@ -317,7 +317,7 @@ } TEST_F(ResourcePoolTest, ReuseResource) { - ResourceFormat format = RGBA_8888; + viz::ResourceFormat format = viz::RGBA_8888; gfx::ColorSpace color_space = gfx::ColorSpace::CreateSRGB(); // Create unused resource with size 100x100. @@ -370,7 +370,7 @@ resource_pool_->SetResourceUsageLimits(bytes_limit, count_limit); gfx::Size size(100, 100); - ResourceFormat format = RGBA_8888; + viz::ResourceFormat format = viz::RGBA_8888; gfx::ColorSpace color_space = gfx::ColorSpace::CreateSRGB(); Resource* resource = resource_pool_->AcquireResource(size, format, color_space); @@ -399,7 +399,7 @@ TEST_F(ResourcePoolTest, TextureHintRespected) { gfx::Size size(100, 100); - ResourceFormat format = RGBA_8888; + viz::ResourceFormat format = viz::RGBA_8888; gfx::ColorSpace color_space; resource_pool_ = @@ -421,7 +421,7 @@ } TEST_F(ResourcePoolTest, ExactRequestsRespected) { - ResourceFormat format = RGBA_8888; + viz::ResourceFormat format = viz::RGBA_8888; gfx::ColorSpace color_space = gfx::ColorSpace::CreateSRGB(); resource_pool_ =
diff --git a/cc/resources/resource_provider.cc b/cc/resources/resource_provider.cc index 26975dab..d4feafe 100644 --- a/cc/resources/resource_provider.cc +++ b/cc/resources/resource_provider.cc
@@ -22,11 +22,11 @@ #include "base/threading/thread_task_runner_handle.h" #include "base/trace_event/memory_dump_manager.h" #include "base/trace_event/trace_event.h" -#include "cc/resources/platform_color.h" #include "cc/resources/resource_util.h" #include "cc/resources/returned_resource.h" #include "cc/resources/shared_bitmap_manager.h" #include "cc/resources/transferable_resource.h" +#include "components/viz/common/resources/platform_color.h" #include "gpu/GLES2/gl2extchromium.h" #include "gpu/command_buffer/client/context_support.h" #include "gpu/command_buffer/client/gles2_interface.h" @@ -90,24 +90,24 @@ return type != ResourceProvider::RESOURCE_TYPE_BITMAP; } -GLenum TextureToStorageFormat(ResourceFormat format) { +GLenum TextureToStorageFormat(viz::ResourceFormat format) { GLenum storage_format = GL_RGBA8_OES; switch (format) { - case RGBA_8888: + case viz::RGBA_8888: break; - case BGRA_8888: + case viz::BGRA_8888: storage_format = GL_BGRA8_EXT; break; - case RGBA_F16: + case viz::RGBA_F16: storage_format = GL_RGBA16F_EXT; break; - case RGBA_4444: - case ALPHA_8: - case LUMINANCE_8: - case RGB_565: - case ETC1: - case RED_8: - case LUMINANCE_F16: + case viz::RGBA_4444: + case viz::ALPHA_8: + case viz::LUMINANCE_8: + case viz::RGB_565: + case viz::ETC1: + case viz::RED_8: + case viz::LUMINANCE_F16: NOTREACHED(); break; } @@ -115,34 +115,34 @@ return storage_format; } -bool IsFormatSupportedForStorage(ResourceFormat format, bool use_bgra) { +bool IsFormatSupportedForStorage(viz::ResourceFormat format, bool use_bgra) { switch (format) { - case RGBA_8888: - case RGBA_F16: + case viz::RGBA_8888: + case viz::RGBA_F16: return true; - case BGRA_8888: + case viz::BGRA_8888: return use_bgra; - case RGBA_4444: - case ALPHA_8: - case LUMINANCE_8: - case RGB_565: - case ETC1: - case RED_8: - case LUMINANCE_F16: + case viz::RGBA_4444: + case viz::ALPHA_8: + case viz::LUMINANCE_8: + case viz::RGB_565: + case viz::ETC1: + case viz::RED_8: + case viz::LUMINANCE_F16: return false; } return false; } -GrPixelConfig ToGrPixelConfig(ResourceFormat format) { +GrPixelConfig ToGrPixelConfig(viz::ResourceFormat format) { switch (format) { - case RGBA_8888: + case viz::RGBA_8888: return kRGBA_8888_GrPixelConfig; - case BGRA_8888: + case viz::BGRA_8888: return kBGRA_8888_GrPixelConfig; - case RGBA_4444: + case viz::RGBA_4444: return kRGBA_4444_GrPixelConfig; - case RGBA_F16: + case viz::RGBA_F16: return kRGBA_half_GrPixelConfig; default: break; @@ -187,7 +187,7 @@ GLenum filter, TextureHint hint, ResourceType type, - ResourceFormat format) + viz::ResourceFormat format) : child_id(0), gl_id(texture_id), gl_pixel_buffer_id(0), @@ -262,7 +262,7 @@ hint(TEXTURE_HINT_IMMUTABLE), type(RESOURCE_TYPE_BITMAP), buffer_format(gfx::BufferFormat::RGBA_8888), - format(RGBA_8888), + format(viz::RGBA_8888), shared_bitmap(bitmap) { DCHECK(origin == DELEGATED || pixels); if (bitmap) @@ -305,7 +305,7 @@ hint(TEXTURE_HINT_IMMUTABLE), type(RESOURCE_TYPE_BITMAP), buffer_format(gfx::BufferFormat::RGBA_8888), - format(RGBA_8888), + format(viz::RGBA_8888), shared_bitmap_id(bitmap_id), shared_bitmap(nullptr) { } @@ -379,7 +379,7 @@ default_resource_type = RESOURCE_TYPE_BITMAP; // Pick an arbitrary limit here similar to what hardware might. max_texture_size = 16 * 1024; - best_texture_format = RGBA_8888; + best_texture_format = viz::RGBA_8888; return; } @@ -392,19 +392,20 @@ use_sync_query = caps.sync_query; if (caps.disable_one_component_textures) { - yuv_resource_format = yuv_highbit_resource_format = RGBA_8888; + yuv_resource_format = yuv_highbit_resource_format = viz::RGBA_8888; } else { - yuv_resource_format = caps.texture_rg ? RED_8 : LUMINANCE_8; - yuv_highbit_resource_format = - caps.texture_half_float_linear ? LUMINANCE_F16 : yuv_resource_format; + yuv_resource_format = caps.texture_rg ? viz::RED_8 : viz::LUMINANCE_8; + yuv_highbit_resource_format = caps.texture_half_float_linear + ? viz::LUMINANCE_F16 + : yuv_resource_format; } GLES2Interface* gl = compositor_context_provider->ContextGL(); gl->GetIntegerv(GL_MAX_TEXTURE_SIZE, &max_texture_size); best_texture_format = - PlatformColor::BestSupportedTextureFormat(use_texture_format_bgra); - best_render_buffer_format = PlatformColor::BestSupportedTextureFormat( + viz::PlatformColor::BestSupportedTextureFormat(use_texture_format_bgra); + best_render_buffer_format = viz::PlatformColor::BestSupportedTextureFormat( caps.render_buffer_format_bgra8888); } @@ -479,26 +480,27 @@ gl->Finish(); } -bool ResourceProvider::IsTextureFormatSupported(ResourceFormat format) const { +bool ResourceProvider::IsTextureFormatSupported( + viz::ResourceFormat format) const { gpu::Capabilities caps; if (compositor_context_provider_) caps = compositor_context_provider_->ContextCapabilities(); switch (format) { - case ALPHA_8: - case RGBA_4444: - case RGBA_8888: - case RGB_565: - case LUMINANCE_8: + case viz::ALPHA_8: + case viz::RGBA_4444: + case viz::RGBA_8888: + case viz::RGB_565: + case viz::LUMINANCE_8: return true; - case BGRA_8888: + case viz::BGRA_8888: return caps.texture_format_bgra8888; - case ETC1: + case viz::ETC1: return caps.texture_format_etc1; - case RED_8: + case viz::RED_8: return caps.texture_rg; - case LUMINANCE_F16: - case RGBA_F16: + case viz::LUMINANCE_F16: + case viz::RGBA_F16: return caps.texture_half_float_linear; } @@ -507,29 +509,29 @@ } bool ResourceProvider::IsRenderBufferFormatSupported( - ResourceFormat format) const { + viz::ResourceFormat format) const { gpu::Capabilities caps; if (compositor_context_provider_) caps = compositor_context_provider_->ContextCapabilities(); switch (format) { - case RGBA_4444: - case RGBA_8888: - case RGB_565: + case viz::RGBA_4444: + case viz::RGBA_8888: + case viz::RGB_565: return true; - case BGRA_8888: + case viz::BGRA_8888: return caps.render_buffer_format_bgra8888; - case RGBA_F16: + case viz::RGBA_F16: // TODO(ccameron): This will always return false on pixel tests, which // makes it un-test-able until we upgrade Mesa. // https://crbug.com/687720 return caps.texture_half_float_linear && caps.color_buffer_half_float_rgba; - case LUMINANCE_8: - case ALPHA_8: - case RED_8: - case ETC1: - case LUMINANCE_F16: + case viz::LUMINANCE_8: + case viz::ALPHA_8: + case viz::RED_8: + case viz::ETC1: + case viz::LUMINANCE_F16: // We don't currently render into these formats. If we need to render into // these eventually, we should expand this logic. return false; @@ -556,7 +558,7 @@ resource->lost = true; } -ResourceFormat ResourceProvider::YuvResourceFormat(int bits) const { +viz::ResourceFormat ResourceProvider::YuvResourceFormat(int bits) const { if (bits > 8) { return settings_.yuv_highbit_resource_format; } else { @@ -567,13 +569,13 @@ ResourceId ResourceProvider::CreateResource( const gfx::Size& size, TextureHint hint, - ResourceFormat format, + viz::ResourceFormat format, const gfx::ColorSpace& color_space) { DCHECK(!size.IsEmpty()); switch (settings_.default_resource_type) { case RESOURCE_TYPE_GPU_MEMORY_BUFFER: - // GPU memory buffers don't support LUMINANCE_F16 yet. - if (format != LUMINANCE_F16) { + // GPU memory buffers don't support viz::LUMINANCE_F16 yet. + if (format != viz::LUMINANCE_F16) { return CreateGLTexture( size, hint, RESOURCE_TYPE_GPU_MEMORY_BUFFER, format, gfx::BufferUsage::GPU_READ_CPU_READ_WRITE, color_space); @@ -585,7 +587,7 @@ color_space); case RESOURCE_TYPE_BITMAP: - DCHECK_EQ(RGBA_8888, format); + DCHECK_EQ(viz::RGBA_8888, format); return CreateBitmap(size, color_space); } @@ -596,7 +598,7 @@ ResourceId ResourceProvider::CreateGpuMemoryBufferResource( const gfx::Size& size, TextureHint hint, - ResourceFormat format, + viz::ResourceFormat format, gfx::BufferUsage usage, const gfx::ColorSpace& color_space) { DCHECK(!size.IsEmpty()); @@ -607,7 +609,7 @@ format, usage, color_space); } case RESOURCE_TYPE_BITMAP: - DCHECK_EQ(RGBA_8888, format); + DCHECK_EQ(viz::RGBA_8888, format); return CreateBitmap(size, color_space); } @@ -619,7 +621,7 @@ const gfx::Size& size, TextureHint hint, ResourceType type, - ResourceFormat format, + viz::ResourceFormat format, gfx::BufferUsage usage, const gfx::ColorSpace& color_space) { DCHECK_LE(size.width(), settings_.max_texture_size); @@ -672,11 +674,11 @@ Resource* resource = nullptr; if (mailbox.IsTexture()) { resource = InsertResource( - id, - Resource(0, mailbox.size_in_pixels(), Resource::EXTERNAL, - mailbox.target(), - mailbox.nearest_neighbor() ? GL_NEAREST : GL_LINEAR, - TEXTURE_HINT_IMMUTABLE, RESOURCE_TYPE_GL_TEXTURE, RGBA_8888)); + id, Resource(0, mailbox.size_in_pixels(), Resource::EXTERNAL, + mailbox.target(), + mailbox.nearest_neighbor() ? GL_NEAREST : GL_LINEAR, + TEXTURE_HINT_IMMUTABLE, RESOURCE_TYPE_GL_TEXTURE, + viz::RGBA_8888)); } else { DCHECK(mailbox.IsSharedMemory()); SharedBitmap* shared_bitmap = mailbox.shared_bitmap(); @@ -889,7 +891,7 @@ if (resource->type == RESOURCE_TYPE_BITMAP) { DCHECK_EQ(RESOURCE_TYPE_BITMAP, resource->type); DCHECK(resource->allocated); - DCHECK_EQ(RGBA_8888, resource->format); + DCHECK_EQ(viz::RGBA_8888, resource->format); SkImageInfo source_info = SkImageInfo::MakeN32Premul(image_size.width(), image_size.height()); size_t image_stride = image_size.width() * 4; @@ -906,10 +908,11 @@ GLES2Interface* gl = ContextGL(); DCHECK(gl); gl->BindTexture(resource->target, resource_texture_id); - if (resource->format == ETC1) { + if (resource->format == viz::ETC1) { DCHECK_EQ(resource->target, static_cast<GLenum>(GL_TEXTURE_2D)); - int image_bytes = ResourceUtil::CheckedSizeInBytes<int>(image_size, ETC1); - gl->CompressedTexImage2D(resource->target, 0, GLInternalFormat(ETC1), + int image_bytes = + ResourceUtil::CheckedSizeInBytes<int>(image_size, viz::ETC1); + gl->CompressedTexImage2D(resource->target, 0, GLInternalFormat(viz::ETC1), image_size.width(), image_size.height(), 0, image_bytes, image); } else { @@ -1208,7 +1211,7 @@ void ResourceProvider::PopulateSkBitmapWithResource(SkBitmap* sk_bitmap, const Resource* resource) { - DCHECK_EQ(RGBA_8888, resource->format); + DCHECK_EQ(viz::RGBA_8888, resource->format); SkImageInfo info = SkImageInfo::MakeN32Premul(resource->size.width(), resource->size.height()); sk_bitmap->installPixels(info, resource->pixels, info.minRowBytes()); @@ -1932,7 +1935,7 @@ resource->allocated = true; GLES2Interface* gl = ContextGL(); gfx::Size& size = resource->size; - ResourceFormat format = resource->format; + viz::ResourceFormat format = resource->format; gl->BindTexture(resource->target, resource->gl_id); if (resource->type == RESOURCE_TYPE_GPU_MEMORY_BUFFER) { resource->gpu_memory_buffer = @@ -1961,8 +1964,8 @@ gl->TexStorage2DEXT(resource->target, 1, storage_format, size.width(), size.height()); } else { - // ETC1 does not support preallocation. - if (format != ETC1) { + // viz::ETC1 does not support preallocation. + if (format != viz::ETC1) { gl->TexImage2D(resource->target, 0, GLInternalFormat(format), size.width(), size.height(), 0, GLDataFormat(format), GLDataType(format), nullptr); @@ -2033,7 +2036,7 @@ } GLenum ResourceProvider::GetImageTextureTarget(gfx::BufferUsage usage, - ResourceFormat format) { + viz::ResourceFormat format) { gfx::BufferFormat buffer_format = BufferFormat(format); auto found = buffer_to_texture_target_map_.find( BufferToTextureTargetKey(usage, buffer_format));
diff --git a/cc/resources/resource_provider.h b/cc/resources/resource_provider.h index 6f9a5038..49b27250 100644 --- a/cc/resources/resource_provider.h +++ b/cc/resources/resource_provider.h
@@ -30,13 +30,13 @@ #include "cc/output/output_surface.h" #include "cc/output/renderer_settings.h" #include "cc/resources/release_callback_impl.h" -#include "cc/resources/resource_format.h" #include "cc/resources/resource_settings.h" #include "cc/resources/return_callback.h" #include "cc/resources/shared_bitmap.h" #include "cc/resources/single_release_callback_impl.h" #include "cc/resources/texture_mailbox.h" #include "cc/resources/transferable_resource.h" +#include "components/viz/common/quads/resource_format.h" #include "third_party/khronos/GLES2/gl2.h" #include "third_party/khronos/GLES2/gl2ext.h" #include "third_party/skia/include/core/SkBitmap.h" @@ -95,24 +95,24 @@ void DidLoseContextProvider() { lost_context_provider_ = true; } int max_texture_size() const { return settings_.max_texture_size; } - ResourceFormat best_texture_format() const { + viz::ResourceFormat best_texture_format() const { return settings_.best_texture_format; } - ResourceFormat best_render_buffer_format() const { + viz::ResourceFormat best_render_buffer_format() const { return settings_.best_render_buffer_format; } - ResourceFormat YuvResourceFormat(int bits) const; + viz::ResourceFormat YuvResourceFormat(int bits) const; bool use_sync_query() const { return settings_.use_sync_query; } gpu::GpuMemoryBufferManager* gpu_memory_buffer_manager() { return gpu_memory_buffer_manager_; } size_t num_resources() const { return resources_.size(); } - bool IsTextureFormatSupported(ResourceFormat format) const; + bool IsTextureFormatSupported(viz::ResourceFormat format) const; // Returns true if the provided |format| can be used as a render buffer. // Note that render buffer support implies texture support. - bool IsRenderBufferFormatSupported(ResourceFormat format) const; + bool IsRenderBufferFormatSupported(viz::ResourceFormat format) const; // Checks whether a resource is in use by a consumer. bool InUseByConsumer(ResourceId id); @@ -135,14 +135,14 @@ // Creates a resource of the default resource type. ResourceId CreateResource(const gfx::Size& size, TextureHint hint, - ResourceFormat format, + viz::ResourceFormat format, const gfx::ColorSpace& color_space); // Creates a resource for a particular texture target (the distinction between // texture targets has no effect in software mode). ResourceId CreateGpuMemoryBufferResource(const gfx::Size& size, TextureHint hint, - ResourceFormat format, + viz::ResourceFormat format, gfx::BufferUsage usage, const gfx::ColorSpace& color_space); @@ -287,7 +287,7 @@ unsigned texture_id() const { return texture_id_; } GLenum target() const { return target_; } - ResourceFormat format() const { return format_; } + viz::ResourceFormat format() const { return format_; } const gfx::Size& size() const { return size_; } // Will return the invalid color space unless // |enable_color_correct_rasterization| is true. @@ -309,7 +309,7 @@ ResourceId resource_id_; unsigned texture_id_; GLenum target_; - ResourceFormat format_; + viz::ResourceFormat format_; gfx::Size size_; TextureMailbox mailbox_; gpu::SyncToken sync_token_; @@ -435,7 +435,7 @@ private: ResourceProvider* resource_provider_; ResourceId resource_id_; - ResourceFormat format_; + viz::ResourceFormat format_; gfx::BufferUsage usage_; gfx::Size size_; std::unique_ptr<gfx::GpuMemoryBuffer> gpu_memory_buffer_; @@ -536,7 +536,8 @@ void ValidateResource(ResourceId id) const; - GLenum GetImageTextureTarget(gfx::BufferUsage usage, ResourceFormat format); + GLenum GetImageTextureTarget(gfx::BufferUsage usage, + viz::ResourceFormat format); // base::trace_event::MemoryDumpProvider implementation. bool OnMemoryDump(const base::trace_event::MemoryDumpArgs& args, @@ -587,7 +588,7 @@ GLenum filter, TextureHint hint, ResourceType type, - ResourceFormat format); + viz::ResourceFormat format); Resource(uint8_t* pixels, SharedBitmap* bitmap, const gfx::Size& size, @@ -669,13 +670,13 @@ // be used. gfx::BufferUsage usage; // This is the the actual format of the underlaying GpuMemoryBuffer, if any, - // and might not correspond to ResourceFormat. This format is needed to + // and might not correspond to viz::ResourceFormat. This format is needed to // scanout the buffer as HW overlay. gfx::BufferFormat buffer_format; // Resource format is the format as seen from the compositor and might not // correspond to buffer_format (e.g: A resouce that was created from a YUV // buffer could be seen as RGB from the compositor/GL.) - ResourceFormat format; + viz::ResourceFormat format; SharedBitmapId shared_bitmap_id; SharedBitmap* shared_bitmap; std::unique_ptr<gfx::GpuMemoryBuffer> gpu_memory_buffer; @@ -709,7 +710,7 @@ ResourceId CreateGLTexture(const gfx::Size& size, TextureHint hint, ResourceType type, - ResourceFormat format, + viz::ResourceFormat format, gfx::BufferUsage usage, const gfx::ColorSpace& color_space); ResourceId CreateBitmap(const gfx::Size& size, @@ -773,10 +774,10 @@ bool use_texture_usage_hint = false; bool use_sync_query = false; ResourceType default_resource_type = RESOURCE_TYPE_GL_TEXTURE; - ResourceFormat yuv_resource_format = LUMINANCE_8; - ResourceFormat yuv_highbit_resource_format = LUMINANCE_8; - ResourceFormat best_texture_format = RGBA_8888; - ResourceFormat best_render_buffer_format = RGBA_8888; + viz::ResourceFormat yuv_resource_format = viz::LUMINANCE_8; + viz::ResourceFormat yuv_highbit_resource_format = viz::LUMINANCE_8; + viz::ResourceFormat best_texture_format = viz::RGBA_8888; + viz::ResourceFormat best_render_buffer_format = viz::RGBA_8888; bool enable_color_correct_rasterization = false; bool delegated_sync_points_required = false; } const settings_;
diff --git a/cc/resources/resource_provider_unittest.cc b/cc/resources/resource_provider_unittest.cc index 3ba950a..b8b9df6 100644 --- a/cc/resources/resource_provider_unittest.cc +++ b/cc/resources/resource_provider_unittest.cc
@@ -28,6 +28,7 @@ #include "cc/test/test_texture.h" #include "cc/test/test_web_graphics_context_3d.h" #include "cc/trees/blocking_task_runner.h" +#include "components/viz/common/resources/resource_format_utils.h" #include "gpu/GLES2/gl2extchromium.h" #include "testing/gmock/include/gmock/gmock.h" #include "testing/gtest/include/gtest/gtest.h" @@ -336,7 +337,7 @@ } void GetPixels(const gfx::Size& size, - ResourceFormat format, + viz::ResourceFormat format, uint8_t* pixels) { CheckTextureIsBound(GL_TEXTURE_2D); base::AutoLock lock_for_texture_access(namespace_->lock); @@ -353,13 +354,13 @@ private: void AllocateTexture(const gfx::Size& size, GLenum format) { CheckTextureIsBound(GL_TEXTURE_2D); - ResourceFormat texture_format = RGBA_8888; + viz::ResourceFormat texture_format = viz::RGBA_8888; switch (format) { case GL_RGBA: - texture_format = RGBA_8888; + texture_format = viz::RGBA_8888; break; case GL_BGRA_EXT: - texture_format = BGRA_8888; + texture_format = viz::BGRA_8888; break; } base::AutoLock lock_for_texture_access(namespace_->lock); @@ -404,7 +405,7 @@ ResourceProviderContext* context, ResourceId id, const gfx::Size& size, - ResourceFormat format, + viz::ResourceFormat format, uint8_t* pixels) { resource_provider->WaitSyncTokenIfNeeded(id); switch (resource_provider->default_resource_type()) { @@ -553,7 +554,7 @@ DCHECK_EQ(expected_default_type, resource_provider->default_resource_type()); gfx::Size size(1, 1); - ResourceFormat format = RGBA_8888; + viz::ResourceFormat format = viz::RGBA_8888; size_t pixel_size = TextureSizeBytes(size, format); ASSERT_EQ(4U, pixel_size); @@ -585,7 +586,7 @@ TEST_P(ResourceProviderTest, SimpleUpload) { gfx::Size size(2, 2); - ResourceFormat format = RGBA_8888; + viz::ResourceFormat format = viz::RGBA_8888; size_t pixel_size = TextureSizeBytes(size, format); ASSERT_EQ(16U, pixel_size); @@ -620,7 +621,7 @@ if (GetParam() != ResourceProvider::RESOURCE_TYPE_GL_TEXTURE) return; gfx::Size size(1, 1); - ResourceFormat format = RGBA_8888; + viz::ResourceFormat format = viz::RGBA_8888; size_t pixel_size = TextureSizeBytes(size, format); ASSERT_EQ(4U, pixel_size); @@ -995,7 +996,7 @@ TEST_P(ResourceProviderTestNoSyncToken, TransferGLResources) { gfx::Size size(1, 1); - ResourceFormat format = RGBA_8888; + viz::ResourceFormat format = viz::RGBA_8888; size_t pixel_size = TextureSizeBytes(size, format); ASSERT_EQ(4U, pixel_size); @@ -1103,7 +1104,7 @@ if (GetParam() != ResourceProvider::RESOURCE_TYPE_GL_TEXTURE) return; gfx::Size size(1, 1); - ResourceFormat format = RGBA_8888; + viz::ResourceFormat format = viz::RGBA_8888; uint8_t data1[4] = {1, 2, 3, 4}; std::vector<ReturnedResource> returned_to_child; @@ -1161,7 +1162,7 @@ if (GetParam() != ResourceProvider::RESOURCE_TYPE_GL_TEXTURE) return; gfx::Size size(1, 1); - ResourceFormat format = RGBA_8888; + viz::ResourceFormat format = viz::RGBA_8888; ResourceId id1 = child_resource_provider_->CreateResource( size, ResourceProvider::TEXTURE_HINT_IMMUTABLE, format, @@ -1228,7 +1229,7 @@ if (GetParam() != ResourceProvider::RESOURCE_TYPE_GL_TEXTURE) return; gfx::Size size(1, 1); - ResourceFormat format = RGBA_8888; + viz::ResourceFormat format = viz::RGBA_8888; ResourceId id1 = child_resource_provider_->CreateResource( size, ResourceProvider::TEXTURE_HINT_IMMUTABLE, format, @@ -1280,7 +1281,7 @@ if (GetParam() != ResourceProvider::RESOURCE_TYPE_GL_TEXTURE) return; gfx::Size size(1, 1); - ResourceFormat format = RGBA_8888; + viz::ResourceFormat format = viz::RGBA_8888; ResourceId id1 = child_resource_provider_->CreateResource( size, ResourceProvider::TEXTURE_HINT_IMMUTABLE, format, @@ -1345,7 +1346,7 @@ if (GetParam() != ResourceProvider::RESOURCE_TYPE_GL_TEXTURE) return; gfx::Size size(1, 1); - ResourceFormat format = RGBA_8888; + viz::ResourceFormat format = viz::RGBA_8888; ResourceId id1 = child_resource_provider_->CreateResource( size, ResourceProvider::TEXTURE_HINT_IMMUTABLE, format, @@ -1404,7 +1405,7 @@ return; gfx::Size size(1, 1); - ResourceFormat format = RGBA_8888; + viz::ResourceFormat format = viz::RGBA_8888; size_t pixel_size = TextureSizeBytes(size, format); ASSERT_EQ(4U, pixel_size); @@ -1612,7 +1613,7 @@ CreateResourceSettings())); gfx::Size size(1, 1); - ResourceFormat format = RGBA_8888; + viz::ResourceFormat format = viz::RGBA_8888; size_t pixel_size = TextureSizeBytes(size, format); ASSERT_EQ(4U, pixel_size); @@ -1660,7 +1661,7 @@ return; gfx::Size size(1, 1); - ResourceFormat format = RGBA_8888; + viz::ResourceFormat format = viz::RGBA_8888; size_t pixel_size = TextureSizeBytes(size, format); ASSERT_EQ(4U, pixel_size); @@ -1709,7 +1710,7 @@ TEST_P(ResourceProviderTest, DeleteExportedResources) { gfx::Size size(1, 1); - ResourceFormat format = RGBA_8888; + viz::ResourceFormat format = viz::RGBA_8888; size_t pixel_size = TextureSizeBytes(size, format); ASSERT_EQ(4U, pixel_size); @@ -1809,7 +1810,7 @@ TEST_P(ResourceProviderTest, DestroyChildWithExportedResources) { gfx::Size size(1, 1); - ResourceFormat format = RGBA_8888; + viz::ResourceFormat format = viz::RGBA_8888; size_t pixel_size = TextureSizeBytes(size, format); ASSERT_EQ(4U, pixel_size); @@ -1926,7 +1927,7 @@ TEST_P(ResourceProviderTest, DeleteTransferredResources) { gfx::Size size(1, 1); - ResourceFormat format = RGBA_8888; + viz::ResourceFormat format = viz::RGBA_8888; size_t pixel_size = TextureSizeBytes(size, format); ASSERT_EQ(4U, pixel_size); @@ -1979,7 +1980,7 @@ TEST_P(ResourceProviderTest, UnuseTransferredResources) { gfx::Size size(1, 1); - ResourceFormat format = RGBA_8888; + viz::ResourceFormat format = viz::RGBA_8888; size_t pixel_size = TextureSizeBytes(size, format); ASSERT_EQ(4U, pixel_size); @@ -2126,7 +2127,7 @@ resource_settings)); gfx::Size size(1, 1); - ResourceFormat format = RGBA_8888; + viz::ResourceFormat format = viz::RGBA_8888; int child_texture_id = 1; int parent_texture_id = 2; @@ -2317,8 +2318,7 @@ unsigned other_texture = context()->createAndConsumeTextureCHROMIUM(GL_TEXTURE_2D, mailbox.name); uint8_t test_data[4] = { 0 }; - context()->GetPixels( - gfx::Size(1, 1), RGBA_8888, test_data); + context()->GetPixels(gfx::Size(1, 1), viz::RGBA_8888, test_data); EXPECT_EQ(0, memcmp(data, test_data, sizeof(data))); context()->produceTextureDirectCHROMIUM(other_texture, GL_TEXTURE_2D, @@ -2372,8 +2372,7 @@ unsigned other_texture = context()->createAndConsumeTextureCHROMIUM(GL_TEXTURE_2D, mailbox.name); uint8_t test_data[4] = { 0 }; - context()->GetPixels( - gfx::Size(1, 1), RGBA_8888, test_data); + context()->GetPixels(gfx::Size(1, 1), viz::RGBA_8888, test_data); EXPECT_EQ(0, memcmp(data, test_data, sizeof(data))); context()->produceTextureDirectCHROMIUM(other_texture, GL_TEXTURE_2D, @@ -2407,7 +2406,7 @@ TEST_P(ResourceProviderTest, LostResourceInParent) { gfx::Size size(1, 1); - ResourceFormat format = RGBA_8888; + viz::ResourceFormat format = viz::RGBA_8888; ResourceId resource = child_resource_provider_->CreateResource( size, ResourceProvider::TEXTURE_HINT_IMMUTABLE, format, gfx::ColorSpace()); @@ -2463,7 +2462,7 @@ TEST_P(ResourceProviderTest, LostResourceInGrandParent) { gfx::Size size(1, 1); - ResourceFormat format = RGBA_8888; + viz::ResourceFormat format = viz::RGBA_8888; ResourceId resource = child_resource_provider_->CreateResource( size, ResourceProvider::TEXTURE_HINT_IMMUTABLE, format, gfx::ColorSpace()); @@ -2761,7 +2760,7 @@ CreateResourceSettings())); gfx::Size size(1, 1); - ResourceFormat format = RGBA_8888; + viz::ResourceFormat format = viz::RGBA_8888; int texture_id = 1; ResourceId id = resource_provider->CreateResource( @@ -2840,7 +2839,7 @@ CreateResourceSettings())); gfx::Size size(1, 1); - ResourceFormat format = RGBA_8888; + viz::ResourceFormat format = viz::RGBA_8888; int texture_id = 1; // Check that the texture gets created with the right sampler settings. @@ -2883,7 +2882,7 @@ CreateResourceSettings())); gfx::Size size(1, 1); - ResourceFormat format = RGBA_8888; + viz::ResourceFormat format = viz::RGBA_8888; for (int texture_id = 1; texture_id <= 2; ++texture_id) { // Check that the texture gets created with the right sampler settings. @@ -2927,7 +2926,7 @@ CreateResourceSettings())); gfx::Size size(1, 1); - ResourceFormat format = RGBA_8888; + viz::ResourceFormat format = viz::RGBA_8888; const ResourceProvider::TextureHint hints[4] = { ResourceProvider::TEXTURE_HINT_DEFAULT, @@ -3464,7 +3463,7 @@ gfx::Size size(2, 2); gfx::Vector2d offset(0, 0); - ResourceFormat format = RGBA_8888; + viz::ResourceFormat format = viz::RGBA_8888; ResourceId id = 0; uint8_t pixels[16] = { 0 }; int texture_id = 123; @@ -3521,7 +3520,8 @@ gfx::Size size(2, 2); - const ResourceFormat formats[3] = {RGBA_8888, BGRA_8888, RGBA_F16}; + const viz::ResourceFormat formats[3] = {viz::RGBA_8888, viz::BGRA_8888, + viz::RGBA_F16}; const ResourceProvider::TextureHint hints[4] = { ResourceProvider::TEXTURE_HINT_DEFAULT, ResourceProvider::TEXTURE_HINT_IMMUTABLE, @@ -3539,7 +3539,7 @@ bool is_immutable_hint = hints[texture_id - 1] & ResourceProvider::TEXTURE_HINT_IMMUTABLE; bool support_immutable_texture = - is_immutable_hint && formats[i] != BGRA_8888; + is_immutable_hint && formats[i] != viz::BGRA_8888; EXPECT_CALL(*context, texStorage2DEXT(_, _, _, 2, 2)) .Times(support_immutable_texture ? 1 : 0); EXPECT_CALL(*context, texImage2D(_, _, _, 2, 2, _, _, _, _)) @@ -3575,7 +3575,7 @@ CreateResourceSettings())); gfx::Size size(2, 2); - const ResourceFormat formats[2] = {RGBA_8888, BGRA_8888}; + const viz::ResourceFormat formats[2] = {viz::RGBA_8888, viz::BGRA_8888}; const ResourceProvider::TextureHint hints[4] = { ResourceProvider::TEXTURE_HINT_DEFAULT, @@ -3620,7 +3620,7 @@ const int kWidth = 2; const int kHeight = 2; gfx::Size size(kWidth, kHeight); - ResourceFormat format = RGBA_8888; + viz::ResourceFormat format = viz::RGBA_8888; ResourceId id = 0; const unsigned kTextureId = 123u; const unsigned kImageId = 234u; @@ -3712,7 +3712,8 @@ int texture_id = 123; ResourceId id = resource_provider->CreateResource( - size, ResourceProvider::TEXTURE_HINT_IMMUTABLE, ETC1, gfx::ColorSpace()); + size, ResourceProvider::TEXTURE_HINT_IMMUTABLE, viz::ETC1, + gfx::ColorSpace()); EXPECT_NE(0u, id); EXPECT_CALL(*context, NextTextureId()).WillOnce(Return(texture_id)); EXPECT_CALL(*context, bindTexture(GL_TEXTURE_2D, texture_id)).Times(2); @@ -3744,7 +3745,8 @@ uint8_t pixels[8]; ResourceId id = resource_provider->CreateResource( - size, ResourceProvider::TEXTURE_HINT_IMMUTABLE, ETC1, gfx::ColorSpace()); + size, ResourceProvider::TEXTURE_HINT_IMMUTABLE, viz::ETC1, + gfx::ColorSpace()); EXPECT_NE(0u, id); EXPECT_CALL(*context, NextTextureId()).WillOnce(Return(texture_id)); EXPECT_CALL(*context, bindTexture(GL_TEXTURE_2D, texture_id)).Times(3); @@ -3785,7 +3787,7 @@ auto shared_bitmap_manager = base::MakeUnique<TestSharedBitmapManager>(); gfx::Size size(1, 1); - ResourceFormat format = RGBA_8888; + viz::ResourceFormat format = viz::RGBA_8888; { size_t kTextureAllocationChunkSize = 1; @@ -3829,7 +3831,7 @@ return; gfx::Size size(1, 1); - ResourceFormat format = RGBA_8888; + viz::ResourceFormat format = viz::RGBA_8888; // ~Random set of |release_count|s to set on sync tokens. uint64_t release_counts[5] = {7, 3, 10, 2, 5};
diff --git a/cc/resources/resource_util.h b/cc/resources/resource_util.h index 99fd2dc0..161b1aa 100644 --- a/cc/resources/resource_util.h +++ b/cc/resources/resource_util.h
@@ -13,7 +13,8 @@ #include "base/numerics/safe_math.h" #include "cc/base/math_util.h" #include "cc/cc_export.h" -#include "cc/resources/resource_format.h" +#include "components/viz/common/quads/resource_format.h" +#include "components/viz/common/resources/resource_format_utils.h" #include "ui/gfx/geometry/size.h" namespace cc { @@ -22,37 +23,40 @@ public: // Returns true if the width is valid and fits in bytes, false otherwise. template <typename T> - static bool VerifyWidthInBytes(int width, ResourceFormat format); + static bool VerifyWidthInBytes(int width, viz::ResourceFormat format); // Returns true if the size is valid and fits in bytes, false otherwise. template <typename T> - static bool VerifySizeInBytes(const gfx::Size& size, ResourceFormat format); + static bool VerifySizeInBytes(const gfx::Size& size, + viz::ResourceFormat format); // Dies with a CRASH() if the width can not be represented as a positive // number of bytes. template <typename T> - static T CheckedWidthInBytes(int width, ResourceFormat format); + static T CheckedWidthInBytes(int width, viz::ResourceFormat format); // Dies with a CRASH() if the size can not be represented as a positive // number of bytes. template <typename T> - static T CheckedSizeInBytes(const gfx::Size& size, ResourceFormat format); + static T CheckedSizeInBytes(const gfx::Size& size, + viz::ResourceFormat format); // Returns the width in bytes but may overflow or return 0. Only do this for // computing widths for sizes that have already been checked. template <typename T> - static T UncheckedWidthInBytes(int width, ResourceFormat format); + static T UncheckedWidthInBytes(int width, viz::ResourceFormat format); // Returns the size in bytes but may overflow or return 0. Only do this for // sizes that have already been checked. template <typename T> - static T UncheckedSizeInBytes(const gfx::Size& size, ResourceFormat format); + static T UncheckedSizeInBytes(const gfx::Size& size, + viz::ResourceFormat format); // Returns the width in bytes aligned but may overflow or return 0. Only do // this for computing widths for sizes that have already been checked. template <typename T> - static T UncheckedWidthInBytesAligned(int width, ResourceFormat format); + static T UncheckedWidthInBytesAligned(int width, viz::ResourceFormat format); // Returns the size in bytes aligned but may overflow or return 0. Only do // this for sizes that have already been checked. template <typename T> static T UncheckedSizeInBytesAligned(const gfx::Size& size, - ResourceFormat format); + viz::ResourceFormat format); private: template <typename T> @@ -61,14 +65,14 @@ template <typename T> static bool VerifyFitsInBytesInternal(int width, int height, - ResourceFormat format, + viz::ResourceFormat format, bool verify_size, bool aligned); template <typename T> static T BytesInternal(int width, int height, - ResourceFormat format, + viz::ResourceFormat format, bool verify_size, bool aligned); @@ -76,21 +80,21 @@ }; template <typename T> -bool ResourceUtil::VerifyWidthInBytes(int width, ResourceFormat format) { +bool ResourceUtil::VerifyWidthInBytes(int width, viz::ResourceFormat format) { VerifyType<T>(); return VerifyFitsInBytesInternal<T>(width, 0, format, false, false); } template <typename T> bool ResourceUtil::VerifySizeInBytes(const gfx::Size& size, - ResourceFormat format) { + viz::ResourceFormat format) { VerifyType<T>(); return VerifyFitsInBytesInternal<T>(size.width(), size.height(), format, true, false); } template <typename T> -T ResourceUtil::CheckedWidthInBytes(int width, ResourceFormat format) { +T ResourceUtil::CheckedWidthInBytes(int width, viz::ResourceFormat format) { VerifyType<T>(); DCHECK(VerifyFitsInBytesInternal<T>(width, 0, format, false, false)); base::CheckedNumeric<T> checked_value = BitsPerPixel(format); @@ -102,7 +106,7 @@ template <typename T> T ResourceUtil::CheckedSizeInBytes(const gfx::Size& size, - ResourceFormat format) { + viz::ResourceFormat format) { VerifyType<T>(); DCHECK(VerifyFitsInBytesInternal<T>(size.width(), size.height(), format, true, false)); @@ -115,7 +119,7 @@ } template <typename T> -T ResourceUtil::UncheckedWidthInBytes(int width, ResourceFormat format) { +T ResourceUtil::UncheckedWidthInBytes(int width, viz::ResourceFormat format) { VerifyType<T>(); DCHECK(VerifyFitsInBytesInternal<T>(width, 0, format, false, false)); return BytesInternal<T>(width, 0, format, false, false); @@ -123,7 +127,7 @@ template <typename T> T ResourceUtil::UncheckedSizeInBytes(const gfx::Size& size, - ResourceFormat format) { + viz::ResourceFormat format) { VerifyType<T>(); DCHECK(VerifyFitsInBytesInternal<T>(size.width(), size.height(), format, true, false)); @@ -131,7 +135,8 @@ } template <typename T> -T ResourceUtil::UncheckedWidthInBytesAligned(int width, ResourceFormat format) { +T ResourceUtil::UncheckedWidthInBytesAligned(int width, + viz::ResourceFormat format) { VerifyType<T>(); DCHECK(VerifyFitsInBytesInternal<T>(width, 0, format, false, true)); return BytesInternal<T>(width, 0, format, false, true); @@ -139,7 +144,7 @@ template <typename T> T ResourceUtil::UncheckedSizeInBytesAligned(const gfx::Size& size, - ResourceFormat format) { + viz::ResourceFormat format) { VerifyType<T>(); DCHECK(VerifyFitsInBytesInternal<T>(size.width(), size.height(), format, true, true)); @@ -156,7 +161,7 @@ template <typename T> bool ResourceUtil::VerifyFitsInBytesInternal(int width, int height, - ResourceFormat format, + viz::ResourceFormat format, bool verify_size, bool aligned) { base::CheckedNumeric<T> checked_value = BitsPerPixel(format); @@ -193,7 +198,7 @@ template <typename T> T ResourceUtil::BytesInternal(int width, int height, - ResourceFormat format, + viz::ResourceFormat format, bool verify_size, bool aligned) { T bytes = BitsPerPixel(format);
diff --git a/cc/resources/resource_util_unittest.cc b/cc/resources/resource_util_unittest.cc index b159d1d..8bffa6b 100644 --- a/cc/resources/resource_util_unittest.cc +++ b/cc/resources/resource_util_unittest.cc
@@ -12,7 +12,7 @@ namespace { struct TestFormat { - ResourceFormat format; + viz::ResourceFormat format; size_t expected_bytes; size_t expected_bytes_aligned; }; @@ -94,10 +94,10 @@ // Check bytes for even width. int width = 10; TestFormat test_formats[] = { - {RGBA_8888, 40, 40}, // for 32 bits - {RGBA_4444, 20, 20}, // for 16 bits - {ALPHA_8, 10, 12}, // for 8 bits - {ETC1, 5, 8} // for 4 bits + {viz::RGBA_8888, 40, 40}, // for 32 bits + {viz::RGBA_4444, 20, 20}, // for 16 bits + {viz::ALPHA_8, 10, 12}, // for 8 bits + {viz::ETC1, 5, 8} // for 4 bits }; TestVerifyWidthInBytes(width, test_formats); @@ -108,10 +108,10 @@ // Check bytes for odd width. int width_odd = 11; TestFormat test_formats_odd[] = { - {RGBA_8888, 44, 44}, // for 32 bits - {RGBA_4444, 22, 24}, // for 16 bits - {ALPHA_8, 11, 12}, // for 8 bits - {ETC1, 6, 8} // for 4 bits + {viz::RGBA_8888, 44, 44}, // for 32 bits + {viz::RGBA_4444, 22, 24}, // for 16 bits + {viz::ALPHA_8, 11, 12}, // for 8 bits + {viz::ETC1, 6, 8} // for 4 bits }; TestVerifyWidthInBytes(width_odd, test_formats_odd); @@ -124,10 +124,10 @@ // Check bytes for even size. gfx::Size size(10, 10); TestFormat test_formats[] = { - {RGBA_8888, 400, 400}, // for 32 bits - {RGBA_4444, 200, 200}, // for 16 bits - {ALPHA_8, 100, 120}, // for 8 bits - {ETC1, 50, 80} // for 4 bits + {viz::RGBA_8888, 400, 400}, // for 32 bits + {viz::RGBA_4444, 200, 200}, // for 16 bits + {viz::ALPHA_8, 100, 120}, // for 8 bits + {viz::ETC1, 50, 80} // for 4 bits }; TestVerifySizeInBytes(size, test_formats); @@ -138,10 +138,10 @@ // Check bytes for odd size. gfx::Size size_odd(11, 11); TestFormat test_formats_odd[] = { - {RGBA_8888, 484, 484}, // for 32 bits - {RGBA_4444, 242, 264}, // for 16 bits - {ALPHA_8, 121, 132}, // for 8 bits - {ETC1, 66, 88} // for 4 bits + {viz::RGBA_8888, 484, 484}, // for 32 bits + {viz::RGBA_4444, 242, 264}, // for 16 bits + {viz::ALPHA_8, 121, 132}, // for 8 bits + {viz::ETC1, 66, 88} // for 4 bits }; TestVerifySizeInBytes(size_odd, test_formats_odd); @@ -153,16 +153,18 @@ TEST_F(ResourceUtilTest, WidthInBytesOverflow) { int width = 10; // 10 * 16 = 160 bits, overflows in char, but fits in unsigned char. - EXPECT_FALSE(ResourceUtil::VerifyWidthInBytes<signed char>(width, RGBA_4444)); + EXPECT_FALSE( + ResourceUtil::VerifyWidthInBytes<signed char>(width, viz::RGBA_4444)); EXPECT_TRUE( - ResourceUtil::VerifyWidthInBytes<unsigned char>(width, RGBA_4444)); + ResourceUtil::VerifyWidthInBytes<unsigned char>(width, viz::RGBA_4444)); } TEST_F(ResourceUtilTest, SizeInBytesOverflow) { gfx::Size size(10, 10); // 10 * 16 * 10 = 1600 bits, overflows in char, but fits in int. - EXPECT_FALSE(ResourceUtil::VerifySizeInBytes<signed char>(size, RGBA_4444)); - EXPECT_TRUE(ResourceUtil::VerifySizeInBytes<int>(size, RGBA_4444)); + EXPECT_FALSE( + ResourceUtil::VerifySizeInBytes<signed char>(size, viz::RGBA_4444)); + EXPECT_TRUE(ResourceUtil::VerifySizeInBytes<int>(size, viz::RGBA_4444)); } } // namespace
diff --git a/cc/resources/scoped_resource.cc b/cc/resources/scoped_resource.cc index d65150d..75fa38f7 100644 --- a/cc/resources/scoped_resource.cc +++ b/cc/resources/scoped_resource.cc
@@ -17,7 +17,7 @@ void ScopedResource::Allocate(const gfx::Size& size, ResourceProvider::TextureHint hint, - ResourceFormat format, + viz::ResourceFormat format, const gfx::ColorSpace& color_space) { DCHECK(!id()); DCHECK(!size.IsEmpty()); @@ -33,7 +33,7 @@ void ScopedResource::AllocateWithGpuMemoryBuffer( const gfx::Size& size, - ResourceFormat format, + viz::ResourceFormat format, gfx::BufferUsage usage, const gfx::ColorSpace& color_space) { DCHECK(!id());
diff --git a/cc/resources/scoped_resource.h b/cc/resources/scoped_resource.h index 5fda730a..1e0b0eb 100644 --- a/cc/resources/scoped_resource.h +++ b/cc/resources/scoped_resource.h
@@ -26,10 +26,10 @@ void Allocate(const gfx::Size& size, ResourceProvider::TextureHint hint, - ResourceFormat format, + viz::ResourceFormat format, const gfx::ColorSpace& color_space); void AllocateWithGpuMemoryBuffer(const gfx::Size& size, - ResourceFormat format, + viz::ResourceFormat format, gfx::BufferUsage usage, const gfx::ColorSpace& color_space); void Free();
diff --git a/cc/resources/scoped_resource_unittest.cc b/cc/resources/scoped_resource_unittest.cc index b3f71341..cbfbe68 100644 --- a/cc/resources/scoped_resource_unittest.cc +++ b/cc/resources/scoped_resource_unittest.cc
@@ -47,7 +47,7 @@ shared_bitmap_manager.get()); auto texture = base::MakeUnique<ScopedResource>(resource_provider.get()); texture->Allocate(gfx::Size(30, 30), ResourceProvider::TEXTURE_HINT_IMMUTABLE, - RGBA_8888, gfx::ColorSpace()); + viz::RGBA_8888, gfx::ColorSpace()); // The texture has an allocated byte-size now. size_t expected_bytes = 30 * 30 * 4; @@ -55,7 +55,7 @@ texture->size(), texture->format())); EXPECT_LT(0u, texture->id()); - EXPECT_EQ(static_cast<unsigned>(RGBA_8888), texture->format()); + EXPECT_EQ(static_cast<unsigned>(viz::RGBA_8888), texture->format()); EXPECT_EQ(gfx::Size(30, 30), texture->size()); } @@ -74,7 +74,7 @@ EXPECT_EQ(0u, resource_provider->num_resources()); texture->Allocate(gfx::Size(30, 30), - ResourceProvider::TEXTURE_HINT_IMMUTABLE, RGBA_8888, + ResourceProvider::TEXTURE_HINT_IMMUTABLE, viz::RGBA_8888, gfx::ColorSpace()); EXPECT_LT(0u, texture->id()); EXPECT_EQ(1u, resource_provider->num_resources()); @@ -85,7 +85,7 @@ auto texture = base::MakeUnique<ScopedResource>(resource_provider.get()); EXPECT_EQ(0u, resource_provider->num_resources()); texture->Allocate(gfx::Size(30, 30), - ResourceProvider::TEXTURE_HINT_IMMUTABLE, RGBA_8888, + ResourceProvider::TEXTURE_HINT_IMMUTABLE, viz::RGBA_8888, gfx::ColorSpace()); EXPECT_LT(0u, texture->id()); EXPECT_EQ(1u, resource_provider->num_resources());
diff --git a/cc/resources/transferable_resource.cc b/cc/resources/transferable_resource.cc index bfe5652b..d64a0670 100644 --- a/cc/resources/transferable_resource.cc +++ b/cc/resources/transferable_resource.cc
@@ -9,7 +9,7 @@ TransferableResource::TransferableResource() : id(0), - format(RGBA_8888), + format(viz::RGBA_8888), buffer_format(gfx::BufferFormat::RGBA_8888), filter(0), read_lock_fences_enabled(false),
diff --git a/cc/resources/transferable_resource.h b/cc/resources/transferable_resource.h index 9be21514..a4e497c 100644 --- a/cc/resources/transferable_resource.h +++ b/cc/resources/transferable_resource.h
@@ -11,7 +11,7 @@ #include "cc/base/resource_id.h" #include "cc/cc_export.h" -#include "cc/resources/resource_format.h" +#include "components/viz/common/quads/resource_format.h" #include "gpu/command_buffer/common/mailbox_holder.h" #include "ui/gfx/buffer_types.h" #include "ui/gfx/color_space.h" @@ -31,7 +31,7 @@ ResourceId id; // Refer to ResourceProvider::Resource for the meaning of the following data. - ResourceFormat format; + viz::ResourceFormat format; gfx::BufferFormat buffer_format; uint32_t filter; gfx::Size size;
diff --git a/cc/resources/video_resource_updater.cc b/cc/resources/video_resource_updater.cc index 32ac2c6..d167201 100644 --- a/cc/resources/video_resource_updater.cc +++ b/cc/resources/video_resource_updater.cc
@@ -32,7 +32,7 @@ namespace { -const ResourceFormat kRGBResourceFormat = RGBA_8888; +const viz::ResourceFormat kRGBResourceFormat = viz::RGBA_8888; VideoFrameExternalResources::ResourceType ResourceTypeForVideoFrame( media::VideoFrame* video_frame, @@ -144,7 +144,7 @@ VideoResourceUpdater::PlaneResource::PlaneResource( unsigned int resource_id, const gfx::Size& resource_size, - ResourceFormat resource_format, + viz::ResourceFormat resource_format, gpu::Mailbox mailbox) : resource_id_(resource_id), resource_size_(resource_size), @@ -196,7 +196,7 @@ VideoResourceUpdater::ResourceList::iterator VideoResourceUpdater::RecycleOrAllocateResource( const gfx::Size& resource_size, - ResourceFormat resource_format, + viz::ResourceFormat resource_format, const gfx::ColorSpace& color_space, bool software_resource, bool immutable_hint, @@ -245,7 +245,7 @@ VideoResourceUpdater::ResourceList::iterator VideoResourceUpdater::AllocateResource(const gfx::Size& plane_size, - ResourceFormat format, + viz::ResourceFormat format, const gfx::ColorSpace& color_space, bool has_mailbox, bool immutable_hint) { @@ -323,12 +323,12 @@ const bool software_compositor = context_provider_ == NULL; - ResourceFormat output_resource_format; + viz::ResourceFormat output_resource_format; gfx::ColorSpace output_color_space = video_frame->ColorSpace(); if (input_frame_format == media::PIXEL_FORMAT_Y16) { // Unable to display directly as yuv planes so convert it to RGBA for // compositing. - output_resource_format = RGBA_8888; + output_resource_format = viz::RGBA_8888; output_color_space = output_color_space.GetAsFullRangeRGB(); } else { // Can be composited directly from yuv planes. @@ -337,12 +337,12 @@ } // If GPU compositing is enabled, but the output resource format - // returned by the resource provider is RGBA_8888, then a GPU driver + // returned by the resource provider is viz::RGBA_8888, then a GPU driver // bug workaround requires that YUV frames must be converted to RGB // before texture upload. bool texture_needs_rgb_conversion = !software_compositor && - output_resource_format == ResourceFormat::RGBA_8888; + output_resource_format == viz::ResourceFormat::RGBA_8888; size_t output_plane_count = media::VideoFrame::NumPlanes(input_frame_format); // TODO(skaslev): If we're in software compositing mode, we do the YUV -> RGB @@ -411,7 +411,7 @@ video_renderer_->Copy(video_frame, &canvas, media::Context3D()); } else { size_t bytes_per_row = ResourceUtil::CheckedWidthInBytes<size_t>( - video_frame->coded_size().width(), ResourceFormat::RGBA_8888); + video_frame->coded_size().width(), viz::ResourceFormat::RGBA_8888); size_t needed_size = bytes_per_row * video_frame->coded_size().height(); if (upload_pixels_.size() < needed_size) upload_pixels_.resize(needed_size); @@ -454,7 +454,7 @@ std::unique_ptr<media::HalfFloatMaker> half_float_maker; if (resource_provider_->YuvResourceFormat(bits_per_channel) == - LUMINANCE_F16) { + viz::LUMINANCE_F16) { half_float_maker = media::HalfFloatMaker::NewHalfFloatMaker(bits_per_channel); external_resources.offset = half_float_maker->Offset(); @@ -489,12 +489,13 @@ bool needs_conversion = false; int shift = 0; - // LUMINANCE_F16 uses half-floats, so we always need a conversion step. - if (plane_resource.resource_format() == LUMINANCE_F16) { + // viz::LUMINANCE_F16 uses half-floats, so we always need a conversion + // step. + if (plane_resource.resource_format() == viz::LUMINANCE_F16) { needs_conversion = true; } else if (bits_per_channel > 8) { - // If bits_per_channel > 8 and we can't use LUMINANCE_F16, we need to - // shift the data down and create an 8-bit texture. + // If bits_per_channel > 8 and we can't use viz::LUMINANCE_F16, we need + // to shift the data down and create an 8-bit texture. needs_conversion = true; shift = bits_per_channel - 8; } @@ -510,7 +511,7 @@ upload_pixels_.resize(needed_size); for (int row = 0; row < resource_size_pixels.height(); ++row) { - if (plane_resource.resource_format() == LUMINANCE_F16) { + if (plane_resource.resource_format() == viz::LUMINANCE_F16) { uint16_t* dst = reinterpret_cast<uint16_t*>( &upload_pixels_[upload_image_stride * row]); const uint16_t* src = reinterpret_cast<uint16_t*>( @@ -596,7 +597,7 @@ const gfx::Size output_plane_resource_size = video_frame->coded_size(); // The copy needs to be a direct transfer of pixel data, so we use an RGBA8 // target to avoid loss of precision or dropping any alpha component. - const ResourceFormat copy_target_format = ResourceFormat::RGBA_8888; + const viz::ResourceFormat copy_target_format = viz::ResourceFormat::RGBA_8888; const bool is_immutable = false; const int no_unique_id = 0;
diff --git a/cc/resources/video_resource_updater.h b/cc/resources/video_resource_updater.h index 576e300..eab4122 100644 --- a/cc/resources/video_resource_updater.h +++ b/cc/resources/video_resource_updater.h
@@ -18,8 +18,8 @@ #include "base/time/time.h" #include "cc/cc_export.h" #include "cc/resources/release_callback_impl.h" -#include "cc/resources/resource_format.h" #include "cc/resources/texture_mailbox.h" +#include "components/viz/common/quads/resource_format.h" #include "ui/gfx/geometry/size.h" namespace media { @@ -85,7 +85,7 @@ public: PlaneResource(unsigned resource_id, const gfx::Size& resource_size, - ResourceFormat resource_format, + viz::ResourceFormat resource_format, gpu::Mailbox mailbox); PlaneResource(const PlaneResource& other); @@ -100,7 +100,7 @@ // Accessors for resource identifiers provided at construction time. unsigned resource_id() const { return resource_id_; } const gfx::Size& resource_size() const { return resource_size_; } - ResourceFormat resource_format() const { return resource_format_; } + viz::ResourceFormat resource_format() const { return resource_format_; } const gpu::Mailbox& mailbox() const { return mailbox_; } // Various methods for managing references. See |ref_count_| for details. @@ -123,7 +123,7 @@ const unsigned resource_id_; const gfx::Size resource_size_; - const ResourceFormat resource_format_; + const viz::ResourceFormat resource_format_; const gpu::Mailbox mailbox_; }; @@ -141,14 +141,14 @@ // resources. ResourceList::iterator RecycleOrAllocateResource( const gfx::Size& resource_size, - ResourceFormat resource_format, + viz::ResourceFormat resource_format, const gfx::ColorSpace& color_space, bool software_resource, bool immutable_hint, int unique_id, int plane_index); ResourceList::iterator AllocateResource(const gfx::Size& plane_size, - ResourceFormat format, + viz::ResourceFormat format, const gfx::ColorSpace& color_space, bool has_mailbox, bool immutable_hint);
diff --git a/cc/surfaces/frame_sink_manager.cc b/cc/surfaces/frame_sink_manager.cc index 5265448..079135c 100644 --- a/cc/surfaces/frame_sink_manager.cc +++ b/cc/surfaces/frame_sink_manager.cc
@@ -67,8 +67,6 @@ if (source_iter != frame_sink_source_map_.end()) { if (source_iter->second.source) client_iter->second->SetBeginFrameSource(nullptr); - if (!source_iter->second.has_children()) - frame_sink_source_map_.erase(source_iter); } clients_.erase(client_iter); }
diff --git a/cc/surfaces/frame_sink_manager_unittest.cc b/cc/surfaces/frame_sink_manager_unittest.cc index 8cd721f4..ea5c852 100644 --- a/cc/surfaces/frame_sink_manager_unittest.cc +++ b/cc/surfaces/frame_sink_manager_unittest.cc
@@ -13,6 +13,11 @@ namespace cc { +namespace { + +constexpr FrameSinkId kArbitraryFrameSinkId(1, 1); +} + class FakeFrameSinkManagerClient : public FrameSinkManagerClient { public: explicit FakeFrameSinkManagerClient(const FrameSinkId& frame_sink_id) @@ -115,6 +120,28 @@ EXPECT_EQ(nullptr, client.source()); } +// This test verifies that a client is still connected to the BeginFrameSource +// after restart. +TEST_F(FrameSinkManagerTest, ClientRestart) { + FakeFrameSinkManagerClient client(kArbitraryFrameSinkId); + StubBeginFrameSource source; + client.Register(&manager_); + + manager_.RegisterBeginFrameSource(&source, kArbitraryFrameSinkId); + EXPECT_EQ(&source, client.source()); + + // |client| is disconnect from |source| after Unregister. + client.Unregister(); + EXPECT_EQ(nullptr, client.source()); + + // |client| is reconnected with |source| after re-Register. + client.Register(&manager_); + EXPECT_EQ(&source, client.source()); + + manager_.UnregisterBeginFrameSource(&source); + EXPECT_EQ(nullptr, client.source()); +} + // This test verifies that a PrimaryBeginFrameSource will receive BeginFrames // from the first BeginFrameSource registered. If that BeginFrameSource goes // away then it will receive BeginFrames from the second BeginFrameSource.
diff --git a/cc/surfaces/surface_synchronization_unittest.cc b/cc/surfaces/surface_synchronization_unittest.cc index dd7ee7d..12414a1 100644 --- a/cc/surfaces/surface_synchronization_unittest.cc +++ b/cc/surfaces/surface_synchronization_unittest.cc
@@ -559,7 +559,7 @@ // its resource list. TransferableResource resource; resource.id = 1337; - resource.format = ALPHA_8; + resource.format = viz::ALPHA_8; resource.filter = 1234; resource.size = gfx::Size(1234, 5678); std::vector<TransferableResource> resource_list = {resource}; @@ -1337,7 +1337,7 @@ // for display. TransferableResource resource; resource.id = 1337; - resource.format = ALPHA_8; + resource.format = viz::ALPHA_8; resource.filter = 1234; resource.size = gfx::Size(1234, 5678); std::vector<ReturnedResource> returned_resources = @@ -1367,7 +1367,7 @@ // closed. TransferableResource resource2; resource2.id = 1246; - resource2.format = ALPHA_8; + resource2.format = viz::ALPHA_8; resource2.filter = 1357; resource2.size = gfx::Size(8765, 4321); std::vector<ReturnedResource> returned_resources2 =
diff --git a/cc/test/fake_raster_buffer_provider.cc b/cc/test/fake_raster_buffer_provider.cc index 9f766913..ccc4142f 100644 --- a/cc/test/fake_raster_buffer_provider.cc +++ b/cc/test/fake_raster_buffer_provider.cc
@@ -25,9 +25,9 @@ void FakeRasterBufferProviderImpl::Flush() {} -ResourceFormat FakeRasterBufferProviderImpl::GetResourceFormat( +viz::ResourceFormat FakeRasterBufferProviderImpl::GetResourceFormat( bool must_support_alpha) const { - return ResourceFormat::RGBA_8888; + return viz::ResourceFormat::RGBA_8888; } bool FakeRasterBufferProviderImpl::IsResourceSwizzleRequired(
diff --git a/cc/test/fake_raster_buffer_provider.h b/cc/test/fake_raster_buffer_provider.h index 29f8653b..7bf988f 100644 --- a/cc/test/fake_raster_buffer_provider.h +++ b/cc/test/fake_raster_buffer_provider.h
@@ -23,7 +23,7 @@ void ReleaseBufferForRaster(std::unique_ptr<RasterBuffer> buffer) override; void OrderingBarrier() override; void Flush() override; - ResourceFormat GetResourceFormat(bool must_support_alpha) const override; + viz::ResourceFormat GetResourceFormat(bool must_support_alpha) const override; bool IsResourceSwizzleRequired(bool must_support_alpha) const override; bool CanPartialRasterIntoProvidedResource() const override; bool IsResourceReadyToDraw(ResourceId id) const override;
diff --git a/cc/test/fake_tile_manager.cc b/cc/test/fake_tile_manager.cc index e7b1bea..48623ae6 100644 --- a/cc/test/fake_tile_manager.cc +++ b/cc/test/fake_tile_manager.cc
@@ -42,7 +42,7 @@ std::numeric_limits<size_t>::max(), TileManagerSettings()), image_decode_cache_( - ResourceFormat::RGBA_8888, + viz::ResourceFormat::RGBA_8888, LayerTreeSettings().decoded_image_working_set_budget_bytes) { SetDecodedImageTracker(&decoded_image_tracker_); SetResources(resource_pool, &image_decode_cache_, GetGlobalTaskGraphRunner(),
diff --git a/cc/test/fake_ui_resource_layer_tree_host_impl.cc b/cc/test/fake_ui_resource_layer_tree_host_impl.cc index 6530706a..6e0a29d9 100644 --- a/cc/test/fake_ui_resource_layer_tree_host_impl.cc +++ b/cc/test/fake_ui_resource_layer_tree_host_impl.cc
@@ -24,8 +24,8 @@ UIResourceData data; data.resource_id = resource_provider()->CreateResource( - bitmap.GetSize(), ResourceProvider::TEXTURE_HINT_IMMUTABLE, RGBA_8888, - gfx::ColorSpace()); + bitmap.GetSize(), ResourceProvider::TEXTURE_HINT_IMMUTABLE, + viz::RGBA_8888, gfx::ColorSpace()); data.opaque = bitmap.GetOpaque(); fake_ui_resource_map_[uid] = data;
diff --git a/cc/test/layer_tree_pixel_resource_test.cc b/cc/test/layer_tree_pixel_resource_test.cc index 1dd5db0e..0088515 100644 --- a/cc/test/layer_tree_pixel_resource_test.cc +++ b/cc/test/layer_tree_pixel_resource_test.cc
@@ -156,7 +156,7 @@ *raster_buffer_provider = base::MakeUnique<GpuRasterBufferProvider>( compositor_context_provider, worker_context_provider, - resource_provider, false, 0, PlatformColor::BestTextureFormat(), + resource_provider, false, 0, viz::PlatformColor::BestTextureFormat(), false); break; case RASTER_BUFFER_PROVIDER_TYPE_ZERO_COPY: @@ -164,7 +164,7 @@ EXPECT_EQ(PIXEL_TEST_GL, test_type_); *raster_buffer_provider = ZeroCopyRasterBufferProvider::Create( - resource_provider, PlatformColor::BestTextureFormat()); + resource_provider, viz::PlatformColor::BestTextureFormat()); break; case RASTER_BUFFER_PROVIDER_TYPE_ONE_COPY: EXPECT_TRUE(compositor_context_provider); @@ -174,8 +174,8 @@ *raster_buffer_provider = base::MakeUnique<OneCopyRasterBufferProvider>( task_runner, compositor_context_provider, worker_context_provider, resource_provider, max_bytes_per_copy_operation, false, - max_staging_buffer_usage_in_bytes, PlatformColor::BestTextureFormat(), - false); + max_staging_buffer_usage_in_bytes, + viz::PlatformColor::BestTextureFormat(), false); break; } }
diff --git a/cc/test/test_in_process_context_provider.cc b/cc/test/test_in_process_context_provider.cc index 5047dc4..f70d68c 100644 --- a/cc/test/test_in_process_context_provider.cc +++ b/cc/test/test_in_process_context_provider.cc
@@ -11,7 +11,7 @@ #include "base/memory/ptr_util.h" #include "base/threading/thread_task_runner_handle.h" #include "cc/output/context_cache_controller.h" -#include "cc/resources/platform_color.h" +#include "components/viz/common/resources/platform_color.h" #include "gpu/GLES2/gl2extchromium.h" #include "gpu/command_buffer/client/gles2_implementation.h" #include "gpu/command_buffer/client/gles2_lib.h" @@ -110,11 +110,11 @@ gpu::Capabilities capabilities; capabilities.texture_rectangle = true; capabilities.sync_query = true; - switch (PlatformColor::Format()) { - case PlatformColor::SOURCE_FORMAT_RGBA8: + switch (viz::PlatformColor::Format()) { + case viz::PlatformColor::SOURCE_FORMAT_RGBA8: capabilities.texture_format_bgra8888 = false; break; - case PlatformColor::SOURCE_FORMAT_BGRA8: + case viz::PlatformColor::SOURCE_FORMAT_BGRA8: capabilities.texture_format_bgra8888 = true; break; }
diff --git a/cc/test/test_texture.cc b/cc/test/test_texture.cc index fea16fbd..662692a 100644 --- a/cc/test/test_texture.cc +++ b/cc/test/test_texture.cc
@@ -12,14 +12,14 @@ namespace cc { -size_t TextureSizeBytes(const gfx::Size& size, ResourceFormat format) { +size_t TextureSizeBytes(const gfx::Size& size, viz::ResourceFormat format) { unsigned int components_per_pixel = 4; unsigned int bytes_per_component = 1; return size.width() * size.height() * components_per_pixel * bytes_per_component; } -TestTexture::TestTexture() : format(RGBA_8888) { +TestTexture::TestTexture() : format(viz::RGBA_8888) { // Initialize default parameter values. params[GL_TEXTURE_MAG_FILTER] = GL_LINEAR; params[GL_TEXTURE_MIN_FILTER] = GL_NEAREST_MIPMAP_LINEAR; @@ -30,7 +30,8 @@ TestTexture::~TestTexture() {} -void TestTexture::Reallocate(const gfx::Size& size, ResourceFormat format) { +void TestTexture::Reallocate(const gfx::Size& size, + viz::ResourceFormat format) { this->size = size; this->format = format; this->data.reset(new uint8_t[TextureSizeBytes(size, format)]);
diff --git a/cc/test/test_texture.h b/cc/test/test_texture.h index ae819ec..2389a9d 100644 --- a/cc/test/test_texture.h +++ b/cc/test/test_texture.h
@@ -12,22 +12,22 @@ #include <unordered_map> #include "base/memory/ref_counted.h" -#include "cc/resources/resource_format.h" +#include "components/viz/common/quads/resource_format.h" #include "third_party/khronos/GLES2/gl2.h" #include "ui/gfx/geometry/size.h" namespace cc { -size_t TextureSizeBytes(const gfx::Size& size, ResourceFormat format); +size_t TextureSizeBytes(const gfx::Size& size, viz::ResourceFormat format); struct TestTexture : public base::RefCounted<TestTexture> { TestTexture(); - void Reallocate(const gfx::Size& size, ResourceFormat format); + void Reallocate(const gfx::Size& size, viz::ResourceFormat format); bool IsValidParameter(GLenum pname); gfx::Size size; - ResourceFormat format; + viz::ResourceFormat format; std::unique_ptr<uint8_t[]> data; using TextureParametersMap = std::unordered_map<GLenum, GLint>;
diff --git a/cc/tiles/gpu_image_decode_cache.cc b/cc/tiles/gpu_image_decode_cache.cc index a6b9228a..b1e7400 100644 --- a/cc/tiles/gpu_image_decode_cache.cc +++ b/cc/tiles/gpu_image_decode_cache.cc
@@ -20,8 +20,8 @@ #include "cc/base/devtools_instrumentation.h" #include "cc/output/context_provider.h" #include "cc/raster/tile_task.h" -#include "cc/resources/resource_format_utils.h" #include "cc/tiles/mipmap_util.h" +#include "components/viz/common/resources/resource_format_utils.h" #include "gpu/command_buffer/client/context_support.h" #include "gpu/command_buffer/client/gles2_interface.h" #include "gpu_image_decode_cache.h" @@ -393,7 +393,7 @@ } GpuImageDecodeCache::GpuImageDecodeCache(ContextProvider* context, - ResourceFormat decode_format, + viz::ResourceFormat decode_format, size_t max_working_set_bytes, size_t max_cache_bytes) : format_(decode_format), @@ -1180,7 +1180,7 @@ if (!draw_image.image()->getDeferredTextureImageData( *context_threadsafe_proxy_.get(), &image_data->upload_params, 1, backing_memory->data(), nullptr, - ResourceFormatToClosestSkColorType(format_))) { + viz::ResourceFormatToClosestSkColorType(format_))) { DLOG(ERROR) << "getDeferredTextureImageData failed despite params " << "having validated."; backing_memory->Unlock(); @@ -1282,7 +1282,7 @@ upload_scale_mip_level); size_t data_size = draw_image.image()->getDeferredTextureImageData( *context_threadsafe_proxy_.get(), ¶ms, 1, nullptr, nullptr, - ResourceFormatToClosestSkColorType(format_)); + viz::ResourceFormatToClosestSkColorType(format_)); if (data_size == 0) { // Can't upload image, too large or other failure. Try to use SW fallback. @@ -1310,7 +1310,7 @@ gfx::Size mip_size = CalculateSizeForMipLevel(draw_image, upload_scale_mip_level); return SkImageInfo::Make(mip_size.width(), mip_size.height(), - ResourceFormatToClosestSkColorType(format_), + viz::ResourceFormatToClosestSkColorType(format_), kPremul_SkAlphaType, draw_image.target_color_space().ToSkColorSpace()); }
diff --git a/cc/tiles/gpu_image_decode_cache.h b/cc/tiles/gpu_image_decode_cache.h index c2fc02e2..b290faf 100644 --- a/cc/tiles/gpu_image_decode_cache.h +++ b/cc/tiles/gpu_image_decode_cache.h
@@ -15,8 +15,8 @@ #include "base/synchronization/lock.h" #include "base/trace_event/memory_dump_provider.h" #include "cc/cc_export.h" -#include "cc/resources/resource_format.h" #include "cc/tiles/image_decode_cache.h" +#include "components/viz/common/quads/resource_format.h" #include "third_party/skia/include/core/SkRefCnt.h" namespace cc { @@ -102,7 +102,7 @@ enum class DecodeTaskType { PART_OF_UPLOAD_TASK, STAND_ALONE_DECODE_TASK }; explicit GpuImageDecodeCache(ContextProvider* context, - ResourceFormat decode_format, + viz::ResourceFormat decode_format, size_t max_working_set_bytes, size_t max_cache_bytes); ~GpuImageDecodeCache() override; @@ -347,7 +347,7 @@ ImageData* image_data); void DeletePendingImages(); - const ResourceFormat format_; + const viz::ResourceFormat format_; ContextProvider* context_; sk_sp<GrContextThreadSafeProxy> context_threadsafe_proxy_;
diff --git a/cc/tiles/gpu_image_decode_cache_unittest.cc b/cc/tiles/gpu_image_decode_cache_unittest.cc index 0257717..721f5b1 100644 --- a/cc/tiles/gpu_image_decode_cache_unittest.cc +++ b/cc/tiles/gpu_image_decode_cache_unittest.cc
@@ -28,7 +28,7 @@ class TestGpuImageDecodeCache : public GpuImageDecodeCache { public: explicit TestGpuImageDecodeCache(ContextProvider* context, - ResourceFormat format) + viz::ResourceFormat format) : GpuImageDecodeCache(context, format, kGpuMemoryLimitBytes, @@ -74,7 +74,7 @@ return matrix; } -using GpuImageDecodeCacheTest = ::testing::TestWithParam<ResourceFormat>; +using GpuImageDecodeCacheTest = ::testing::TestWithParam<viz::ResourceFormat>; TEST_P(GpuImageDecodeCacheTest, GetTaskForImageSameImage) { auto context_provider = TestContextProvider::Create(); @@ -1503,7 +1503,8 @@ // Setup - Image cache has a normal working set, but zero cache size. auto context_provider = TestContextProvider::Create(); context_provider->BindToCurrentThread(); - GpuImageDecodeCache cache(context_provider.get(), ResourceFormat::RGBA_8888, + GpuImageDecodeCache cache(context_provider.get(), + viz::ResourceFormat::RGBA_8888, kGpuMemoryLimitBytes, 0); bool is_decomposable = true; SkFilterQuality quality = kHigh_SkFilterQuality; @@ -1560,7 +1561,8 @@ auto context_provider = TestContextProvider::Create(); context_provider->BindToCurrentThread(); - GpuImageDecodeCache cache(context_provider.get(), ResourceFormat::RGBA_8888, + GpuImageDecodeCache cache(context_provider.get(), + viz::ResourceFormat::RGBA_8888, kGpuMemoryLimitBytes, cache_size); bool is_decomposable = true; SkFilterQuality quality = kHigh_SkFilterQuality; @@ -1813,8 +1815,8 @@ INSTANTIATE_TEST_CASE_P(GpuImageDecodeCacheTests, GpuImageDecodeCacheTest, - ::testing::Values(ResourceFormat::RGBA_8888, - ResourceFormat::RGBA_4444)); + ::testing::Values(viz::ResourceFormat::RGBA_8888, + viz::ResourceFormat::RGBA_4444)); } // namespace } // namespace cc
diff --git a/cc/tiles/software_image_decode_cache.cc b/cc/tiles/software_image_decode_cache.cc index 83b7026..2cbb8cc 100644 --- a/cc/tiles/software_image_decode_cache.cc +++ b/cc/tiles/software_image_decode_cache.cc
@@ -21,8 +21,8 @@ #include "base/trace_event/memory_dump_manager.h" #include "cc/base/devtools_instrumentation.h" #include "cc/raster/tile_task.h" -#include "cc/resources/resource_format_utils.h" #include "cc/tiles/mipmap_util.h" +#include "components/viz/common/resources/resource_format_utils.h" #include "third_party/skia/include/core/SkCanvas.h" #include "third_party/skia/include/core/SkImage.h" #include "third_party/skia/include/core/SkPixmap.h" @@ -159,9 +159,9 @@ SkImageInfo CreateImageInfo(size_t width, size_t height, - ResourceFormat format) { + viz::ResourceFormat format) { return SkImageInfo::Make(width, height, - ResourceFormatToClosestSkColorType(format), + viz::ResourceFormatToClosestSkColorType(format), kPremul_SkAlphaType); } @@ -194,7 +194,7 @@ } // namespace SoftwareImageDecodeCache::SoftwareImageDecodeCache( - ResourceFormat format, + viz::ResourceFormat format, size_t locked_memory_limit_bytes) : decoded_images_(ImageMRUCache::NO_AUTO_EVICT), at_raster_decoded_images_(ImageMRUCache::NO_AUTO_EVICT), @@ -919,8 +919,9 @@ } // SoftwareImageDecodeCacheKey -ImageDecodeCacheKey ImageDecodeCacheKey::FromDrawImage(const DrawImage& image, - ResourceFormat format) { +ImageDecodeCacheKey ImageDecodeCacheKey::FromDrawImage( + const DrawImage& image, + viz::ResourceFormat format) { const SkSize& scale = image.scale(); // If the src_rect falls outside of the image, we need to clip it since // otherwise we might end up with uninitialized memory in the decode process. @@ -949,8 +950,9 @@ quality = kMedium_SkFilterQuality; } - // Skia doesn't scale an RGBA_4444 format, so always use the original decode. - if (format == RGBA_4444) + // Skia doesn't scale an viz::RGBA_4444 format, so always use the original + // decode. + if (format == viz::RGBA_4444) quality = std::min(quality, kLow_SkFilterQuality); // Drop from high to medium if the the matrix we applied wasn't decomposable,
diff --git a/cc/tiles/software_image_decode_cache.h b/cc/tiles/software_image_decode_cache.h index a81c5f6..78777894 100644 --- a/cc/tiles/software_image_decode_cache.h +++ b/cc/tiles/software_image_decode_cache.h
@@ -22,9 +22,9 @@ #include "base/trace_event/memory_dump_provider.h" #include "cc/cc_export.h" #include "cc/paint/draw_image.h" -#include "cc/resources/resource_format.h" #include "cc/tiles/decoded_draw_image.h" #include "cc/tiles/image_decode_cache.h" +#include "components/viz/common/quads/resource_format.h" #include "third_party/skia/include/core/SkRefCnt.h" #include "ui/gfx/geometry/rect.h" @@ -37,7 +37,7 @@ class CC_EXPORT ImageDecodeCacheKey { public: static ImageDecodeCacheKey FromDrawImage(const DrawImage& image, - ResourceFormat format); + viz::ResourceFormat format); ImageDecodeCacheKey(const ImageDecodeCacheKey& other); @@ -121,7 +121,7 @@ enum class DecodeTaskType { USE_IN_RASTER_TASKS, USE_OUT_OF_RASTER_TASKS }; - SoftwareImageDecodeCache(ResourceFormat format, + SoftwareImageDecodeCache(viz::ResourceFormat format, size_t locked_memory_limit_bytes); ~SoftwareImageDecodeCache() override; @@ -324,7 +324,7 @@ MemoryBudget locked_images_budget_; - ResourceFormat format_; + viz::ResourceFormat format_; size_t max_items_in_cache_; // Used to uniquely identify DecodedImages for memory traces.
diff --git a/cc/tiles/software_image_decode_cache_perftest.cc b/cc/tiles/software_image_decode_cache_perftest.cc index 3a4b93ff..fb9ed0df 100644 --- a/cc/tiles/software_image_decode_cache_perftest.cc +++ b/cc/tiles/software_image_decode_cache_perftest.cc
@@ -68,7 +68,7 @@ timer_.Reset(); do { for (auto& image : images) - ImageDecodeCacheKey::FromDrawImage(image, RGBA_8888); + ImageDecodeCacheKey::FromDrawImage(image, viz::RGBA_8888); timer_.NextLap(); } while (!timer_.HasTimeLimitExpired());
diff --git a/cc/tiles/software_image_decode_cache_unittest.cc b/cc/tiles/software_image_decode_cache_unittest.cc index 90aa66e4..9d3560e 100644 --- a/cc/tiles/software_image_decode_cache_unittest.cc +++ b/cc/tiles/software_image_decode_cache_unittest.cc
@@ -5,8 +5,8 @@ #include "cc/tiles/software_image_decode_cache.h" #include "cc/paint/draw_image.h" -#include "cc/resources/resource_format.h" #include "cc/test/test_tile_task_runner.h" +#include "components/viz/common/quads/resource_format.h" #include "testing/gtest/include/gtest/gtest.h" #include "third_party/skia/include/core/SkRefCnt.h" @@ -21,7 +21,7 @@ class TestSoftwareImageDecodeCache : public SoftwareImageDecodeCache { public: TestSoftwareImageDecodeCache() - : SoftwareImageDecodeCache(ResourceFormat::RGBA_8888, + : SoftwareImageDecodeCache(viz::ResourceFormat::RGBA_8888, kLockedMemoryLimitBytes) {} }; @@ -65,7 +65,7 @@ CreateMatrix(SkSize::Make(0.5f, 1.5f), is_decomposable), DefaultColorSpace()); - auto key = ImageDecodeCacheKey::FromDrawImage(draw_image, RGBA_8888); + auto key = ImageDecodeCacheKey::FromDrawImage(draw_image, viz::RGBA_8888); EXPECT_EQ(image->uniqueID(), key.image_id()); EXPECT_EQ(kNone_SkFilterQuality, key.filter_quality()); EXPECT_EQ(100, key.target_size().width()); @@ -86,7 +86,7 @@ CreateMatrix(SkSize::Make(0.5f, 1.5f), is_decomposable), DefaultColorSpace()); - auto key = ImageDecodeCacheKey::FromDrawImage(draw_image, RGBA_8888); + auto key = ImageDecodeCacheKey::FromDrawImage(draw_image, viz::RGBA_8888); EXPECT_EQ(image->uniqueID(), key.image_id()); EXPECT_EQ(kMedium_SkFilterQuality, key.filter_quality()); EXPECT_EQ(100, key.target_size().width()); @@ -104,7 +104,7 @@ CreateMatrix(SkSize::Make(0.5f, 1.5f), is_decomposable), DefaultColorSpace()); - auto key = ImageDecodeCacheKey::FromDrawImage(draw_image, RGBA_4444); + auto key = ImageDecodeCacheKey::FromDrawImage(draw_image, viz::RGBA_4444); EXPECT_EQ(image->uniqueID(), key.image_id()); EXPECT_EQ(kLow_SkFilterQuality, key.filter_quality()); EXPECT_EQ(100, key.target_size().width()); @@ -122,7 +122,7 @@ CreateMatrix(SkSize::Make(1.5f, 1.5f), is_decomposable), DefaultColorSpace()); - auto key = ImageDecodeCacheKey::FromDrawImage(draw_image, RGBA_4444); + auto key = ImageDecodeCacheKey::FromDrawImage(draw_image, viz::RGBA_4444); EXPECT_EQ(image->uniqueID(), key.image_id()); EXPECT_EQ(kLow_SkFilterQuality, key.filter_quality()); EXPECT_EQ(100, key.target_size().width()); @@ -140,7 +140,7 @@ CreateMatrix(SkSize::Make(1.5f, 1.5f), is_decomposable), DefaultColorSpace()); - auto key = ImageDecodeCacheKey::FromDrawImage(draw_image, RGBA_8888); + auto key = ImageDecodeCacheKey::FromDrawImage(draw_image, viz::RGBA_8888); EXPECT_EQ(image->uniqueID(), key.image_id()); EXPECT_EQ(kLow_SkFilterQuality, key.filter_quality()); EXPECT_EQ(100, key.target_size().width()); @@ -159,7 +159,7 @@ quality, CreateMatrix(SkSize::Make(0.5f, 1.5f), is_decomposable), DefaultColorSpace()); - auto key = ImageDecodeCacheKey::FromDrawImage(draw_image, RGBA_8888); + auto key = ImageDecodeCacheKey::FromDrawImage(draw_image, viz::RGBA_8888); EXPECT_EQ(image->uniqueID(), key.image_id()); EXPECT_EQ(quality, key.filter_quality()); EXPECT_EQ(100, key.target_size().width()); @@ -178,7 +178,7 @@ quality, CreateMatrix(SkSize::Make(1.5f, 1.5f), is_decomposable), DefaultColorSpace()); - auto key = ImageDecodeCacheKey::FromDrawImage(draw_image, RGBA_8888); + auto key = ImageDecodeCacheKey::FromDrawImage(draw_image, viz::RGBA_8888); EXPECT_EQ(image->uniqueID(), key.image_id()); EXPECT_EQ(kLow_SkFilterQuality, key.filter_quality()); EXPECT_EQ(100, key.target_size().width()); @@ -197,7 +197,7 @@ quality, CreateMatrix(SkSize::Make(1.f, 1.f), is_decomposable), DefaultColorSpace()); - auto key = ImageDecodeCacheKey::FromDrawImage(draw_image, RGBA_8888); + auto key = ImageDecodeCacheKey::FromDrawImage(draw_image, viz::RGBA_8888); EXPECT_EQ(image->uniqueID(), key.image_id()); EXPECT_EQ(kLow_SkFilterQuality, key.filter_quality()); EXPECT_EQ(100, key.target_size().width()); @@ -217,7 +217,7 @@ quality, CreateMatrix(SkSize::Make(1.001f, 1.001f), is_decomposable), DefaultColorSpace()); - auto key = ImageDecodeCacheKey::FromDrawImage(draw_image, RGBA_8888); + auto key = ImageDecodeCacheKey::FromDrawImage(draw_image, viz::RGBA_8888); EXPECT_EQ(image->uniqueID(), key.image_id()); EXPECT_EQ(kLow_SkFilterQuality, key.filter_quality()); EXPECT_EQ(100, key.target_size().width()); @@ -237,7 +237,7 @@ quality, CreateMatrix(SkSize::Make(0.999f, 0.999f), is_decomposable), DefaultColorSpace()); - auto key = ImageDecodeCacheKey::FromDrawImage(draw_image, RGBA_8888); + auto key = ImageDecodeCacheKey::FromDrawImage(draw_image, viz::RGBA_8888); EXPECT_EQ(image->uniqueID(), key.image_id()); EXPECT_EQ(kLow_SkFilterQuality, key.filter_quality()); EXPECT_EQ(100, key.target_size().width()); @@ -257,7 +257,7 @@ quality, CreateMatrix(SkSize::Make(0.5f, 1.5f), is_decomposable), DefaultColorSpace()); - auto key = ImageDecodeCacheKey::FromDrawImage(draw_image, RGBA_8888); + auto key = ImageDecodeCacheKey::FromDrawImage(draw_image, viz::RGBA_8888); EXPECT_EQ(image->uniqueID(), key.image_id()); EXPECT_EQ(kLow_SkFilterQuality, key.filter_quality()); EXPECT_EQ(100, key.target_size().width()); @@ -276,7 +276,7 @@ quality, CreateMatrix(SkSize::Make(1.5f, 1.5f), is_decomposable), DefaultColorSpace()); - auto key = ImageDecodeCacheKey::FromDrawImage(draw_image, RGBA_8888); + auto key = ImageDecodeCacheKey::FromDrawImage(draw_image, viz::RGBA_8888); EXPECT_EQ(image->uniqueID(), key.image_id()); EXPECT_EQ(kLow_SkFilterQuality, key.filter_quality()); EXPECT_EQ(500, key.target_size().width()); @@ -295,7 +295,7 @@ quality, CreateMatrix(SkSize::Make(1.f, 1.f), is_decomposable), DefaultColorSpace()); - auto key = ImageDecodeCacheKey::FromDrawImage(draw_image, RGBA_8888); + auto key = ImageDecodeCacheKey::FromDrawImage(draw_image, viz::RGBA_8888); EXPECT_EQ(image->uniqueID(), key.image_id()); EXPECT_EQ(kLow_SkFilterQuality, key.filter_quality()); EXPECT_EQ(500, key.target_size().width()); @@ -314,7 +314,7 @@ quality, CreateMatrix(SkSize::Make(0.75f, 0.75f), is_decomposable), DefaultColorSpace()); - auto key = ImageDecodeCacheKey::FromDrawImage(draw_image, RGBA_8888); + auto key = ImageDecodeCacheKey::FromDrawImage(draw_image, viz::RGBA_8888); EXPECT_EQ(image->uniqueID(), key.image_id()); EXPECT_EQ(quality, key.filter_quality()); EXPECT_EQ(500, key.target_size().width()); @@ -333,7 +333,7 @@ quality, CreateMatrix(SkSize::Make(0.5f, 0.5f), is_decomposable), DefaultColorSpace()); - auto key = ImageDecodeCacheKey::FromDrawImage(draw_image, RGBA_8888); + auto key = ImageDecodeCacheKey::FromDrawImage(draw_image, viz::RGBA_8888); EXPECT_EQ(image->uniqueID(), key.image_id()); EXPECT_EQ(quality, key.filter_quality()); EXPECT_EQ(250, key.target_size().width()); @@ -352,7 +352,7 @@ quality, CreateMatrix(SkSize::Make(0.49f, 0.49f), is_decomposable), DefaultColorSpace()); - auto key = ImageDecodeCacheKey::FromDrawImage(draw_image, RGBA_8888); + auto key = ImageDecodeCacheKey::FromDrawImage(draw_image, viz::RGBA_8888); EXPECT_EQ(image->uniqueID(), key.image_id()); EXPECT_EQ(quality, key.filter_quality()); EXPECT_EQ(250, key.target_size().width()); @@ -371,7 +371,7 @@ quality, CreateMatrix(SkSize::Make(0.1f, 0.1f), is_decomposable), DefaultColorSpace()); - auto key = ImageDecodeCacheKey::FromDrawImage(draw_image, RGBA_8888); + auto key = ImageDecodeCacheKey::FromDrawImage(draw_image, viz::RGBA_8888); EXPECT_EQ(image->uniqueID(), key.image_id()); EXPECT_EQ(quality, key.filter_quality()); EXPECT_EQ(62, key.target_size().width()); @@ -390,7 +390,7 @@ quality, CreateMatrix(SkSize::Make(0.01f, 0.01f), is_decomposable), DefaultColorSpace()); - auto key = ImageDecodeCacheKey::FromDrawImage(draw_image, RGBA_8888); + auto key = ImageDecodeCacheKey::FromDrawImage(draw_image, viz::RGBA_8888); EXPECT_EQ(image->uniqueID(), key.image_id()); EXPECT_EQ(quality, key.filter_quality()); EXPECT_EQ(7, key.target_size().width()); @@ -410,7 +410,7 @@ quality, CreateMatrix(SkSize::Make(0.5f, 1.5f), is_decomposable), DefaultColorSpace()); - auto key = ImageDecodeCacheKey::FromDrawImage(draw_image, RGBA_8888); + auto key = ImageDecodeCacheKey::FromDrawImage(draw_image, viz::RGBA_8888); EXPECT_EQ(image->uniqueID(), key.image_id()); EXPECT_EQ(kMedium_SkFilterQuality, key.filter_quality()); EXPECT_EQ(100, key.target_size().width()); @@ -430,7 +430,7 @@ quality, CreateMatrix(SkSize::Make(0.5f, 0.2f), is_decomposable), DefaultColorSpace()); - auto key = ImageDecodeCacheKey::FromDrawImage(draw_image, RGBA_8888); + auto key = ImageDecodeCacheKey::FromDrawImage(draw_image, viz::RGBA_8888); EXPECT_EQ(image->uniqueID(), key.image_id()); EXPECT_EQ(kMedium_SkFilterQuality, key.filter_quality()); EXPECT_EQ(50, key.target_size().width()); @@ -449,7 +449,7 @@ quality, CreateMatrix(SkSize::Make(2.5f, 1.5f), is_decomposable), DefaultColorSpace()); - auto key = ImageDecodeCacheKey::FromDrawImage(draw_image, RGBA_8888); + auto key = ImageDecodeCacheKey::FromDrawImage(draw_image, viz::RGBA_8888); EXPECT_EQ(image->uniqueID(), key.image_id()); EXPECT_EQ(quality, key.filter_quality()); EXPECT_EQ(250, key.target_size().width()); @@ -471,7 +471,7 @@ quality, CreateMatrix(SkSize::Make(0.9f, 2.f), is_decomposable), DefaultColorSpace()); - auto key = ImageDecodeCacheKey::FromDrawImage(draw_image, RGBA_8888); + auto key = ImageDecodeCacheKey::FromDrawImage(draw_image, viz::RGBA_8888); EXPECT_EQ(image->uniqueID(), key.image_id()); EXPECT_EQ(kMedium_SkFilterQuality, key.filter_quality()); EXPECT_EQ(4555, key.target_size().width()); @@ -491,7 +491,7 @@ quality, CreateMatrix(SkSize::Make(0.5f, 1.5f), is_decomposable), DefaultColorSpace()); - auto key = ImageDecodeCacheKey::FromDrawImage(draw_image, RGBA_8888); + auto key = ImageDecodeCacheKey::FromDrawImage(draw_image, viz::RGBA_8888); EXPECT_EQ(image->uniqueID(), key.image_id()); EXPECT_EQ(kLow_SkFilterQuality, key.filter_quality()); EXPECT_EQ(100, key.target_size().width()); @@ -510,7 +510,7 @@ quality, CreateMatrix(SkSize::Make(1.f, 1.f), is_decomposable), DefaultColorSpace()); - auto key = ImageDecodeCacheKey::FromDrawImage(draw_image, RGBA_8888); + auto key = ImageDecodeCacheKey::FromDrawImage(draw_image, viz::RGBA_8888); EXPECT_EQ(image->uniqueID(), key.image_id()); EXPECT_EQ(kLow_SkFilterQuality, key.filter_quality()); EXPECT_EQ(100, key.target_size().width()); @@ -530,7 +530,7 @@ quality, CreateMatrix(SkSize::Make(1.001f, 1.001f), is_decomposable), DefaultColorSpace()); - auto key = ImageDecodeCacheKey::FromDrawImage(draw_image, RGBA_8888); + auto key = ImageDecodeCacheKey::FromDrawImage(draw_image, viz::RGBA_8888); EXPECT_EQ(image->uniqueID(), key.image_id()); EXPECT_EQ(kLow_SkFilterQuality, key.filter_quality()); EXPECT_EQ(100, key.target_size().width()); @@ -550,7 +550,7 @@ quality, CreateMatrix(SkSize::Make(0.999f, 0.999f), is_decomposable), DefaultColorSpace()); - auto key = ImageDecodeCacheKey::FromDrawImage(draw_image, RGBA_8888); + auto key = ImageDecodeCacheKey::FromDrawImage(draw_image, viz::RGBA_8888); EXPECT_EQ(image->uniqueID(), key.image_id()); EXPECT_EQ(kLow_SkFilterQuality, key.filter_quality()); EXPECT_EQ(100, key.target_size().width()); @@ -569,7 +569,7 @@ quality, CreateMatrix(SkSize::Make(0.5f, 0.5), is_decomposable), DefaultColorSpace()); - auto key = ImageDecodeCacheKey::FromDrawImage(draw_image, RGBA_8888); + auto key = ImageDecodeCacheKey::FromDrawImage(draw_image, viz::RGBA_8888); EXPECT_EQ(image->uniqueID(), key.image_id()); EXPECT_EQ(kNone_SkFilterQuality, key.filter_quality()); EXPECT_EQ(100, key.target_size().width()); @@ -583,7 +583,7 @@ DefaultColorSpace()); auto another_key = - ImageDecodeCacheKey::FromDrawImage(another_draw_image, RGBA_8888); + ImageDecodeCacheKey::FromDrawImage(another_draw_image, viz::RGBA_8888); EXPECT_EQ(image->uniqueID(), another_key.image_id()); EXPECT_EQ(kNone_SkFilterQuality, another_key.filter_quality()); EXPECT_EQ(100, another_key.target_size().width()); @@ -605,7 +605,7 @@ CreateMatrix(SkSize::Make(1.f, 1.f), is_decomposable), DefaultColorSpace()); - auto key = ImageDecodeCacheKey::FromDrawImage(draw_image, RGBA_8888); + auto key = ImageDecodeCacheKey::FromDrawImage(draw_image, viz::RGBA_8888); EXPECT_EQ(image->uniqueID(), key.image_id()); EXPECT_EQ(kLow_SkFilterQuality, key.filter_quality()); EXPECT_EQ(100, key.target_size().width()); @@ -625,7 +625,7 @@ CreateMatrix(SkSize::Make(0.5f, 0.5f), is_decomposable), DefaultColorSpace()); - auto key = ImageDecodeCacheKey::FromDrawImage(draw_image, RGBA_8888); + auto key = ImageDecodeCacheKey::FromDrawImage(draw_image, viz::RGBA_8888); EXPECT_EQ(image->uniqueID(), key.image_id()); EXPECT_EQ(kMedium_SkFilterQuality, key.filter_quality()); EXPECT_EQ(40, key.target_size().width());
diff --git a/cc/tiles/tile_draw_info.h b/cc/tiles/tile_draw_info.h index dc1a8855..390b4346 100644 --- a/cc/tiles/tile_draw_info.h +++ b/cc/tiles/tile_draw_info.h
@@ -8,9 +8,9 @@ #include <memory> #include "base/trace_event/trace_event_argument.h" -#include "cc/resources/platform_color.h" #include "cc/resources/resource_provider.h" #include "cc/resources/scoped_resource.h" +#include "components/viz/common/resources/platform_color.h" namespace cc {
diff --git a/cc/tiles/tile_manager.cc b/cc/tiles/tile_manager.cc index d9a680d6..94addce 100644 --- a/cc/tiles/tile_manager.cc +++ b/cc/tiles/tile_manager.cc
@@ -1445,7 +1445,8 @@ client_->RequestImplSideInvalidation(); } -ResourceFormat TileManager::DetermineResourceFormat(const Tile* tile) const { +viz::ResourceFormat TileManager::DetermineResourceFormat( + const Tile* tile) const { return raster_buffer_provider_->GetResourceFormat(!tile->is_opaque()); } @@ -1636,7 +1637,7 @@ // static TileManager::MemoryUsage TileManager::MemoryUsage::FromConfig( const gfx::Size& size, - ResourceFormat format) { + viz::ResourceFormat format) { // We can use UncheckedSizeInBytes here since this is used with a tile // size which is determined by the compositor (it's at most max texture // size).
diff --git a/cc/tiles/tile_manager.h b/cc/tiles/tile_manager.h index 1b08ae0e..91388826 100644 --- a/cc/tiles/tile_manager.h +++ b/cc/tiles/tile_manager.h
@@ -279,7 +279,8 @@ MemoryUsage(); MemoryUsage(size_t memory_bytes, size_t resource_count); - static MemoryUsage FromConfig(const gfx::Size& size, ResourceFormat format); + static MemoryUsage FromConfig(const gfx::Size& size, + viz::ResourceFormat format); static MemoryUsage FromTile(const Tile* tile); MemoryUsage& operator+=(const MemoryUsage& other); @@ -342,7 +343,7 @@ void MarkTilesOutOfMemory( std::unique_ptr<RasterTilePriorityQueue> queue) const; - ResourceFormat DetermineResourceFormat(const Tile* tile) const; + viz::ResourceFormat DetermineResourceFormat(const Tile* tile) const; bool DetermineResourceRequiresSwizzle(const Tile* tile) const; void DidFinishRunningTileTasksRequiredForActivation();
diff --git a/cc/tiles/tile_manager_unittest.cc b/cc/tiles/tile_manager_unittest.cc index d497d963f..6497489 100644 --- a/cc/tiles/tile_manager_unittest.cc +++ b/cc/tiles/tile_manager_unittest.cc
@@ -1369,11 +1369,12 @@ EXPECT_FALSE(queue->IsEmpty()); EXPECT_TRUE(queue->Top().tile()->required_for_draw()); EXPECT_EQ(gfx::Size(256, 256), queue->Top().tile()->desired_texture_size()); - EXPECT_EQ(RGBA_8888, host_impl()->resource_provider()->best_texture_format()); + EXPECT_EQ(viz::RGBA_8888, + host_impl()->resource_provider()->best_texture_format()); ManagedMemoryPolicy policy = host_impl()->ActualManagedMemoryPolicy(); policy.bytes_limit_when_visible = ResourceUtil::UncheckedSizeInBytes<size_t>( - gfx::Size(256, 256), RGBA_8888); + gfx::Size(256, 256), viz::RGBA_8888); host_impl()->SetMemoryPolicy(policy); EXPECT_FALSE(host_impl()->is_likely_to_require_a_draw()); @@ -1381,7 +1382,7 @@ EXPECT_TRUE(host_impl()->is_likely_to_require_a_draw()); Resource* resource = host_impl()->resource_pool()->AcquireResource( - gfx::Size(256, 256), RGBA_8888, gfx::ColorSpace()); + gfx::Size(256, 256), viz::RGBA_8888, gfx::ColorSpace()); host_impl()->tile_manager()->CheckIfMoreTilesNeedToBePreparedForTesting(); EXPECT_FALSE(host_impl()->is_likely_to_require_a_draw()); @@ -1929,7 +1930,7 @@ // Ensure there's a resource with our |kInvalidatedId| in the resource pool. auto* resource = host_impl->resource_pool()->AcquireResource( - kTileSize, RGBA_8888, gfx::ColorSpace()); + kTileSize, viz::RGBA_8888, gfx::ColorSpace()); host_impl->resource_pool()->OnContentReplaced(resource->id(), kInvalidatedId); host_impl->resource_pool()->ReleaseResource(resource); host_impl->resource_pool()->CheckBusyResources();
diff --git a/cc/trees/layer_tree_host.h b/cc/trees/layer_tree_host.h index 6b742a01..1ef7a20 100644 --- a/cc/trees/layer_tree_host.h +++ b/cc/trees/layer_tree_host.h
@@ -35,7 +35,6 @@ #include "cc/layers/layer_list_iterator.h" #include "cc/output/layer_tree_frame_sink.h" #include "cc/output/swap_promise.h" -#include "cc/resources/resource_format.h" #include "cc/surfaces/surface_reference_owner.h" #include "cc/surfaces/surface_sequence_generator.h" #include "cc/trees/compositor_mode.h" @@ -45,6 +44,7 @@ #include "cc/trees/proxy.h" #include "cc/trees/swap_promise_manager.h" #include "cc/trees/target_property.h" +#include "components/viz/common/quads/resource_format.h" #include "third_party/skia/include/core/SkColor.h" #include "ui/gfx/geometry/rect.h"
diff --git a/cc/trees/layer_tree_host_impl.cc b/cc/trees/layer_tree_host_impl.cc index 99f22caa..63d133c 100644 --- a/cc/trees/layer_tree_host_impl.cc +++ b/cc/trees/layer_tree_host_impl.cc
@@ -4050,15 +4050,15 @@ return; } - ResourceFormat format = resource_provider_->best_texture_format(); + viz::ResourceFormat format = resource_provider_->best_texture_format(); switch (bitmap.GetFormat()) { case UIResourceBitmap::RGBA8: break; case UIResourceBitmap::ALPHA_8: - format = ALPHA_8; + format = viz::ALPHA_8; break; case UIResourceBitmap::ETC1: - format = ETC1; + format = viz::ETC1; break; }
diff --git a/cc/trees/layer_tree_host_impl_unittest.cc b/cc/trees/layer_tree_host_impl_unittest.cc index ea14f33..850284f 100644 --- a/cc/trees/layer_tree_host_impl_unittest.cc +++ b/cc/trees/layer_tree_host_impl_unittest.cc
@@ -7423,7 +7423,7 @@ resource_id_(resource_provider->CreateResource( gfx::Size(1, 1), ResourceProvider::TEXTURE_HINT_IMMUTABLE, - RGBA_8888, + viz::RGBA_8888, gfx::ColorSpace())) { resource_provider->AllocateForTesting(resource_id_); SetBounds(gfx::Size(10, 10));
diff --git a/cc/trees/layer_tree_host_unittest_context.cc b/cc/trees/layer_tree_host_unittest_context.cc index e7429b2..55b84af 100644 --- a/cc/trees/layer_tree_host_unittest_context.cc +++ b/cc/trees/layer_tree_host_unittest_context.cc
@@ -888,8 +888,8 @@ gpu::gles2::GLES2Interface* gl = child_context_provider_->ContextGL(); ResourceId resource = child_resource_provider_->CreateResource( - gfx::Size(4, 4), ResourceProvider::TEXTURE_HINT_IMMUTABLE, RGBA_8888, - gfx::ColorSpace()); + gfx::Size(4, 4), ResourceProvider::TEXTURE_HINT_IMMUTABLE, + viz::RGBA_8888, gfx::ColorSpace()); ResourceProvider::ScopedWriteLockGL lock(child_resource_provider_.get(), resource, false);
diff --git a/cc/trees/layer_tree_settings.cc b/cc/trees/layer_tree_settings.cc index b11b107..5586f35 100644 --- a/cc/trees/layer_tree_settings.cc +++ b/cc/trees/layer_tree_settings.cc
@@ -4,7 +4,7 @@ #include "cc/trees/layer_tree_settings.h" -#include "cc/resources/platform_color.h" +#include "components/viz/common/resources/platform_color.h" #include "third_party/khronos/GLES2/gl2.h" namespace cc { @@ -19,7 +19,7 @@ software_memory_policy(128 * 1024 * 1024, gpu::MemoryAllocation::CUTOFF_ALLOW_NICE_TO_HAVE, ManagedMemoryPolicy::kDefaultNumResourcesLimit), - preferred_tile_format(PlatformColor::BestTextureFormat()) {} + preferred_tile_format(viz::PlatformColor::BestTextureFormat()) {} LayerTreeSettings::LayerTreeSettings(const LayerTreeSettings& other) = default; LayerTreeSettings::~LayerTreeSettings() = default;
diff --git a/cc/trees/layer_tree_settings.h b/cc/trees/layer_tree_settings.h index 7010581..a154d9b 100644 --- a/cc/trees/layer_tree_settings.h +++ b/cc/trees/layer_tree_settings.h
@@ -14,10 +14,10 @@ #include "cc/debug/layer_tree_debug_state.h" #include "cc/output/managed_memory_policy.h" #include "cc/output/renderer_settings.h" -#include "cc/resources/resource_format.h" #include "cc/resources/resource_settings.h" #include "cc/scheduler/scheduler_settings.h" #include "cc/tiles/tile_manager_settings.h" +#include "components/viz/common/quads/resource_format.h" #include "third_party/skia/include/core/SkColor.h" #include "ui/gfx/geometry/size.h" @@ -88,7 +88,7 @@ size_t decoded_image_cache_budget_bytes = 128 * 1024 * 1024; size_t decoded_image_working_set_budget_bytes = 128 * 1024 * 1024; int max_preraster_distance_in_screen_pixels = 1000; - ResourceFormat preferred_tile_format; + viz::ResourceFormat preferred_tile_format; bool enable_color_correct_rasterization = false;
diff --git a/chrome/VERSION b/chrome/VERSION index c1e4964..1bb73ad 100644 --- a/chrome/VERSION +++ b/chrome/VERSION
@@ -1,4 +1,4 @@ MAJOR=61 MINOR=0 -BUILD=3152 +BUILD=3154 PATCH=0
diff --git a/chrome/android/java/src/org/chromium/chrome/browser/infobar/InfoBarContainerLayout.java b/chrome/android/java/src/org/chromium/chrome/browser/infobar/InfoBarContainerLayout.java index fd259f0..82c333b 100644 --- a/chrome/android/java/src/org/chromium/chrome/browser/infobar/InfoBarContainerLayout.java +++ b/chrome/android/java/src/org/chromium/chrome/browser/infobar/InfoBarContainerLayout.java
@@ -15,8 +15,6 @@ import android.view.Gravity; import android.view.MotionEvent; import android.view.View; -import android.view.ViewGroup; -import android.view.ViewGroup.LayoutParams; import android.widget.FrameLayout; import org.chromium.base.ObserverList; @@ -24,7 +22,6 @@ import org.chromium.chrome.browser.infobar.InfoBarContainer.InfoBarAnimationListener; import java.util.ArrayList; -import java.util.List; /** * Layout that displays infobars in a stack. Handles all the animations when adding or removing @@ -115,15 +112,6 @@ Resources res = context.getResources(); mBackInfobarHeight = res.getDimensionPixelSize(R.dimen.infobar_peeking_height); mFloatingBehavior = new FloatingBehavior(this); - mBackgroundPeekSize = getResources().getDimensionPixelSize(R.dimen.infobar_compact_size); - mInfoBarShadowHeight = getResources().getDimensionPixelSize(R.dimen.infobar_shadow_height); - } - - @Override - public void onAttachedToWindow() { - super.onAttachedToWindow(); - - mBottomContainer = (ViewGroup) getRootView().findViewById(R.id.bottom_container); } /** @@ -187,20 +175,10 @@ // Animation durations. private static final int DURATION_SLIDE_UP_MS = 250; - private static final int DURATION_PEEK_MS = 500; private static final int DURATION_SLIDE_DOWN_MS = 250; private static final int DURATION_FADE_MS = 100; private static final int DURATION_FADE_OUT_MS = 200; - /** The height that an infobar will peek when being added behind another one. */ - private final int mBackgroundPeekSize; - - /** The height of the shadow that sits above the infobar. */ - private final int mInfoBarShadowHeight; - - /** The bottom container that the infobar container sits inside of. */ - private ViewGroup mBottomContainer; - /** * Base class for animations inside the InfoBarContainerLayout. * @@ -237,10 +215,11 @@ * value to endValue and updates the side shadow positions on each frame. */ ValueAnimator createTranslationYAnimator(final InfoBarWrapper wrapper, float endValue) { - ValueAnimator animator = ObjectAnimator.ofFloat(wrapper, View.TRANSLATION_Y, endValue); + ValueAnimator animator = ValueAnimator.ofFloat(wrapper.getTranslationY(), endValue); animator.addUpdateListener(new ValueAnimator.AnimatorUpdateListener() { @Override public void onAnimationUpdate(ValueAnimator animation) { + wrapper.setTranslationY((float) animation.getAnimatedValue()); mFloatingBehavior.updateShadowPosition(); } }); @@ -428,39 +407,14 @@ @Override Animator createAnimator() { - AnimatorSet set = new AnimatorSet(); - List<Animator> animators = new ArrayList<>(); - mAppearingWrapper.setTranslationY(mAppearingWrapper.getHeight()); - mAppearingWrapper.setRestrictHeightForAnimation(true); - mAppearingWrapper.setHeightForAnimation(mInfoBarShadowHeight + mBackgroundPeekSize); - mAppearingWrapper.addView(mAppearingWrapper.getItem().getView()); - ValueAnimator animator = createTranslationYAnimator( - mAppearingWrapper, mBackInfobarHeight - mBackgroundPeekSize); - animators.add(animator); - - animators.add(createTranslationYAnimator(mAppearingWrapper, 0)); - - // When the infobar container is running this specific animation, do not clip the - // children so the infobars can animate outside their container. - set.addListener(new AnimatorListenerAdapter() { - @Override - public void onAnimationStart(Animator animation) { - setHierarchyClipsChildren(false); - } - }); - - set.playSequentially(animators); - set.setDuration(DURATION_PEEK_MS); - - return set; + return createTranslationYAnimator(mAppearingWrapper, 0f) + .setDuration(DURATION_SLIDE_UP_MS); } @Override public void onAnimationEnd() { - mAppearingWrapper.setRestrictHeightForAnimation(false); mAppearingWrapper.removeView(mAppearingWrapper.getItem().getView()); - setHierarchyClipsChildren(true); } @Override @@ -470,17 +424,6 @@ } /** - * Used to set the relevant view hierarchy to not clip its children. This is used during - * animation so views can draw outside the normal bounds. - * @param clip Whether or not to clip child views. - */ - private void setHierarchyClipsChildren(boolean clip) { - setClipChildren(clip); - ((ViewGroup) getParent()).setClipChildren(clip); - mBottomContainer.setClipChildren(clip); - } - - /** * The animation to hide the front infobar and reveal the second-to-front infobar. The front * infobar slides down and off the screen. The back infobar(s) will adjust to the size of the * new front infobar, and then the new front infobar's contents will fade in. @@ -899,10 +842,7 @@ protected void onMeasure(int widthMeasureSpec, int heightMeasureSpec) { widthMeasureSpec = mFloatingBehavior.beforeOnMeasure(widthMeasureSpec); super.onMeasure(widthMeasureSpec, heightMeasureSpec); - - // Make sure the shadow is tall enough to compensate for the peek animation of other - // infboars. - mFloatingBehavior.afterOnMeasure(getMeasuredHeight() + mBackgroundPeekSize); + mFloatingBehavior.afterOnMeasure(getMeasuredHeight()); } @Override
diff --git a/chrome/android/java/src/org/chromium/chrome/browser/infobar/InfoBarWrapper.java b/chrome/android/java/src/org/chromium/chrome/browser/infobar/InfoBarWrapper.java index c64ded9e..f0c5e8c 100644 --- a/chrome/android/java/src/org/chromium/chrome/browser/infobar/InfoBarWrapper.java +++ b/chrome/android/java/src/org/chromium/chrome/browser/infobar/InfoBarWrapper.java
@@ -19,15 +19,6 @@ private final InfoBarContainerLayout.Item mItem; - /** Whether or not the height of the layout should be restricted for animations. */ - private boolean mRestrictHeightForAnimation; - - /** - * The height in px that this view will be restricted to if - * {@link #mRestrictHeightForAnimation} is set. - */ - private int mHeightForAnimationPx; - /** * Constructor for inflating from Java. */ @@ -42,22 +33,6 @@ // setBackgroundResource() changes the padding, so call setPadding() second. setBackgroundResource(R.drawable.infobar_wrapper_bg); setPadding(0, shadowHeight, 0, 0); - setClipChildren(true); - } - - /** - * @param restrict Whether or not the height of this view should be restricted for animations. - */ - public void setRestrictHeightForAnimation(boolean restrict) { - mRestrictHeightForAnimation = restrict; - } - - /** - * @param heightPx The restricted height in px that will be used if - * {@link #mRestrictHeightForAnimation} is set. - */ - public void setHeightForAnimation(int heightPx) { - mHeightForAnimationPx = heightPx; } InfoBarContainerLayout.Item getItem() { @@ -65,16 +40,6 @@ } @Override - public void onMeasure(int widthSpec, int heightSpec) { - if (mRestrictHeightForAnimation) { - int heightPx = Math.min(mHeightForAnimationPx, MeasureSpec.getSize(heightSpec)); - heightSpec = MeasureSpec.makeMeasureSpec(heightPx, MeasureSpec.getMode(heightSpec)); - } - - super.onMeasure(widthSpec, heightSpec); - } - - @Override public void onViewAdded(View child) { child.setLayoutParams(new LayoutParams(LayoutParams.MATCH_PARENT, LayoutParams.WRAP_CONTENT, Gravity.TOP));
diff --git a/chrome/android/java/src/org/chromium/chrome/browser/vr_shell/VrShellDelegate.java b/chrome/android/java/src/org/chromium/chrome/browser/vr_shell/VrShellDelegate.java index 5786caf..fdc2049 100644 --- a/chrome/android/java/src/org/chromium/chrome/browser/vr_shell/VrShellDelegate.java +++ b/chrome/android/java/src/org/chromium/chrome/browser/vr_shell/VrShellDelegate.java
@@ -980,6 +980,8 @@ unregisterDaydreamIntent(mVrDaydreamApi); if (mVrSupportLevel == VR_NOT_AVAILABLE) return; + if (mInVr) mVSyncEstimator.pause(); + cancelPendingVrEntry(); // When the active web page has a vrdisplayactivate event handler, @@ -1000,10 +1002,7 @@ cancelPendingVrEntry(); // We defer pausing of VrShell until the app is stopped to keep head tracking working for // as long as possible while going to daydream home. - if (mInVr) { - mVrShell.pause(); - mVSyncEstimator.pause(); - } + if (mInVr) mVrShell.pause(); if (mShowingDaydreamDoff || mProbablyInDon) return; // TODO(mthiesse): When the user resumes Chrome in a 2D context, we don't want to tear down
diff --git a/chrome/android/java/src/org/chromium/chrome/browser/webapps/WebappDirectoryManager.java b/chrome/android/java/src/org/chromium/chrome/browser/webapps/WebappDirectoryManager.java index a811afa..5d7631d 100644 --- a/chrome/android/java/src/org/chromium/chrome/browser/webapps/WebappDirectoryManager.java +++ b/chrome/android/java/src/org/chromium/chrome/browser/webapps/WebappDirectoryManager.java
@@ -111,28 +111,24 @@ } } - if (webappBaseDirectory != null) { - // Delete all web app directories in the main directory, which were for pre-L web apps. - File appDirectory = new File(context.getApplicationInfo().dataDir); - String webappDirectoryAppBaseName = webappBaseDirectory.getName(); - File[] files = appDirectory.listFiles(); - if (files != null) { - for (File file : files) { - String filename = file.getName(); - if (!filename.startsWith(webappDirectoryAppBaseName)) continue; - if (filename.length() == webappDirectoryAppBaseName.length()) continue; - directoriesToDelete.add(file); - } + // Delete all web app directories in the main directory, which were for pre-L web apps. + File appDirectory = new File(context.getApplicationInfo().dataDir); + String webappDirectoryAppBaseName = webappBaseDirectory.getName(); + File[] files = appDirectory.listFiles(); + if (files != null) { + for (File file : files) { + String filename = file.getName(); + if (!filename.startsWith(webappDirectoryAppBaseName)) continue; + if (filename.length() == webappDirectoryAppBaseName.length()) continue; + directoriesToDelete.add(file); } + } - // Clean out web app directories no longer corresponding to tasks in Recents. - if (webappBaseDirectory.exists()) { - files = webappBaseDirectory.listFiles(); - if (files != null) { - for (File file : files) { - if (!liveWebapps.contains(file.getName())) directoriesToDelete.add(file); - } - } + // Clean out web app directories no longer corresponding to tasks in Recents. + files = webappBaseDirectory.listFiles(); + if (files != null) { + for (File file : files) { + if (!liveWebapps.contains(file.getName())) directoriesToDelete.add(file); } } }
diff --git a/chrome/app/settings_strings.grdp b/chrome/app/settings_strings.grdp index 54baa96..1991bbc3 100644 --- a/chrome/app/settings_strings.grdp +++ b/chrome/app/settings_strings.grdp
@@ -1636,6 +1636,15 @@ <message name="IDS_SETTINGS_ON_STARTUP" desc="Name of the on startup page."> On startup </message> + <message name="IDS_SETTINGS_ON_STARTUP_DESCRIPTION" desc="Secondary line for IDS_SETTINGS_ON_STARTUP_MANAGE describing the OnStartup features."> + Restore tabs or open specific pages + </message> + <message name="IDS_SETTINGS_ON_STARTUP_MANAGE" desc="Button label to open subpage for OnStartup URLs and heading for that subpage."> + Manage on startup pages + </message> + <message name="IDS_SETTINGS_ON_STARTUP_PAGES" desc="Label for list of OnStartup URLs."> + Pages to open on startup + </message> <message name="IDS_SETTINGS_ON_STARTUP_OPEN_NEW_TAB" desc="Radio button option to open the new tab page."> Open the New Tab page </message>
diff --git a/chrome/browser/about_flags.cc b/chrome/browser/about_flags.cc index 0e45042..d2ad4bf2 100644 --- a/chrome/browser/about_flags.cc +++ b/chrome/browser/about_flags.cc
@@ -64,6 +64,7 @@ #include "components/password_manager/core/common/password_manager_features.h" #include "components/previews/core/previews_features.h" #include "components/proximity_auth/switches.h" +#include "components/search_provider_logos/features.h" #include "components/security_state/core/security_state.h" #include "components/security_state/core/switches.h" #include "components/signin/core/common/signin_features.h" @@ -1081,6 +1082,15 @@ {"14px vertical margin", kOmniboxUIVerticalMargin14px, arraysize(kOmniboxUIVerticalMargin14px), nullptr}}; +const FeatureEntry::FeatureParam kClientPlaceholdersForServerLoFiEnabled[] = { + {"replace_server_placeholders", "true"}}; + +const FeatureEntry::FeatureVariation + kClientPlaceholdersForServerLoFiFeatureVariations[] = { + {"(replace Server Lo-Fi placeholders)", + kClientPlaceholdersForServerLoFiEnabled, + arraysize(kClientPlaceholdersForServerLoFiEnabled), nullptr}}; + // RECORDING USER METRICS FOR FLAGS: // ----------------------------------------------------------------------------- // The first line of the entry is the internal name. @@ -1994,10 +2004,13 @@ {"enable-offline-previews", flag_descriptions::kEnableOfflinePreviewsName, flag_descriptions::kEnableOfflinePreviewsDescription, kOsAndroid, FEATURE_VALUE_TYPE(previews::features::kOfflinePreviews)}, - {"enable-client-lo-fi", flag_descriptions::kEnableClientLoFiName, - flag_descriptions::kEnableClientLoFiDescription, kOsAndroid, - FEATURE_VALUE_TYPE(previews::features::kClientLoFi)}, #endif // OS_ANDROID + {"enable-client-lo-fi", flag_descriptions::kEnableClientLoFiName, + flag_descriptions::kEnableClientLoFiDescription, kOsAll, + FEATURE_WITH_PARAMS_VALUE_TYPE( + previews::features::kClientLoFi, + kClientPlaceholdersForServerLoFiFeatureVariations, + "PreviewsClientLoFi")}, {"allow-insecure-localhost", flag_descriptions::kAllowInsecureLocalhostName, flag_descriptions::kAllowInsecureLocalhostDescription, kOsAll, SINGLE_VALUE_TYPE(switches::kAllowInsecureLocalhost)}, @@ -3131,6 +3144,12 @@ flag_descriptions::kEnableNetworkServiceDescription, kOsAll, FEATURE_VALUE_TYPE(features::kNetworkService)}, +#if defined(OS_ANDROID) + {"use-ddljson-api", flag_descriptions::kUseDdljsonApiName, + flag_descriptions::kUseDdljsonApiDescription, kOsAndroid, + FEATURE_VALUE_TYPE(search_provider_logos::features::kUseDdljsonApi)}, +#endif // defined(OS_ANDROID) + // NOTE: Adding new command-line switches requires adding corresponding // entries to enum "LoginCustomFlags" in histograms/enums.xml. See note in // enums.xml and don't forget to run AboutFlagsHistogramTest unit test.
diff --git a/chrome/browser/android/logo_service.cc b/chrome/browser/android/logo_service.cc index c2fd971e..feb9ddc 100644 --- a/chrome/browser/android/logo_service.cc +++ b/chrome/browser/android/logo_service.cc
@@ -5,6 +5,7 @@ #include "chrome/browser/android/logo_service.h" #include "base/command_line.h" +#include "base/feature_list.h" #include "base/macros.h" #include "base/memory/weak_ptr.h" #include "chrome/browser/android/chrome_feature_list.h" @@ -30,17 +31,6 @@ const char kCachedLogoDirectory[] = "Search Logo"; const int kDecodeLogoTimeoutSeconds = 30; -// Returns the URL where the doodle can be downloaded, e.g. -// https://www.google.com/async/newtab_mobile. This depends on the user's -// Google domain. -GURL GetGoogleDoodleURL(Profile* profile) { - GURL google_base_url(UIThreadSearchTermsData(profile).GoogleBaseURLValue()); - const char kGoogleDoodleURLPath[] = "async/newtab_mobile"; - GURL::Replacements replacements; - replacements.SetPathStr(kGoogleDoodleURLPath); - return google_base_url.ReplaceComponents(replacements); -} - class LogoDecoderDelegate : public ImageDecoder::ImageRequest { public: LogoDecoderDelegate( @@ -139,22 +129,25 @@ profile_->GetRequestContext(), base::MakeUnique<ChromeLogoDelegate>()); } - GURL url = use_fixed_logo ? logo_url : GetGoogleDoodleURL(profile_); - auto parse_logo_response_callback = - use_fixed_logo - ? base::Bind(&search_provider_logos::ParseFixedLogoResponse) - : base::Bind(&search_provider_logos::GoogleParseLogoResponse); + if (use_fixed_logo) { + logo_tracker_->SetServerAPI( + logo_url, base::Bind(&search_provider_logos::ParseFixedLogoResponse), + base::Bind(&search_provider_logos::UseFixedLogoUrl)); + } else { + GURL google_base_url = + GURL(UIThreadSearchTermsData(profile_).GoogleBaseURLValue()); - bool use_gray_background = - !base::FeatureList::IsEnabled(chrome::android::kChromeHomeFeature); - auto append_query_params_callback = - use_fixed_logo - ? base::Bind(&search_provider_logos::UseFixedLogoUrl) - : base::Bind(&search_provider_logos::GoogleAppendQueryparamsToLogoURL, - use_gray_background); + bool use_gray_background = + !base::FeatureList::IsEnabled(chrome::android::kChromeHomeFeature); - logo_tracker_->SetServerAPI(url, parse_logo_response_callback, - append_query_params_callback); + logo_tracker_->SetServerAPI( + search_provider_logos::GetGoogleDoodleURL(google_base_url), + search_provider_logos::GetGoogleParseLogoResponseCallback( + google_base_url), + search_provider_logos::GetGoogleAppendQueryparamsCallback( + use_gray_background)); + } + logo_tracker_->GetLogo(observer); }
diff --git a/chrome/browser/browsing_data/chrome_browsing_data_remover_delegate.cc b/chrome/browser/browsing_data/chrome_browsing_data_remover_delegate.cc index c1ffa1c3b..0cdfbea 100644 --- a/chrome/browser/browsing_data/chrome_browsing_data_remover_delegate.cc +++ b/chrome/browser/browsing_data/chrome_browsing_data_remover_delegate.cc
@@ -4,6 +4,8 @@ #include "chrome/browser/browsing_data/chrome_browsing_data_remover_delegate.h" +#include <stdint.h> + #include <set> #include <string> #include <utility> @@ -193,8 +195,8 @@ DCHECK_CURRENTLY_ON(BrowserThread::IO); net::CookieStore* cookie_store = rq_context->GetURLRequestContext()->cookie_store(); - cookie_store->DeleteAllCreatedBetweenAsync(delete_begin, delete_end, - IgnoreArgument<int>(callback)); + cookie_store->DeleteAllCreatedBetweenAsync( + delete_begin, delete_end, IgnoreArgument<uint32_t>(callback)); } void ClearCookiesWithPredicateOnIOThread( @@ -207,7 +209,7 @@ net::CookieStore* cookie_store = rq_context->GetURLRequestContext()->cookie_store(); cookie_store->DeleteAllCreatedBetweenWithPredicateAsync( - delete_begin, delete_end, predicate, IgnoreArgument<int>(callback)); + delete_begin, delete_end, predicate, IgnoreArgument<uint32_t>(callback)); } void ClearNetworkPredictorOnIOThread(chrome_browser_net::Predictor* predictor) {
diff --git a/chrome/browser/browsing_data/chrome_browsing_data_remover_delegate_unittest.cc b/chrome/browser/browsing_data/chrome_browsing_data_remover_delegate_unittest.cc index 05c1b04e..3fe46b93 100644 --- a/chrome/browser/browsing_data/chrome_browsing_data_remover_delegate_unittest.cc +++ b/chrome/browser/browsing_data/chrome_browsing_data_remover_delegate_unittest.cc
@@ -4,6 +4,8 @@ #include "chrome/browser/browsing_data/chrome_browsing_data_remover_delegate.h" +#include <stdint.h> + #include "base/guid.h" #include "base/memory/ptr_util.h" #include "base/message_loop/message_loop.h" @@ -233,7 +235,7 @@ }; void RunClosureAfterCookiesCleared(const base::Closure& task, - int cookies_deleted) { + uint32_t cookies_deleted) { task.Run(); }
diff --git a/chrome/browser/chrome_content_gpu_manifest_overlay.json b/chrome/browser/chrome_content_gpu_manifest_overlay.json index 7e275bf..6f9513d 100644 --- a/chrome/browser/chrome_content_gpu_manifest_overlay.json +++ b/chrome/browser/chrome_content_gpu_manifest_overlay.json
@@ -6,6 +6,8 @@ "browser": [ "arc::mojom::VideoDecodeAccelerator", "arc::mojom::VideoDecodeClient", + "arc::mojom::VideoEncodeAccelerator", + "arc::mojom::VideoEncodeClient", "chrome::mojom::ResourceUsageReporter" ] }
diff --git a/chrome/browser/chromeos/arc/video/gpu_arc_video_service_host.cc b/chrome/browser/chromeos/arc/video/gpu_arc_video_service_host.cc index 75b859203..70b43767 100644 --- a/chrome/browser/chromeos/arc/video/gpu_arc_video_service_host.cc +++ b/chrome/browser/chromeos/arc/video/gpu_arc_video_service_host.cc
@@ -31,6 +31,11 @@ content::BindInterfaceInGpuProcess(std::move(request)); } +void ConnectToVideoEncodeAcceleratorOnIOThread( + mojom::VideoEncodeAcceleratorRequest request) { + content::BindInterfaceInGpuProcess(std::move(request)); +} + } // namespace class VideoAcceleratorFactoryService : public mojom::VideoAcceleratorFactory { @@ -47,7 +52,10 @@ void CreateEncodeAccelerator( mojom::VideoEncodeAcceleratorRequest request) override { - // TODO(owenlin): Implement this function. + content::BrowserThread::PostTask( + content::BrowserThread::IO, FROM_HERE, + base::BindOnce(&ConnectToVideoEncodeAcceleratorOnIOThread, + base::Passed(&request))); } private:
diff --git a/chrome/browser/chromeos/attestation/platform_verification_impl.cc b/chrome/browser/chromeos/attestation/platform_verification_impl.cc index 13640901..f6aee0b4 100644 --- a/chrome/browser/chromeos/attestation/platform_verification_impl.cc +++ b/chrome/browser/chromeos/attestation/platform_verification_impl.cc
@@ -41,7 +41,7 @@ void PlatformVerificationImpl::ChallengePlatform( const std::string& service_id, const std::string& challenge, - const ChallengePlatformCallback& callback) { + ChallengePlatformCallback callback) { DVLOG(2) << __FUNCTION__; DCHECK_CURRENTLY_ON(content::BrowserThread::UI); @@ -50,12 +50,13 @@ platform_verification_flow_->ChallengePlatformKey( content::WebContents::FromRenderFrameHost(render_frame_host_), service_id, - challenge, base::Bind(&PlatformVerificationImpl::OnPlatformChallenged, - weak_factory_.GetWeakPtr(), callback)); + challenge, + base::Bind(&PlatformVerificationImpl::OnPlatformChallenged, + weak_factory_.GetWeakPtr(), base::Passed(&callback))); } void PlatformVerificationImpl::OnPlatformChallenged( - const ChallengePlatformCallback& callback, + ChallengePlatformCallback callback, Result result, const std::string& signed_data, const std::string& signature, @@ -68,14 +69,15 @@ DCHECK(signature.empty()); DCHECK(platform_key_certificate.empty()); LOG(ERROR) << "Platform verification failed."; - callback.Run(false, "", "", ""); + std::move(callback).Run(false, "", "", ""); return; } DCHECK(!signed_data.empty()); DCHECK(!signature.empty()); DCHECK(!platform_key_certificate.empty()); - callback.Run(true, signed_data, signature, platform_key_certificate); + std::move(callback).Run(true, signed_data, signature, + platform_key_certificate); } } // namespace attestation
diff --git a/chrome/browser/chromeos/attestation/platform_verification_impl.h b/chrome/browser/chromeos/attestation/platform_verification_impl.h index fe9032b..f0bb6c9 100644 --- a/chrome/browser/chromeos/attestation/platform_verification_impl.h +++ b/chrome/browser/chromeos/attestation/platform_verification_impl.h
@@ -33,12 +33,12 @@ // mojo::InterfaceImpl<PlatformVerification> implementation. void ChallengePlatform(const std::string& service_id, const std::string& challenge, - const ChallengePlatformCallback& callback) override; + ChallengePlatformCallback callback) override; private: using Result = PlatformVerificationFlow::Result; - void OnPlatformChallenged(const ChallengePlatformCallback& callback, + void OnPlatformChallenged(ChallengePlatformCallback callback, Result result, const std::string& signed_data, const std::string& signature,
diff --git a/chrome/browser/chromeos/login/lock/webui_screen_locker.cc b/chrome/browser/chromeos/login/lock/webui_screen_locker.cc index 6e109bc..532b557e 100644 --- a/chrome/browser/chromeos/login/lock/webui_screen_locker.cc +++ b/chrome/browser/chromeos/login/lock/webui_screen_locker.cc
@@ -40,6 +40,7 @@ #include "content/public/browser/web_contents.h" #include "content/public/browser/web_ui.h" #include "ui/aura/client/capture_client.h" +#include "ui/aura/window.h" #include "ui/aura/window_event_dispatcher.h" #include "ui/base/l10n/l10n_util.h" #include "ui/base/x/x11_util.h"
diff --git a/chrome/browser/extensions/api/desktop_capture/desktop_capture_base.cc b/chrome/browser/extensions/api/desktop_capture/desktop_capture_base.cc index 05ca164..93df4fd4 100644 --- a/chrome/browser/extensions/api/desktop_capture/desktop_capture_base.cc +++ b/chrome/browser/extensions/api/desktop_capture/desktop_capture_base.cc
@@ -20,6 +20,7 @@ #include "chrome/browser/ui/browser_finder.h" #include "chrome/browser/ui/browser_window.h" #include "chrome/grit/chromium_strings.h" +#include "content/public/browser/desktop_capture.h" #include "content/public/browser/render_frame_host.h" #include "content/public/browser/render_process_host.h" #include "content/public/browser/web_contents.h" @@ -119,12 +120,10 @@ screen_list = base::MakeUnique<DesktopMediaListAsh>( DesktopMediaID::TYPE_SCREEN); #else // !defined(USE_ASH) - webrtc::DesktopCaptureOptions capture_options = - webrtc::DesktopCaptureOptions::CreateDefault(); - capture_options.set_disable_effects(false); screen_list = base::MakeUnique<NativeDesktopMediaList>( - DesktopMediaID::TYPE_SCREEN, - webrtc::DesktopCapturer::CreateScreenCapturer(capture_options)); + content::DesktopMediaID::TYPE_SCREEN, + webrtc::DesktopCapturer::CreateScreenCapturer( + content::CreateDesktopCaptureOptions())); #endif // !defined(USE_ASH) } have_screen_list = true; @@ -149,12 +148,10 @@ // windows) created here cannot share the same DesktopCaptureOptions // instance. DesktopCaptureOptions owns X connection, which cannot be // used on multiple threads concurrently. - webrtc::DesktopCaptureOptions capture_options = - webrtc::DesktopCaptureOptions::CreateDefault(); - capture_options.set_disable_effects(false); window_list = base::MakeUnique<NativeDesktopMediaList>( - DesktopMediaID::TYPE_WINDOW, - webrtc::DesktopCapturer::CreateWindowCapturer(capture_options)); + content::DesktopMediaID::TYPE_WINDOW, + webrtc::DesktopCapturer::CreateWindowCapturer( + content::CreateDesktopCaptureOptions())); #endif // !defined(USE_ASH) } have_window_list = true;
diff --git a/chrome/browser/favicon/content_favicon_driver_browsertest.cc b/chrome/browser/favicon/content_favicon_driver_browsertest.cc index b0182bf..957545e6 100644 --- a/chrome/browser/favicon/content_favicon_driver_browsertest.cc +++ b/chrome/browser/favicon/content_favicon_driver_browsertest.cc
@@ -54,13 +54,6 @@ private: // content::ResourceDispatcherHostDelegate: - bool ShouldBeginRequest(const std::string& method, - const GURL& url, - content::ResourceType resource_type, - content::ResourceContext* resource_context) override { - return true; - } - void RequestBeginning(net::URLRequest* request, content::ResourceContext* resource_context, content::AppCacheService* appcache_service,
diff --git a/chrome/browser/flag_descriptions.cc b/chrome/browser/flag_descriptions.cc index 912f646ce..672ffc3 100644 --- a/chrome/browser/flag_descriptions.cc +++ b/chrome/browser/flag_descriptions.cc
@@ -6,52 +6,511 @@ namespace flag_descriptions { -const char kBrowserSideNavigationName[] = "Enable browser side navigation"; +const char kAccelerated2dCanvasName[] = "Accelerated 2D canvas"; +const char kAccelerated2dCanvasDescription[] = + "Enables the use of the GPU to perform 2d canvas rendering instead of " + "using software rendering."; +const char kAcceleratedVideoDecodeName[] = "Hardware-accelerated video decode"; +const char kAcceleratedVideoDecodeDescription[] = + "Hardware-accelerated video decode where available."; + +const char kAffiliationBasedMatchingName[] = + "Affiliation based matching in password manager"; +const char kAffiliationBasedMatchingDescription[] = + "Allow credentials stored for Android applications to be filled into " + "corresponding websites."; + +const char kAllowInsecureLocalhostName[] = + "Allow invalid certificates for resources loaded from localhost."; +const char kAllowInsecureLocalhostDescription[] = + "Allows requests to localhost over HTTPS even when an invalid certificate " + "is presented."; + +const char kAllowNaclSocketApiName[] = "NaCl Socket API."; +const char kAllowNaclSocketApiDescription[] = + "Allows applications to use NaCl Socket API. Use only to test NaCl " + "plugins."; + +const char kAppBannersName[] = "App Banners"; +const char kAppBannersDescription[] = + "Enable the display of Progressive Web App banners, which prompt a user to " + "add a web app to their shelf, or other platform-specific equivalent."; + +const char kAutoplayPolicyName[] = "Autoplay policy"; +const char kAutoplayPolicyDescription[] = + "Policy used when deciding if audio or video is allowed to autoplay."; + +const char kAutoplayPolicyUserGestureRequiredForCrossOrigin[] = + "User gesture is required for cross-origin iframes."; +const char kAutoplayPolicyNoUserGestureRequired[] = + "No user gesture is required."; +const char kAutoplayPolicyUserGestureRequired[] = "User gesture is required."; +const char kAutoplayPolicyDocumentUserActivation[] = + "Document user activation is required."; + +const char kBackgroundVideoTrackOptimizationName[] = + "Optimize background video playback."; +const char kBackgroundVideoTrackOptimizationDescription[] = + "Disable video tracks when the video is played in the background to " + "optimize performance."; + +const char kBleAdvertisingInExtensionsName[] = "BLE Advertising in Chrome Apps"; +const char kBleAdvertisingInExtensionsDescription[] = + "Enables BLE Advertising in Chrome Apps. BLE Advertising might interfere " + "with regular use of Bluetooth Low Energy features."; + +const char kBrowserSideNavigationName[] = "Enable browser side navigation"; const char kBrowserSideNavigationDescription[] = "Enable browser side navigation (aka PlzNavigate)."; -// Material Design version of chrome://bookmarks +const char kBrowserTaskSchedulerName[] = "Task Scheduler"; +const char kBrowserTaskSchedulerDescription[] = + "Enables redirection of some task posting APIs to the task scheduler."; + +const char kBypassAppBannerEngagementChecksName[] = + "Bypass user engagement checks"; +const char kBypassAppBannerEngagementChecksDescription[] = + "Bypasses user engagement checks for displaying app banners, such as " + "requiring that users have visited the site before and that the banner " + "hasn't been shown recently. This allows developers to test that other " + "eligibility requirements for showing app banners, such as having a " + "manifest, are met."; + +const char kCaptureThumbnailOnLoadFinishedName[] = + "Capture page thumbnail on load finished"; +const char kCaptureThumbnailOnLoadFinishedDescription[] = + "Capture a page thumbnail (for use on the New Tab page) when the page load " + "finishes, in addition to other times a thumbnail may be captured."; + +const char kCastStreamingHwEncodingName[] = + "Cast Streaming hardware video encoding"; +const char kCastStreamingHwEncodingDescription[] = + "This option enables support in Cast Streaming for encoding video streams " + "using platform hardware."; + +const char kCloudImportName[] = "Cloud Import"; +const char kCloudImportDescription[] = "Allows the cloud-import feature."; + +const char kColorCorrectRenderingName[] = "Color correct rendering"; +const char kColorCorrectRenderingDescription[] = + "Enables color correct rendering of web content."; + +const char kCompositedLayerBordersName[] = "Composited render layer borders"; +const char kCompositedLayerBordersDescription[] = + "Renders a border around composited Render Layers to help debug and study " + "layer compositing."; + +const char kContextualSuggestionsCarouselName[] = + "Enable Contextual Suggestions"; +const char kContextualSuggestionsCarouselDescription[] = + "If enabled, shows contextual suggestions in a horizontal carousel in " + "bottom sheet content."; + +const char kCreditCardAssistName[] = "Credit Card Assisted Filling"; +const char kCreditCardAssistDescription[] = + "Enable assisted credit card filling on certain sites."; + +const char kCrossProcessGuestViewIsolationName[] = + "Cross process frames for guests"; +const char kCrossProcessGuestViewIsolationDescription[] = + "Highly experimental where guests such as <webview> are implemented on " + "the out-of-process iframe infrastructure."; + +const char kDataReductionProxyCarrierTestName[] = + "Enable a carrier-specific Data Reduction Proxy for testing."; +const char kDataReductionProxyCarrierTestDescription[] = + "Use a carrier-specific Data Reduction Proxy for testing."; + +const char kDataReductionProxyLoFiName[] = "Data Saver Lo-Fi mode"; +const char kDataReductionProxyLoFiDescription[] = + "Forces Data Saver Lo-Fi mode to be always enabled, enabled only on " + "cellular connections, or disabled. Data Saver must be enabled for Lo-Fi " + "mode to be used."; +const char kDataReductionProxyLoFiAlwaysOn[] = "Always on"; +const char kDataReductionProxyLoFiCellularOnly[] = "Cellular only"; +const char kDataReductionProxyLoFiDisabled[] = "Disable"; +const char kDataReductionProxyLoFiSlowConnectionsOnly[] = + "Slow connections only"; + +const char kDatasaverPromptName[] = "Cellular Data Saver Prompt"; +const char kDatasaverPromptDescription[] = + "Enables a prompt, which appears when a cellular network connection is " + "detected, to take the user to the Data Saver extension page on Chrome Web " + "Store."; +const char kDatasaverPromptDemoMode[] = "Demo mode"; + +const char kDebugPackedAppName[] = "Debugging for packed apps"; +const char kDebugPackedAppDescription[] = + "Enables debugging context menu options such as Inspect Element for packed " + "applications."; + +const char kDefaultTileHeightName[] = "Default tile height"; +const char kDefaultTileHeightDescription[] = "Specify the default tile height."; +const char kDefaultTileHeightShort[] = "128"; +const char kDefaultTileHeightTall[] = "256"; +const char kDefaultTileHeightGrande[] = "512"; +const char kDefaultTileHeightVenti[] = "1024"; + +const char kDefaultTileWidthName[] = "Default tile width"; +const char kDefaultTileWidthDescription[] = "Specify the default tile width."; +const char kDefaultTileWidthShort[] = "128"; +const char kDefaultTileWidthTall[] = "256"; +const char kDefaultTileWidthGrande[] = "512"; +const char kDefaultTileWidthVenti[] = "1024"; + +const char kDebugShortcutsName[] = "Debugging keyboard shortcuts"; +const char kDebugShortcutsDescription[] = + "Enables additional keyboard shortcuts that are useful for debugging Ash."; + +const char kDeviceDiscoveryNotificationsName[] = + "Device Discovery Notifications"; +const char kDeviceDiscoveryNotificationsDescription[] = + "Device discovery notifications on local network."; + +const char kDevtoolsExperimentsName[] = "Developer Tools experiments"; +const char kDevtoolsExperimentsDescription[] = + "Enables Developer Tools experiments. Use Settings panel in Developer " + "Tools to toggle individual experiments."; + +const char kDisableAudioForDesktopShareName[] = + "Disable Audio For Desktop Share"; +const char kDisableAudioForDesktopShareDescription[] = + "With this flag on, desktop share picker window will not let the user " + "choose whether to share audio."; + +const char kDisableNightLightName[] = "Disable Night Light"; +const char kDisableNightLightDescription[] = + "Disable the Night Light feature which controls the color temperature of " + "the screen."; + +const char kDisableTabForDesktopShareName[] = + "Disable Desktop Share with tab source"; +const char kDisableTabForDesktopShareDescription[] = + "This flag controls whether users can choose a tab for desktop share."; + +const char kDisallowDocWrittenScriptsUiName[] = + "Block scripts loaded via document.write"; +const char kDisallowDocWrittenScriptsUiDescription[] = + "Disallows fetches for third-party parser-blocking scripts inserted into " + "the main frame via document.write."; + +const char kDisplayList2dCanvasName[] = "Display list 2D canvas"; +const char kDisplayList2dCanvasDescription[] = + "Enables the use of display lists to record 2D canvas commands. This " + "allows 2D canvas rasterization to be performed on separate thread."; + +const char kDistanceFieldTextName[] = "Distance field text"; +const char kDistanceFieldTextDescription[] = + "Text is rendered with signed distance fields rather than bitmap alpha " + "masks."; + +const char kDriveSearchInChromeLauncherName[] = + "Drive Search in Chrome App Launcher"; +const char kDriveSearchInChromeLauncherDescription[] = + "Files from Drive will show up when searching the Chrome App Launcher."; + +const char kDropSyncCredentialName[] = + "Drop sync credentials from password manager"; +const char kDropSyncCredentialDescription[] = + "The password manager will not offer to save the credential used to sync."; + +const char kEasyUnlockBluetoothLowEnergyDiscoveryName[] = + "Smart Lock Bluetooth Low Energy Discovery"; +const char kEasyUnlockBluetoothLowEnergyDiscoveryDescription[] = + "Enables a Smart Lock setting that allows Chromebook to discover phones " + "over Bluetooth Low Energy in order to unlock the Chromebook when the " + "phone is in its proximity."; + +const char kEasyUnlockProximityDetectionName[] = + "Smart Lock proximity detection"; +const char kEasyUnlockProximityDetectionDescription[] = + "Enables a Smart Lock setting that restricts unlocking to only work when " + "your phone is very close to (roughly, within an arm's length of) the " + "Chrome device."; + +const char kEmbeddedExtensionOptionsName[] = "Embedded extension options"; +const char kEmbeddedExtensionOptionsDescription[] = + "Display extension options as an embedded element in chrome://extensions " + "rather than opening a new tab."; + +const char kEnableAsmWasmName[] = + "Experimental Validate Asm.js and convert to WebAssembly when valid."; +const char kEnableAsmWasmDescription[] = + R"*(Validate Asm.js when "use asm" is present and then convert to )*" + R"*(WebAssembly.)*"; + +const char kEnableAutofillCreditCardBankNameDisplayName[] = + "Display the issuer bank name of a credit card in autofill."; +const char kEnableAutofillCreditCardBankNameDisplayDescription[] = + "If enabled, displays the issuer bank name of a credit card in autofill."; + +const char kEnableAutofillCreditCardLastUsedDateDisplayName[] = + "Display the last used date of a credit card in autofill."; +const char kEnableAutofillCreditCardLastUsedDateDisplayDescription[] = + "If enabled, display the last used date of a credit card in autofill."; + +const char kEnableAutofillCreditCardUploadCvcPromptName[] = + "Enable requesting missing CVC during Autofill credit card upload"; +const char kEnableAutofillCreditCardUploadCvcPromptDescription[] = + "If enabled, requests missing CVC when offering to upload credit cards to " + "Google Payments."; + +const char kEnableBrotliName[] = "Brotli Content-Encoding."; +const char kEnableBrotliDescription[] = + "Enable Brotli Content-Encoding support."; + +const char kEnableClearBrowsingDataCountersName[] = + "Enable Clear browsing data counters."; +const char kEnableClearBrowsingDataCountersDescription[] = + "Shows data volume counters in the Clear browsing data dialog."; + +const char kEnableClientLoFiName[] = "Client-side Lo-Fi previews"; + +const char kEnableClientLoFiDescription[] = + "Enable showing low fidelity images on some pages on slow networks."; + +const char kEnableDataReductionProxyLitePageName[] = + "Lite pages for Data Saver Lo-Fi mode"; +const char kEnableDataReductionProxyLitePageDescription[] = + "Enable lite pages in Data Saver Lo-Fi mode. Previews of pages will be " + "shown instead of image placeholders when Lo-Fi is on. Data Saver and " + "Lo-Fi must be enabled for lite pages to be shown."; + +const char kDataReductionProxyServerAlternative[] = + "Use alternative server configuration"; +const char kEnableDataReductionProxyServerExperimentName[] = + "Use an alternative Data Saver back end configuration."; +const char kEnableDataReductionProxyServerExperimentDescription[] = + "Enable a different approach to saving data by configuring the back end " + "server"; + +const char kEnableDataReductionProxySavingsPromoName[] = + "Data Saver 1 MB Savings Promo"; +const char kEnableDataReductionProxySavingsPromoDescription[] = + "Enable a Data Saver promo for 1 MB of savings. If Data Saver has already " + "saved 1 MB of data, then the promo will not be shown. Data Saver must be " + "enabled for the promo to be shown."; + +const char kEnableEnumeratingAudioDevicesName[] = + "Experimentally enable enumerating audio devices."; +const char kEnableEnumeratingAudioDevicesDescription[] = + "Experimentally enable the use of enumerating audio devices."; + +const char kEnableGenericSensorName[] = "Generic Sensor"; +const char kEnableGenericSensorDescription[] = + "Enable sensor APIs based on Generic Sensor API."; + +const char kEnableGroupedHistoryName[] = "Group history by domain"; +const char kEnableGroupedHistoryDescription[] = + "Group history by website domain (i.e. google.com) on chrome://history."; + +const char kEnableHDRName[] = "HDR mode"; +const char kEnableHDRDescription[] = + "Enables HDR support on compatible displays."; + +const char kEnableHeapProfilingName[] = "Heap profiling"; +const char kEnableHeapProfilingDescription[] = "Enables heap profiling."; +const char kEnableHeapProfilingModePseudo[] = "Enabled (pseudo mode)"; +const char kEnableHeapProfilingModeNative[] = "Enabled (native mode)"; +const char kEnableHeapProfilingTaskProfiler[] = "Enabled (task mode)"; + +const char kEnableHttpFormWarningName[] = + "Show in-form warnings for sensitive fields when the top-level page is not " + "not HTTPS"; +const char kEnableHttpFormWarningDescription[] = + "Attaches a warning UI to any password or credit card fields detected when " + "the top-level page is not HTTPS"; + +const char kEnableIdleTimeSpellCheckingName[] = + "Enable idle time spell checker"; +const char kEnableIdleTimeSpellCheckingDescription[] = + "Make spell-checking code run only when the browser is idle, so that input " + "latency is reduced, especially when editing long articles, emails, etc."; const char kEnableMaterialDesignBookmarksName[] = "Enable Material Design bookmarks"; - const char kEnableMaterialDesignBookmarksDescription[] = "If enabled, the chrome://bookmarks/ URL loads the Material Design " "bookmarks page."; -// Material Design version of chrome://policy - -const char kEnableMaterialDesignPolicyPageName[] = - "Enable Material Design policy page"; - -const char kEnableMaterialDesignPolicyPageDescription[] = - "If enabled, the chrome://md-policy URL loads the Material Design policy " - "page."; - -// Material Design version of chrome://extensions - const char kEnableMaterialDesignExtensionsName[] = "Enable Material Design extensions"; - const char kEnableMaterialDesignExtensionsDescription[] = "If enabled, the chrome://extensions/ URL loads the Material Design " "extensions page."; -// Material Design version of feedback form - const char kEnableMaterialDesignFeedbackName[] = "Enable Material Design feedback"; - const char kEnableMaterialDesignFeedbackDescription[] = "If enabled, reporting an issue will load the Material Design feedback UI."; -const char kContextualSuggestionsCarouselName[] = - "Enable Contextual Suggestions"; +const char kEnableMaterialDesignPolicyPageName[] = + "Enable Material Design policy page"; +const char kEnableMaterialDesignPolicyPageDescription[] = + "If enabled, the chrome://md-policy URL loads the Material Design policy " + "page."; -const char kContextualSuggestionsCarouselDescription[] = - "If enabled, shows contextual suggestions in a horizontal carousel in " - "bottom sheet content."; +const char kEnableMidiManagerDynamicInstantiationName[] = + "MIDIManager dynamic instantiation for Web MIDI."; +const char kEnableMidiManagerDynamicInstantiationDescription[] = + "Enable MIDIManager dynamic instantiation for Web MIDI."; + +const char kEnableNavigationTracingName[] = "Enable navigation tracing"; +const char kEnableNavigationTracingDescription[] = + "This is to be used in conjunction with the trace-upload-url flag. " + "WARNING: When enabled, Chrome will record performance data for every " + "navigation and upload it to the URL specified by the trace-upload-url " + "flag. The trace may include personally identifiable information (PII) " + "such as the titles and URLs of websites you visit."; + +const char kEnableNetworkServiceName[] = "Enable network service"; +const char kEnableNetworkServiceDescription[] = + "Enables the network service, which makes network requests through a " + "separate service. Note: most features don't work with this yet."; + +const char kEnablePictureInPictureName[] = "Enable picture in picture."; +const char kEnablePictureInPictureDescription[] = + "Enable the picture in picture feature for videos."; + +const char kEnableTokenBindingName[] = "Token Binding."; +const char kEnableTokenBindingDescription[] = "Enable Token Binding support."; + +const char kEnableUseZoomForDsfName[] = + "Use Blink's zoom for device scale factor."; +const char kEnableUseZoomForDsfDescription[] = + "If enabled, Blink uses its zooming mechanism to scale content for device " + "scale factor."; +const char kEnableUseZoomForDsfChoiceDefault[] = "Default"; +const char kEnableUseZoomForDsfChoiceEnabled[] = "Enabled"; +const char kEnableUseZoomForDsfChoiceDisabled[] = "Disabled"; + +const char kEnableScrollAnchoringName[] = "Scroll Anchoring"; +const char kEnableScrollAnchoringDescription[] = + "Adjusts scroll position to prevent visible jumps when offscreen content " + "changes."; + +const char kEnableSharedArrayBufferName[] = + "Experimental enabled SharedArrayBuffer support in JavaScript."; +const char kEnableSharedArrayBufferDescription[] = + "Enable SharedArrayBuffer support in JavaScript."; + +const char kEnableWasmName[] = "WebAssembly structured cloning support."; +const char kEnableWasmDescription[] = + "Enable web pages to use WebAssembly structured cloning."; + +const char kEnableWebUsbName[] = "WebUSB"; +const char kEnableWebUsbDescription[] = "Enable WebUSB support."; + +const char kEnableImageCaptureAPIName[] = "Image Capture API"; +const char kEnableImageCaptureAPIDescription[] = + "Enables the Web Platform Image Capture API: takePhoto(), " + "getPhotoCapabilities(), etc."; + +const char kEnableZeroSuggestRedirectToChromeName[] = + "Experimental contextual omnibox suggestion"; +const char kEnableZeroSuggestRedirectToChromeDescription[] = + "Change omnibox contextual suggestions to an experimental source. Note " + "that this is not an on/off switch for contextual omnibox and it only " + "applies to suggestions provided before the user starts typing a URL or a " + "search query (i.e. zero suggest)."; + +const char kEnableWasmStreamingName[] = + "WebAssembly streaming compile/instantiate support."; +const char kEnableWasmStreamingDescription[] = + "WebAssembly.{compile|instantiate} taking a Response as parameter."; + +const char kEnableWebfontsInterventionName[] = + "New version of User Agent Intervention for WebFonts loading."; +const char kEnableWebfontsInterventionDescription[] = + "Enable New version of User Agent Intervention for WebFonts loading."; +const char kEnableWebfontsInterventionV2ChoiceDefault[] = "Default"; +const char kEnableWebfontsInterventionV2ChoiceEnabledWith2g[] = "Enabled: 2G"; +const char kEnableWebfontsInterventionV2ChoiceEnabledWith3g[] = "Enabled: 3G"; +const char kEnableWebfontsInterventionV2ChoiceEnabledWithSlow2g[] = + "Enabled: Slow 2G"; +const char kEnableWebfontsInterventionV2ChoiceDisabled[] = "Disabled"; + +const char kEnableWebfontsInterventionTriggerName[] = + "Trigger User Agent Intervention for WebFonts loading always."; +const char kEnableWebfontsInterventionTriggerDescription[] = + "Enable to trigger User Agent Intervention for WebFonts loading always. " + "This flag affects only when the intervention is enabled."; + +const char kEnableWebNotificationCustomLayoutsName[] = + "Enable custom layouts for Web Notifications."; +const char kEnableWebNotificationCustomLayoutsDescription[] = + "Enable custom layouts for Web Notifications. They will have subtle layout " + "improvements that are otherwise not possible."; + +const char kExpensiveBackgroundTimerThrottlingName[] = + "Throttle expensive background timers"; +const char kExpensiveBackgroundTimerThrottlingDescription[] = + "Enables intervention to limit CPU usage of background timers to 1%."; + +const char kExperimentalAppBannersName[] = "Experimental app banners"; +const char kExperimentalAppBannersDescription[] = + "Enables a new experimental app banner flow and UI"; + +const char kExperimentalCanvasFeaturesName[] = "Experimental canvas features"; +const char kExperimentalCanvasFeaturesDescription[] = + "Enables the use of experimental canvas features which are still in " + "development."; + +const char kExperimentalExtensionApisName[] = "Experimental Extension APIs"; +const char kExperimentalExtensionApisDescription[] = + "Enables experimental extension APIs. Note that the extension gallery " + "doesn't allow you to upload extensions that use experimental APIs."; + +const char kExperimentalFullscreenExitUIName[] = + "Experimental fullscreen exit UI"; +const char kExperimentalFullscreenExitUIDescription[] = + "Displays experimental UI to allow mouse and touch input methods to exit " + "fullscreen mode."; + +const char kExperimentalHotwordHardwareName[] = + "Simulated hardware 'Ok Google' features"; +const char kExperimentalHotwordHardwareDescription[] = + "Enables an experimental version of 'Ok Google' hotword detection features " + "that have a hardware dependency."; + +const char kExperimentalKeyboardLockUiName[] = "Experimental keyboard lock UI."; +const char kExperimentalKeyboardLockUiDescription[] = + "An experimental full screen with keyboard lock mode requiring users to " + "hold Esc to exit."; + +const char kExperimentalSecurityFeaturesName[] = + "Potentially annoying security features"; +const char kExperimentalSecurityFeaturesDescription[] = + "Enables several security features that will likely break one or more " + "pages that you visit on a daily basis. Strict mixed content checking, for " + "example. And locking powerful features to secure contexts. This flag will " + "probably annoy you."; + +const char kExperimentalWebPlatformFeaturesName[] = + "Experimental Web Platform features"; +const char kExperimentalWebPlatformFeaturesDescription[] = + "Enables experimental Web Platform features that are in development."; + +const char kExtensionContentVerificationName[] = + "Extension Content Verification"; +const char kExtensionContentVerificationDescription[] = + "This flag can be used to turn on verification that the contents of the " + "files on disk for extensions from the webstore match what they're " + "expected to be. This can be used to turn on this feature if it would not " + "otherwise have been turned on, but cannot be used to turn it off (because " + "this setting can be tampered with by malware)."; +const char kExtensionContentVerificationBootstrap[] = + "Bootstrap (get expected hashes, but do not enforce them)"; +const char kExtensionContentVerificationEnforce[] = + "Enforce (try to get hashes, and enforce them if successful)"; +const char kExtensionContentVerificationEnforceStrict[] = + "Enforce strict (hard fail if we can't get hashes)"; + +const char kExtensionsOnChromeUrlsName[] = "Extensions on chrome:// URLs"; +const char kExtensionsOnChromeUrlsDescription[] = + "Enables running extensions on chrome:// URLs, where extensions explicitly " + "request this permission."; // Report URL to SafeSearch @@ -60,21 +519,6 @@ const char kSafeSearchUrlReportingDescription[] = "If enabled, inappropriate URLs can be reported back to SafeSearch."; -// Device scale factor change in content crbug.com/485650. - -const char kEnableUseZoomForDsfName[] = - "Use Blink's zoom for device scale factor."; - -const char kEnableUseZoomForDsfDescription[] = - "If enabled, Blink uses its zooming mechanism to scale content for device " - "scale factor."; - -const char kEnableUseZoomForDsfChoiceDefault[] = "Default"; - -const char kEnableUseZoomForDsfChoiceEnabled[] = "Enabled"; - -const char kEnableUseZoomForDsfChoiceDisabled[] = "Disabled"; - const char kNostatePrefetchName[] = "No-State Prefetch"; const char kNostatePrefetchDescription[] = @@ -163,14 +607,6 @@ #endif -const char kEnableHttpFormWarningName[] = - "Show in-form warnings for sensitive fields when the top-level page is not " - "HTTPS"; - -const char kEnableHttpFormWarningDescription[] = - "Attaches a warning UI to any password or credit card fields detected when " - "the top-level page is not HTTPS"; - const char kMarkHttpAsName[] = "Mark non-secure origins as non-secure"; const char kMarkHttpAsDescription[] = "Change the UI treatment for HTTP pages"; @@ -208,12 +644,6 @@ const char kMhtmlSkipNostoreAll[] = "Skips all no-store resources."; -const char kDeviceDiscoveryNotificationsName[] = - "Device Discovery Notifications"; - -const char kDeviceDiscoveryNotificationsDescription[] = - "Device discovery notifications on local network."; - #if defined(OS_WIN) const char kCloudPrintXpsName[] = "XPS in Google Cloud Print"; @@ -271,22 +701,6 @@ "Predicts the finger's future position during scrolls allowing time to " "render the frame before the finger is there."; -const char kAppBannersName[] = "App Banners"; - -const char kAppBannersDescription[] = - "Enable the display of Progressive Web App banners, which prompt a user to " - "add a web app to their shelf, or other platform-specific equivalent."; - -const char kBypassAppBannerEngagementChecksName[] = - "Bypass user engagement checks"; - -const char kBypassAppBannerEngagementChecksDescription[] = - "Bypasses user engagement checks for displaying app banners, such as " - "requiring that users have visited the site before and that the banner " - "hasn't been shown recently. This allows developers to test that other " - "eligibility requirements for showing app banners, such as having a " - "manifest, are met."; - #if defined(OS_ANDROID) const char kAccessibilityTabSwitcherName[] = "Accessibility Tab Switcher"; @@ -319,12 +733,6 @@ "Refine the position of a touch gesture in order to compensate for touches " "having poor resolution compared to a mouse."; -const char kCompositedLayerBordersName[] = "Composited render layer borders"; - -const char kCompositedLayerBordersDescription[] = - "Renders a border around composited Render Layers to help debug and study " - "layer compositing."; - const char kGlCompositedTextureQuadBordersName[] = "GL composited texture quad borders"; @@ -342,8 +750,6 @@ const char kUiPartialSwapDescription[] = "Sets partial swap behavior."; -const char kDebugShortcutsName[] = "Debugging keyboard shortcuts"; - const char kIgnoreGpuBlacklistName[] = "Override software rendering list"; const char kIgnoreGpuBlacklistDescription[] = @@ -361,53 +767,6 @@ const char kInProductHelpDemoModeChoiceDescription[] = "Selects the In-Product Help demo mode."; -const char kColorCorrectRenderingName[] = "Color correct rendering"; - -const char kColorCorrectRenderingDescription[] = - "Enables color correct rendering of web content."; - -const char kExperimentalAppBannersName[] = "Experimental app banners"; - -const char kExperimentalAppBannersDescription[] = - "Enables a new experimental app banner flow and UI"; - -const char kExperimentalCanvasFeaturesName[] = "Experimental canvas features"; - -const char kExperimentalCanvasFeaturesDescription[] = - "Enables the use of experimental canvas features which are still in " - "development."; - -const char kAccelerated2dCanvasName[] = "Accelerated 2D canvas"; - -const char kAccelerated2dCanvasDescription[] = - "Enables the use of the GPU to perform 2d canvas rendering instead of " - "using software rendering."; - -const char kDisplayList2dCanvasName[] = "Display list 2D canvas"; - -const char kDisplayList2dCanvasDescription[] = - "Enables the use of display lists to record 2D canvas commands. This " - "allows 2D canvas rasterization to be performed on separate thread."; - -const char kExperimentalExtensionApisName[] = "Experimental Extension APIs"; - -const char kExperimentalExtensionApisDescription[] = - "Enables experimental extension APIs. Note that the extension gallery " - "doesn't allow you to upload extensions that use experimental APIs."; - -const char kExtensionsOnChromeUrlsName[] = "Extensions on chrome:// URLs"; - -const char kExtensionsOnChromeUrlsDescription[] = - "Enables running extensions on chrome:// URLs, where extensions explicitly " - "request this permission."; - -const char kExperimentalFullscreenExitUIName[] = - "Experimental fullscreen exit UI"; - -const char kExperimentalFullscreenExitUIDescription[] = - "Displays experimental UI to allow mouse and touch input methods to exit " - "fullscreen mode."; - const char kFastUnloadName[] = "Fast tab/window close"; const char kFastUnloadDescription[] = @@ -659,10 +1018,6 @@ const char kSslVersionMaxTls13[] = "TLS 1.3"; -const char kEnableTokenBindingName[] = "Token Binding."; - -const char kEnableTokenBindingDescription[] = "Enable Token Binding support."; - const char kPassiveDocumentEventListenersDescription[] = "Forces touchstart, and touchmove event listeners on document level " "targets (which haven't requested otherwise) to be treated as passive."; @@ -779,28 +1134,6 @@ const char kJavascriptHarmonyDescription[] = "Enable web pages to use experimental JavaScript features."; -const char kEnableAsmWasmName[] = - "Experimental Validate Asm.js and convert to WebAssembly when valid."; - -const char kEnableAsmWasmDescription[] = - R"*(Validate Asm.js when "use asm" is present and then convert to )*" - R"*(WebAssembly.)*"; - -const char kEnableSharedArrayBufferName[] = - "Experimental enabled SharedArrayBuffer support in JavaScript."; - -const char kEnableSharedArrayBufferDescription[] = - "Enable SharedArrayBuffer support in JavaScript."; - -const char kEnableWasmName[] = "WebAssembly structured cloning support."; -const char kEnableWasmDescription[] = - "Enable web pages to use WebAssembly structured cloning."; - -const char kEnableWasmStreamingName[] = - "WebAssembly streaming compile/instantiate support."; -const char kEnableWasmStreamingDescription[] = - "WebAssembly.{compile|instantiate} taking a Response as parameter."; - #if defined(OS_ANDROID) const char kMediaDocumentDownloadButtonName[] = @@ -844,38 +1177,11 @@ const char kSlimmingPaintInvalidationDescription[] = "Whether to enable a new paint invalidation system."; -const char kExperimentalSecurityFeaturesName[] = - "Potentially annoying security features"; - -const char kExperimentalSecurityFeaturesDescription[] = - "Enables several security features that will likely break one or more " - "pages that you visit on a daily basis. Strict mixed content checking, for " - "example. And locking powerful features to secure contexts. This flag will " - "probably annoy you."; - -const char kExperimentalWebPlatformFeaturesName[] = - "Experimental Web Platform features"; - -const char kExperimentalWebPlatformFeaturesDescription[] = - "Enables experimental Web Platform features that are in development."; - const char kOriginTrialsName[] = "Origin Trials"; const char kOriginTrialsDescription[] = "Enables origin trials for controlling access to feature/API experiments."; -const char kBleAdvertisingInExtensionsName[] = "BLE Advertising in Chrome Apps"; - -const char kBleAdvertisingInExtensionsDescription[] = - "Enables BLE Advertising in Chrome Apps. BLE Advertising might interfere " - "with regular use of Bluetooth Low Energy features."; - -const char kDevtoolsExperimentsName[] = "Developer Tools experiments"; - -const char kDevtoolsExperimentsDescription[] = - "Enables Developer Tools experiments. Use Settings panel in Developer " - "Tools to toggle individual experiments."; - const char kSilentDebuggerExtensionApiName[] = "Silent Debugging"; const char kSilentDebuggerExtensionApiDescription[] = @@ -894,12 +1200,6 @@ const char kPreferHtmlOverPluginsDescription[] = "Prefer HTML content by hiding Flash from the list of plugins."; -const char kAllowNaclSocketApiName[] = "NaCl Socket API."; - -const char kAllowNaclSocketApiDescription[] = - "Allows applications to use NaCl Socket API. Use only to test NaCl " - "plugins."; - const char kRunAllFlashInAllowModeName[] = R"*(Run all Flash content when Flash setting is set to "allow")*"; @@ -956,20 +1256,6 @@ #endif // defined(OS_CHROMEOS) -const char kAcceleratedVideoDecodeName[] = "Hardware-accelerated video decode"; - -const char kAcceleratedVideoDecodeDescription[] = - "Hardware-accelerated video decode where available."; - -const char kEnableHDRName[] = "HDR mode"; - -const char kEnableHDRDescription[] = - "Enables HDR support on compatible displays."; - -const char kCloudImportName[] = "Cloud Import"; - -const char kCloudImportDescription[] = "Allows the cloud-import feature."; - const char kRequestTabletSiteName[] = "Request tablet site option in the settings menu"; @@ -979,18 +1265,6 @@ "changed to indicate a tablet device. Web content optimized for tablets is " "received there after for the current tab."; -const char kDebugPackedAppName[] = "Debugging for packed apps"; - -const char kDebugPackedAppDescription[] = - "Enables debugging context menu options such as Inspect Element for packed " - "applications."; - -const char kDropSyncCredentialName[] = - "Drop sync credentials from password manager"; - -const char kDropSyncCredentialDescription[] = - "The password manager will not offer to save the credential used to sync."; - const char kPasswordGenerationName[] = "Password generation"; const char kPasswordGenerationDescription[] = @@ -1021,13 +1295,6 @@ "Match Autofill suggestions based on substrings (token prefixes) rather " "than just prefixes."; -const char kAffiliationBasedMatchingName[] = - "Affiliation based matching in password manager"; - -const char kAffiliationBasedMatchingDescription[] = - "Allow credentials stored for Android applications to be filled into " - "corresponding websites."; - const char kProtectSyncCredentialName[] = "Autofill sync credential"; const char kProtectSyncCredentialDescription[] = @@ -1057,26 +1324,6 @@ "running after the last window is closed, and to launch at OS startup, if " "the Push API needs it."; -const char kEnableNavigationTracingName[] = "Enable navigation tracing"; - -const char kEnableNavigationTracingDescription[] = - "This is to be used in conjunction with the trace-upload-url flag. " - "WARNING: When enabled, Chrome will record performance data for every " - "navigation and upload it to the URL specified by the trace-upload-url " - "flag. The trace may include personally identifiable information (PII) " - "such as the titles and URLs of websites you visit."; - -const char kEnableNetworkServiceName[] = "Enable network service"; - -const char kEnableNetworkServiceDescription[] = - "Enables the network service, which makes network requests through a " - "separate service. Note: most features don't work with this yet."; - -const char kEnablePictureInPictureName[] = "Enable picture in picture."; - -const char kEnablePictureInPictureDescription[] = - "Enable the picture in picture feature for videos."; - const char kTraceUploadUrlName[] = "Trace label for navigation tracing"; const char kTraceUploadUrlDescription[] = @@ -1085,24 +1332,6 @@ "This will choose the destination the traces are uploaded to. If you are " "not sure, select other. If left empty, no traces will be uploaded."; -const char kDisableAudioForDesktopShareName[] = - "Disable Audio For Desktop Share"; - -const char kDisableAudioForDesktopShareDescription[] = - "With this flag on, desktop share picker window will not let the user " - "choose whether to share audio."; - -const char kDisableNightLightName[] = "Disable Night Light"; -const char kDisableNightLightDescription[] = - "Disable the Night Light feature which controls the color temperature of " - "the screen."; - -const char kDisableTabForDesktopShareName[] = - "Disable Desktop Share with tab source"; - -const char kDisableTabForDesktopShareDescription[] = - "This flag controls whether users can choose a tab for desktop share."; - const char kTraceUploadUrlChoiceOther[] = "Other"; const char kTraceUploadUrlChoiceEmloading[] = "emloading"; @@ -1123,12 +1352,6 @@ "Enable App Launcher sync. This also enables Folders where available (non " "OSX)."; -const char kDriveSearchInChromeLauncherName[] = - "Drive Search in Chrome App Launcher"; - -const char kDriveSearchInChromeLauncherDescription[] = - "Files from Drive will show up when searching the Chrome App Launcher."; - const char kV8CacheOptionsName[] = "V8 caching mode."; const char kV8CacheOptionsDescription[] = @@ -1160,56 +1383,6 @@ "Enable web pages to use the experimental service worker navigation " "preload API."; -// Data Reduction Proxy - -const char kDataReductionProxyLoFiName[] = "Data Saver Lo-Fi mode"; - -const char kDataReductionProxyLoFiDescription[] = - "Forces Data Saver Lo-Fi mode to be always enabled, enabled only on " - "cellular connections, or disabled. Data Saver must be enabled for Lo-Fi " - "mode to be used."; - -const char kDataReductionProxyLoFiAlwaysOn[] = "Always on"; - -const char kDataReductionProxyLoFiCellularOnly[] = "Cellular only"; - -const char kDataReductionProxyLoFiDisabled[] = "Disable"; - -const char kDataReductionProxyLoFiSlowConnectionsOnly[] = - "Slow connections only"; - -const char kEnableDataReductionProxyLitePageName[] = - "Lite pages for Data Saver Lo-Fi mode"; - -const char kEnableDataReductionProxyLitePageDescription[] = - "Enable lite pages in Data Saver Lo-Fi mode. Previews of pages will be " - "shown instead of image placeholders when Lo-Fi is on. Data Saver and " - "Lo-Fi must be enabled for lite pages to be shown."; - -const char kDataReductionProxyServerAlternative[] = - "Use alternative server configuration"; - -const char kEnableDataReductionProxyServerExperimentName[] = - "Use an alternative Data Saver back end configuration."; - -const char kEnableDataReductionProxyServerExperimentDescription[] = - "Enable a different approach to saving data by configuring the back end " - "server"; - -const char kDataReductionProxyCarrierTestName[] = - "Enable a carrier-specific Data Reduction Proxy for testing."; - -const char kDataReductionProxyCarrierTestDescription[] = - "Use a carrier-specific Data Reduction Proxy for testing."; - -const char kEnableDataReductionProxySavingsPromoName[] = - "Data Saver 1 MB Savings Promo"; - -const char kEnableDataReductionProxySavingsPromoDescription[] = - "Enable a Data Saver promo for 1 MB of savings. If Data Saver has already " - "saved 1 MB of data, then the promo will not be shown. Data Saver must be " - "enabled for the promo to be shown."; - #if defined(OS_ANDROID) const char kEnableDataReductionProxyMainMenuName[] = @@ -1229,11 +1402,6 @@ const char kEnableOfflinePreviewsDescription[] = "Enable showing offline page previews on slow networks."; -const char kEnableClientLoFiName[] = "Client-side Lo-Fi previews"; - -const char kEnableClientLoFiDescription[] = - "Enable showing low fidelity images on some pages on slow networks."; - #endif // defined(OS_ANDROID) const char kLcdTextName[] = "LCD text antialiasing"; @@ -1242,41 +1410,11 @@ "If disabled, text is rendered with grayscale antialiasing instead of LCD " "(subpixel) when doing accelerated compositing."; -const char kDistanceFieldTextName[] = "Distance field text"; - -const char kDistanceFieldTextDescription[] = - "Text is rendered with signed distance fields rather than bitmap alpha " - "masks."; - const char kZeroCopyName[] = "Zero-copy rasterizer"; const char kZeroCopyDescription[] = "Raster threads write directly to GPU memory associated with tiles."; -const char kDefaultTileWidthName[] = "Default tile width"; - -const char kDefaultTileWidthDescription[] = "Specify the default tile width."; - -const char kDefaultTileWidthShort[] = "128"; - -const char kDefaultTileWidthTall[] = "256"; - -const char kDefaultTileWidthGrande[] = "512"; - -const char kDefaultTileWidthVenti[] = "1024"; - -const char kDefaultTileHeightName[] = "Default tile height"; - -const char kDefaultTileHeightDescription[] = "Specify the default tile height."; - -const char kDefaultTileHeightShort[] = "128"; - -const char kDefaultTileHeightTall[] = "256"; - -const char kDefaultTileHeightGrande[] = "512"; - -const char kDefaultTileHeightVenti[] = "1024"; - const char kNumRasterThreadsName[] = "Number of raster threads"; const char kNumRasterThreadsDescription[] = @@ -1415,12 +1553,6 @@ "Enable cross-platform HarfBuzz layout engine for UI text. Doesn't affect " "web content."; -const char kEmbeddedExtensionOptionsName[] = "Embedded extension options"; - -const char kEmbeddedExtensionOptionsDescription[] = - "Display extension options as an embedded element in chrome://extensions " - "rather than opening a new tab."; - const char kTabAudioMutingName[] = "Tab audio muting UI control"; const char kTabAudioMutingDescription[] = @@ -1428,22 +1560,6 @@ "mute controls. This also adds commands in the tab context menu for " "quickly muting multiple selected tabs."; -const char kEasyUnlockBluetoothLowEnergyDiscoveryName[] = - "Smart Lock Bluetooth Low Energy Discovery"; - -const char kEasyUnlockBluetoothLowEnergyDiscoveryDescription[] = - "Enables a Smart Lock setting that allows Chromebook to discover phones " - "over Bluetooth Low Energy in order to unlock the Chromebook when the " - "phone is in its proximity."; - -const char kEasyUnlockProximityDetectionName[] = - "Smart Lock proximity detection"; - -const char kEasyUnlockProximityDetectionDescription[] = - "Enables a Smart Lock setting that restricts unlocking to only work when " - "your phone is very close to (roughly, within an arm's length of) the " - "Chrome device."; - const char kWifiCredentialSyncName[] = "WiFi credential sync"; const char kWifiCredentialSyncDescription[] = @@ -1457,15 +1573,6 @@ const char kSyncSandboxDescription[] = "Connects to the testing server for Chrome Sync."; -const char kDatasaverPromptName[] = "Cellular Data Saver Prompt"; - -const char kDatasaverPromptDescription[] = - "Enables a prompt, which appears when a cellular network connection is " - "detected, to take the user to the Data Saver extension page on Chrome Web " - "Store."; - -const char kDatasaverPromptDemoMode[] = "Demo mode"; - const char kTrySupportedChannelLayoutsName[] = "Causes audio output streams to check if channel layouts other than the " "default hardware layout are available."; @@ -1530,12 +1637,6 @@ "A simplified new user experience when entering page-triggered full screen " "or mouse pointer lock states."; -const char kExperimentalKeyboardLockUiName[] = "Experimental keyboard lock UI."; - -const char kExperimentalKeyboardLockUiDescription[] = - "An experimental full screen with keyboard lock mode requiring users to " - "hold Esc to exit."; - #if defined(OS_ANDROID) extern const char kPayWithGoogleV1Name[] = "Pay with Google v1"; @@ -1581,13 +1682,6 @@ #endif // defined(OS_ANDROID) -const char kDisallowDocWrittenScriptsUiName[] = - "Block scripts loaded via document.write"; - -const char kDisallowDocWrittenScriptsUiDescription[] = - "Disallows fetches for third-party parser-blocking scripts inserted into " - "the main frame via document.write."; - #if defined(OS_WIN) const char kEnableAppcontainerName[] = "Enable AppContainer Lockdown."; @@ -1645,11 +1739,6 @@ #endif // defined(OS_WIN) || defined(OS_LINUX) -const char kEnableGroupedHistoryName[] = "Group history by domain"; - -const char kEnableGroupedHistoryDescription[] = - "Group history by website domain (i.e. google.com) on chrome://history."; - const char kSaveasMenuLabelExperimentName[] = "Switch 'Save as' menu labels to 'Download'"; @@ -1657,12 +1746,6 @@ "Enables an experiment to switch menu labels that use 'Save as...' to " "'Download'."; -const char kEnableEnumeratingAudioDevicesName[] = - "Experimentally enable enumerating audio devices."; - -const char kEnableEnumeratingAudioDevicesDescription[] = - "Experimentally enable the use of enumerating audio devices."; - const char kNewUsbBackendName[] = "Enable new USB backend"; const char kNewUsbBackendDescription[] = @@ -1676,27 +1759,12 @@ "conversions, dictionary definitions, sports scores, translations, and " "when is."; -const char kEnableZeroSuggestRedirectToChromeName[] = - "Experimental contextual omnibox suggestion"; - -const char kEnableZeroSuggestRedirectToChromeDescription[] = - "Change omnibox contextual suggestions to an experimental source. Note " - "that this is not an on/off switch for contextual omnibox and it only " - "applies to suggestions provided before the user starts typing a URL or a " - "search query (i.e. zero suggest)."; - const char kFillOnAccountSelectName[] = "Fill passwords on account selection"; const char kFillOnAccountSelectDescription[] = "Filling of passwords when an account is explicitly selected by the user " "rather than autofilling credentials on page load."; -const char kEnableClearBrowsingDataCountersName[] = - "Enable Clear browsing data counters."; - -const char kEnableClearBrowsingDataCountersDescription[] = - "Shows data volume counters in the Clear browsing data dialog."; - #if defined(OS_ANDROID) const char kTabsInCbdName[] = "Enable tabs for the Clear Browsing Data dialog."; @@ -1721,13 +1789,6 @@ #endif // defined(OS_ANDROID) -const char kEnableWebNotificationCustomLayoutsName[] = - "Enable custom layouts for Web Notifications."; - -const char kEnableWebNotificationCustomLayoutsDescription[] = - "Enable custom layouts for Web Notifications. They will have subtle layout " - "improvements that are otherwise not possible."; - const char kGoogleProfileInfoName[] = "Google profile name and icon"; const char kGoogleProfileInfoDescription[] = @@ -1846,13 +1907,6 @@ #endif // defined(OS_CHROMEOS) -// Strings for controlling credit card assist feature in about:flags. - -const char kCreditCardAssistName[] = "Credit Card Assisted Filling"; - -const char kCreditCardAssistDescription[] = - "Enable assisted credit card filling on certain sites."; - // Strings for controlling credit card scanning feature in about:flags. // Simple Cache Backend experiment. @@ -1894,22 +1948,6 @@ "a separate process from the top document. In this mode, iframes from " "different third-party sites will be allowed to share a process."; -// Cross process guest frames isolation mode - -const char kCrossProcessGuestViewIsolationName[] = - "Cross process frames for guests"; - -const char kCrossProcessGuestViewIsolationDescription[] = - "Highly experimental where guests such as <webview> are implemented on " - "the out-of-process iframe infrastructure."; - -// Task Scheduler - -const char kBrowserTaskSchedulerName[] = "Task Scheduler"; - -const char kBrowserTaskSchedulerDescription[] = - "Enables redirection of some task posting APIs to the task scheduler."; - // Arc authorization #if defined(OS_CHROMEOS) @@ -1992,36 +2030,6 @@ const char kSettingsWindowDescription[] = "Settings will be shown in a dedicated window instead of as a browser tab."; -// Extension Content Verification - -const char kExtensionContentVerificationName[] = - "Extension Content Verification"; - -const char kExtensionContentVerificationDescription[] = - "This flag can be used to turn on verification that the contents of the " - "files on disk for extensions from the webstore match what they're " - "expected to be. This can be used to turn on this feature if it would not " - "otherwise have been turned on, but cannot be used to turn it off (because " - "this setting can be tampered with by malware)."; - -const char kExtensionContentVerificationBootstrap[] = - "Bootstrap (get expected hashes, but do not enforce them)"; - -const char kExtensionContentVerificationEnforce[] = - "Enforce (try to get hashes, and enforce them if successful)"; - -const char kExtensionContentVerificationEnforceStrict[] = - "Enforce strict (hard fail if we can't get hashes)"; - -// Built-in hotword detection display strings - -const char kExperimentalHotwordHardwareName[] = - "Simulated hardware 'Ok Google' features"; - -const char kExperimentalHotwordHardwareDescription[] = - "Enables an experimental version of 'Ok Google' hotword detection features " - "that have a hardware dependency."; - // Message center strings const char kMessageCenterAlwaysScrollUpUponRemovalName[] = @@ -2037,20 +2045,6 @@ const char kMessageCenterNewStyleNotificationDescription[] = "Enables the experiment style of material-design notification"; -const char kCastStreamingHwEncodingName[] = - "Cast Streaming hardware video encoding"; - -const char kCastStreamingHwEncodingDescription[] = - "This option enables support in Cast Streaming for encoding video streams " - "using platform hardware."; - -const char kAllowInsecureLocalhostName[] = - "Allow invalid certificates for resources loaded from localhost."; - -const char kAllowInsecureLocalhostDescription[] = - "Allows requests to localhost over HTTPS even when an invalid certificate " - "is presented."; - #if defined(OS_WIN) || defined(OS_MACOSX) // Tab discarding @@ -2256,41 +2250,6 @@ #endif // defined(OS_ANDROID) -const char kEnableBrotliName[] = "Brotli Content-Encoding."; - -const char kEnableBrotliDescription[] = - "Enable Brotli Content-Encoding support."; - -const char kEnableWebfontsInterventionName[] = - "New version of User Agent Intervention for WebFonts loading."; - -const char kEnableWebfontsInterventionDescription[] = - "Enable New version of User Agent Intervention for WebFonts loading."; - -const char kEnableWebfontsInterventionV2ChoiceDefault[] = "Default"; - -const char kEnableWebfontsInterventionV2ChoiceEnabledWith2g[] = "Enabled: 2G"; - -const char kEnableWebfontsInterventionV2ChoiceEnabledWith3g[] = "Enabled: 3G"; - -const char kEnableWebfontsInterventionV2ChoiceEnabledWithSlow2g[] = - "Enabled: Slow 2G"; - -const char kEnableWebfontsInterventionV2ChoiceDisabled[] = "Disabled"; - -const char kEnableWebfontsInterventionTriggerName[] = - "Trigger User Agent Intervention for WebFonts loading always."; - -const char kEnableWebfontsInterventionTriggerDescription[] = - "Enable to trigger User Agent Intervention for WebFonts loading always. " - "This flag affects only when the intervention is enabled."; - -const char kEnableScrollAnchoringName[] = "Scroll Anchoring"; - -const char kEnableScrollAnchoringDescription[] = - "Adjusts scroll position to prevent visible jumps when offscreen content " - "changes."; - #if defined(OS_CHROMEOS) const char kDisableNativeCupsName[] = "Native CUPS"; @@ -2491,25 +2450,6 @@ #endif // defined(OS_ANDROID) -const char kEnableAutofillCreditCardBankNameDisplayName[] = - "Display the issuer bank name of a credit card in autofill."; - -const char kEnableAutofillCreditCardBankNameDisplayDescription[] = - "If enabled, displays the issuer bank name of a credit card in autofill."; - -const char kEnableAutofillCreditCardLastUsedDateDisplayName[] = - "Display the last used date of a credit card in autofill."; - -const char kEnableAutofillCreditCardLastUsedDateDisplayDescription[] = - "If enabled, display the last used date of a credit card in autofill."; - -const char kEnableAutofillCreditCardUploadCvcPromptName[] = - "Enable requesting missing CVC during Autofill credit card upload"; - -const char kEnableAutofillCreditCardUploadCvcPromptDescription[] = - "If enabled, requests missing CVC when offering to upload credit cards to " - "Google Payments."; - #if !defined(OS_ANDROID) && defined(GOOGLE_CHROME_BUILD) const char kGoogleBrandedContextMenuName[] = @@ -2521,21 +2461,6 @@ #endif // !defined(OS_ANDROID) && defined(GOOGLE_CHROME_BUILD) -const char kEnableWebUsbName[] = "WebUSB"; - -const char kEnableWebUsbDescription[] = "Enable WebUSB support."; - -const char kEnableImageCaptureAPIName[] = "Image Capture API"; - -const char kEnableImageCaptureAPIDescription[] = - "Enables the Web Platform Image Capture API: takePhoto(), " - "getPhotoCapabilities(), etc."; - -const char kEnableGenericSensorName[] = "Generic Sensor"; - -const char kEnableGenericSensorDescription[] = - "Enable sensor APIs based on Generic Sensor API."; - const char kFontCacheScalingName[] = "FontCache scaling"; const char kFontCacheScalingDescription[] = @@ -2628,15 +2553,6 @@ const char kNewAudioRenderingMixingStrategyDescription[] = "Use the new audio rendering mixing strategy."; -// Background video track disabling experiment strings. - -const char kBackgroundVideoTrackOptimizationName[] = - "Optimize background video playback."; - -const char kBackgroundVideoTrackOptimizationDescription[] = - "Disable video tracks when the video is played in the background to " - "optimize performance."; - // New remote playback pipeline experiment strings. const char kNewRemotePlaybackPipelineName[] = @@ -2664,14 +2580,6 @@ "Enter/exit fullscreen when device is rotated to/from the orientation of " "the video. Only on phones."; -// Expensive background timer throttling flag - -const char kExpensiveBackgroundTimerThrottlingName[] = - "Throttle expensive background timers"; - -const char kExpensiveBackgroundTimerThrottlingDescription[] = - "Enables intervention to limit CPU usage of background timers to 1%."; - // Enable default MediaSession flag #if !defined(OS_ANDROID) @@ -2795,14 +2703,6 @@ #endif // defined(OS_ANDROID) -// Web MIDI supports MIDIManager dynamic instantiation chrome://flags strings - -const char kEnableMidiManagerDynamicInstantiationName[] = - "MIDIManager dynamic instantiation for Web MIDI."; - -const char kEnableMidiManagerDynamicInstantiationDescription[] = - "Enable MIDIManager dynamic instantiation for Web MIDI."; - // Desktop iOS promotion chrome://flags strings #if defined(OS_WIN) @@ -2870,16 +2770,13 @@ #if defined(OS_ANDROID) -const char kUseNewDoodleApiName[] = "Use new Doodle API"; +const char kUseDdljsonApiName[] = "Use new ddljson API for Doodles"; -const char kUseNewDoodleApiDescription[] = - "Enables the new API to fetch Doodles for the NTP."; +const char kUseDdljsonApiDescription[] = + "Enables the new ddljson API to fetch Doodles for the NTP."; #endif // defined(OS_ANDROID) -const char kDebugShortcutsDescription[] = - "Enables additional keyboard shortcuts that are useful for debugging Ash."; - const char kMemoryAblationName[] = "Memory ablation experiment"; const char kMemoryAblationDescription[] = "Allocates extra memory in the browser process."; @@ -3109,13 +3006,6 @@ #endif // defined(OS_ANDROID) -const char kEnableIdleTimeSpellCheckingName[] = - "Enable idle time spell checker"; - -const char kEnableIdleTimeSpellCheckingDescription[] = - "Make spell-checking code run only when the browser is idle, so that input " - "latency is reduced, especially when editing long articles, emails, etc."; - #if defined(OS_ANDROID) const char kEnableOmniboxClipboardProviderName[] = @@ -3127,22 +3017,6 @@ #endif // defined(OS_ANDROID) -const char kAutoplayPolicyName[] = "Autoplay policy"; - -const char kAutoplayPolicyDescription[] = - "Policy used when deciding if audio or video is allowed to autoplay."; - -const char kAutoplayPolicyNoUserGestureRequired[] = - "No user gesture is required."; - -const char kAutoplayPolicyUserGestureRequired[] = "User gesture is required."; - -const char kAutoplayPolicyUserGestureRequiredForCrossOrigin[] = - "User gesture is required for cross-origin iframes."; - -const char kAutoplayPolicyDocumentUserActivation[] = - "Document user activation is required."; - const char kOmniboxDisplayTitleForCurrentUrlName[] = "Include title for the current URL in the omnibox"; @@ -3204,16 +3078,6 @@ const char kEffectiveConnectionType3GDescription[] = "3G"; const char kEffectiveConnectionType4GDescription[] = "4G"; -const char kEnableHeapProfilingName[] = "Heap profiling"; - -const char kEnableHeapProfilingDescription[] = "Enables heap profiling."; - -const char kEnableHeapProfilingModePseudo[] = "Enabled (pseudo mode)"; - -const char kEnableHeapProfilingModeNative[] = "Enabled (native mode)"; - -const char kEnableHeapProfilingTaskProfiler[] = "Enabled (task mode)"; - const char kUseSuggestionsEvenIfFewFeatureName[] = "Disable minimum for server-side tile suggestions on NTP."; @@ -3221,13 +3085,6 @@ "Request server-side suggestions even if there are only very few of them " "and use them for tiles on the New Tab Page."; -const char kCaptureThumbnailOnLoadFinishedName[] = - "Capture page thumbnail on load finished"; - -const char kCaptureThumbnailOnLoadFinishedDescription[] = - "Capture a page thumbnail (for use on the New Tab page) when the page load " - "finishes, in addition to other times a thumbnail may be captured."; - #if defined(OS_WIN) // Name and description of the flag that enables D3D v-sync.
diff --git a/chrome/browser/flag_descriptions.h b/chrome/browser/flag_descriptions.h index b449e74..5b3fd7b 100644 --- a/chrome/browser/flag_descriptions.h +++ b/chrome/browser/flag_descriptions.h
@@ -127,9 +127,6 @@ extern const char kDebugShortcutsName[]; extern const char kDebugShortcutsDescription[]; -extern const char kDelayNavigationName[]; -extern const char kDelayNavigationDescription[]; - extern const char kDeviceDiscoveryNotificationsName[]; extern const char kDeviceDiscoveryNotificationsDescription[]; @@ -169,9 +166,6 @@ extern const char kEmbeddedExtensionOptionsName[]; extern const char kEmbeddedExtensionOptionsDescription[]; -extern const char kEnableAdjustableLargeCursorName[]; -extern const char kEnableAdjustableLargeCursorDescription[]; - extern const char kEnableAsmWasmName[]; extern const char kEnableAsmWasmDescription[]; @@ -190,6 +184,9 @@ extern const char kEnableClearBrowsingDataCountersName[]; extern const char kEnableClearBrowsingDataCountersDescription[]; +extern const char kEnableClientLoFiName[]; +extern const char kEnableClientLoFiDescription[]; + extern const char kEnableDataReductionProxyLitePageName[]; extern const char kEnableDataReductionProxyLitePageDescription[]; @@ -304,6 +301,9 @@ extern const char kExperimentalExtensionApisName[]; extern const char kExperimentalExtensionApisDescription[]; +extern const char kExperimentalFullscreenExitUIName[]; +extern const char kExperimentalFullscreenExitUIDescription[]; + extern const char kExperimentalHotwordHardwareName[]; extern const char kExperimentalHotwordHardwareDescription[]; @@ -346,9 +346,6 @@ extern const char kEffectiveConnectionType3GDescription[]; extern const char kEffectiveConnectionType4GDescription[]; -extern const char kExperimentalFullscreenExitUIName[]; -extern const char kExperimentalFullscreenExitUIDescription[]; - extern const char kFillOnAccountSelectName[]; extern const char kFillOnAccountSelectDescription[]; @@ -901,9 +898,6 @@ extern const char kEnableAndroidSpellcheckerDescription[]; extern const char kEnableAndroidSpellcheckerName[]; -extern const char kEnableClientLoFiName[]; -extern const char kEnableClientLoFiDescription[]; - extern const char kEnableConsistentOmniboxGeolocationName[]; extern const char kEnableConsistentOmniboxGeolocationDescription[]; @@ -1138,8 +1132,8 @@ extern const char kUseAndroidMidiApiName[]; extern const char kUseAndroidMidiApiDescription[]; -extern const char kUseNewDoodleApiName[]; -extern const char kUseNewDoodleApiDescription[]; +extern const char kUseDdljsonApiName[]; +extern const char kUseDdljsonApiDescription[]; extern const char kWebPaymentsModifiersName[]; extern const char kWebPaymentsModifiersDescription[];
diff --git a/chrome/browser/io_thread.cc b/chrome/browser/io_thread.cc index 4d9f63b..e5eeba76 100644 --- a/chrome/browser/io_thread.cc +++ b/chrome/browser/io_thread.cc
@@ -642,6 +642,9 @@ globals_ = NULL; base::debug::LeakTracker<SystemURLRequestContextGetter>::CheckForLeaks(); + + if (net_log_) + net_log_->ShutDownBeforeTaskScheduler(); } // static
diff --git a/chrome/browser/media/output_protection_impl.cc b/chrome/browser/media/output_protection_impl.cc index 80808f28dd..a4b33b7b 100644 --- a/chrome/browser/media/output_protection_impl.cc +++ b/chrome/browser/media/output_protection_impl.cc
@@ -37,43 +37,42 @@ DCHECK_CURRENTLY_ON(content::BrowserThread::UI); } -void OutputProtectionImpl::QueryStatus(const QueryStatusCallback& callback) { +void OutputProtectionImpl::QueryStatus(QueryStatusCallback callback) { DVLOG(2) << __func__; DCHECK_CURRENTLY_ON(content::BrowserThread::UI); GetProxy()->QueryStatus(base::Bind(&OutputProtectionImpl::OnQueryStatusResult, - weak_factory_.GetWeakPtr(), callback)); + weak_factory_.GetWeakPtr(), + base::Passed(&callback))); } -void OutputProtectionImpl::EnableProtection( - uint32_t desired_protection_mask, - const EnableProtectionCallback& callback) { +void OutputProtectionImpl::EnableProtection(uint32_t desired_protection_mask, + EnableProtectionCallback callback) { DVLOG(2) << __func__; DCHECK_CURRENTLY_ON(content::BrowserThread::UI); GetProxy()->EnableProtection( desired_protection_mask, base::Bind(&OutputProtectionImpl::OnEnableProtectionResult, - weak_factory_.GetWeakPtr(), callback)); + weak_factory_.GetWeakPtr(), base::Passed(&callback))); } -void OutputProtectionImpl::OnQueryStatusResult( - const QueryStatusCallback& callback, - bool success, - uint32_t link_mask, - uint32_t protection_mask) { +void OutputProtectionImpl::OnQueryStatusResult(QueryStatusCallback callback, + bool success, + uint32_t link_mask, + uint32_t protection_mask) { DVLOG(2) << __func__ << ": success=" << success << ", link_mask=" << link_mask << ", protection_mask=" << protection_mask; DCHECK_CURRENTLY_ON(content::BrowserThread::UI); - callback.Run(success, link_mask, protection_mask); + std::move(callback).Run(success, link_mask, protection_mask); } void OutputProtectionImpl::OnEnableProtectionResult( - const EnableProtectionCallback& callback, + EnableProtectionCallback callback, bool success) { DVLOG(2) << __func__ << ": success=" << success; DCHECK_CURRENTLY_ON(content::BrowserThread::UI); - callback.Run(success); + std::move(callback).Run(success); } // Helper function to lazily create the |proxy_| and return it.
diff --git a/chrome/browser/media/output_protection_impl.h b/chrome/browser/media/output_protection_impl.h index dde26d9..b04ff25 100644 --- a/chrome/browser/media/output_protection_impl.h +++ b/chrome/browser/media/output_protection_impl.h
@@ -26,19 +26,19 @@ ~OutputProtectionImpl() final; // media::mojom::OutputProtection implementation. - void QueryStatus(const QueryStatusCallback& callback) final; + void QueryStatus(QueryStatusCallback callback) final; void EnableProtection(uint32_t desired_protection_mask, - const EnableProtectionCallback& callback) final; + EnableProtectionCallback callback) final; private: // Callbacks for QueryStatus and EnableProtection results. // Note: These are bound using weak pointers so that we won't fire |callback| // after the binding is destroyed. - void OnQueryStatusResult(const QueryStatusCallback& callback, + void OnQueryStatusResult(QueryStatusCallback callback, bool success, uint32_t link_mask, uint32_t protection_mask); - void OnEnableProtectionResult(const EnableProtectionCallback& callback, + void OnEnableProtectionResult(EnableProtectionCallback callback, bool success); // Helper function to lazily create the |proxy_| and return it.
diff --git a/chrome/browser/media/router/discovery/BUILD.gn b/chrome/browser/media/router/discovery/BUILD.gn index 34f1b5d8..79ad9c1 100644 --- a/chrome/browser/media/router/discovery/BUILD.gn +++ b/chrome/browser/media/router/discovery/BUILD.gn
@@ -12,6 +12,7 @@ "//base:i18n", "//chrome/app:generated_resources", "//chrome/common:constants", + "//components/cast_channel", "//content/public/browser", "//content/public/common", ] @@ -34,6 +35,8 @@ "dial/parsed_dial_device_description.h", "dial/safe_dial_device_description_parser.cc", "dial/safe_dial_device_description_parser.h", + "mdns/cast_media_sink_service.cc", + "mdns/cast_media_sink_service.h", "mdns/dns_sd_delegate.cc", "mdns/dns_sd_delegate.h", "mdns/dns_sd_device_lister.cc",
diff --git a/chrome/browser/media/router/discovery/mdns/cast_media_sink_service.cc b/chrome/browser/media/router/discovery/mdns/cast_media_sink_service.cc new file mode 100644 index 0000000..1ad648b --- /dev/null +++ b/chrome/browser/media/router/discovery/mdns/cast_media_sink_service.cc
@@ -0,0 +1,245 @@ +// Copyright 2017 The Chromium Authors. All rights reserved. +// Use of this source code is governed by a BSD-style license that can be +// found in the LICENSE file. + +#include "chrome/browser/media/router/discovery/mdns/cast_media_sink_service.h" + +#include "base/memory/ptr_util.h" +#include "chrome/browser/browser_process.h" +#include "chrome/common/media_router/discovery/media_sink_internal.h" +#include "components/cast_channel/cast_socket_service.h" +#include "components/cast_channel/cast_socket_service_factory.h" +#include "components/net_log/chrome_net_log.h" +#include "content/public/common/content_client.h" +#include "net/base/host_port_pair.h" +#include "net/base/ip_address.h" + +namespace { + +constexpr char kObserverId[] = "browser_observer_id"; + +enum ErrorType { + NONE, + NOT_CAST_DEVICE, + MISSING_ID, + MISSING_FRIENDLY_NAME, + MISSING_OR_INVALID_IP_ADDRESS, + MISSING_OR_INVALID_PORT, +}; + +ErrorType CreateCastMediaSink(const media_router::DnsSdService& service, + int channel_id, + bool audio_only, + media_router::MediaSinkInternal* cast_sink) { + DCHECK(cast_sink); + if (service.service_name.find( + media_router::CastMediaSinkService::kCastServiceType) == + std::string::npos) + return ErrorType::NOT_CAST_DEVICE; + + net::IPAddress ip_address; + if (!ip_address.AssignFromIPLiteral(service.ip_address)) + return ErrorType::MISSING_OR_INVALID_IP_ADDRESS; + + std::map<std::string, std::string> service_data; + for (const auto& item : service.service_data) { + // |item| format should be "id=xxxxxx", etc. + size_t split_idx = item.find('='); + if (split_idx == std::string::npos) + continue; + + std::string key = item.substr(0, split_idx); + std::string val = + split_idx < item.length() ? item.substr(split_idx + 1) : ""; + service_data[key] = val; + } + + // When use this "sink" within browser, please note it will have a different + // ID when it is sent to the extension, because it derives a different sink ID + // using the given sink ID. + std::string unique_id = service_data["id"]; + if (unique_id.empty()) + return ErrorType::MISSING_ID; + std::string friendly_name = service_data["fn"]; + if (friendly_name.empty()) + return ErrorType::MISSING_FRIENDLY_NAME; + media_router::MediaSink sink(unique_id, friendly_name, + media_router::MediaSink::IconType::CAST); + + media_router::CastSinkExtraData extra_data; + extra_data.ip_address = ip_address; + extra_data.model_name = service_data["md"]; + extra_data.capabilities = cast_channel::CastDeviceCapability::AUDIO_OUT; + if (!audio_only) + extra_data.capabilities |= cast_channel::CastDeviceCapability::VIDEO_OUT; + extra_data.cast_channel_id = channel_id; + + cast_sink->set_sink(sink); + cast_sink->set_cast_data(extra_data); + + return ErrorType::NONE; +} + +} // namespace + +namespace media_router { + +// static +const char CastMediaSinkService::kCastServiceType[] = "_googlecast._tcp.local"; + +CastMediaSinkService::CastMediaSinkService( + const OnSinksDiscoveredCallback& callback, + content::BrowserContext* browser_context) + : MediaSinkServiceBase(callback) { + DCHECK_CALLED_ON_VALID_THREAD(thread_checker_); + cast_socket_service_ = cast_channel::CastSocketServiceFactory::GetInstance() + ->GetForBrowserContext(browser_context); + DCHECK(cast_socket_service_); +} + +CastMediaSinkService::CastMediaSinkService( + const OnSinksDiscoveredCallback& callback, + cast_channel::CastSocketService* cast_socket_service) + : MediaSinkServiceBase(callback), + cast_socket_service_(cast_socket_service) { + DCHECK_CALLED_ON_VALID_THREAD(thread_checker_); + DCHECK(cast_socket_service_); +} + +CastMediaSinkService::~CastMediaSinkService() {} + +void CastMediaSinkService::Start() { + DCHECK_CALLED_ON_VALID_THREAD(thread_checker_); + if (dns_sd_registry_) + return; + + dns_sd_registry_ = DnsSdRegistry::GetInstance(); + dns_sd_registry_->AddObserver(this); + dns_sd_registry_->RegisterDnsSdListener(kCastServiceType); + MediaSinkServiceBase::StartTimer(); +} + +void CastMediaSinkService::Stop() { + DCHECK_CALLED_ON_VALID_THREAD(thread_checker_); + if (!dns_sd_registry_) + return; + + dns_sd_registry_->UnregisterDnsSdListener(kCastServiceType); + dns_sd_registry_->RemoveObserver(this); + dns_sd_registry_ = nullptr; + MediaSinkServiceBase::StopTimer(); +} + +void CastMediaSinkService::SetDnsSdRegistryForTest(DnsSdRegistry* registry) { + DCHECK(!dns_sd_registry_); + dns_sd_registry_ = registry; + dns_sd_registry_->AddObserver(this); + dns_sd_registry_->RegisterDnsSdListener(kCastServiceType); + MediaSinkServiceBase::StartTimer(); +} + +void CastMediaSinkService::OnDnsSdEvent( + const std::string& service_type, + const DnsSdRegistry::DnsSdServiceList& services) { + DCHECK_CALLED_ON_VALID_THREAD(thread_checker_); + DVLOG(2) << "CastMediaSinkService::OnDnsSdEvent found " << services.size() + << " services"; + + current_sinks_.clear(); + current_services_ = services; + + for (const auto& service : services) { + net::IPAddress ip_address; + if (!ip_address.AssignFromIPLiteral(service.ip_address)) { + DVLOG(2) << "Invalid ip_addresss: " << service.ip_address; + continue; + } + net::HostPortPair host_port_pair = + net::HostPortPair::FromString(service.service_host_port); + + content::BrowserThread::PostTask( + content::BrowserThread::IO, FROM_HERE, + base::Bind(&CastMediaSinkService::OpenChannelOnIOThread, this, service, + net::IPEndPoint(ip_address, host_port_pair.port()))); + } + + MediaSinkServiceBase::RestartTimer(); +} + +void CastMediaSinkService::OpenChannelOnIOThread( + const DnsSdService& service, + const net::IPEndPoint& ip_endpoint) { + auto* observer = cast_socket_service_->GetObserver(kObserverId); + if (!observer) { + observer = new CastSocketObserver(); + cast_socket_service_->AddObserver(kObserverId, base::WrapUnique(observer)); + } + + cast_socket_service_->OpenSocket( + ip_endpoint, g_browser_process->net_log(), + base::Bind(&CastMediaSinkService::OnChannelOpenedOnIOThread, this, + service), + observer); +} + +void CastMediaSinkService::OnChannelOpenedOnIOThread( + const DnsSdService& service, + int channel_id, + cast_channel::ChannelError channel_error) { + if (channel_error != cast_channel::ChannelError::NONE) { + DVLOG(2) << "Fail to open channel " << service.ip_address << ": " + << service.service_host_port + << " [ChannelError]: " << (int)channel_error; + return; + } + + auto* socket = cast_socket_service_->GetSocket(channel_id); + if (!socket) { + DVLOG(2) << "Fail to find socket with [channel_id]: " << channel_id; + return; + } + + content::BrowserThread::PostTask( + content::BrowserThread::UI, FROM_HERE, + base::Bind(&CastMediaSinkService::OnChannelOpenedOnUIThread, this, + service, channel_id, socket->audio_only())); +} + +void CastMediaSinkService::OnChannelOpenedOnUIThread( + const DnsSdService& service, + int channel_id, + bool audio_only) { + DCHECK_CALLED_ON_VALID_THREAD(thread_checker_); + MediaSinkInternal sink; + ErrorType error = CreateCastMediaSink(service, channel_id, audio_only, &sink); + if (error != ErrorType::NONE) { + DVLOG(2) << "Fail to create Cast device [error]: " << error; + return; + } + + if (!base::ContainsValue(current_services_, service)) { + DVLOG(2) << "Service data not found in current service data list..."; + return; + } + + DVLOG(2) << "Ading sink to current_sinks_ [id]: " << sink.sink().id(); + current_sinks_.insert(sink); + MediaSinkServiceBase::RestartTimer(); +} + +CastMediaSinkService::CastSocketObserver::CastSocketObserver() {} +CastMediaSinkService::CastSocketObserver::~CastSocketObserver() {} + +void CastMediaSinkService::CastSocketObserver::OnError( + const cast_channel::CastSocket& socket, + cast_channel::ChannelError error_state) { + DVLOG(1) << "OnError [ip_endpoint]: " << socket.ip_endpoint().ToString() + << " [error_state]: " + << cast_channel::ChannelErrorToString(error_state); +} + +void CastMediaSinkService::CastSocketObserver::OnMessage( + const cast_channel::CastSocket& socket, + const cast_channel::CastMessage& message) {} + +} // namespace media_router
diff --git a/chrome/browser/media/router/discovery/mdns/cast_media_sink_service.h b/chrome/browser/media/router/discovery/mdns/cast_media_sink_service.h new file mode 100644 index 0000000..2030c05 --- /dev/null +++ b/chrome/browser/media/router/discovery/mdns/cast_media_sink_service.h
@@ -0,0 +1,132 @@ +// Copyright 2017 The Chromium Authors. All rights reserved. +// Use of this source code is governed by a BSD-style license that can be +// found in the LICENSE file. + +#ifndef CHROME_BROWSER_MEDIA_ROUTER_DISCOVERY_MDNS_CAST_MEDIA_SINK_SERVICE_H_ +#define CHROME_BROWSER_MEDIA_ROUTER_DISCOVERY_MDNS_CAST_MEDIA_SINK_SERVICE_H_ + +#include <memory> +#include <set> + +#include "base/gtest_prod_util.h" +#include "base/memory/ref_counted.h" +#include "base/threading/thread_checker.h" +#include "chrome/browser/media/router/discovery/mdns/dns_sd_delegate.h" +#include "chrome/browser/media/router/discovery/mdns/dns_sd_registry.h" +#include "chrome/browser/media/router/discovery/media_sink_service_base.h" +#include "components/cast_channel/cast_channel_enum.h" +#include "components/cast_channel/cast_socket.h" +#include "net/base/ip_endpoint.h" + +namespace cast_channel { +class CastSocketService; +} // namespace cast_channel + +namespace content { +class BrowserContext; +} // namespace content + +namespace media_router { + +// A service which can be used to start background discovery and resolution of +// Cast devices. +// Public APIs should be invoked on the UI thread. +class CastMediaSinkService + : public MediaSinkServiceBase, + public DnsSdRegistry::DnsSdObserver, + public base::RefCountedThreadSafe<CastMediaSinkService> { + public: + CastMediaSinkService(const OnSinksDiscoveredCallback& callback, + content::BrowserContext* browser_context); + + // Used by unit tests. + CastMediaSinkService(const OnSinksDiscoveredCallback& callback, + cast_channel::CastSocketService* cast_socket_service); + + // mDNS service types. + static const char kCastServiceType[]; + + // MediaSinkService implementation + void Start() override; + void Stop() override; + + protected: + // Used to mock out the DnsSdRegistry for testing. + void SetDnsSdRegistryForTest(DnsSdRegistry* registry); + + ~CastMediaSinkService() override; + + private: + // Receives incoming messages and errors and provides additional API context. + class CastSocketObserver : public cast_channel::CastSocket::Observer { + public: + CastSocketObserver(); + ~CastSocketObserver() override; + + // CastSocket::Observer implementation. + void OnError(const cast_channel::CastSocket& socket, + cast_channel::ChannelError error_state) override; + void OnMessage(const cast_channel::CastSocket& socket, + const cast_channel::CastMessage& message) override; + + private: + DISALLOW_COPY_AND_ASSIGN(CastSocketObserver); + }; + + friend class base::RefCountedThreadSafe<CastMediaSinkService>; + friend class CastMediaSinkServiceTest; + + FRIEND_TEST_ALL_PREFIXES(CastMediaSinkServiceTest, TestReStartAfterStop); + FRIEND_TEST_ALL_PREFIXES(CastMediaSinkServiceTest, TestMultipleStartAndStop); + FRIEND_TEST_ALL_PREFIXES(CastMediaSinkServiceTest, + TestOnChannelOpenedOnIOThread); + FRIEND_TEST_ALL_PREFIXES(CastMediaSinkServiceTest, + TestMultipleOnChannelOpenedOnIOThread); + FRIEND_TEST_ALL_PREFIXES(CastMediaSinkServiceTest, TestOnDnsSdEvent); + FRIEND_TEST_ALL_PREFIXES(CastMediaSinkServiceTest, TestMultipleOnDnsSdEvent); + FRIEND_TEST_ALL_PREFIXES(CastMediaSinkServiceTest, TestTimer); + + // DnsSdRegistry::DnsSdObserver implementation + void OnDnsSdEvent(const std::string& service_type, + const DnsSdRegistry::DnsSdServiceList& services) override; + + // Opens cast channel on IO thread. + // |service|: mDNS service description. + // |ip_endpoint|: cast channel's target IP endpoint. + void OpenChannelOnIOThread(const DnsSdService& service, + const net::IPEndPoint& ip_endpoint); + + // Invoked when opening cast channel on IO thread completes. + // |service|: mDNS service description. + // |channel_id|: channel id of newly created cast channel. + // |channel_error|: error encounted when opending cast channel. + void OnChannelOpenedOnIOThread(const DnsSdService& service, + int channel_id, + cast_channel::ChannelError channel_error); + + // Invoked by |OnChannelOpenedOnIOThread| to post task on UI thread. + // |service|: mDNS service description. + // |channel_id|: channel id of newly created cast channel. + // |audio_only|: if cast channel is audio only or not. + void OnChannelOpenedOnUIThread(const DnsSdService& service, + int channel_id, + bool audio_only); + + // Raw pointer to DnsSdRegistry instance, which is a global leaky singleton + // and lives as long as the browser process. + DnsSdRegistry* dns_sd_registry_ = nullptr; + + // Service list from current round of discovery. + DnsSdRegistry::DnsSdServiceList current_services_; + + // Service managing creating and removing cast channels. + scoped_refptr<cast_channel::CastSocketService> cast_socket_service_; + + THREAD_CHECKER(thread_checker_); + + DISALLOW_COPY_AND_ASSIGN(CastMediaSinkService); +}; + +} // namespace media_router + +#endif // CHROME_BROWSER_MEDIA_ROUTER_DISCOVERY_MDNS_CAST_MEDIA_SINK_SERVICE_H_
diff --git a/chrome/browser/media/router/discovery/mdns/cast_media_sink_service_unittest.cc b/chrome/browser/media/router/discovery/mdns/cast_media_sink_service_unittest.cc new file mode 100644 index 0000000..7e12a975 --- /dev/null +++ b/chrome/browser/media/router/discovery/mdns/cast_media_sink_service_unittest.cc
@@ -0,0 +1,309 @@ +// Copyright 2017 The Chromium Authors. All rights reserved. +// Use of this source code is governed by a BSD-style license that can be +// found in the LICENSE file. + +#include "chrome/browser/media/router/discovery/mdns/cast_media_sink_service.h" +#include "base/strings/stringprintf.h" +#include "base/test/mock_callback.h" +#include "base/timer/mock_timer.h" +#include "chrome/browser/media/router/discovery/mdns/mock_dns_sd_registry.h" +#include "chrome/browser/media/router/test_helper.h" +#include "chrome/test/base/testing_profile.h" +#include "components/cast_channel/cast_socket.h" +#include "components/cast_channel/cast_socket_service.h" +#include "components/cast_channel/cast_test_util.h" +#include "content/public/test/test_browser_thread_bundle.h" +#include "testing/gmock/include/gmock/gmock.h" +#include "testing/gtest/include/gtest/gtest.h" + +using ::testing::_; +using ::testing::Return; +using ::testing::SaveArg; + +namespace { + +net::IPEndPoint CreateIPEndPoint(int num) { + net::IPAddress ip_address; + CHECK(ip_address.AssignFromIPLiteral( + base::StringPrintf("192.168.0.10%d", num))); + return net::IPEndPoint(ip_address, 8009 + num); +} + +media_router::DnsSdService CreateDnsService(int num) { + net::IPEndPoint ip_endpoint = CreateIPEndPoint(num); + media_router::DnsSdService service; + service.service_name = + "_myDevice." + + std::string(media_router::CastMediaSinkService::kCastServiceType); + service.ip_address = ip_endpoint.address().ToString(); + service.service_host_port = ip_endpoint.ToString(); + service.service_data.push_back(base::StringPrintf("id=service %d", num)); + service.service_data.push_back( + base::StringPrintf("fn=friendly name %d", num)); + service.service_data.push_back(base::StringPrintf("md=model name %d", num)); + + return service; +} + +void VerifyMediaSinkInternal(const media_router::MediaSinkInternal& cast_sink, + const media_router::DnsSdService& service, + int channel_id, + bool audio_only) { + std::string id = base::StringPrintf("service %d", channel_id); + std::string name = base::StringPrintf("friendly name %d", channel_id); + std::string model_name = base::StringPrintf("model name %d", channel_id); + EXPECT_EQ(id, cast_sink.sink().id()); + EXPECT_EQ(name, cast_sink.sink().name()); + EXPECT_EQ(model_name, cast_sink.cast_data().model_name); + EXPECT_EQ(service.ip_address, cast_sink.cast_data().ip_address.ToString()); + + int capabilities = cast_channel::CastDeviceCapability::AUDIO_OUT; + if (!audio_only) + capabilities |= cast_channel::CastDeviceCapability::VIDEO_OUT; + EXPECT_EQ(capabilities, cast_sink.cast_data().capabilities); + EXPECT_EQ(channel_id, cast_sink.cast_data().cast_channel_id); +} + +} // namespace + +namespace media_router { + +class MockCastSocketService : public cast_channel::CastSocketService { + public: + MOCK_METHOD4(OpenSocket, + int(const net::IPEndPoint& ip_endpoint, + net::NetLog* net_log, + const cast_channel::CastSocket::OnOpenCallback& open_cb, + cast_channel::CastSocket::Observer* observer)); + MOCK_CONST_METHOD1(GetSocket, cast_channel::CastSocket*(int channel_id)); + + private: + ~MockCastSocketService() {} +}; + +class CastMediaSinkServiceTest : public ::testing::Test { + public: + CastMediaSinkServiceTest() + : mock_cast_socket_service_(new MockCastSocketService()), + media_sink_service_( + new CastMediaSinkService(mock_sink_discovered_cb_.Get(), + mock_cast_socket_service_.get())), + test_dns_sd_registry_(media_sink_service_.get()) {} + + void SetUp() override { + auto mock_timer = base::MakeUnique<base::MockTimer>( + true /*retain_user_task*/, false /*is_repeating*/); + mock_timer_ = mock_timer.get(); + media_sink_service_->SetTimerForTest(std::move(mock_timer)); + } + + protected: + const content::TestBrowserThreadBundle thread_bundle_; + TestingProfile profile_; + + base::MockCallback<MediaSinkService::OnSinksDiscoveredCallback> + mock_sink_discovered_cb_; + scoped_refptr<MockCastSocketService> mock_cast_socket_service_; + scoped_refptr<CastMediaSinkService> media_sink_service_; + MockDnsSdRegistry test_dns_sd_registry_; + base::MockTimer* mock_timer_; + + DISALLOW_COPY_AND_ASSIGN(CastMediaSinkServiceTest); +}; + +TEST_F(CastMediaSinkServiceTest, TestReStartAfterStop) { + EXPECT_CALL(test_dns_sd_registry_, AddObserver(media_sink_service_.get())) + .Times(2); + EXPECT_CALL(test_dns_sd_registry_, RegisterDnsSdListener(_)).Times(2); + EXPECT_FALSE(mock_timer_->IsRunning()); + media_sink_service_->SetDnsSdRegistryForTest(&test_dns_sd_registry_); + media_sink_service_->Start(); + EXPECT_TRUE(mock_timer_->IsRunning()); + + EXPECT_CALL(test_dns_sd_registry_, RemoveObserver(media_sink_service_.get())); + EXPECT_CALL(test_dns_sd_registry_, UnregisterDnsSdListener(_)); + media_sink_service_->Stop(); + + mock_timer_ = + new base::MockTimer(true /*retain_user_task*/, false /*is_repeating*/); + media_sink_service_->SetTimerForTest(base::WrapUnique(mock_timer_)); + media_sink_service_->SetDnsSdRegistryForTest(&test_dns_sd_registry_); + media_sink_service_->Start(); + EXPECT_TRUE(mock_timer_->IsRunning()); +} + +TEST_F(CastMediaSinkServiceTest, TestMultipleStartAndStop) { + EXPECT_CALL(test_dns_sd_registry_, AddObserver(media_sink_service_.get())); + EXPECT_CALL(test_dns_sd_registry_, RegisterDnsSdListener(_)); + media_sink_service_->SetDnsSdRegistryForTest(&test_dns_sd_registry_); + media_sink_service_->Start(); + media_sink_service_->Start(); + EXPECT_TRUE(mock_timer_->IsRunning()); + + EXPECT_CALL(test_dns_sd_registry_, RemoveObserver(media_sink_service_.get())); + EXPECT_CALL(test_dns_sd_registry_, UnregisterDnsSdListener(_)); + media_sink_service_->Stop(); + media_sink_service_->Stop(); +} + +TEST_F(CastMediaSinkServiceTest, TestOnChannelOpenedOnIOThread) { + DnsSdService service = CreateDnsService(1); + cast_channel::MockCastSocket socket; + EXPECT_CALL(*mock_cast_socket_service_, GetSocket(1)) + .WillOnce(Return(&socket)); + + media_sink_service_->current_services_.push_back(service); + media_sink_service_->OnChannelOpenedOnIOThread( + service, 1, cast_channel::ChannelError::NONE); + // Invoke CastMediaSinkService::OnChannelOpenedOnUIThread on the UI thread. + base::RunLoop().RunUntilIdle(); + + // Verify sink content + EXPECT_EQ(size_t(1), media_sink_service_->current_sinks_.size()); + for (const auto& sink_it : media_sink_service_->current_sinks_) + VerifyMediaSinkInternal(sink_it, service, 1, false); +} + +TEST_F(CastMediaSinkServiceTest, TestMultipleOnChannelOpenedOnIOThread) { + DnsSdService service1 = CreateDnsService(1); + DnsSdService service2 = CreateDnsService(2); + DnsSdService service3 = CreateDnsService(3); + + cast_channel::MockCastSocket socket2; + cast_channel::MockCastSocket socket3; + // Fail to open channel 1. + EXPECT_CALL(*mock_cast_socket_service_, GetSocket(1)) + .WillOnce(Return(nullptr)); + EXPECT_CALL(*mock_cast_socket_service_, GetSocket(2)) + .WillOnce(Return(&socket2)); + EXPECT_CALL(*mock_cast_socket_service_, GetSocket(3)) + .WillOnce(Return(&socket2)); + + // Current round of Dns discovery finds service1 and service 2. + media_sink_service_->current_services_.push_back(service1); + media_sink_service_->current_services_.push_back(service2); + media_sink_service_->OnChannelOpenedOnIOThread( + service1, 1, cast_channel::ChannelError::NONE); + media_sink_service_->OnChannelOpenedOnIOThread( + service2, 2, cast_channel::ChannelError::NONE); + media_sink_service_->OnChannelOpenedOnIOThread( + service3, 3, cast_channel::ChannelError::NONE); + // Invoke CastMediaSinkService::OnChannelOpenedOnUIThread on the UI thread. + base::RunLoop().RunUntilIdle(); + + // Verify sink content + EXPECT_EQ(size_t(1), media_sink_service_->current_sinks_.size()); + for (const auto& sink_it : media_sink_service_->current_sinks_) + VerifyMediaSinkInternal(sink_it, service2, 2, false); +} + +TEST_F(CastMediaSinkServiceTest, TestOnDnsSdEvent) { + DnsSdService service1 = CreateDnsService(1); + DnsSdService service2 = CreateDnsService(2); + net::IPEndPoint ip_endpoint1 = CreateIPEndPoint(1); + net::IPEndPoint ip_endpoint2 = CreateIPEndPoint(2); + + // Add dns services. + DnsSdRegistry::DnsSdServiceList service_list{service1, service2}; + + cast_channel::CastSocket::OnOpenCallback callback1; + cast_channel::CastSocket::OnOpenCallback callback2; + EXPECT_CALL(*mock_cast_socket_service_, OpenSocket(ip_endpoint1, _, _, _)) + .WillOnce(DoAll(SaveArg<2>(&callback1), Return(1))); + EXPECT_CALL(*mock_cast_socket_service_, OpenSocket(ip_endpoint2, _, _, _)) + .WillOnce(DoAll(SaveArg<2>(&callback2), Return(2))); + + // Invoke CastSocketService::OpenSocket on the IO thread. + media_sink_service_->OnDnsSdEvent(CastMediaSinkService::kCastServiceType, + service_list); + base::RunLoop().RunUntilIdle(); + + cast_channel::MockCastSocket socket1; + cast_channel::MockCastSocket socket2; + + EXPECT_CALL(*mock_cast_socket_service_, GetSocket(1)) + .WillOnce(Return(&socket1)); + EXPECT_CALL(*mock_cast_socket_service_, GetSocket(2)) + .WillOnce(Return(&socket2)); + + callback1.Run(1, cast_channel::ChannelError::NONE); + callback2.Run(2, cast_channel::ChannelError::NONE); + + // Invoke CastMediaSinkService::OnChannelOpenedOnUIThread on the UI thread. + base::RunLoop().RunUntilIdle(); + // Verify sink content + EXPECT_EQ(size_t(2), media_sink_service_->current_sinks_.size()); +} + +TEST_F(CastMediaSinkServiceTest, TestMultipleOnDnsSdEvent) { + DnsSdService service1 = CreateDnsService(1); + DnsSdService service2 = CreateDnsService(2); + DnsSdService service3 = CreateDnsService(3); + net::IPEndPoint ip_endpoint1 = CreateIPEndPoint(1); + net::IPEndPoint ip_endpoint2 = CreateIPEndPoint(2); + net::IPEndPoint ip_endpoint3 = CreateIPEndPoint(3); + + // 1st round finds service 1 & 2. + DnsSdRegistry::DnsSdServiceList service_list1{service1, service2}; + media_sink_service_->OnDnsSdEvent(CastMediaSinkService::kCastServiceType, + service_list1); + + EXPECT_CALL(*mock_cast_socket_service_, OpenSocket(ip_endpoint1, _, _, _)); + EXPECT_CALL(*mock_cast_socket_service_, OpenSocket(ip_endpoint2, _, _, _)); + base::RunLoop().RunUntilIdle(); + + // Channel 2 opened. + media_sink_service_->OnChannelOpenedOnUIThread(service2, 2, false); + + // 2nd round finds service 2 & 3. + DnsSdRegistry::DnsSdServiceList service_list2{service2, service3}; + media_sink_service_->OnDnsSdEvent(CastMediaSinkService::kCastServiceType, + service_list2); + + EXPECT_CALL(*mock_cast_socket_service_, OpenSocket(ip_endpoint2, _, _, _)); + EXPECT_CALL(*mock_cast_socket_service_, OpenSocket(ip_endpoint3, _, _, _)); + base::RunLoop().RunUntilIdle(); + + // Channel 1 and 3 opened. + media_sink_service_->OnChannelOpenedOnUIThread(service1, 1, false); + media_sink_service_->OnChannelOpenedOnUIThread(service3, 3, false); + + EXPECT_EQ(size_t(1), media_sink_service_->current_sinks_.size()); + for (const auto& sink_it : media_sink_service_->current_sinks_) + VerifyMediaSinkInternal(sink_it, service3, 3, false); +} + +TEST_F(CastMediaSinkServiceTest, TestTimer) { + DnsSdService service1 = CreateDnsService(1); + DnsSdService service2 = CreateDnsService(2); + net::IPEndPoint ip_endpoint1 = CreateIPEndPoint(1); + net::IPEndPoint ip_endpoint2 = CreateIPEndPoint(2); + + EXPECT_FALSE(mock_timer_->IsRunning()); + // finds service 1 & 2. + DnsSdRegistry::DnsSdServiceList service_list1{service1, service2}; + media_sink_service_->OnDnsSdEvent(CastMediaSinkService::kCastServiceType, + service_list1); + + EXPECT_CALL(*mock_cast_socket_service_, OpenSocket(ip_endpoint1, _, _, _)); + EXPECT_CALL(*mock_cast_socket_service_, OpenSocket(ip_endpoint2, _, _, _)); + base::RunLoop().RunUntilIdle(); + + // Channel 2 is opened. + media_sink_service_->OnChannelOpenedOnUIThread(service2, 2, false); + + std::vector<MediaSinkInternal> sinks; + EXPECT_CALL(mock_sink_discovered_cb_, Run(_)).WillOnce(SaveArg<0>(&sinks)); + + // Fire timer. + mock_timer_->Fire(); + EXPECT_EQ(size_t(1), sinks.size()); + VerifyMediaSinkInternal(sinks[0], service2, 2, false); + + EXPECT_FALSE(mock_timer_->IsRunning()); + // Channel 1 is opened and timer is restarted. + media_sink_service_->OnChannelOpenedOnUIThread(service1, 1, false); + EXPECT_TRUE(mock_timer_->IsRunning()); +} + +} // namespace media_router
diff --git a/chrome/browser/media/router/discovery/mdns/mock_dns_sd_registry.cc b/chrome/browser/media/router/discovery/mdns/mock_dns_sd_registry.cc index 2e8f055a..dd32a7f 100644 --- a/chrome/browser/media/router/discovery/mdns/mock_dns_sd_registry.cc +++ b/chrome/browser/media/router/discovery/mdns/mock_dns_sd_registry.cc
@@ -7,7 +7,7 @@ namespace media_router { MockDnsSdRegistry::MockDnsSdRegistry(DnsSdRegistry::DnsSdObserver* observer) - : observer_(observer) {} + : DnsSdRegistry(nullptr), observer_(observer) {} MockDnsSdRegistry::~MockDnsSdRegistry() {}
diff --git a/chrome/browser/media/router/mojo/media_router_mojo_impl.cc b/chrome/browser/media/router/mojo/media_router_mojo_impl.cc index ee3c4c6..3c7d8bf 100644 --- a/chrome/browser/media/router/mojo/media_router_mojo_impl.cc +++ b/chrome/browser/media/router/mojo/media_router_mojo_impl.cc
@@ -16,6 +16,7 @@ #include "base/stl_util.h" #include "base/strings/stringprintf.h" #include "chrome/browser/media/router/discovery/dial/dial_media_sink_service_proxy.h" +#include "chrome/browser/media/router/discovery/mdns/cast_media_sink_service.h" #include "chrome/browser/media/router/event_page_request_manager.h" #include "chrome/browser/media/router/event_page_request_manager_factory.h" #include "chrome/browser/media/router/issues_observer.h" @@ -429,8 +430,8 @@ void MediaRouterMojoImpl::ProvideSinks(const std::string& provider_name, std::vector<MediaSinkInternal> sinks) { DCHECK_CURRENTLY_ON(content::BrowserThread::UI); - DVLOG_WITH_INSTANCE(1) << "OnDialMediaSinkDiscovered found " << sinks.size() - << " devices..."; + DVLOG_WITH_INSTANCE(1) << "Provider [" << provider_name << "] found " + << sinks.size() << " devices..."; event_page_request_manager_->RunOrDefer( base::Bind(&MediaRouterMojoImpl::DoProvideSinks, @@ -941,8 +942,7 @@ } #endif - if (media_router::DialLocalDiscoveryEnabled()) - StartDiscovery(); + StartDiscovery(); } #if defined(OS_WIN) @@ -976,14 +976,25 @@ DCHECK_CURRENTLY_ON(content::BrowserThread::UI); DVLOG_WITH_INSTANCE(1) << "StartDiscovery"; - if (!dial_media_sink_service_proxy_) { - dial_media_sink_service_proxy_ = new DialMediaSinkServiceProxy( - base::Bind(&MediaRouterMojoImpl::ProvideSinks, - weak_factory_.GetWeakPtr(), "dial"), - context_); + if (media_router::DialLocalDiscoveryEnabled()) { + if (!dial_media_sink_service_proxy_) { + dial_media_sink_service_proxy_ = new DialMediaSinkServiceProxy( + base::Bind(&MediaRouterMojoImpl::ProvideSinks, + weak_factory_.GetWeakPtr(), "dial"), + context_); + } + dial_media_sink_service_proxy_->Start(); } - dial_media_sink_service_proxy_->Start(); + if (media_router::CastDiscoveryEnabled()) { + if (!cast_media_sink_service_) { + cast_media_sink_service_ = new CastMediaSinkService( + base::Bind(&MediaRouterMojoImpl::ProvideSinks, + weak_factory_.GetWeakPtr(), "cast"), + context_); + } + cast_media_sink_service_->Start(); + } } void MediaRouterMojoImpl::UpdateMediaSinks(
diff --git a/chrome/browser/media/router/mojo/media_router_mojo_impl.h b/chrome/browser/media/router/mojo/media_router_mojo_impl.h index 01cb711..3e9627c 100644 --- a/chrome/browser/media/router/mojo/media_router_mojo_impl.h +++ b/chrome/browser/media/router/mojo/media_router_mojo_impl.h
@@ -44,6 +44,7 @@ namespace media_router { enum class MediaRouteProviderWakeReason; +class CastMediaSinkService; class DialMediaSinkServiceProxy; class EventPageRequestManager; @@ -415,6 +416,9 @@ // Media sink service for DIAL devices. scoped_refptr<DialMediaSinkServiceProxy> dial_media_sink_service_proxy_; + // Media sink service for CAST devices. + scoped_refptr<CastMediaSinkService> cast_media_sink_service_; + content::BrowserContext* const context_; // Request manager responsible for waking the component extension and calling
diff --git a/chrome/browser/media/webrtc/webrtc_event_log_handler.cc b/chrome/browser/media/webrtc/webrtc_event_log_handler.cc index 7ed5871..d8a3a6f 100644 --- a/chrome/browser/media/webrtc/webrtc_event_log_handler.cc +++ b/chrome/browser/media/webrtc/webrtc_event_log_handler.cc
@@ -11,6 +11,7 @@ #include "base/command_line.h" #include "base/files/file_util.h" #include "base/strings/string_number_conversions.h" +#include "base/task_scheduler/post_task.h" #include "base/time/time.h" #include "chrome/browser/media/webrtc/webrtc_log_list.h" #include "chrome/browser/profiles/profile.h" @@ -34,7 +35,10 @@ WebRtcEventLogHandler::WebRtcEventLogHandler(int render_process_id, Profile* profile) - : render_process_id_(render_process_id), + : background_task_runner_(base::CreateSequencedTaskRunnerWithTraits( + {base::MayBlock(), base::WithBaseSyncPrimitives(), + base::TaskPriority::BACKGROUND})), + render_process_id_(render_process_id), profile_(profile), current_rtc_event_log_id_(0) { DCHECK(profile_); @@ -48,8 +52,8 @@ const RecordingErrorCallback& error_callback) { DCHECK_CURRENTLY_ON(BrowserThread::UI); - BrowserThread::PostTaskAndReplyWithResult( - BrowserThread::FILE, FROM_HERE, + base::PostTaskAndReplyWithResult( + background_task_runner_.get(), FROM_HERE, base::Bind(&WebRtcEventLogHandler::GetLogDirectoryAndEnsureExists, this), base::Bind(&WebRtcEventLogHandler::DoStartWebRtcEventLogging, this, duration, callback, error_callback)); @@ -61,8 +65,8 @@ DCHECK_CURRENTLY_ON(BrowserThread::UI); const bool is_manual_stop = true; - BrowserThread::PostTaskAndReplyWithResult( - BrowserThread::FILE, FROM_HERE, + base::PostTaskAndReplyWithResult( + background_task_runner_.get(), FROM_HERE, base::Bind(&WebRtcEventLogHandler::GetLogDirectoryAndEnsureExists, this), base::Bind(&WebRtcEventLogHandler::DoStopWebRtcEventLogging, this, is_manual_stop, current_rtc_event_log_id_, callback, @@ -70,7 +74,7 @@ } base::FilePath WebRtcEventLogHandler::GetLogDirectoryAndEnsureExists() { - DCHECK_CURRENTLY_ON(BrowserThread::FILE); + DCHECK(background_task_runner_->RunsTasksInCurrentSequence()); base::FilePath log_dir_path = WebRtcLogList::GetWebRtcLogDirectoryForProfile(profile_->GetPath()); base::File::Error error;
diff --git a/chrome/browser/media/webrtc/webrtc_event_log_handler.h b/chrome/browser/media/webrtc/webrtc_event_log_handler.h index b02b5e5..9f5c5cf6 100644 --- a/chrome/browser/media/webrtc/webrtc_event_log_handler.h +++ b/chrome/browser/media/webrtc/webrtc_event_log_handler.h
@@ -13,6 +13,7 @@ #include "base/callback.h" #include "base/files/file_path.h" #include "base/memory/ref_counted.h" +#include "base/sequenced_task_runner.h" #include "base/threading/thread_checker.h" #include "base/time/time.h" @@ -65,6 +66,8 @@ const RecordingErrorCallback& error_callback, const base::FilePath& log_directory); + scoped_refptr<base::SequencedTaskRunner> background_task_runner_; + // The ID of our render process. int render_process_id_;
diff --git a/chrome/browser/metrics/chrome_metrics_services_manager_client.cc b/chrome/browser/metrics/chrome_metrics_services_manager_client.cc index 83594d47..d451a34 100644 --- a/chrome/browser/metrics/chrome_metrics_services_manager_client.cc +++ b/chrome/browser/metrics/chrome_metrics_services_manager_client.cc
@@ -10,11 +10,13 @@ #include "base/memory/ptr_util.h" #include "base/strings/string_number_conversions.h" #include "base/task_scheduler/post_task.h" +#include "build/build_config.h" #include "chrome/browser/browser_process.h" #include "chrome/browser/metrics/chrome_metrics_service_accessor.h" #include "chrome/browser/metrics/chrome_metrics_service_client.h" #include "chrome/browser/metrics/variations/chrome_variations_service_client.h" #include "chrome/browser/metrics/variations/ui_string_overrider_factory.h" +#include "chrome/browser/ui/browser_list.h" #include "chrome/browser/ui/browser_otr_state.h" #include "chrome/common/chrome_switches.h" #include "chrome/installer/util/google_update_settings.h" @@ -288,5 +290,15 @@ } bool ChromeMetricsServicesManagerClient::IsIncognitoSessionActive() { - return chrome::IsIncognitoSessionActive(); +#if defined(OS_ANDROID) + // TODO(crbug/739971) On Android, we don't get notifications from TabModel + // when incognito tabs are opened, so this won't get re-evaluated reliably + // yet. Assume there always an incognito tab open, which will keep UKM + // disabled. + return true; +#else + // Depending directly on BrowserList, since that is the implementation + // that we get correct notifications for. + return BrowserList::IsIncognitoSessionActive(); +#endif }
diff --git a/chrome/browser/metrics/process_memory_metrics_emitter.cc b/chrome/browser/metrics/process_memory_metrics_emitter.cc index e9098cca..b82634e2 100644 --- a/chrome/browser/metrics/process_memory_metrics_emitter.cc +++ b/chrome/browser/metrics/process_memory_metrics_emitter.cc
@@ -8,6 +8,8 @@ #include "base/trace_event/memory_dump_request_args.h" #include "content/public/common/service_manager_connection.h" #include "content/public/common/service_names.mojom.h" +#include "services/metrics/public/cpp/ukm_entry_builder.h" +#include "services/metrics/public/cpp/ukm_recorder.h" #include "services/service_manager/public/cpp/connector.h" using ProcessMemoryDumpPtr = @@ -15,44 +17,87 @@ namespace { -void EmitBrowserMemoryMetrics(const ProcessMemoryDumpPtr& pmd) { +void EmitBrowserMemoryMetrics(const ProcessMemoryDumpPtr& pmd, + ukm::UkmEntryBuilder* builder) { + builder->AddMetric("ProcessType", + static_cast<int64_t>( + memory_instrumentation::mojom::ProcessType::BROWSER)); + UMA_HISTOGRAM_MEMORY_LARGE_MB("Memory.Experimental.Browser2.Resident", pmd->os_dump->resident_set_kb / 1024); + builder->AddMetric("Resident", pmd->os_dump->resident_set_kb / 1024); + UMA_HISTOGRAM_MEMORY_LARGE_MB("Memory.Experimental.Browser2.Malloc", pmd->chrome_dump.malloc_total_kb / 1024); + builder->AddMetric("Malloc", pmd->chrome_dump.malloc_total_kb / 1024); + UMA_HISTOGRAM_MEMORY_LARGE_MB( "Memory.Experimental.Browser2.PrivateMemoryFootprint", pmd->os_dump->private_footprint_kb / 1024); + builder->AddMetric("PrivateMemoryFootprint", + pmd->os_dump->private_footprint_kb / 1024); } -void EmitRendererMemoryMetrics(const ProcessMemoryDumpPtr& pmd) { +void EmitRendererMemoryMetrics(const ProcessMemoryDumpPtr& pmd, + ukm::UkmEntryBuilder* builder) { + builder->AddMetric("ProcessType", + static_cast<int64_t>( + memory_instrumentation::mojom::ProcessType::RENDERER)); + UMA_HISTOGRAM_MEMORY_LARGE_MB("Memory.Experimental.Renderer2.Resident", pmd->os_dump->resident_set_kb / 1024); + builder->AddMetric("Resident", pmd->os_dump->resident_set_kb / 1024); + + UMA_HISTOGRAM_MEMORY_LARGE_MB("Memory.Experimental.Renderer2.Malloc", + pmd->chrome_dump.malloc_total_kb / 1024); + builder->AddMetric("Malloc", pmd->chrome_dump.malloc_total_kb / 1024); + UMA_HISTOGRAM_MEMORY_LARGE_MB( "Memory.Experimental.Renderer2.PrivateMemoryFootprint", pmd->os_dump->private_footprint_kb / 1024); - UMA_HISTOGRAM_MEMORY_LARGE_MB("Memory.Experimental.Renderer2.Malloc", - pmd->chrome_dump.malloc_total_kb / 1024); + builder->AddMetric("PrivateMemoryFootprint", + pmd->os_dump->private_footprint_kb / 1024); + UMA_HISTOGRAM_MEMORY_LARGE_MB( "Memory.Experimental.Renderer2.PartitionAlloc", pmd->chrome_dump.partition_alloc_total_kb / 1024); + builder->AddMetric("PartitionAlloc", + pmd->chrome_dump.partition_alloc_total_kb / 1024); + UMA_HISTOGRAM_MEMORY_LARGE_MB("Memory.Experimental.Renderer2.BlinkGC", pmd->chrome_dump.blink_gc_total_kb / 1024); + builder->AddMetric("BlinkGC", pmd->chrome_dump.blink_gc_total_kb / 1024); + UMA_HISTOGRAM_MEMORY_LARGE_MB("Memory.Experimental.Renderer2.V8", pmd->chrome_dump.v8_total_kb / 1024); + builder->AddMetric("V8", pmd->chrome_dump.v8_total_kb / 1024); } -void EmitGpuMemoryMetrics(const ProcessMemoryDumpPtr& pmd) { +void EmitGpuMemoryMetrics(const ProcessMemoryDumpPtr& pmd, + ukm::UkmEntryBuilder* builder) { + builder->AddMetric( + "ProcessType", + static_cast<int64_t>(memory_instrumentation::mojom::ProcessType::GPU)); + UMA_HISTOGRAM_MEMORY_LARGE_MB("Memory.Experimental.Gpu2.Resident", pmd->os_dump->resident_set_kb / 1024); + builder->AddMetric("Resident", pmd->os_dump->resident_set_kb / 1024); + UMA_HISTOGRAM_MEMORY_LARGE_MB("Memory.Experimental.Gpu2.Malloc", pmd->chrome_dump.malloc_total_kb / 1024); + builder->AddMetric("Malloc", pmd->chrome_dump.malloc_total_kb / 1024); + UMA_HISTOGRAM_MEMORY_LARGE_MB( "Memory.Experimental.Gpu2.CommandBuffer", pmd->chrome_dump.command_buffer_total_kb / 1024); + builder->AddMetric("CommandBuffer", + pmd->chrome_dump.command_buffer_total_kb / 1024); + UMA_HISTOGRAM_MEMORY_LARGE_MB( "Memory.Experimental.Gpu2.PrivateMemoryFootprint", pmd->os_dump->private_footprint_kb / 1024); + builder->AddMetric("PrivateMemoryFootprint", + pmd->os_dump->private_footprint_kb / 1024); } } // namespace @@ -77,6 +122,16 @@ ProcessMemoryMetricsEmitter::~ProcessMemoryMetricsEmitter() {} +std::unique_ptr<ukm::UkmEntryBuilder> +ProcessMemoryMetricsEmitter::CreateUkmBuilder(const char* event_name) { + ukm::UkmRecorder* ukm_recorder = ukm::UkmRecorder::Get(); + if (!ukm_recorder) + return nullptr; + + const int32_t source_id = ukm_recorder->GetNewSourceID(); + return ukm_recorder->GetEntryBuilder(source_id, event_name); +} + void ProcessMemoryMetricsEmitter::ReceivedMemoryDump( bool success, uint64_t dump_guid, @@ -89,15 +144,23 @@ uint32_t private_footprint_total_kb = 0; for (const ProcessMemoryDumpPtr& pmd : ptr->process_dumps) { private_footprint_total_kb += pmd->os_dump->private_footprint_kb; + + // Populate a new entry for each ProcessMemoryDumpPtr in the global dump, + // annotating each entry with the dump GUID so that entries in the same + // global dump can be correlated with each other. + // TODO(jchinlee): Add URLs. + std::unique_ptr<ukm::UkmEntryBuilder> builder = + CreateUkmBuilder("Memory.Experimental"); + switch (pmd->process_type) { case memory_instrumentation::mojom::ProcessType::BROWSER: - EmitBrowserMemoryMetrics(pmd); + EmitBrowserMemoryMetrics(pmd, builder.get()); break; case memory_instrumentation::mojom::ProcessType::RENDERER: - EmitRendererMemoryMetrics(pmd); + EmitRendererMemoryMetrics(pmd, builder.get()); break; case memory_instrumentation::mojom::ProcessType::GPU: - EmitGpuMemoryMetrics(pmd); + EmitGpuMemoryMetrics(pmd, builder.get()); break; case memory_instrumentation::mojom::ProcessType::UTILITY: case memory_instrumentation::mojom::ProcessType::PLUGIN: @@ -108,4 +171,9 @@ UMA_HISTOGRAM_MEMORY_LARGE_MB( "Memory.Experimental.Total2.PrivateMemoryFootprint", private_footprint_total_kb / 1024); + + std::unique_ptr<ukm::UkmEntryBuilder> builder = + CreateUkmBuilder("Memory.Experimental"); + builder->AddMetric("Total2.PrivateMemoryFootprint", + private_footprint_total_kb / 1024); }
diff --git a/chrome/browser/metrics/process_memory_metrics_emitter.h b/chrome/browser/metrics/process_memory_metrics_emitter.h index 0358a8f..fa91d276 100644 --- a/chrome/browser/metrics/process_memory_metrics_emitter.h +++ b/chrome/browser/metrics/process_memory_metrics_emitter.h
@@ -8,6 +8,10 @@ #include "base/memory/ref_counted.h" #include "services/resource_coordinator/public/interfaces/memory_instrumentation/memory_instrumentation.mojom.h" +namespace ukm { +class UkmEntryBuilder; +} + // This class asynchronously fetches memory metrics for each process, and then // emits UMA metrics from those metrics. // Each instance is self-owned, and will delete itself once it has finished @@ -35,6 +39,9 @@ private: friend class base::RefCountedThreadSafe<ProcessMemoryMetricsEmitter>; + std::unique_ptr<ukm::UkmEntryBuilder> CreateUkmBuilder( + const char* event_name); + memory_instrumentation::mojom::CoordinatorPtr coordinator_; DISALLOW_COPY_AND_ASSIGN(ProcessMemoryMetricsEmitter);
diff --git a/chrome/browser/metrics/process_memory_metrics_emitter_unittest.cc b/chrome/browser/metrics/process_memory_metrics_emitter_unittest.cc new file mode 100644 index 0000000..1b27d2c8 --- /dev/null +++ b/chrome/browser/metrics/process_memory_metrics_emitter_unittest.cc
@@ -0,0 +1,265 @@ +// Copyright 2017 The Chromium Authors. All rights reserved. +// Use of this source code is governed by a BSD-style license that can be +// found in the LICENSE file. + +#include "chrome/browser/metrics/process_memory_metrics_emitter.h" + +#include "base/containers/flat_map.h" +#include "base/memory/ref_counted.h" +#include "components/ukm/test_ukm_recorder.h" +#include "testing/gtest/include/gtest/gtest.h" + +using GlobalMemoryDumpPtr = memory_instrumentation::mojom::GlobalMemoryDumpPtr; +using ProcessMemoryDumpPtr = + memory_instrumentation::mojom::ProcessMemoryDumpPtr; +using OSMemDumpPtr = memory_instrumentation::mojom::OSMemDumpPtr; +using ProcessType = memory_instrumentation::mojom::ProcessType; + +namespace { + +// Provide fake to surface ReceivedMemoryDump to public visibility. +class ProcessMemoryMetricsEmitterFake : public ProcessMemoryMetricsEmitter { + public: + ProcessMemoryMetricsEmitterFake() {} + + void ReceivedMemoryDump( + bool success, + uint64_t dump_guid, + memory_instrumentation::mojom::GlobalMemoryDumpPtr ptr) override { + ProcessMemoryMetricsEmitter::ReceivedMemoryDump(success, dump_guid, + std::move(ptr)); + } + + private: + ~ProcessMemoryMetricsEmitterFake() override {} + + DISALLOW_COPY_AND_ASSIGN(ProcessMemoryMetricsEmitterFake); +}; + +void PopulateBrowserMetrics(GlobalMemoryDumpPtr& global_dump, + base::flat_map<const char*, int64_t>& metrics_mb) { + ProcessMemoryDumpPtr pmd( + memory_instrumentation::mojom::ProcessMemoryDump::New()); + pmd->process_type = ProcessType::BROWSER; + pmd->chrome_dump.malloc_total_kb = metrics_mb["Malloc"] * 1024; + OSMemDumpPtr os_dump(memory_instrumentation::mojom::OSMemDump::New( + metrics_mb["Resident"] * 1024, + metrics_mb["PrivateMemoryFootprint"] * 1024)); + pmd->os_dump = std::move(os_dump); + global_dump->process_dumps.push_back(std::move(pmd)); +} + +base::flat_map<const char*, int64_t> GetExpectedBrowserMetrics() { + return base::flat_map<const char*, int64_t>( + { + {"ProcessType", static_cast<int64_t>(ProcessType::BROWSER)}, + {"Resident", 10}, + {"Malloc", 20}, + {"PrivateMemoryFootprint", 30}, + }, + base::KEEP_FIRST_OF_DUPES); +} + +void PopulateRendererMetrics(GlobalMemoryDumpPtr& global_dump, + base::flat_map<const char*, int64_t>& metrics_mb) { + ProcessMemoryDumpPtr pmd( + memory_instrumentation::mojom::ProcessMemoryDump::New()); + pmd->process_type = ProcessType::RENDERER; + pmd->chrome_dump.malloc_total_kb = metrics_mb["Malloc"] * 1024; + pmd->chrome_dump.partition_alloc_total_kb = + metrics_mb["PartitionAlloc"] * 1024; + pmd->chrome_dump.blink_gc_total_kb = metrics_mb["BlinkGC"] * 1024; + pmd->chrome_dump.v8_total_kb = metrics_mb["V8"] * 1024; + OSMemDumpPtr os_dump(memory_instrumentation::mojom::OSMemDump::New( + metrics_mb["Resident"] * 1024, + metrics_mb["PrivateMemoryFootprint"] * 1024)); + pmd->os_dump = std::move(os_dump); + global_dump->process_dumps.push_back(std::move(pmd)); +} + +base::flat_map<const char*, int64_t> GetExpectedRendererMetrics() { + return base::flat_map<const char*, int64_t>( + { + {"ProcessType", static_cast<int64_t>(ProcessType::RENDERER)}, + {"Resident", 110}, + {"Malloc", 120}, + {"PrivateMemoryFootprint", 130}, + {"PartitionAlloc", 140}, + {"BlinkGC", 150}, + {"V8", 160}, + }, + base::KEEP_FIRST_OF_DUPES); +} + +void PopulateGpuMetrics(GlobalMemoryDumpPtr& global_dump, + base::flat_map<const char*, int64_t>& metrics_mb) { + ProcessMemoryDumpPtr pmd( + memory_instrumentation::mojom::ProcessMemoryDump::New()); + pmd->process_type = ProcessType::GPU; + pmd->chrome_dump.malloc_total_kb = metrics_mb["Malloc"] * 1024; + pmd->chrome_dump.command_buffer_total_kb = metrics_mb["CommandBuffer"] * 1024; + OSMemDumpPtr os_dump(memory_instrumentation::mojom::OSMemDump::New( + metrics_mb["Resident"] * 1024, + metrics_mb["PrivateMemoryFootprint"] * 1024)); + pmd->os_dump = std::move(os_dump); + global_dump->process_dumps.push_back(std::move(pmd)); +} + +base::flat_map<const char*, int64_t> GetExpectedGpuMetrics() { + return base::flat_map<const char*, int64_t>( + { + {"ProcessType", static_cast<int64_t>(ProcessType::GPU)}, + {"Resident", 210}, + {"Malloc", 220}, + {"PrivateMemoryFootprint", 230}, + {"CommandBuffer", 240}, + }, + base::KEEP_FIRST_OF_DUPES); +} + +void PopulateMetrics(GlobalMemoryDumpPtr& global_dump, + ProcessType ptype, + base::flat_map<const char*, int64_t>& metrics_mb) { + switch (ptype) { + case ProcessType::BROWSER: + PopulateBrowserMetrics(global_dump, metrics_mb); + return; + case ProcessType::RENDERER: + PopulateRendererMetrics(global_dump, metrics_mb); + return; + case ProcessType::GPU: + PopulateGpuMetrics(global_dump, metrics_mb); + return; + case ProcessType::UTILITY: + case ProcessType::PLUGIN: + case ProcessType::OTHER: + break; + } + + // We shouldn't reach here. + FAIL() << "Unknown process type case " << ptype << "."; +} + +base::flat_map<const char*, int64_t> GetExpectedProcessMetrics( + ProcessType ptype) { + switch (ptype) { + case ProcessType::BROWSER: + return GetExpectedBrowserMetrics(); + case ProcessType::RENDERER: + return GetExpectedRendererMetrics(); + case ProcessType::GPU: + return GetExpectedGpuMetrics(); + case ProcessType::UTILITY: + case ProcessType::PLUGIN: + case ProcessType::OTHER: + break; + } + + // We shouldn't reach here. + CHECK(false); + return base::flat_map<const char*, int64_t>(); +} + +} // namespace + +class ProcessMemoryMetricsEmitterTest + : public testing::TestWithParam<ProcessType> { + public: + ProcessMemoryMetricsEmitterTest() {} + ~ProcessMemoryMetricsEmitterTest() override {} + + protected: + void CheckMemoryUkmEntryMetrics( + size_t entry_num, + base::flat_map<const char*, int64_t> expected) { + const ukm::mojom::UkmEntry* entry = test_ukm_recorder_.GetEntry(entry_num); + CHECK(entry != nullptr); + EXPECT_EQ(expected.size(), entry->metrics.size()); + for (auto it = expected.begin(); it != expected.end(); ++it) { + const ukm::mojom::UkmMetric* actual = + test_ukm_recorder_.FindMetric(entry, it->first); + CHECK(actual != nullptr); + EXPECT_EQ(it->second, actual->value); + } + } + + ukm::TestUkmRecorder test_ukm_recorder_; + + private: + DISALLOW_COPY_AND_ASSIGN(ProcessMemoryMetricsEmitterTest); +}; + +TEST_P(ProcessMemoryMetricsEmitterTest, CollectsSingleProcessUKMs) { + base::flat_map<const char*, int64_t> expected_metrics = + GetExpectedProcessMetrics(GetParam()); + uint64_t dump_guid = 333; + + GlobalMemoryDumpPtr global_dump( + memory_instrumentation::mojom::GlobalMemoryDump::New()); + PopulateMetrics(global_dump, GetParam(), expected_metrics); + + scoped_refptr<ProcessMemoryMetricsEmitterFake> emitter( + new ProcessMemoryMetricsEmitterFake()); + emitter->ReceivedMemoryDump(true, dump_guid, std::move(global_dump)); + + EXPECT_EQ(2u, test_ukm_recorder_.entries_count()); + CheckMemoryUkmEntryMetrics(0, expected_metrics); +} + +INSTANTIATE_TEST_CASE_P(SinglePtype, + ProcessMemoryMetricsEmitterTest, + testing::Values(ProcessType::BROWSER, + ProcessType::RENDERER, + ProcessType::GPU)); + +TEST_F(ProcessMemoryMetricsEmitterTest, CollectsManyProcessUKMsSingleDump) { + std::vector<ProcessType> entries_ptypes = { + ProcessType::BROWSER, ProcessType::RENDERER, ProcessType::GPU, + ProcessType::GPU, ProcessType::RENDERER, ProcessType::BROWSER, + }; + uint64_t dump_guid = 333; + + GlobalMemoryDumpPtr global_dump( + memory_instrumentation::mojom::GlobalMemoryDump::New()); + std::vector<base::flat_map<const char*, int64_t>> entries_metrics; + for (const auto& ptype : entries_ptypes) { + auto expected_metrics = GetExpectedProcessMetrics(ptype); + PopulateMetrics(global_dump, ptype, expected_metrics); + entries_metrics.push_back(expected_metrics); + } + + scoped_refptr<ProcessMemoryMetricsEmitterFake> emitter( + new ProcessMemoryMetricsEmitterFake()); + emitter->ReceivedMemoryDump(true, dump_guid, std::move(global_dump)); + + EXPECT_EQ(7u, test_ukm_recorder_.entries_count()); + for (size_t i = 0; i < entries_ptypes.size(); ++i) { + CheckMemoryUkmEntryMetrics(i, entries_metrics[i]); + } +} + +TEST_F(ProcessMemoryMetricsEmitterTest, CollectsManyProcessUKMsManyDumps) { + std::vector<std::vector<ProcessType>> entries_ptypes = { + {ProcessType::BROWSER, ProcessType::RENDERER, ProcessType::GPU}, + {ProcessType::GPU, ProcessType::RENDERER, ProcessType::BROWSER}, + }; + + std::vector<base::flat_map<const char*, int64_t>> entries_metrics; + scoped_refptr<ProcessMemoryMetricsEmitterFake> emitter( + new ProcessMemoryMetricsEmitterFake()); + for (int i = 0; i < 2; ++i) { + GlobalMemoryDumpPtr global_dump( + memory_instrumentation::mojom::GlobalMemoryDump::New()); + for (const auto& ptype : entries_ptypes[i]) { + auto expected_metrics = GetExpectedProcessMetrics(ptype); + PopulateMetrics(global_dump, ptype, expected_metrics); + entries_metrics.push_back(expected_metrics); + } + emitter->ReceivedMemoryDump(true, i, std::move(global_dump)); + } + + EXPECT_EQ(8u, test_ukm_recorder_.entries_count()); + for (size_t i = 0; i < entries_ptypes.size(); ++i) { + CheckMemoryUkmEntryMetrics(i, entries_metrics[i]); + } +}
diff --git a/chrome/browser/net/predictor.cc b/chrome/browser/net/predictor.cc index c1dc2d12..f99580da 100644 --- a/chrome/browser/net/predictor.cc +++ b/chrome/browser/net/predictor.cc
@@ -33,6 +33,7 @@ #include "chrome/browser/io_thread.h" #include "chrome/browser/prefs/session_startup_pref.h" #include "chrome/browser/profiles/profile_io_data.h" +#include "chrome/common/chrome_features.h" #include "chrome/common/chrome_switches.h" #include "chrome/common/pref_names.h" #include "components/pref_registry/pref_registry_syncable.h" @@ -59,9 +60,6 @@ namespace { -const base::Feature kNetworkPrediction{"NetworkPrediction", - base::FEATURE_ENABLED_BY_DEFAULT}; - #if defined(OS_ANDROID) // Disabled on Android, as there are no "pinned tabs", meaning that a startup // is unlikely to request the same URL, and hence to resolve the same domains @@ -171,7 +169,8 @@ // static Predictor* Predictor::CreatePredictor(bool simple_shutdown) { - bool predictor_enabled = base::FeatureList::IsEnabled(kNetworkPrediction); + bool predictor_enabled = + base::FeatureList::IsEnabled(features::kNetworkPrediction); if (simple_shutdown) return new SimplePredictor(predictor_enabled); return new Predictor(predictor_enabled);
diff --git a/chrome/browser/permissions/permission_request_manager.cc b/chrome/browser/permissions/permission_request_manager.cc index 494b880..b5e45fb 100644 --- a/chrome/browser/permissions/permission_request_manager.cc +++ b/chrome/browser/permissions/permission_request_manager.cc
@@ -121,15 +121,9 @@ } PermissionRequestManager::~PermissionRequestManager() { - if (view_ != NULL) - view_->SetDelegate(NULL); - - for (PermissionRequest* request : requests_) - request->RequestFinished(); - for (PermissionRequest* request : queued_requests_) - request->RequestFinished(); - for (const auto& entry : duplicate_requests_) - entry.second->RequestFinished(); + DCHECK(requests_.empty()); + DCHECK(duplicate_requests_.empty()); + DCHECK(queued_requests_.empty()); } void PermissionRequestManager::AddRequest(PermissionRequest* request) {
diff --git a/chrome/browser/permissions/permission_request_manager_unittest.cc b/chrome/browser/permissions/permission_request_manager_unittest.cc index 559ea5e..0a3ba3f 100644 --- a/chrome/browser/permissions/permission_request_manager_unittest.cc +++ b/chrome/browser/permissions/permission_request_manager_unittest.cc
@@ -51,13 +51,13 @@ SetContents(CreateTestWebContents()); NavigateAndCommit(GURL("http://www.google.com")); - manager_.reset(new PermissionRequestManager(web_contents())); - prompt_factory_.reset(new MockPermissionPromptFactory(manager_.get())); + PermissionRequestManager::CreateForWebContents(web_contents()); + manager_ = PermissionRequestManager::FromWebContents(web_contents()); + prompt_factory_.reset(new MockPermissionPromptFactory(manager_)); } void TearDown() override { prompt_factory_.reset(); - manager_.reset(); ChromeRenderViewHostTestHarness::TearDown(); } @@ -101,7 +101,7 @@ MockPermissionRequest iframe_request_same_domain_; MockPermissionRequest iframe_request_other_domain_; MockPermissionRequest iframe_request_mic_other_domain_; - std::unique_ptr<PermissionRequestManager> manager_; + PermissionRequestManager* manager_; std::unique_ptr<MockPermissionPromptFactory> prompt_factory_; };
diff --git a/chrome/browser/resources/extensions/extensions.css b/chrome/browser/resources/extensions/extensions.css index 57468d4..a18931e 100644 --- a/chrome/browser/resources/extensions/extensions.css +++ b/chrome/browser/resources/extensions/extensions.css
@@ -104,7 +104,6 @@ } [dir='rtl'] #page-header { - left: auto; right: 0; }
diff --git a/chrome/browser/resources/options/autofill_edit_address_overlay.html b/chrome/browser/resources/options/autofill_edit_address_overlay.html index 0deecad..980d9ba 100644 --- a/chrome/browser/resources/options/autofill_edit_address_overlay.html +++ b/chrome/browser/resources/options/autofill_edit_address_overlay.html
@@ -7,7 +7,7 @@ <div class="settings-row"> <label> - <div i18n-content="autofillCountryLabel"></div> + <div>$i18n{autofillCountryLabel}</div> <select class="country" field="country"></select> </label> </div> @@ -15,14 +15,14 @@ <div class="input-group settings-row"> <div> <label> - <div i18n-content="autofillPhoneLabel"></div> + <div>$i18n{autofillPhoneLabel}</div> <input class="short" field="phone"></input> </label> </div> <div> <label> - <div i18n-content="autofillEmailLabel"></div> + <div>$i18n{autofillEmailLabel}</div> <input class="short" field="email"></input> </label> </div> @@ -31,9 +31,12 @@ </div> <div class="action-area button-strip"> - <button id="autofill-edit-address-cancel-button" type="reset" - i18n-content="cancel"></button> + <button id="autofill-edit-address-cancel-button" type="reset"> + $i18n{cancel} + </button> <button id="autofill-edit-address-apply-button" type="submit" - class="default-button" i18n-content="ok" disabled></button> + class="default-button" disabled> + $i18n{ok} + </button> </div> </div>
diff --git a/chrome/browser/resources/options/autofill_edit_creditcard_overlay.html b/chrome/browser/resources/options/autofill_edit_creditcard_overlay.html index 3c5b07f..9b2c5f8 100644 --- a/chrome/browser/resources/options/autofill_edit_creditcard_overlay.html +++ b/chrome/browser/resources/options/autofill_edit_creditcard_overlay.html
@@ -3,18 +3,19 @@ <h1 id="autofill-credit-card-title"></h1> <div class="content-area"> <label class="settings-row"> - <div i18n-content="nameOnCardLabel"></div> + <div>$i18n{nameOnCardLabel}</div> <input id="name-on-card" type="text"> </label> <label class="settings-row"> - <div i18n-content="creditCardNumberLabel"></div> + <div>$i18n{creditCardNumberLabel}</div> <input id="credit-card-number" type="text"> </label> <div class="settings-row"> - <div id="creditCardExpirationLabel" - i18n-content="creditCardExpirationDateLabel"></div> + <div id="creditCardExpirationLabel"> + $i18n{creditCardExpirationDateLabel} + </div> <select id="expiration-month" aria-labelledby="creditCardExpirationLabel"> </select> <select id="expiration-year" aria-labelledby="creditCardExpirationLabel"> @@ -23,9 +24,12 @@ </div> <div class="action-area button-strip"> - <button id="autofill-edit-credit-card-cancel-button" type="reset" - i18n-content="cancel"></button> + <button id="autofill-edit-credit-card-cancel-button" type="reset"> + $i18n{cancel} + </button> <button id="autofill-edit-credit-card-apply-button" type="submit" - class="default-button" i18n-content="ok" disabled></button> + class="default-button" disabled> + $i18n{ok} + </button> </div> </div>
diff --git a/chrome/browser/resources/options/autofill_options.html b/chrome/browser/resources/options/autofill_options.html index ab3931b..d820ebee 100644 --- a/chrome/browser/resources/options/autofill_options.html +++ b/chrome/browser/resources/options/autofill_options.html
@@ -1,18 +1,18 @@ <div id="autofill-options" class="page" hidden> <div class="close-button"></div> - <h1 i18n-content="autofillOptionsPage"></h1> + <h1>$i18n{autofillOptionsPage}</h1> <div class="content-area"> <div class="autofill-section-header"> - <h3 i18n-content="autofillAddresses"></h3> - <button id="autofill-add-address" i18n-content="autofillAddAddress"> - </button> + <h3>$i18n{autofillAddresses}</h3> + <button id="autofill-add-address">$i18n{autofillAddAddress}</button> </div> <div class="settings-list"> <list id="address-list"></list> </div> <div class="autofill-section-header"> - <h3 i18n-content="autofillCreditCards"></h3> - <button id="autofill-add-creditcard" i18n-content="autofillAddCreditCard"> + <h3>$i18n{autofillCreditCards}</h3> + <button id="autofill-add-creditcard"> + $i18n{autofillAddCreditCard} </button> </div> <div class="settings-list"> @@ -21,13 +21,13 @@ </div> <div class="action-area"> - <a id="autofill-help" target="_blank" i18n-values="href:helpUrl" - i18n-content="helpButton"> - </a> + <a id="autofill-help" target="_blank" + href="$i18nRaw{helpUrl}">$i18n{helpButton}</a> <div class="spacer-div"></div> <div class="button-strip"> - <button id="autofill-options-confirm" class="default-button" - i18n-content="done"></button> + <button id="autofill-options-confirm" class="default-button"> + $i18n{done} + </button> </div> </div> </div>
diff --git a/chrome/browser/resources/options/automatic_settings_reset_banner.html b/chrome/browser/resources/options/automatic_settings_reset_banner.html index 4af723b..fcb16c40 100644 --- a/chrome/browser/resources/options/automatic_settings_reset_banner.html +++ b/chrome/browser/resources/options/automatic_settings_reset_banner.html
@@ -4,16 +4,16 @@ <div class="badge"></div> <div class="text"> <p> - <span i18n-values=".innerHTML:automaticSettingsResetBannerText"> - </span> + <span>$i18nRaw{automaticSettingsResetBannerText}</span> <a id="automatic-settings-reset-learn-more" class="nowrap" - i18n-values="href:automaticSettingsResetLearnMoreUrl" - i18n-content="learnMore" target="_blank"></a> + href="$i18nRaw{automaticSettingsResetLearnMoreUrl}" + target="_blank">$i18n{learnMore}</a> </p> </div> <div class="button-area"> - <button id="automatic-settings-reset-banner-activate-reset" - i18n-content="automaticSettingsResetBannerResetButtonText"></button> + <button id="automatic-settings-reset-banner-activate-reset"> + $i18n{automaticSettingsResetBannerResetButtonText} + </button> </div> </div> </div>
diff --git a/chrome/browser/resources/options/browser_options.html b/chrome/browser/resources/options/browser_options.html index 3c1661d..94147eac 100644 --- a/chrome/browser/resources/options/browser_options.html +++ b/chrome/browser/resources/options/browser_options.html
@@ -3,7 +3,7 @@ </if> <div id="settings" class="page" hidden> <header> - <h1 i18n-content="settingsTitle"></h1> + <h1>$i18n{settingsTitle}</h1> </header> <include src="automatic_settings_reset_banner.html"> <if expr="chromeos"> @@ -12,7 +12,7 @@ <include src="secondary_user_banner.html"> <section id="network-section-cros"> <div id="network-section-header" class="section-header"> - <h3 i18n-content="sectionTitleInternet"></h3> + <h3>$i18n{sectionTitleInternet}</h3> <span class="controlled-setting-indicator" plural></span> </div> <div id="network-settings"> @@ -22,7 +22,7 @@ <input id="use-shared-proxies" type="checkbox" metric="Options_NetworkUseSharedProxies" pref="settings.use_shared_proxies"> - <span i18n-content="useSharedProxies"></span> + <span>$i18n{useSharedProxies}</span> </label> </div> <div id="network-menus"></div> @@ -34,29 +34,28 @@ <include src="startup_section.html"> </if> <section id="proxy-section" hidden> - <h3 i18n-content="sectionTitleProxy"></h3> + <h3>$i18n{sectionTitleProxy}</h3> <div id="proxy-section-content"></div> </section> <section id="appearance-section"> - <h3 i18n-content="sectionTitleAppearance"></h3> + <h3>$i18n{sectionTitleAppearance}</h3> <div class="settings-row"> <if expr="chromeos"> - <button id="set-wallpaper" i18n-content="setWallpaper" - guest-visibility="disabled"></button> + <button id="set-wallpaper" guest-visibility="disabled"> + $i18n{setWallpaper} + </button> <span id="wallpaper-indicator" class="controlled-setting-indicator"> </span> </if> <if expr="not chromeos and is_posix and not is_macosx"> - <button id="themes-gallery" i18n-content="themesGallery"></button> - <button id="themes-native-button" - i18n-content="themesNativeButton"></button> - <button id="themes-reset" - i18n-content="themesSetClassic"></button> + <button id="themes-gallery">$i18n{themesGallery}</button> + <button id="themes-native-button">$i18n{themesNativeButton}</button> + <button id="themes-reset">$i18n{themesSetClassic}</button> </if> <if expr="chromeos or is_win or is_macosx"> - <button id="themes-gallery" i18n-content="themesGallery"></button> - <button id="themes-reset" i18n-content="themesReset"></button> + <button id="themes-gallery">$i18n{themesGallery}</button> + <button id="themes-reset">$i18n{themesReset}</button> </if> </div> <div class="checkbox controlled-setting-with-label" @@ -66,7 +65,7 @@ pref="browser.show_home_button" metric="Options_Homepage_HomeButton"> <span> - <span i18n-content="homePageShowHomeButton"></span> + <span>$i18n{homePageShowHomeButton}</span> <span class="controlled-setting-indicator" pref="browser.show_home_button"></span> </span> @@ -74,11 +73,11 @@ </div> <div id="change-home-page-section" hidden> <div id="change-home-page-section-container" guest-visibility="disabled"> - <span id="home-page-ntp" class="home-page-label" - i18n-content="homePageNtp"></span> + <span id="home-page-ntp" class="home-page-label"> + $i18n{homePageNtp} + </span> <span id="home-page-url" class="home-page-label"></span> - <a is="action-link" id="change-home-page" i18n-content="changeHomePage"> - </a> + <a is="action-link" id="change-home-page">$i18n{changeHomePage}</a> <div id="extension-controlled-container"></div> </div> </div> @@ -89,7 +88,7 @@ pref="bookmark_bar.show_on_all_tabs" metric="Options_ShowBookmarksBar"> <span> - <span i18n-content="toolbarShowBookmarksBar"></span> + <span>$i18n{toolbarShowBookmarksBar}</span> <span class="controlled-setting-indicator" pref="bookmark_bar.show_on_all_tabs"></span> </span> @@ -100,77 +99,81 @@ <input id="show-window-decorations" type="checkbox" pref="browser.custom_chrome_frame" metric="Options_CustomFrame" inverted_pref> - <span i18n-content="showWindowDecorations"></span> + <span>$i18n{showWindowDecorations}</span> </label></div> </if> </section> <if expr="chromeos"> <section id="device-section"> - <h3 i18n-content="sectionTitleDevice"></h3> + <h3>$i18n{sectionTitleDevice}</h3> <div> - <span i18n-content="deviceGroupDescription"></span> + <span>$i18n{deviceGroupDescription}</span> <div id="touchpad-settings" class="settings-row" hidden> - <span id="touchpad-speed-label" class="option-name" - i18n-content="touchpadSpeed"></span> + <span id="touchpad-speed-label" class="option-name"> + $i18n{touchpadSpeed} + </span> <input id="touchpad-sensitivity-range" type="range" min="1" max="5" pref="settings.touchpad.sensitivity2" class="touch-slider" aria-labelledby="touchpad-speed-label"> </div> <div id="mouse-settings" class="settings-row" hidden> - <span id="mouse-speed-label" class="option-name" - i18n-content="mouseSpeed"></span> + <span id="mouse-speed-label" class="option-name"> + $i18n{mouseSpeed} + </span> <input id="mouse-sensitivity-range" type="range" min="1" max="5" pref="settings.mouse.sensitivity2" class="touch-slider" aria-labelledby="mouse-speed-label"> </div> - <div id="no-pointing-devices" i18n-content="noPointingDevices" - class="settings-row" hidden> + <div id="no-pointing-devices" class="settings-row" hidden> + $i18n{noPointingDevices} </div> <div class="settings-row"> <button id="pointer-settings-button" hidden> </button> - <button id="keyboard-settings-button" - i18n-content="keyboardSettingsButtonTitle"> + <button id="keyboard-settings-button"> + $i18n{keyboardSettingsButtonTitle} </button> <span id="display-options-section"> - <button id="display-options" i18n-content="displayOptions" disabled> - </button> + <button id="display-options" disabled>$i18n{displayOptions}</button> </span> - <button id="storage-manager-button" - i18n-content="storageManagerButtonTitle"> + <button id="storage-manager-button"> + $i18n{storageManagerButtonTitle} </button> </div> <div id="stylus-row" hidden> - <a is="action-link" id="stylus-settings-link" - i18n-content="stylusSettingsButtonTitle"></a> + <a is="action-link" id="stylus-settings-link"> + $i18n{stylusSettingsButtonTitle} + </a> </div> <div id="power-row" hidden> - <a is="action-link" id="power-settings-link" - i18n-content="powerSettingsButton"></a> + <a is="action-link" id="power-settings-link"> + $i18n{powerSettingsButton} + </a> </div> </div> </section> </if> <section id="search-section"> - <h3 i18n-content="sectionTitleSearch"></h3> + <h3>$i18n{sectionTitleSearch}</h3> <div id="search-section-content"> - <span id="default-search-engine-label" - i18n-values=".innerHTML:defaultSearchGroupLabel"></span> + <span id="default-search-engine-label"> + $i18nRaw{defaultSearchGroupLabel} + </span> <div class="settings-row"> <select id="default-search-engine" class="weakrtl" aria-labelledby="default-search-engine-label"></select> <span class="controlled-setting-indicator" pref="default_search_provider_data.template_url_data"> </span> - <button id="manage-default-search-engines" - i18n-content="defaultSearchManageEngines"> + <button id="manage-default-search-engines"> + $i18n{defaultSearchManageEngines} </button> </div> <div id="google-now-launcher" hidden> <div class="checkbox"> <label> <input pref="google_now_launcher.enabled" type="checkbox"> - <span i18n-content="googleNowLauncherEnable"></span> + <span>$i18n{googleNowLauncherEnable}</span> </label> </div> </div> @@ -179,20 +182,20 @@ <label> <input id="hotword-always-on-search-checkbox" pref="hotword.always_on_search_enabled" type="checkbox"> - <span i18n-content="hotwordSearchEnable"></span> + <span>$i18n{hotwordSearchEnable}</span> </label> <a target="_blank" class="hotword-link" - i18n-content="learnMore" - i18n-values="href:hotwordLearnMoreURL"> + href="$i18nRaw{hotwordLearnMoreURL}"> + $i18n{learnMore} </a> <span id="hotword-always-on-search-setting-indicator" pref="hotword.always_on_search_enabled" dialog-pref></span> <div> - <span class="setting-extra-description" - i18n-content="hotwordAlwaysOnDesc"> + <span class="setting-extra-description"> + $i18n{hotwordAlwaysOnDesc} </span> - <a id="hotword-retrain-link" is="action-link" - i18n-content="hotwordRetrainLink" hidden> + <a id="hotword-retrain-link" is="action-link" hidden> + $i18n{hotwordRetrainLink} </a> </div> </div> @@ -202,17 +205,17 @@ <label> <input id="hotword-no-dsp-search-checkbox" pref="hotword.search_enabled_2" type="checkbox"> - <span i18n-content="hotwordSearchEnable"></span> + <span>$i18n{hotwordSearchEnable}</span> </label> <a target="_blank" class="hotword-link" - i18n-content="learnMore" - i18n-values="href:hotwordLearnMoreURL"> + href="$i18nRaw{hotwordLearnMoreURL}"> + $i18n{learnMore} </a> <span id="hotword-no-dsp-search-setting-indicator" pref="hotword.search_enabled_2" dialog-pref></span> <div> - <span class="setting-extra-description" - i18n-content="hotwordNoDSPDesc"> + <span class="setting-extra-description"> + $i18n{hotwordNoDSPDesc} </span> </div> </div> @@ -223,13 +226,13 @@ <span id="audio-history-label"></span> </label> <a target="_blank" class="hotword-link" - i18n-content="hotwordAudioHistoryManage" - i18n-values="href:hotwordManageAudioHistoryURL"> + href="$i18nRaw{hotwordManageAudioHistoryURL}"> + $i18n{hotwordAudioHistoryManage} </a> </div> <div class="settings-row" id="audio-history-always-on-description"> - <span class="setting-extra-description" - i18n-content="hotwordAlwaysOnAudioHistoryDescription"> + <span class="setting-extra-description"> + $i18n{hotwordAlwaysOnAudioHistoryDescription} </span> </div> </div> @@ -237,21 +240,23 @@ </section> <if expr="chromeos"> <section id="android-apps-section" hidden> - <h3 i18n-content="androidAppsTitle"></h3> + <h3>$i18n{androidAppsTitle}</h3> <div class="checkbox controlled-setting-with-label"> <label> <input id="android-apps-enabled" pref="arc.enabled" metric="Options_AndroidApps" type="checkbox" dialog-pref> <span> - <span i18n-content="androidAppsEnabled"></span> + <span>$i18n{androidAppsEnabled}</span> <span class="controlled-setting-indicator" pref="arc.enabled"></span> </span> </label> - <a target="_blank" i18n-content="learnMore" - href="http://support.google.com/chromebook?p=playapps"></a> + <a target="_blank" href="http://support.google.com/chromebook?p=playapps"> + $i18n{learnMore} + </a> </div> - <div id="android-apps-settings" class="controlled-setting-with-label" hidden> + <div id="android-apps-settings" class="controlled-setting-with-label" + hidden> <label> <span id="android-apps-settings-label"></span> </label> @@ -259,14 +264,14 @@ </section> </if> <section id="sync-users-section" guest-visibility="hidden"> - <h3 i18n-content="sectionTitleUsers"></h3> + <h3>$i18n{sectionTitleUsers}</h3> <if expr="chromeos"> <include src="sync_section.html"> </if> <div id="profiles-section" hidden> <list id="profiles-list" class="settings-list" hidden></list> - <div id="profiles-single-message" class="settings-row" - i18n-content="profilesSingleUser"> + <div id="profiles-single-message" class="settings-row"> + $i18n{profilesSingleUser} </div> <if expr="not chromeos"> <div id="profiles-enable-guest" class="checkbox"> @@ -274,7 +279,7 @@ <input pref="profile.browser_guest_enabled" type="checkbox" metric="Options_BrowserGuestEnabled"> - <span i18n-content="profileBrowserGuestEnable"></span> + <span>$i18n{profileBrowserGuestEnable}</span> </label> </div> <div id="profiles-enable-add-person" class="checkbox"> @@ -282,33 +287,31 @@ <input pref="profile.add_person_enabled" type="checkbox" metric="Options_AddPersonEnabled"> - <span i18n-content="profileAddPersonEnable"></span> + <span>$i18n{profileAddPersonEnable}</span> </label> </div> </if> <div id="profiles-buttons"> - <button id="profiles-create" i18n-content="profilesCreate"></button> - <button id="profiles-manage" i18n-content="profilesManage" disabled> - </button> - <button id="profiles-delete" i18n-content="profilesDelete"></button> + <button id="profiles-create">$i18n{profilesCreate}</button> + <button id="profiles-manage" disabled>$i18n{profilesManage}</button> + <button id="profiles-delete">$i18n{profilesDelete}</button> <if expr="not chromeos"> - <button id="import-data" i18n-content="importData"></button> + <button id="import-data">$i18n{importData}</button> </if> </div> </div> - <div id="profiles-supervised-dashboard-tip" - i18n-values=".innerHTML:profilesSupervisedDashboardTip" hidden> + <div id="profiles-supervised-dashboard-tip" hidden> + $i18nRaw{profilesSupervisedDashboardTip} </div> </section> <if expr="not chromeos"> <section id="set-default-browser-section"> - <h3 i18n-content="sectionTitleDefaultBrowser"></h3> + <h3>$i18n{sectionTitleDefaultBrowser}</h3> <div> - <button id="set-as-default-browser" - i18n-content="defaultBrowserUseAsDefault" hidden> + <button id="set-as-default-browser" hidden> + $i18n{defaultBrowserUseAsDefault} </button> - <div id="default-browser-state" i18n-content="defaultBrowserUnknown"> - </div> + <div id="default-browser-state">$i18n{defaultBrowserUnknown}</div> </div> </section> </if> <!-- not chromeos --> @@ -316,11 +319,12 @@ <div id="advanced-settings-container"> <if expr="chromeos"> <section id="date-time-section"> - <h3 i18n-content="datetimeTitle"></h3> + <h3>$i18n{datetimeTitle}</h3> <div class="option-control-table"> <div guest-visibility="disabled"> - <span id="timezone-value-label" class="option-name" - i18n-content="timezone"></span> + <span id="timezone-value-label" class="option-name"> + $i18n{timezone} + </span> <div id="timezone-value"> <select class="control" id="timezone-value-select" @@ -336,36 +340,38 @@ <input id="resolve-timezone-by-geolocation" pref="settings.resolve_timezone_by_geolocation" metric="Options_ResolveTimezoneByGeoLocation" type="checkbox"> - <span i18n-content="resolveTimezoneByGeoLocation"></span> + <span>$i18n{resolveTimezoneByGeoLocation}</span> </label> </div> <label> <input id="use-24hour-clock" pref="settings.clock.use_24hour_clock" metric="Options_Use24HourClockCheckbox" type="checkbox"> - <span i18n-content="use24HourClock"></span> + <span>$i18n{use24HourClock}</span> </label> </div> <div id="set-time" class="settings-row" hidden> - <button id="set-time-button" - i18n-content="setTimeButton"></button> + <button id="set-time-button">$i18n{setTimeButton}</button> </div> </div> </section> </if> <section id="privacy-section"> - <h3 i18n-content="advancedSectionTitlePrivacy"></h3> + <h3>$i18n{advancedSectionTitlePrivacy}</h3> <div> <div class="settings-row"> - <button id="privacyContentSettingsButton" - i18n-content="privacyContentSettingsButton"></button> - <button id="privacyClearDataButton" - i18n-content="privacyClearDataButton"></button> + <button id="privacyContentSettingsButton"> + $i18n{privacyContentSettingsButton} + </button> + <button id="privacyClearDataButton"> + $i18n{privacyClearDataButton} + </button> </div> <p id="privacy-explanation" class="settings-row"> - <span i18n-content="improveBrowsingExperience"></span> - <span i18n-content="disableWebServices"></span> - <a target="_blank" i18n-content="learnMore" - i18n-values="href:privacyLearnMoreURL"></a> + <span>$i18n{improveBrowsingExperience}</span> + <span>$i18n{disableWebServices}</span> + <a target="_blank" href="$i18nRaw{privacyLearnMoreURL}"> + $i18n{learnMore} + </a> </p> <div class="checkbox controlled-setting-with-label"> <label> @@ -373,7 +379,7 @@ pref="alternate_error_pages.enabled" metric="Options_LinkDoctorCheckbox" type="checkbox"> <span> - <span i18n-content="linkDoctorPref"></span> + <span>$i18n{linkDoctorPref}</span> <span class="controlled-setting-indicator" pref="alternate_error_pages.enabled"></span> </span> @@ -385,7 +391,7 @@ <input pref="search.suggest_enabled" metric="Options_UseSuggestCheckbox" type="checkbox"> <span> - <span i18n-content="suggestPref"></span> + <span>$i18n{suggestPref}</span> <span class="controlled-setting-indicator" pref="search.suggest_enabled"></span> </span> @@ -397,7 +403,7 @@ <input id="networkPredictionOptions" metric="Options_DnsPrefetchCheckbox" type="checkbox"> <span> - <span i18n-content="networkPredictionEnabledDescription"></span> + <span>$i18n{networkPredictionEnabledDescription}</span> <span class="controlled-setting-indicator" pref="net.network_prediction_options"></span> </span> @@ -411,7 +417,7 @@ metric="Options_SafeBrowsingExtendedReportingCheckbox" type="checkbox"> <span> - <span i18n-content="safeBrowsingEnableExtendedReporting"></span> + <span>$i18n{safeBrowsingEnableExtendedReporting}</span> <span class="controlled-setting-indicator"></span> </span> </label> @@ -421,7 +427,7 @@ <input pref="safebrowsing.enabled" metric="Options_SafeBrowsingCheckbox" type="checkbox"> <span> - <span i18n-content="safeBrowsingEnableProtection"></span> + <span>$i18n{safeBrowsingEnableProtection}</span> <span class="controlled-setting-indicator" pref="safebrowsing.enabled"></span> </span> @@ -434,7 +440,7 @@ metric="Options_SpellingServiceCheckbox" pref="spellcheck.use_spelling_service" dialog-pref> <span> - <span i18n-content="spellingPref"></span> + <span>$i18n{spellingPref}</span> <span id="spelling-enabled-indicator" class="controlled-setting-indicator" pref="spellcheck.use_spelling_service" dialog-pref> @@ -447,7 +453,7 @@ <label> <input id="metrics-reporting-enabled" type="checkbox"> <span> - <span i18n-content="enableLogging"></span> + <span>$i18n{enableLogging}</span> <span id="metrics-reporting-disabled-icon" class="controlled-setting-indicator"></span> </span> @@ -465,7 +471,7 @@ <label> <input id="do-not-track-enabled" pref="enable_do_not_track" metric="Options_DoNotTrackCheckbox" type="checkbox" dialog-pref> - <span i18n-content="doNotTrack"></span> + <span>$i18n{doNotTrack}</span> </label> </div> <if expr="chromeos"> @@ -474,14 +480,15 @@ <input id="content-protection-attestation-enabled" type="checkbox" pref="cros.device.attestation_for_content_protection_enabled"> <span> - <span i18n-content="enableContentProtectionAttestation"></span> + <span>$i18n{enableContentProtectionAttestation}</span> <span class="controlled-setting-indicator" pref="cros.device.attestation_for_content_protection_enabled"> </span> </span> </label> - <a target="_blank" i18n-content="learnMore" - i18n-values="href:contentProtectionAttestationLearnMoreURL"> + <a target="_blank" + href="$i18nRaw{contentProtectionAttestationLearnMoreURL}"> + $i18n{learnMore} </a> </div> </if> @@ -491,7 +498,7 @@ <input id="hotword-search-enable" pref="hotword.search_enabled_2" metric="Options_HotwordCheckbox" type="checkbox" dialog-pref> <span> - <span i18n-values=".innerHTML:hotwordSearchEnable"></span> + <span>$i18nRaw{hotwordSearchEnable}</span> <span id="hotword-search-setting-indicator" pref="hotword.search_enabled_2" dialog-pref></span> </span> @@ -506,7 +513,7 @@ metric="Options_WakeOnWifiSsid" pref="settings.internet.wake_on_wifi_darkconnect"> <span> - <span i18n-content="wakeOnWifiLabel"></span> + <span>$i18n{wakeOnWifiLabel}</span> <span id="wake-on-wifi-indicator" class="controlled-setting-indicator" pref="settings.internet.wake_on_wifi_darkconnect"></span> @@ -520,14 +527,14 @@ <!-- By default, the bluetooth section is hidden. It is only visible if a bluetooth adapter is discovered --> <section id="bluetooth-devices" hidden> - <h3 i18n-content="bluetooth"></h3> + <h3>$i18n{bluetooth}</h3> <div id="bluetooth-options-div"> <div class="checkbox controlled-setting-with-label"> <label> <input type="checkbox" id="enable-bluetooth" metric="Options_BluetoothEnabled"> <span> - <span i18n-content="enableBluetooth"></span> + <span>$i18n{enableBluetooth}</span> <span id="bluetooth-controlled-setting-indicator" class="controlled-setting-indicator" pref="cros.device.allow_bluetooth" @@ -540,32 +547,35 @@ <list id="bluetooth-paired-devices-list"></list> <div id="bluetooth-paired-devices-list-empty-placeholder" class="bluetooth-empty-list-label" hidden> - <span i18n-content="bluetoothNoDevices"></span> + <span>$i18n{bluetoothNoDevices}</span> </div> </div> <div id="bluetooth-button-group"> - <button id="bluetooth-add-device" - i18n-content="addBluetoothDevice" hidden></button> - <button id="bluetooth-reconnect-device" - i18n-content="bluetoothConnectDevice" disabled hidden></button> + <button id="bluetooth-add-device" hidden> + $i18n{addBluetoothDevice} + </button> + <button id="bluetooth-reconnect-device" disabled hidden> + $i18n{bluetoothConnectDevice} + </button> </div> </div> </section> </if> <section id="passwords-and-autofill-section"> - <h3 i18n-content="passwordsAndAutofillGroupName"></h3> + <h3>$i18n{passwordsAndAutofillGroupName}</h3> <div class="checkbox controlled-setting-with-label"> <label> <input id="autofill-enabled" pref="autofill.enabled" metric="Options_FormAutofill" type="checkbox"> <span> - <span i18n-content="autofillEnabled"></span> + <span>$i18n{autofillEnabled}</span> <span class="controlled-setting-indicator" pref="autofill.enabled"> </span> </span> </label> - <a is="action-link" id="autofill-settings" - i18n-content="manageAutofillSettings"></a> + <a is="action-link" id="autofill-settings"> + $i18n{manageAutofillSettings} + </a> </div> <div class="checkbox controlled-setting-with-label"> <label> @@ -573,75 +583,76 @@ pref="credentials_enable_service" metric="Options_PasswordManager" type="checkbox"> <span> - <span i18n-content="passwordManagerEnabled"></span> + <span>$i18n{passwordManagerEnabled}</span> <span class="controlled-setting-indicator" pref="credentials_enable_service"></span> </span> </label> - <a is="action-link" id="manage-passwords" i18n-content="managePasswords"> - </a> + <a is="action-link" id="manage-passwords">$i18n{managePasswords}</a> </div> <if expr="is_macosx"> - <div id="mac-passwords-warning" i18n-content="macPasswordsWarning" hidden> - </div> + <div id="mac-passwords-warning" hidden>$i18n{macPasswordsWarning}</div> </if> </section> <section id="easy-unlock-section" guest-visibility="hidden" hidden> - <h3 i18n-content="easyUnlockSectionTitle"></h3> + <h3>$i18n{easyUnlockSectionTitle}</h3> <!-- Options shown when the user has not set up Easy Unlock --> <div id="easy-unlock-disabled" hidden> <div class="settings-row"> - <span i18n-content="easyUnlockSetupIntro"></span> - <a target="_blank" i18n-content="learnMore" - i18n-values="href:easyUnlockLearnMoreURL"></a> + <span>$i18n{easyUnlockSetupIntro}</span> + <a target="_blank" href="$i18nRaw{easyUnlockLearnMoreURL}"> + $i18n{learnMore} + </a> </div> - <button id="easy-unlock-setup-button" - i18n-content="easyUnlockSetupButton"></button> + <button id="easy-unlock-setup-button"> + $i18n{easyUnlockSetupButton} + </button> </div> <!-- Options shown when the user has set up Easy Unlock --> <div id="easy-unlock-enabled" hidden> <div class="settings-row"> - <span i18n-content="easyUnlockDescription"></span> - <a target="_blank" i18n-content="learnMore" - i18n-values="href:easyUnlockLearnMoreURL"></a> + <span>$i18n{easyUnlockDescription}</span> + <a target="_blank" href="$i18nRaw{easyUnlockLearnMoreURL}"> + $i18n{learnMore} + </a> <div id="easy-unlock-enable-proximity-detection" class="checkbox" hidden> <label> <input type="checkbox" metric="Options_EasyUnlockRequireProximity" pref="easy_unlock.proximity_required"> - <span i18n-content="easyUnlockRequireProximityLabel"></span> + <span>$i18n{easyUnlockRequireProximityLabel}</span> </label> </div> </div> - <button id="easy-unlock-turn-off-button" - i18n-content="easyUnlockTurnOffButton"></button> + <button id="easy-unlock-turn-off-button"> + $i18n{easyUnlockTurnOffButton} + </button> </div> </section> <section id="web-content-section"> - <h3 i18n-content="advancedSectionTitleContent"></h3> + <h3>$i18n{advancedSectionTitleContent}</h3> <div> <div class="settings-row"> <label class="web-content-select-label"> - <span i18n-content="defaultFontSizeLabel"></span> + <span>$i18n{defaultFontSizeLabel}</span> <select id="defaultFontSize"> - <option value="9" i18n-content="fontSizeLabelVerySmall"> - </option> - <option value="12" i18n-content="fontSizeLabelSmall"></option> - <option value="16" i18n-content="fontSizeLabelMedium"></option> - <option value="20" i18n-content="fontSizeLabelLarge"></option> - <option value="24" i18n-content="fontSizeLabelVeryLarge"> - </option> + <option value="9">$i18n{fontSizeLabelVerySmall}</option> + <option value="12">$i18n{fontSizeLabelSmall}</option> + <option value="16">$i18n{fontSizeLabelMedium}</option> + <option value="20">$i18n{fontSizeLabelLarge}</option> + <option value="24">$i18n{fontSizeLabelVeryLarge}</option> </select> </label> <span id="font-size-indicator" class="controlled-setting-indicator"></span> - <button id="fontSettingsCustomizeFontsButton" - i18n-content="fontSettingsCustomizeFontsButton"></button> + <button id="fontSettingsCustomizeFontsButton"> + $i18n{fontSettingsCustomizeFontsButton} + </button> </div> <div class="settings-row" guest-visibility="disabled"> <label class="web-content-select-label"> - <span i18n-content="defaultZoomFactorLabel"></span> + <span>$i18n{defaultZoomFactorLabel}</span> <select id="defaultZoomFactor" dataType="double"></select> </label> </div> @@ -650,7 +661,7 @@ <label> <input id="tabsToLinksPref" pref="webkit.webprefs.tabs_to_links" metric="Options_TabsToLinks" type="checkbox"> - <span i18n-content="tabsToLinksPref"></span> + <span>$i18n{tabsToLinksPref}</span> </label> </div> </if> @@ -658,57 +669,59 @@ </section> <if expr="not chromeos"> <section id="network-section"> - <h3 i18n-content="advancedSectionTitleNetwork"></h3> + <h3>$i18n{advancedSectionTitleNetwork}</h3> <div> - <span id="proxiesLabel" - class="settings-row" - i18n-content="proxiesLabelSystem"></span> + <span id="proxiesLabel" class="settings-row"> + $i18n{proxiesLabelSystem} + </span> <div class="settings-row"> - <button id="proxiesConfigureButton" - i18n-content="proxiesConfigureButton"></button> + <button id="proxiesConfigureButton"> + $i18n{proxiesConfigureButton} + </button> <span class="controlled-setting-indicator" pref="proxy" plural></span> </div> </div> </section> </if> <section id="languages-section"> - <h3 i18n-content="advancedSectionTitleLanguages"></h3> + <h3>$i18n{advancedSectionTitleLanguages}</h3> <div class="settings-row"> - <span i18n-content="languageSectionLabel"></span> - <a target="_blank" i18n-content="learnMore" - i18n-values="href:languagesLearnMoreURL"></a> + <span>$i18n{languageSectionLabel}</span> + <a target="_blank" href="$i18nRaw{languagesLearnMoreURL}"> + $i18n{learnMore} + </a> </div> <div class="settings-row"> - <button id="language-button" - i18n-content="languageAndSpellCheckSettingsButton"></button> + <button id="language-button"> + $i18n{languageAndSpellCheckSettingsButton} + </button> </div> <div class="checkbox controlled-setting-with-label"> <label> <input pref="translate.enabled" metric="Options_Translate" type="checkbox"> <span> - <span i18n-content="translateEnableTranslate"></span> + <span>$i18n{translateEnableTranslate}</span> <span class="controlled-setting-indicator" pref="translate.enabled"> </span> </span> </label> - <a is="action-link" id="manage-languages" i18n-content="manageLanguages"> - </a> + <a is="action-link" id="manage-languages">$i18n{manageLanguages}</a> </div> </section> <section id="downloads-section"> - <h3 i18n-content="downloadLocationGroupName"></h3> + <h3>$i18n{downloadLocationGroupName}</h3> <div> <div class="settings-row"> <label> - <span id="download-location-label" - i18n-content="downloadLocationBrowseTitle"> + <span id="download-location-label"> + $i18n{downloadLocationBrowseTitle} </span> <input id="downloadLocationPath" class="weakrtl" type="text" size="36" readonly> </label> - <button id="downloadLocationChangeButton" - i18n-content="downloadLocationChangeButton"> + <button id="downloadLocationChangeButton"> + $i18n{downloadLocationChangeButton} </button> <span class="controlled-setting-indicator" pref="download.default_directory"> @@ -720,7 +733,7 @@ pref="download.prompt_for_download" metric="Options_AskForSaveLocation"> <span> - <span i18n-content="downloadLocationAskForSaveLocation"></span> + <span>$i18n{downloadLocationAskForSaveLocation}</span> <span class="controlled-setting-indicator" pref="download.prompt_for_download"></span> </span> @@ -734,7 +747,7 @@ pref="gdata.disabled" metric="Options_DisableGData"> <span> - <span i18n-content="disableGData"></span> + <span>$i18n{disableGData}</span> <span class="controlled-setting-indicator" pref="gdata.disabled"> </span> </span> @@ -743,53 +756,59 @@ </if> <div id="auto-open-file-types-section" hidden> <div id="auto-open-file-types-container"> - <div id="auto-open-file-types-label" class="settings-row" - i18n-content="autoOpenFileTypesInfo"></div> + <div id="auto-open-file-types-label" class="settings-row"> + $i18n{autoOpenFileTypesInfo} + </div> <div class="settings-row"> - <button id="autoOpenFileTypesResetToDefault" - i18n-content="autoOpenFileTypesResetToDefault"></button> + <button id="autoOpenFileTypesResetToDefault"> + $i18n{autoOpenFileTypesResetToDefault} + </button> </div> </div> </div> </div> </section> <section id="certificates-section"> - <h3 i18n-content="advancedSectionTitleCertificates"></h3> + <h3>$i18n{advancedSectionTitleCertificates}</h3> <div> <if expr="use_nss_certs or is_win or is_macosx"> <div class="settings-row"> - <button id="certificatesManageButton" - i18n-content="certificatesManageButton"></button> + <button id="certificatesManageButton"> + $i18n{certificatesManageButton} + </button> </div> </if> </div> </section> <if expr="chromeos"> <section id="cups-printers-section" hidden> - <h3 i18n-content="advancedSectionTitleCupsPrint"></h3> + <h3>$i18n{advancedSectionTitleCupsPrint}</h3> <div class="settings-row"> - <span i18n-content="cupsPrintOptionLabel"></span> - <a target="_blank" i18n-content="learnMore" - i18n-values="href:cupsPrintLearnMoreURL"> + <span>$i18n{cupsPrintOptionLabel}</span> + <a target="_blank" href="$i18nRaw{cupsPrintLearnMoreURL}"> + $i18n{learnMore} </a> </div> <div class="settings-row"> - <button id="cupsPrintersManageButton" - i18n-content="cupsPrintersManageButton"></button> + <button id="cupsPrintersManageButton"> + $i18n{cupsPrintersManageButton} + </button> </div> </section> </if> <if expr="enable_service_discovery"> <section id="cloudprint-options-mdns"> - <h3 i18n-content="advancedSectionTitleCloudPrint"></h3> + <h3>$i18n{advancedSectionTitleCloudPrint}</h3> <div class="settings-row"> - <span i18n-content="cloudPrintOptionLabel"></span> - <a target="_blank" i18n-content="learnMore" - i18n-values="href:cloudPrintLearnMoreURL"></a> + <span>$i18n{cloudPrintOptionLabel}</span> + <a target="_blank" href="$i18nRaw{cloudPrintLearnMoreURL}"> + $i18n{learnMore} + </a> </div> <div class="settings-row"> - <button id="cloudPrintDevicesPageButton" - i18n-content="cloudPrintDevicesPageButton"></button> + <button id="cloudPrintDevicesPageButton"> + $i18n{cloudPrintDevicesPageButton} + </button> </div> <div class="settings-row checkbox controlled-setting-with-label" @@ -800,7 +819,7 @@ type="checkbox" metric="LocalDiscoveryNotificationsDisabled_Settings"> <span> - <span i18n-content="cloudPrintEnableNotificationsLabel"></span> + <span>$i18n{cloudPrintEnableNotificationsLabel}</span> <span class="controlled-setting-indicator" pref="local_discovery.notifications_enabled"></span> </span> @@ -814,21 +833,23 @@ </if> <section id="a11y-section"> - <h3 i18n-content="accessibilityTitle"></h3> + <h3>$i18n{accessibilityTitle}</h3> <div> <a href="https://chrome.google.com/webstore/category/collection/accessibility" - id="accessibility-features" target="_blank" - i18n-content="accessibilityFeaturesLink"></a> + id="accessibility-features" target="_blank"> + $i18n{accessibilityFeaturesLink} + </a> </div> <if expr="chromeos"> <div class="option-control-table"> <p id="accessibility-explanation" class="settings-row"> - <span i18n-content="accessibilityExplanation"></span> + <span>$i18n{accessibilityExplanation}</span> <a id="accessibility-learn-more" target="_blank" - i18n-values="href:accessibilityLearnMoreURL" - i18n-content="learnMore"></a> + href="$i18nRaw{accessibilityLearnMoreURL}"> + $i18n{learnMore} + </a> </p> <div class="option-name"> <div class="checkbox controlled-setting-with-label"> @@ -837,7 +858,7 @@ pref="settings.a11y.enable_menu" type="checkbox" metric="Options_AccessibilitySystemMenu"> <span> - <span i18n-content="accessibilityAlwaysShowMenu"></span> + <span>$i18n{accessibilityAlwaysShowMenu}</span> <span class="controlled-setting-indicator" pref="settings.a11y.enable_menu"></span> </span> @@ -851,7 +872,7 @@ pref="settings.a11y.large_cursor_enabled" type="checkbox" metric="Options_AccessibilityLargeMouseCursor"> <span> - <span i18n-content="accessibilityLargeCursor"></span> + <span>$i18n{accessibilityLargeCursor}</span> <span class="controlled-setting-indicator" pref="settings.a11y.large_cursor_enabled"></span> </span> @@ -865,7 +886,7 @@ pref="settings.a11y.high_contrast_enabled" type="checkbox" metric="Options_AccessibilityHighContrastMode"> <span> - <span i18n-content="accessibilityHighContrast"></span> + <span>$i18n{accessibilityHighContrast}</span> <span class="controlled-setting-indicator" pref="settings.a11y.high_contrast_enabled"></span> </span> @@ -879,7 +900,7 @@ pref="settings.a11y.sticky_keys_enabled" type="checkbox" metric="Options_AccessibilityStickyKeys"> <span> - <span i18n-content="accessibilityStickyKeys"></span> + <span>$i18n{accessibilityStickyKeys}</span> <span class="controlled-setting-indicator" pref="settings.a11y.sticky_keys_enabled"></span> </span> @@ -893,16 +914,18 @@ pref="settings.accessibility" type="checkbox" metric="Options_AccessibilitySpokenFeedback"> <span> - <span i18n-content="accessibilitySpokenFeedback"></span> + <span>$i18n{accessibilitySpokenFeedback}</span> <span class="controlled-setting-indicator" pref="settings.accessibility"></span> </span> </label> <div id="accessibility-settings" hidden> - <button id="accessibility-settings-button" - i18n-content="accessibilitySettings"></button> - <button id="talkback-settings-button" - i18n-content="accessibilityTalkBackSettings"></button> + <button id="accessibility-settings-button"> + $i18n{accessibilitySettings} + </button> + <button id="talkback-settings-button"> + $i18n{accessibilityTalkBackSettings} + </button> </div> </div> </div> @@ -914,7 +937,7 @@ pref="settings.a11y.screen_magnifier" type="checkbox" metric="Options_AccessibilityScreenMagnifier"> <span> - <span i18n-content="accessibilityScreenMagnifier"></span> + <span>$i18n{accessibilityScreenMagnifier}</span> <span class="controlled-setting-indicator" pref="settings.a11y.screen_magnifier"></span> </span> @@ -929,7 +952,7 @@ pref="settings.a11y.screen_magnifier_center_focus" type="checkbox" metric="Options_AccessibilityScreenMagnifierCenterFocus"> <span> - <span i18n-content="accessibilityScreenMagnifierCenterFocus"></span> + <span>$i18n{accessibilityScreenMagnifierCenterFocus}</span> <span class="controlled-setting-indicator" pref="settings.a11y.screen_magnifier_center_focus"></span> </span> @@ -942,7 +965,7 @@ <input id="accessibility-tap-dragging-check" pref="settings.touchpad.enable_tap_dragging" type="checkbox" metric="Options_AccessibilityTapDragging"> - <span i18n-content="accessibilityTapDragging"></span> + <span>$i18n{accessibilityTapDragging}</span> </label> </div> </div> @@ -952,7 +975,7 @@ <input id="accessibility-autoclick-check" pref="settings.a11y.autoclick" type="checkbox"> <span> - <span i18n-content="accessibilityAutoclick"></span> + <span>$i18n{accessibilityAutoclick}</span> <span class="controlled-setting-indicator" pref="settings.a11y.autoclick"></span> </span> @@ -960,26 +983,22 @@ </div> <div class="checkbox"> <!-- No whitespace between elements. --> - <input type="checkbox" class="spacer-checkbox"><span - id="accessibility-autoclick-label" - i18n-content="accessibilityAutoclickDropdown"> - </span><select id="accessibility-autoclick-dropdown" class="control" + <input type="checkbox" class="spacer-checkbox"> + <span id="accessibility-autoclick-label"> + $i18n{accessibilityAutoclickDropdown} + </span> + <select id="accessibility-autoclick-dropdown" class="control" data-type="number" aria-labelledby="accessibility-autoclick-label" pref="settings.a11y.autoclick_delay_ms"> <!-- i18n strings contain the autoclick duration; if the autoclick timing gets changed, then the i18n strings also needs to be updated. --> - <option value="600" - i18n-content="autoclickDelayExtremelyShort"></option> - <option value="800" - i18n-content="autoclickDelayVeryShort"></option> - <option value="1000" i18n-content="autoclickDelayShort"> - </option> - <option value="2000" i18n-content="autoclickDelayLong"> - </option> - <option value="4000" - i18n-content="autoclickDelayVeryLong"></option> + <option value="600">$i18n{autoclickDelayExtremelyShort}</option> + <option value="800">$i18n{autoclickDelayVeryShort}</option> + <option value="1000">$i18n{autoclickDelayShort}</option> + <option value="2000">$i18n{autoclickDelayLong}</option> + <option value="4000">$i18n{autoclickDelayVeryLong}</option> </select> <span class="controlled-setting-indicator" pref="settings.a11y.autoclick_delay_ms"></span> @@ -991,7 +1010,7 @@ <input pref="settings.a11y.virtual_keyboard" type="checkbox" metric="Options_AccessibilityOnScreenKeyboard"> <span> - <span i18n-content="accessibilityVirtualKeyboard"></span> + <span>$i18n{accessibilityVirtualKeyboard}</span> <span class="controlled-setting-indicator" pref="settings.a11y.virtual_keyboard"></span> </span> @@ -1004,7 +1023,7 @@ <input pref="settings.a11y.mono_audio" type="checkbox" metric="Options_AccessibilityMonoAudio"> <span> - <span i18n-content="accessibilityMonoAudio"></span> + <span>$i18n{accessibilityMonoAudio}</span> <span class="controlled-setting-indicator" pref="settings.a11y.mono_audio"></span> </span> @@ -1017,7 +1036,7 @@ <input pref="settings.a11y.caret_highlight" type="checkbox" metric="Options_AccessibilityCaretHighlight"> <span> - <span i18n-content="accessibilityCaretHighlight"></span> + <span>$i18n{accessibilityCaretHighlight}</span> <span class="controlled-setting-indicator" pref="settings.a11y.caret_highlight"></span> </span> @@ -1030,7 +1049,7 @@ <input pref="settings.a11y.cursor_highlight" type="checkbox" metric="Options_AccessibilityCursorHighlight"> <span> - <span i18n-content="accessibilityCursorHighlight"></span> + <span>$i18n{accessibilityCursorHighlight}</span> <span class="controlled-setting-indicator" pref="settings.a11y.cursor_highlight"></span> </span> @@ -1043,7 +1062,7 @@ <input pref="settings.a11y.focus_highlight" type="checkbox" metric="Options_AccessibilityFocusHighlight"> <span> - <span i18n-content="accessibilityFocusHighlight"></span> + <span>$i18n{accessibilityFocusHighlight}</span> <span class="controlled-setting-indicator" pref="settings.a11y.focus_highlight"></span> </span> @@ -1057,7 +1076,7 @@ <input pref="settings.a11y.select_to_speak" type="checkbox" metric="Options_AccessibilitySelectToSpeak"> <span> - <span i18n-content="accessibilitySelectToSpeak"></span> + <span>$i18n{accessibilitySelectToSpeak}</span> <span class="controlled-setting-indicator" pref="settings.a11y.select_to_speak"></span> </span> @@ -1070,7 +1089,7 @@ <input pref="settings.a11y.switch_access" type="checkbox" metric="Options_AccessibilitySwitchAccess"> <span> - <span i18n-content="accessibilitySwitchAccess"></span> + <span>$i18n{accessibilitySwitchAccess}</span> <span class="controlled-setting-indicator" pref="settings.a11y.switch_access"></span> </span> @@ -1085,26 +1104,23 @@ <if expr="chromeos"> <section id="factory-reset-section" hidden> - <h3 i18n-content="factoryResetTitle"></h3> + <h3>$i18n{factoryResetTitle}</h3> <div> - <span class="settings-row" i18n-content="factoryResetDescription"> - </span> - <button id="factory-reset-restart" - i18n-content="factoryResetRestart"> - </button> + <span class="settings-row">$i18n{factoryResetDescription}</span> + <button id="factory-reset-restart">$i18n{factoryResetRestart}</button> </div> </section> </if> <if expr="not chromeos"> <section id="system-section"> - <h3 i18n-content="advancedSectionTitleSystem"></h3> + <h3>$i18n{advancedSectionTitleSystem}</h3> <if expr="not is_macosx"> <div class="checkbox controlled-setting-with-label"> <label> <input pref="background_mode.enabled" type="checkbox"> <span> - <span i18n-content="backgroundModeCheckbox"></span> + <span>$i18n{backgroundModeCheckbox}</span> <span class="controlled-setting-indicator" pref="background_mode.enabled"></span> </span> @@ -1116,29 +1132,27 @@ <input id="gpu-mode-checkbox" pref="hardware_acceleration_mode.enabled" type="checkbox"> <span> - <span i18n-content="gpuModeCheckbox"></span> + <span>$i18n{gpuModeCheckbox}</span> <span class="controlled-setting-indicator" pref="hardware_acceleration_mode.enabled"></span> </span> </label> - <span id="gpu-mode-reset-restart" - i18n-values=".innerHTML:gpuModeResetRestart"></span> + <span id="gpu-mode-reset-restart">$i18nRaw{gpuModeResetRestart}</span> </div> </section> </if> <section id="reset-profile-settings-section"> - <h3 i18n-content="resetProfileSettingsSectionTitle"></h3> + <h3>$i18n{resetProfileSettingsSectionTitle}</h3> <div> - <span class="settings-row" i18n-content="resetProfileSettingsDescription"> - </span> - <button id="reset-profile-settings" i18n-content="resetProfileSettings"> - </button> + <span class="settings-row">$i18n{resetProfileSettingsDescription}</span> + <button id="reset-profile-settings">$i18n{resetProfileSettings}</button> </div> </section> </div> <!-- advanced-settings-container --> </div> <!-- advanced-settings --> <footer id="advanced-settings-footer"> - <a is="action-link" id="advanced-settings-expander" - i18n-content="showAdvancedSettings"></a> + <a is="action-link" id="advanced-settings-expander"> + $i18n{showAdvancedSettings} + </a> </footer> </div>
diff --git a/chrome/browser/resources/options/certificate_backup_overlay.html b/chrome/browser/resources/options/certificate_backup_overlay.html index ded4f5e..92601ef 100644 --- a/chrome/browser/resources/options/certificate_backup_overlay.html +++ b/chrome/browser/resources/options/certificate_backup_overlay.html
@@ -1,19 +1,21 @@ <div id="certificateBackupOverlay" class="page" hidden> <div class="close-button"></div> - <h1 i18n-content="certificateExportPasswordDescription"></h1> + <h1>$i18n{certificateExportPasswordDescription}</h1> <div class="content-area"> <table> <tr> - <td id="certificate-backup-password-label" - i18n-content="certificatePasswordLabel"></td> + <td id="certificate-backup-password-label"> + $i18n{certificatePasswordLabel} + </td> <td> <input id="certificateBackupPassword" type="password" aria-labelledby="certificate-backup-password-label"> </td> </tr> <tr> - <td id="certificate-backup-password-2-label" - i18n-content="certificateConfirmPasswordLabel"></td> + <td id="certificate-backup-password-2-label"> + $i18n{certificateConfirmPasswordLabel} + </td> <td> <input id="certificateBackupPassword2" type="password" aria-labelledby="certificate-backup-password-2-label"> @@ -21,15 +23,17 @@ </tr> </table> <p> - <span i18n-content="certificateExportPasswordHelp"></span> + <span>$i18n{certificateExportPasswordHelp}</span> </p> </div> <div class="action-area"> <div class="button-strip"> - <button id="certificateBackupCancelButton" type="reset" - i18n-content="cancel"></button> + <button id="certificateBackupCancelButton" type="reset"> + $i18n{cancel} + </button> <button id="certificateBackupOkButton" class="default-button" - type="submit" i18n-content="ok" disabled> + type="submit" disabled> + $i18n{ok} </button> </div> </div>
diff --git a/chrome/browser/resources/options/certificate_edit_ca_trust_overlay.html b/chrome/browser/resources/options/certificate_edit_ca_trust_overlay.html index 4dabea2..198002d 100644 --- a/chrome/browser/resources/options/certificate_edit_ca_trust_overlay.html +++ b/chrome/browser/resources/options/certificate_edit_ca_trust_overlay.html
@@ -1,38 +1,40 @@ <div id="certificateEditCaTrustOverlay" class="page" hidden> - <h1><span i18n-content="certificateEditCaTitle"></span></h1> + <h1><span>$i18n{certificateEditCaTitle}</span></h1> <div class="close-button"></div> <div class="content-area"> <div> <span id="certificateEditCaTrustDescription"></span> </div> <section> - <h3><span i18n-content="certificateEditTrustLabel"></span></h3> + <h3><span>$i18n{certificateEditTrustLabel}</span></h3> <div class="checkbox"> <label id="certificateCaTrustSSLLabel"> <input id="certificateCaTrustSSLCheckbox" type="checkbox"> - <span i18n-content="certificateCaTrustSSLLabel"></span> + <span>$i18n{certificateCaTrustSSLLabel}</span> </label> </div> <div class="checkbox"> <label id="certificateCaTrustEmailLabel"> <input id="certificateCaTrustEmailCheckbox" type="checkbox"> - <span i18n-content="certificateCaTrustEmailLabel"></span> + <span>$i18n{certificateCaTrustEmailLabel}</span> </label> </div> <div class="checkbox"> <label id="certificateCaTrustObjSignLabel"> <input id="certificateCaTrustObjSignCheckbox" type="checkbox"> - <span i18n-content="certificateCaTrustObjSignLabel"></span> + <span>$i18n{certificateCaTrustObjSignLabel}</span> </label> </div> </section> </div> <div class="action-area"> <div class="button-strip"> - <button id="certificateEditCaTrustCancelButton" type="reset" - i18n-content="cancel"></button> + <button id="certificateEditCaTrustCancelButton" type="reset"> + $i18n{cancel} + </button> <button id="certificateEditCaTrustOkButton" class="default-button" - type="submit" i18n-content="ok"> + type="submit"> + $i18n{ok} </button> </div> </div>
diff --git a/chrome/browser/resources/options/certificate_import_error_overlay.html b/chrome/browser/resources/options/certificate_import_error_overlay.html index b36d4db..c468b01 100644 --- a/chrome/browser/resources/options/certificate_import_error_overlay.html +++ b/chrome/browser/resources/options/certificate_import_error_overlay.html
@@ -8,7 +8,8 @@ <div class="action-area"> <div class="button-strip"> <button id="certificateImportErrorOverlayOk" class="default-button" - type="submit" i18n-content="done"> + type="submit"> + $i18n{done} </button> </div> </div>
diff --git a/chrome/browser/resources/options/certificate_manager.html b/chrome/browser/resources/options/certificate_manager.html index 30fe9dc6..b619dd81 100644 --- a/chrome/browser/resources/options/certificate_manager.html +++ b/chrome/browser/resources/options/certificate_manager.html
@@ -1,28 +1,25 @@ <div id="certificateManagerPage" class="page" hidden> <div class="close-button"></div> - <h1 id='cert-manager-header' i18n-content="certificateManagerPage"></h1> + <h1 id='cert-manager-header'>$i18n{certificateManagerPage}</h1> <div id="certificate-manager-content-area" class="content-area"> <!-- Navigation tabs --> <div class="subpages-nav-tabs"> <span id="personal-certs-nav-tab" class="tab" tab-contents="personalCertsTab"> - <span class="tab-label" i18n-content="personalCertsTabTitle"></span> - <span class="active-tab-label" i18n-content="personalCertsTabTitle"> - </span> + <span class="tab-label">$i18n{personalCertsTabTitle}</span> + <span class="active-tab-label">$i18n{personalCertsTabTitle}</span> </span> <span id="server-certs-nav-tab" class="tab" tab-contents="serverCertsTab"> - <span class="tab-label" i18n-content="serverCertsTabTitle"></span> - <span class="active-tab-label" i18n-content="serverCertsTabTitle"> - </span> + <span class="tab-label">$i18n{serverCertsTabTitle}</span> + <span class="active-tab-label">$i18n{serverCertsTabTitle}</span> </span> <span id="ca-certs-nav-tab" class="tab" tab-contents="caCertsTab"> - <span class="tab-label" i18n-content="caCertsTabTitle"></span> - <span class="active-tab-label" i18n-content="caCertsTabTitle"></span> + <span class="tab-label">$i18n{caCertsTabTitle}</span> + <span class="active-tab-label">$i18n{caCertsTabTitle}</span> </span> <span id="other-certs-nav-tab" class="tab" tab-contents="otherCertsTab"> - <span class="tab-label" i18n-content="otherCertsTabTitle"></span> - <span class="active-tab-label" i18n-content="otherCertsTabTitle"> - </span> + <span class="tab-label">$i18n{otherCertsTabTitle}</span> + <span class="active-tab-label">$i18n{otherCertsTabTitle}</span> </span> </div> <!-- TODO(mattm): get rid of use of tables --> @@ -30,7 +27,7 @@ <div id="personalCertsTab" class="subpages-tab-contents"> <table class="certificate-tree-table"> <tr><td> - <span i18n-content="personalCertsTabDescription"></span> + <span>$i18n{personalCertsTabDescription}</span> </td></tr> <tr><td> <tree id="personalCertsTab-tree" class="certificate-tree" @@ -38,22 +35,22 @@ </tree> </td></tr> <tr><td> - <button id="personalCertsTab-view" i18n-content="view_certificate" - disabled> + <button id="personalCertsTab-view" disabled> + $i18n{view_certificate} </button> - <button id="personalCertsTab-import" - i18n-content="import_certificate" disabled> + <button id="personalCertsTab-import" disabled> + $i18n{import_certificate} </button> <if expr="chromeos"> - <button id="personalCertsTab-import-and-bind" - i18n-content="importAndBindCertificate" disabled> + <button id="personalCertsTab-import-and-bind" disabled> + $i18n{importAndBindCertificate} </button> </if> - <button id="personalCertsTab-backup" i18n-content="export_certificate" - disabled> + <button id="personalCertsTab-backup" disabled> + $i18n{export_certificate} </button> - <button id="personalCertsTab-delete" i18n-content="delete_certificate" - disabled> + <button id="personalCertsTab-delete" disabled> + $i18n{delete_certificate} </button> </td></tr> </table> @@ -61,7 +58,7 @@ <div id="serverCertsTab" class="subpages-tab-contents"> <table class="certificate-tree-table"> <tr><td> - <span i18n-content="serverCertsTabDescription"></span> + <span>$i18n{serverCertsTabDescription}</span> </td></tr> <tr><td> <tree id="serverCertsTab-tree" class="certificate-tree" @@ -69,17 +66,17 @@ </tree> </td></tr> <tr><td> - <button id="serverCertsTab-view" i18n-content="view_certificate" - disabled> + <button id="serverCertsTab-view" disabled> + $i18n{view_certificate} </button> - <button id="serverCertsTab-import" i18n-content="import_certificate" - disabled> + <button id="serverCertsTab-import" disabled> + $i18n{import_certificate} </button> - <button id="serverCertsTab-export" i18n-content="export_certificate" - disabled> + <button id="serverCertsTab-export" disabled> + $i18n{export_certificate} </button> - <button id="serverCertsTab-delete" i18n-content="delete_certificate" - disabled> + <button id="serverCertsTab-delete" disabled> + $i18n{delete_certificate} </button> </td></tr> </table> @@ -87,7 +84,7 @@ <div id="caCertsTab" class="subpages-tab-contents"> <table class="certificate-tree-table"> <tr><td> - <span i18n-content="caCertsTabDescription"></span> + <span>$i18n{caCertsTabDescription}</span> </td></tr> <tr><td> <tree id="caCertsTab-tree" class="certificate-tree" @@ -95,19 +92,20 @@ </tree> </td></tr> <tr><td> - <button id="caCertsTab-view" i18n-content="view_certificate" - disabled> + <button id="caCertsTab-view" disabled> + $i18n{view_certificate} </button> - <button id="caCertsTab-edit" i18n-content="edit_certificate" - disabled> + <button id="caCertsTab-edit" disabled> + $i18n{edit_certificate} </button> - <button id="caCertsTab-import" i18n-content="import_certificate" - disabled></button> - <button id="caCertsTab-export" i18n-content="export_certificate" - disabled> + <button id="caCertsTab-import" disabled> + $i18n{import_certificate} </button> - <button id="caCertsTab-delete" i18n-content="delete_certificate" - disabled> + <button id="caCertsTab-export" disabled> + $i18n{export_certificate} + </button> + <button id="caCertsTab-delete" disabled> + $i18n{delete_certificate} </button> </td></tr> </table> @@ -115,21 +113,21 @@ <div id="otherCertsTab" class="subpages-tab-contents"> <table class="certificate-tree-table"> <tr><td> - <span i18n-content="otherCertsTabDescription"></span> + <span>$i18n{otherCertsTabDescription}</span> </td></tr> <tr><td> <tree id="otherCertsTab-tree" class="certificate-tree" icon-visibility="parent"></tree> </td></tr> <tr><td> - <button id="otherCertsTab-view" i18n-content="view_certificate" - disabled> + <button id="otherCertsTab-view" disabled> + $i18n{view_certificate} </button> - <button id="otherCertsTab-export" i18n-content="export_certificate" - disabled> + <button id="otherCertsTab-export" disabled> + $i18n{export_certificate} </button> - <button id="otherCertsTab-delete" i18n-content="delete_certificate" - disabled> + <button id="otherCertsTab-delete" disabled> + $i18n{delete_certificate} </button> </td></tr> </table> @@ -137,8 +135,8 @@ </div> <div class="action-area"> <div class="button-strip"> - <button id="certificate-confirm" class="default-button" - i18n-content="done"> + <button id="certificate-confirm" class="default-button"> + $i18n{done} </button> </div> </div>
diff --git a/chrome/browser/resources/options/certificate_restore_overlay.html b/chrome/browser/resources/options/certificate_restore_overlay.html index d68fafb..f238cbc 100644 --- a/chrome/browser/resources/options/certificate_restore_overlay.html +++ b/chrome/browser/resources/options/certificate_restore_overlay.html
@@ -1,18 +1,20 @@ <div id="certificateRestoreOverlay" class="page" hidden> <div class="close-button"></div> - <h1 i18n-content="certificateRestorePasswordDescription"></h1> + <h1>$i18n{certificateRestorePasswordDescription}</h1> <div class="content-area"> <label id="certificateRestorePasswordLabel"> - <span i18n-content="certificatePasswordLabel"></span> + <span>$i18n{certificatePasswordLabel}</span> <input id="certificateRestorePassword" type="password"> </label> </div> <div class="action-area"> <div class="button-strip"> - <button id="certificateRestoreCancelButton" type="reset" - i18n-content="cancel"></button> + <button id="certificateRestoreCancelButton" type="reset"> + $i18n{cancel} + </button> <button id="certificateRestoreOkButton" class="default-button" - type="submit" i18n-content="ok"> + type="submit"> + $i18n{ok} </button> </div> </div>
diff --git a/chrome/browser/resources/options/chromeos/accounts_options.html b/chrome/browser/resources/options/chromeos/accounts_options.html index 2ddc846d..1cbfe32 100644 --- a/chrome/browser/resources/options/chromeos/accounts_options.html +++ b/chrome/browser/resources/options/chromeos/accounts_options.html
@@ -1,11 +1,11 @@ <div id="accountsPage" class="page" hidden> <div class="close-button"></div> - <h1 i18n-content="accountsPage"></h1> + <h1>$i18n{accountsPage}</h1> <div class="content-area"> <div class="option"> <div id="ownerOnlyWarning" hidden> - <span i18n-content="owner_only"></span> - <span i18n-content="ownerUserId"></span> + <span>$i18n{owner_only}</span> + <span>$i18n{ownerUserId}</span> </div> <table class="option-control-table"> <tr> @@ -15,7 +15,7 @@ <input id="allowBwsiCheck" type="checkbox" metric="Options_GuestBrowsing" pref="cros.accounts.allowBWSI"> - <span i18n-content="allow_BWSI"></span> + <span>$i18n{allow_BWSI}</span> </label> </div> </td> @@ -27,7 +27,7 @@ <input id="allowSupervisedCheck" type="checkbox" metric="Options_SupervisedUsers" pref="cros.accounts.supervisedUsersEnabled"> - <span i18n-content="allow_supervised_users"></span> + <span>$i18n{allow_supervised_users}</span> </label> </div> </td> @@ -39,7 +39,7 @@ <input id="showUserNamesCheck" type="checkbox" metric="Options_ShowUserNamesOnSignin" pref="cros.accounts.showUserNamesOnSignIn"> - <span i18n-content="show_user_on_signin"></span> + <span>$i18n{show_user_on_signin}</span> </label> </div> </td> @@ -52,7 +52,7 @@ metric="Options_AllowAllUsers" pref="cros.accounts.allowGuest" inverted_pref> - <span i18n-content="use_whitelist"></span> + <span>$i18n{use_whitelist}</span> </label> </div> </td> @@ -64,9 +64,9 @@ <list id="userList"></list> </td></tr> <tr><td class="user-name-edit-row"> - <label><span i18n-content="add_users"></span><br> + <label><span>$i18n{add_users}</span><br> <input id="userNameEdit" type="text" - i18n-values="placeholder:username_edit_hint"> + placeholder="$i18n{username_edit_hint}"> </span> </label> </td></tr> @@ -77,8 +77,8 @@ </div> <div class="action-area"> <div class="button-strip"> - <button id="accounts-options-overlay-confirm" class="default-button" - i18n-content="done"> + <button id="accounts-options-overlay-confirm" class="default-button"> + $i18n{done} </button> </div> </div>
diff --git a/chrome/browser/resources/options/chromeos/arc_opt_out_confirm_overlay.html b/chrome/browser/resources/options/chromeos/arc_opt_out_confirm_overlay.html index 3105453..6e6575d 100644 --- a/chrome/browser/resources/options/chromeos/arc_opt_out_confirm_overlay.html +++ b/chrome/browser/resources/options/chromeos/arc_opt_out_confirm_overlay.html
@@ -1,19 +1,19 @@ <div id="arc-opt-out-confirm-overlay" class="page" hidden> <div class="close-button"></div> - <h1 i18n-content="arcOptOutDialogHeader"></h1> + <h1>$i18n{arcOptOutDialogHeader}</h1> <div class="content-area"> - <span id="arc-opt-out-confirm-text" - i18n-values=".innerHTML:arcOptOutDialogDescription"> + <span id="arc-opt-out-confirm-text"> + $i18nRaw{arcOptOutDialogDescription} </span> </div> <div class="action-area"> <div class="action-area-right"> <div class="button-strip"> - <button id="arc-opt-out-confirm-cancel" - i18n-content="arcOptOutDialogButtonCancel"> + <button id="arc-opt-out-confirm-cancel"> + $i18n{arcOptOutDialogButtonCancel} </button> - <button id="arc-opt-out-confirm-ok" - i18n-content="arcOptOutDialogButtonConfirmDisable"> + <button id="arc-opt-out-confirm-ok"> + $i18n{arcOptOutDialogButtonConfirmDisable} </button> </div> </div>
diff --git a/chrome/browser/resources/options/chromeos/bluetooth_add_device_overlay.html b/chrome/browser/resources/options/chromeos/bluetooth_add_device_overlay.html index dcb87ab..99cafad2 100644 --- a/chrome/browser/resources/options/chromeos/bluetooth_add_device_overlay.html +++ b/chrome/browser/resources/options/chromeos/bluetooth_add_device_overlay.html
@@ -1,26 +1,23 @@ <div id="bluetooth-options" class="page" hidden> <div class="close-button"></div> - <h1 i18n-content="bluetoothAddDeviceTitle"></h1> + <h1>$i18n{bluetoothAddDeviceTitle}</h1> <div class="settings-list bluetooth-device-list content-area"> <list id="bluetooth-unpaired-devices-list"></list> <div id="bluetooth-unpaired-devices-list-empty-placeholder" class="bluetooth-empty-list-label" hidden> - <span i18n-content="bluetoothNoDevicesFound"></span> + <span>$i18n{bluetoothNoDevicesFound}</span> </div> </div> <div class="action-area button-strip"> - <button id="bluetooth-add-device-cancel-button" type="reset" - i18n-content="cancel"> + <button id="bluetooth-add-device-cancel-button" type="reset"> + $i18n{cancel} </button> <button id="bluetooth-add-device-apply-button" type="submit" - class="default-button" i18n-content="bluetoothConnectDevice" disabled> + class="default-button" disabled> + $i18n{bluetoothConnectDevice} </button> - <span id="bluetooth-scanning-label" - i18n-content="bluetoothScanning"> - </span> - <span id="bluetooth-scan-stopped-label" - i18n-content="bluetoothScanStopped"> - </span> + <span id="bluetooth-scanning-label">$i18n{bluetoothScanning}</span> + <span id="bluetooth-scan-stopped-label">$i18n{bluetoothScanStopped}</span> <div id="bluetooth-scanning-icon" class="inline-spinner"></div> </div> </div>
diff --git a/chrome/browser/resources/options/chromeos/bluetooth_pair_device_overlay.html b/chrome/browser/resources/options/chromeos/bluetooth_pair_device_overlay.html index 255dec0..cc37aa1 100644 --- a/chrome/browser/resources/options/chromeos/bluetooth_pair_device_overlay.html +++ b/chrome/browser/resources/options/chromeos/bluetooth_pair_device_overlay.html
@@ -1,6 +1,6 @@ <div id="bluetooth-pairing" class="page" hidden> <div id="bluetooth-pairing-close-button" class="close-button"></div> - <h1 i18n-content="bluetoothAddDeviceTitle"></h1> + <h1>$i18n{bluetoothAddDeviceTitle}</h1> <div id="bluetooth-pairing-message-area" class="content-area"> <div id="bluetooth-pairing-message-contents"> <div id="bluetooth-pairing-instructions"></div> @@ -14,15 +14,20 @@ </div> </div> <div class="action-area button-strip"> - <button id="bluetooth-pair-device-cancel-button" type="reset" - i18n-content="cancel" hidden></button> - <button id="bluetooth-pair-device-connect-button" type="reset" - i18n-content="bluetoothConnectDevice" hidden></button> - <button id="bluetooth-pair-device-reject-button" type="reset" - i18n-content="bluetoothRejectPasskey" hidden></button> - <button id="bluetooth-pair-device-accept-button" type="reset" - i18n-content="bluetoothAcceptPasskey" hidden></button> - <button id="bluetooth-pair-device-dismiss-button" type="reset" - i18n-content="bluetoothDismissError" hidden></button> + <button id="bluetooth-pair-device-cancel-button" type="reset" hidden> + $i18n{cancel} + </button> + <button id="bluetooth-pair-device-connect-button" type="reset" hidden> + $i18n{bluetoothConnectDevice} + </button> + <button id="bluetooth-pair-device-reject-button" type="reset" hidden> + $i18n{bluetoothRejectPasskey} + </button> + <button id="bluetooth-pair-device-accept-button" type="reset" hidden> + $i18n{bluetoothAcceptPasskey} + </button> + <button id="bluetooth-pair-device-dismiss-button" type="reset" hidden> + $i18n{bluetoothDismissError} + </button> </div> </div>
diff --git a/chrome/browser/resources/options/chromeos/change_picture_options.html b/chrome/browser/resources/options/chromeos/change_picture_options.html index 146585d..55f4bcb 100644 --- a/chrome/browser/resources/options/chromeos/change_picture_options.html +++ b/chrome/browser/resources/options/chromeos/change_picture_options.html
@@ -1,12 +1,12 @@ <div id="change-picture-page" class="page" hidden> <div class="close-button"></div> - <h1 i18n-content="changePicturePage"></h1> + <h1>$i18n{changePicturePage}</h1> <div class="content-area"> - <div i18n-content="changePicturePageDescription"></div> + <div>$i18n{changePicturePageDescription}</div> <div id="user-images-area"> <grid id="user-image-grid" class="user-image-picker" tabindex="1"></grid> <div id="user-image-preview"> - <img id="user-image-preview-img" i18n-values="alt:previewAltText"> + <img id="user-image-preview-img" alt="$i18n{previewAltText}"> <div class="user-image-stream-area"> <div class="perspective-box"> <div id="user-image-stream-crop"> @@ -15,24 +15,25 @@ </div> <div class="spinner"></div> </div> - <button id="discard-photo" i18n-values="title:discardPhoto" - tabindex="2"></button> - <button id="take-photo" i18n-values="title:takePhoto" tabindex="2"> + <button id="discard-photo" title="$i18n{discardPhoto}" tabindex="2"> + </button> + <button id="take-photo" title="$i18n{takePhoto}" tabindex="2"> </button> <button id="flip-photo" class="custom-appearance" - i18n-values="title:flipPhoto" tabindex="1"></button> + title="$i18n{flipPhoto}" tabindex="1"></button> </div> </div> <div id="user-image-attribution"> - <span i18n-content="authorCredit"></span> + <span>$i18n{authorCredit}</span> <strong id="user-image-author-name"></strong> <a id="user-image-author-website" target="_blank"></a> </div> </div> <div class="action-area"> <div class="button-strip"> - <button id="change-picture-overlay-confirm" i18n-content="done" - tabindex="2"></button> + <button id="change-picture-overlay-confirm" tabindex="2"> + $i18n{done} + </button> </div> </div> </div>
diff --git a/chrome/browser/resources/options/chromeos/display_options.html b/chrome/browser/resources/options/chromeos/display_options.html index d915ec7b..13be28d 100644 --- a/chrome/browser/resources/options/chromeos/display_options.html +++ b/chrome/browser/resources/options/chromeos/display_options.html
@@ -1,6 +1,6 @@ <div id="display-options-page" class="page" hidden> <div class="close-button"></div> - <h1 i18n-content="displayOptionsPage"></h1> + <h1>$i18n{displayOptionsPage}</h1> <div class="content-area" id="display-options-content-area"> <div id="display-options-displays-view-host"> </div> @@ -8,16 +8,17 @@ <div id="selected-display-data-container"> <div id="selected-display-name"></div> <div class="selected-display-option-row"> - <div class="selected-display-option-title" - i18n-content="selectedDisplayTitleOptions"> + <div class="selected-display-option-title"> + $i18n{selectedDisplayTitleOptions} </div> <select id="display-options-select-mirroring" class="display-options-button"> - <option value="extended" i18n-content="extendedMode"></option> - <option value="mirroring" i18n-content="mirroringMode"></option> + <option value="extended">$i18n{extendedMode}</option> + <option value="mirroring">$i18n{mirroringMode}</option> </select> <button id="display-options-set-primary" - class="display-options-button2" i18n-content="setPrimary"> + class="display-options-button2"> + $i18n{setPrimary} </button> </div> <div id="display-options-unified-desktop" @@ -27,43 +28,44 @@ </div> <label> <input id="display-options-toggle-unified-desktop" type="checkbox"> - <span class="controlled-setting-with-label" - i18n-content="enableUnifiedDesktop"></span> + <span class="controlled-setting-with-label"> + $i18n{enableUnifiedDesktop} + </span> </label> </div> <div class="selected-display-option-row"> - <div class="selected-display-option-title" - i18n-content="selectedDisplayTitleResolution"> + <div class="selected-display-option-title"> + $i18n{selectedDisplayTitleResolution} </div> <select id="display-options-resolution-selection" class="display-options-button"> </select> </div> <div class="selected-display-option-row"> - <div class="selected-display-option-title" - i18n-content="selectedDisplayTitleOrientation"> + <div class="selected-display-option-title"> + $i18n{selectedDisplayTitleOrientation} </div> <select id="display-options-orientation-selection" class="display-options-button"> - <option value="0" i18n-content="orientation0"></option> - <option value="90" i18n-content="orientation90"></option> - <option value="180" i18n-content="orientation180"></option> - <option value="270" i18n-content="orientation270"></option> + <option value="0">$i18n{orientation0}</option> + <option value="90">$i18n{orientation90}</option> + <option value="180">$i18n{orientation180}</option> + <option value="270">$i18n{orientation270}</option> </select> </div> <div class="selected-display-option-row"> - <div class="selected-display-option-title" - i18n-content="selectedDisplayTitleOverscan"> + <div class="selected-display-option-title"> + $i18n{selectedDisplayTitleOverscan} </div> <button id="selected-display-start-calibrating-overscan" - class="display-options-button" - i18n-content="startCalibratingOverscan"> + class="display-options-button"> + $i18n{startCalibratingOverscan} </button> </div> <div class="selected-display-option-row" id="selected-display-color-profile-row" hidden> - <div class="selected-display-option-title" - i18n-content="selectedDisplayColorProfile"> + <div class="selected-display-option-title"> + $i18n{selectedDisplayColorProfile} </div> <select id="display-options-color-profile-selection" class="display-options-button"> @@ -78,8 +80,9 @@ </div> <div class="action-area"> <div class="button-strip"> - <button id="display-options-done" i18n-content="done" - class="default-button"></button> + <button id="display-options-done" class="default-button"> + $i18n{done} + </button> </div> </div> </div>
diff --git a/chrome/browser/resources/options/chromeos/display_overscan.html b/chrome/browser/resources/options/chromeos/display_overscan.html index 53c280a..ce5b97f 100644 --- a/chrome/browser/resources/options/chromeos/display_overscan.html +++ b/chrome/browser/resources/options/chromeos/display_overscan.html
@@ -9,22 +9,20 @@ <div id="display-overscan-operation-shift"></div></td> </tr> <tr> - <td><span i18n-content="shrinkAndExpand"></span></td> - <td><span i18n-content="move"></span></td> + <td><span>$i18n{shrinkAndExpand}</span></td> + <td><span>$i18n{move}</span></td> </tr> </table> <!-- Specify 'reversed' to prevernt re-reversing the button order by options_page. --> <div class="button-strip" id="display-overscan-button-strip" reversed> - <button id="display-overscan-operation-reset" - i18n-content="overscanReset"> + <button id="display-overscan-operation-reset"> + $i18n{overscanReset} </button> <div id="display-overscan-buttons-spacer"></div> - <button id="display-overscan-operation-ok" - i18n-content="overscanOK"> - </button> - <button id="display-overscan-operation-cancel" - i18n-content="overscanCancel"> + <button id="display-overscan-operation-ok">$i18n{overscanOK}</button> + <button id="display-overscan-operation-cancel"> + $i18n{overscanCancel} </button> </div> </div>
diff --git a/chrome/browser/resources/options/chromeos/internet_detail.html b/chrome/browser/resources/options/chromeos/internet_detail.html index 847a27fe..b3b07bb 100644 --- a/chrome/browser/resources/options/chromeos/internet_detail.html +++ b/chrome/browser/resources/options/chromeos/internet_detail.html
@@ -14,52 +14,43 @@ <div id="details-tab-strip" class="subpages-nav-tabs"> <span id="wifi-network-nav-tab" class="tab wifi-details" tab-contents="wifi-network-tab"> - <span class="tab-label" - i18n-content="wifiNetworkTabLabel"></span> - <span class="active-tab-label" - i18n-content="wifiNetworkTabLabel"></span> + <span class="tab-label">$i18n{wifiNetworkTabLabel}</span> + <span class="active-tab-label">$i18n{wifiNetworkTabLabel}</span> </span> <span id="vpn-nav-tab" class="tab vpn-details" tab-contents="vpn-tab"> - <span class="tab-label" - i18n-content="vpnTabLabel"></span> - <span class="active-tab-label" i18n-content="vpnTabLabel"></span> + <span class="tab-label">$i18n{vpnTabLabel}</span> + <span class="active-tab-label">$i18n{vpnTabLabel}</span> </span> <span id="wimax-network-nav-tab" class="tab wimax-details" tab-contents="wimax-network-tab"> - <span class="tab-label" - i18n-content="wimaxConnTabLabel"></span> - <span class="active-tab-label" - i18n-content="wimaxConnTabLabel"></span> + <span class="tab-label">$i18n{wimaxConnTabLabel}</span> + <span class="active-tab-label">$i18n{wimaxConnTabLabel}</span> </span> <span id="cellular-conn-nav-tab" class="tab cellular-details" tab-contents="cellular-conn-tab"> - <span class="tab-label" - i18n-content="cellularConnTabLabel"></span> - <span class="active-tab-label" - i18n-content="cellularConnTabLabel"></span> + <span class="tab-label">$i18n{cellularConnTabLabel}</span> + <span class="active-tab-label">$i18n{cellularConnTabLabel}</span> </span> <span id="cellular-device-nav-tab" class="tab cellular-details" tab-contents="cellular-device-tab"> - <span class="tab-label" - i18n-content="cellularDeviceTabLabel"></span> - <span class="active-tab-label" - i18n-content="cellularDeviceTabLabel"></span> + <span class="tab-label">$i18n{cellularDeviceTabLabel}</span> + <span class="active-tab-label">$i18n{cellularDeviceTabLabel}</span> </span> <span id="internet-nav-tab" class="tab network-details" tab-contents="internet-tab"> - <span class="tab-label" i18n-content="networkTabLabel"></span> - <span class="active-tab-label" i18n-content="networkTabLabel"></span> + <span class="tab-label">$i18n{networkTabLabel}</span> + <span class="active-tab-label">$i18n{networkTabLabel}</span> </span> <span id="security-nav-tab" class="tab cellular-details gsm-only" tab-contents="security-tab"> - <span class="tab-label" i18n-content="securityTabLabel"></span> - <span class="active-tab-label" i18n-content="securityTabLabel"></span> + <span class="tab-label">$i18n{securityTabLabel}</span> + <span class="active-tab-label">$i18n{securityTabLabel}</span> </span> <span id="internet-proxy-nav-tab" class="tab proxy-details" tab-contents="network-proxy-tab"> - <span class="tab-label" i18n-content="proxyTabLabel"></span> - <span class="active-tab-label" i18n-content="proxyTabLabel"></span> + <span class="tab-label">$i18n{proxyTabLabel}</span> + <span class="active-tab-label">$i18n{proxyTabLabel}</span> </span> </div> <div id="wifi-network-tab" class="subpages-tab-contents wifi-details"> @@ -71,7 +62,7 @@ <label> <input id="prefer-network-wifi" type="checkbox"> <span> - <span i18n-content="inetPreferredNetwork"></span> + <span>$i18n{inetPreferredNetwork}</span> <span class="controlled-setting-indicator" managed="Priority" internet-detail-for="prefer-network-wifi"></span> @@ -86,7 +77,7 @@ <label> <input id="auto-connect-network-wifi" type="checkbox"> <span> - <span i18n-content="inetAutoConnectNetwork"></span> + <span>$i18n{inetAutoConnectNetwork}</span> <span class="controlled-setting-indicator" managed="WiFi.AutoConnect" internet-detail-for="auto-connect-network-wifi"> @@ -101,35 +92,35 @@ <section> <table id="wifi-settings-table"> <tr> - <td class="option-name" i18n-content="connectionState"></td> + <td class="option-name">$i18n{connectionState}</td> <td id="wifi-connection-state" class="option-value"></td> </tr> <tr> - <td class="option-name" i18n-content="restrictedConnectivity"></td> + <td class="option-name">$i18n{restrictedConnectivity}</td> <td id="wifi-restricted-connectivity" class="option-value"></td> </tr> <tr> - <td class="option-name" i18n-content="inetSsid"></td> + <td class="option-name">$i18n{inetSsid}</td> <td id="wifi-ssid" class="option-value"></td> </tr> <tr id="wifi-bssid-entry"> - <td class="option-name" i18n-content="inetBssid"></td> + <td class="option-name">$i18n{inetBssid}</td> <td id="wifi-bssid" class="option-value"></td> </tr> <tr id="wifi-security-entry"> - <td class="options-name" i18n-content="inetEncryption"></td> + <td class="options-name">$i18n{inetEncryption}</td> <td id="wifi-security" class="option-value"></td> </tr> <tr> - <td class="options-name" i18n-content="inetFrequency"></td> + <td class="options-name">$i18n{inetFrequency}</td> <td id="wifi-frequency" class="option-value"></td> </tr> <tr> - <td class="options-name" i18n-content="inetSignalStrength"></td> + <td class="options-name">$i18n{inetSignalStrength}</td> <td id="wifi-signal-strength" class="option-value"></td> </tr> <tr id="wifi-hardware-address-entry"> - <td class="option-name" i18n-content="hardwareAddress"></td> + <td class="option-name">$i18n{hardwareAddress}</td> <td id="wifi-hardware-address" class="option-value"></td> </tr> </table> @@ -137,13 +128,13 @@ <section> <table class="option-control-table"> <tr> - <td id="password-details" class="option-name" - i18n-content="inetPassProtected"> + <td id="password-details" class="option-name"> + $i18n{inetPassProtected} </td> </tr> <tr> - <td id="wifi-shared-network" class="option-name" - i18n-content="inetNetworkShared"> + <td id="wifi-shared-network" class="option-name"> + $i18n{inetNetworkShared} </td> </tr> </table> @@ -158,7 +149,7 @@ <label> <input id="auto-connect-network-wimax" type="checkbox"> <span> - <span i18n-content="inetAutoConnectNetwork"></span> + <span>$i18n{inetAutoConnectNetwork}</span> <span class="controlled-setting-indicator" managed="WiMAX.AutoConnect" internet-detail-for="auto-connect-network-wimax"> @@ -173,19 +164,19 @@ <section> <table id="wimax-settings-table"> <tr> - <td class="option-name" i18n-content="connectionState"></td> + <td class="option-name">$i18n{connectionState}</td> <td id="wimax-connection-state" class="option-value"></td> </tr> <tr> - <td class="option-name" i18n-content="restrictedConnectivity"></td> + <td class="option-name">$i18n{restrictedConnectivity}</td> <td id="wimax-restricted-connectivity" class="option-value"></td> </tr> <tr id="wimax-eap-identity-entry"> - <td class="option-name" i18n-content="inetUsername"></td> + <td class="option-name">$i18n{inetUsername}</td> <td id="wimax-eap-identity" class="option-value"></td> </tr> <tr> - <td class="options-name" i18n-content="inetSignalStrength"></td> + <td class="options-name">$i18n{inetSignalStrength}</td> <td id="wimax-signal-strength" class="option-value"></td> </tr> </table> @@ -193,8 +184,8 @@ <section> <table class="option-control-table"> <tr> - <td id="wimax-shared-network" class="option-name" - i18n-content="inetNetworkShared"> + <td id="wimax-shared-network" class="option-name"> + $i18n{inetNetworkShared} </td> </tr> </table> @@ -209,7 +200,7 @@ <label> <input id="auto-connect-network-vpn" type="checkbox"> <span> - <span i18n-content="inetAutoConnectNetwork"></span> + <span>$i18n{inetAutoConnectNetwork}</span> <span class="controlled-setting-indicator" managed="VPN.AutoConnect" internet-detail-for="auto-connect-network-vpn"></span> @@ -219,11 +210,11 @@ </td> </tr> <tr> - <td class="option-name" i18n-content="inetServiceName"></td> + <td class="option-name">$i18n{inetServiceName}</td> <td id="inet-service-name" class="option-value"></td> </tr> <tr class="built-in-vpn-provider-only"> - <td class="option-name" i18n-content="inetServerHostname"></td> + <td class="option-name">$i18n{inetServerHostname}</td> <td> <input class="option-value" id="inet-server-hostname"></input> <span class="controlled-setting-indicator" @@ -232,15 +223,15 @@ </td> </tr> <tr> - <td class="option-name" i18n-content="inetProviderType"></td> + <td class="option-name">$i18n{inetProviderType}</td> <td id="inet-provider-type" class="option-value"></td> </tr> <tr class="third-party-vpn-provider-only"> - <td class="option-name" i18n-content="inetProviderName"></td> + <td class="option-name">$i18n{inetProviderName}</td> <td id="inet-provider-name" class="option-value"></td> </tr> <tr class="built-in-vpn-provider-only"> - <td class="option-name" i18n-content="inetUsername"></td> + <td class="option-name">$i18n{inetUsername}</td> <td id="inet-username" class="option-value"></td> </tr> </table> @@ -250,43 +241,42 @@ <section id="cellular-network-options"> <table class="option-control-table"> <tr> - <td class="option-name" i18n-content="serviceName"></td> + <td class="option-name">$i18n{serviceName}</td> <td id="service-name" class="option-value"></td> </tr> <tr> - <td class="option-name" i18n-content="networkTechnology"></td> + <td class="option-name">$i18n{networkTechnology}</td> <td id="network-technology" class="option-value"></td> </tr> <tr> - <td class="option-name" i18n-content="activationState"></td> + <td class="option-name">$i18n{activationState}</td> <td id="activation-state" class="option-value"></td> </tr> <tr> - <td class="option-name" i18n-content="roamingState"></td> + <td class="option-name">$i18n{roamingState}</td> <td id="roaming-state" class="option-value"></td> </tr> <tr> - <td class="option-name" i18n-content="restrictedConnectivity"></td> + <td class="option-name">$i18n{restrictedConnectivity}</td> <td id="cellular-restricted-connectivity" class="option-value"></td> </tr> <tr> - <td class="option-name" i18n-content="operatorName"></td> + <td class="option-name">$i18n{operatorName}</td> <td id="operator-name" class="option-value"></td> </tr> <tr> - <td class="option-name" i18n-content="operatorCode"></td> + <td class="option-name">$i18n{operatorCode}</td> <td id="operator-code" class="option-value"></td> </tr> <tr> - <td class="option-name" i18n-content="errorState"></td> + <td class="option-name">$i18n{errorState}</td> <td id="error-state" class="option-value"></td> </tr> <tr class="gsm-only apn-list-view"> - <td class="option-name" i18n-content="cellularApnLabel"></td> + <td class="option-name">$i18n{cellularApnLabel}</td> <td id="cellular-apn-label" class="option-value"> <select id="select-apn"> - <option value="-1" i18n-content="cellularApnOther"> - </option> + <option value="-1">$i18n{cellularApnOther}</option> </select> <span class="controlled-setting-indicator" managed="Cellular.APN" @@ -294,19 +284,19 @@ </td> </tr> <tr class="gsm-only apn-details-view"> - <td class="option-name" i18n-content="cellularApnLabel"></td> + <td class="option-name">$i18n{cellularApnLabel}</td> <td id="cellular-apn-label" class="option-value"> <input id="cellular-apn" type="text"> </td> </tr> <tr class="gsm-only apn-details-view"> - <td class="option-name" i18n-content="cellularApnUsername"></td> + <td class="option-name">$i18n{cellularApnUsername}</td> <td id="cellular-apn-username-label" class="option-value"> <input id="cellular-apn-username" type="text"> </td> </tr> <tr class="gsm-only apn-details-view"> - <td class="option-name" i18n-content="cellularApnPassword"></td> + <td class="option-name">$i18n{cellularApnPassword}</td> <td id="cellular-apn-password-label" class="option-value"> <input id="cellular-apn-password" type="password"> </td> @@ -314,12 +304,13 @@ <tr class="gsm-only apn-details-view"> <td class="option-name"></td> <td class="option-value"> - <button id="cellular-apn-use-default" - i18n-content="cellularApnUseDefault"></button> - <button id="cellular-apn-set" - i18n-content="cellularApnSet"></button> - <button id="cellular-apn-cancel" - i18n-content="cellularApnCancel"></button> + <button id="cellular-apn-use-default"> + $i18n{cellularApnUseDefault} + </button> + <button id="cellular-apn-set">$i18n{cellularApnSet}</button> + <button id="cellular-apn-cancel"> + $i18n{cellularApnCancel} + </button> </td> </tr> <tr> @@ -328,7 +319,7 @@ <label> <input id="auto-connect-network-cellular" type="checkbox"> <span> - <span i18n-content="inetAutoConnectNetwork"></span> + <span>$i18n{inetAutoConnectNetwork}</span> <span class="controlled-setting-indicator" managed="Cellular.AutoConnect" internet-detail-for="auto-connect-network-cellular"> @@ -346,23 +337,23 @@ <section id="cellular-device-options"> <table class="option-control-table"> <tr> - <td class="option-name" i18n-content="cellularManufacturer"></td> + <td class="option-name">$i18n{cellularManufacturer}</td> <td id="manufacturer" class="option-value"></td> </tr> <tr> - <td class="option-name" i18n-content="modelId"></td> + <td class="option-name">$i18n{modelId}</td> <td id="model-id" class="option-value"></td> </tr> <tr> - <td class="option-name" i18n-content="firmwareRevision"></td> + <td class="option-name">$i18n{firmwareRevision}</td> <td id="firmware-revision" class="option-value"></td> </tr> <tr> - <td class="option-name" i18n-content="hardwareRevision"></td> + <td class="option-name">$i18n{hardwareRevision}</td> <td id="hardware-revision" class="option-value"></td> </tr> <tr class="cdma-only"> - <td class="option-name" i18n-content="prlVersion"></td> + <td class="option-name">$i18n{prlVersion}</td> <td id="prl-version" class="option-value"></td> </tr> <tr> @@ -400,11 +391,11 @@ <section id="advanced-section"> <table class="option-control-table"> <tr> - <td class="option-name" i18n-content="connectionState"></td> + <td class="option-name">$i18n{connectionState}</td> <td id="connection-state" class="option-value"></td> </tr> <tr id="hardware-address-row"> - <td class="option-name" i18n-content="hardwareAddress"></td> + <td class="option-name">$i18n{hardwareAddress}</td> <td id="hardware-address" class="option-value"></td> </tr> </table> @@ -416,7 +407,7 @@ <input id="ip-automatic-configuration-checkbox" type="checkbox"> <span> - <span i18n-content="ipAutomaticConfiguration"></span> + <span>$i18n{ipAutomaticConfiguration}</span> <span class="controlled-setting-indicator" managed="IPAddressConfigType"></span> </span> @@ -426,23 +417,24 @@ <table id="ip-address-settings"> <tr> <td class="spacer" width="14px"></td> - <td class="option-name" i18n-content="inetAddress"></td> + <td class="option-name">$i18n{inetAddress}</td> <td><div id="ip-address"></div></td> </tr> <tr> <td class="spacer" width="14px"></td> - <td class="option-name" id="ip-netmask-label" - i18n-content="inetNetmask"></td> + <td class="option-name" id="ip-netmask-label"> + $i18n{inetNetmask} + </td> <td><div id="ip-netmask"></div></td> </tr> <tr> <td class="spacer" width="14px"></td> - <td class="option-name" i18n-content="inetGateway"></td> + <td class="option-name">$i18n{inetGateway}</td> <td><div id="ip-gateway"></div></td> </tr> <tr> <td class="spacer" width="14px"></td> - <td class="option-name" i18n-content="ipv6Address"></td> + <td class="option-name">$i18n{ipv6Address}</td> <td><div id="ipv6-address"></div></td> </tr> </table> @@ -453,7 +445,7 @@ <input id="automatic-dns-radio" type="radio" name="dnstype" value="automatic"> <span> - <span i18n-content="automaticNameServers"></span> + <span>$i18n{automaticNameServers}</span> <span class="controlled-setting-indicator" managed="NameServersConfigType"></span> </span> @@ -472,7 +464,7 @@ <label> <input id="user-dns-radio" type="radio" name="dnstype" value="user"> - <span i18n-content="userNameServers"></span> + <span>$i18n{userNameServers}</span> </label> </div> <table id="user-dns-settings"> @@ -513,7 +505,7 @@ <label> <input id="sim-card-lock-enabled" type="checkbox"> <span> - <span i18n-content="lockSimCard"></span> + <span>$i18n{lockSimCard}</span> <span class="controlled-setting-indicator" managed="Cellular.SIMLockStatus.LockEnabled" internet-detail-for="sim-card-lock-enabled"></span> @@ -523,7 +515,7 @@ </section> <section> <div id="change-pin-area"> - <button id="change-pin" i18n-content="changePinButton"></button> + <button id="change-pin">$i18n{changePinButton}</button> <span class="controlled-setting-indicator" managed="Cellular.SIMLockStatus.LockType" internet-detail-for="change-pin"></span> @@ -540,14 +532,14 @@ <label> <input id="direct-proxy" type="radio" name="proxytype" value="1" pref="cros.session.proxy.type"> - <span i18n-content="proxyDirectInternetConnection"></span> + <span>$i18n{proxyDirectInternetConnection}</span> </label> </div> <div class="radio"> <label> <input id="auto-proxy" type="radio" name="proxytype" value="3" pref="cros.session.proxy.type"> - <span i18n-content="proxyAutomatic"></span> + <span>$i18n{proxyAutomatic}</span> </label> </div> <div class="proxy-subsection" id="auto-proxy-parms"> @@ -555,7 +547,7 @@ <label> <input id="proxy-use-pac-url" type="checkbox" pref="cros.session.proxy.usepacurl"> - <span i18n-content="proxyUseConfigUrl"></span> + <span>$i18n{proxyUseConfigUrl}</span> </label> </div> <div> @@ -569,7 +561,7 @@ <label> <input id="manual-proxy" type="radio" name="proxytype" value="2" pref="cros.session.proxy.type"> - <span i18n-content="proxyManual"></span> + <span>$i18n{proxyManual}</span> </label> </div> <div class="proxy-subsection" id="manual-proxy-parms"> @@ -577,19 +569,19 @@ <label> <input id="proxy-all-protocols" type="checkbox" pref="cros.session.proxy.single"> - <span i18n-content="sameProxyProtocols"></span> + <span>$i18n{sameProxyProtocols}</span> </label> </div> <div id="single-proxy"> <table> <tr> <td> - <span i18n-content="httpProxy"></span> + <span>$i18n{httpProxy}</span> <input id="proxy-host-single-name" type="text" size="25" pref="cros.session.proxy.singlehttp" disabled> </td> <td> - <span i18n-content="proxyPort"></span> + <span>$i18n{proxyPort}</span> <input id="proxy-host-single-port" size="4" pref="cros.session.proxy.singlehttpport" disabled> </td> @@ -600,14 +592,14 @@ <table> <tr> <td> - <span i18n-content="httpProxy"></span> + <span>$i18n{httpProxy}</span> </td> <td> <input id="proxy-host-name" type="text" size="25" pref="cros.session.proxy.httpurl" disabled> </td> <td> - <span i18n-content="proxyPort"></span> + <span>$i18n{proxyPort}</span> </td> <td> <input id="proxy-host-port" size="4" @@ -616,14 +608,14 @@ </tr> <tr> <td> - <span i18n-content="secureHttpProxy"></span> + <span>$i18n{secureHttpProxy}</span> </td> <td> <input id="secure-proxy-host-name" type="text" size="25" pref="cros.session.proxy.httpsurl" disabled> </td> <td> - <span i18n-content="proxyPort"></span> + <span>$i18n{proxyPort}</span> </td> <td> <input id="secure-proxy-port" size="4" @@ -632,14 +624,14 @@ </tr> <tr> <td> - <span i18n-content="ftpProxy"></span> + <span>$i18n{ftpProxy}</span> </td> <td> <input id="ftp-proxy" type="text" size="25" pref="cros.session.proxy.ftpurl" disabled> </td> <td> - <span i18n-content="proxyPort"></span> + <span>$i18n{proxyPort}</span> </td> <td> <input id="ftp-proxy-port" size="4" @@ -648,14 +640,14 @@ </tr> <tr> <td> - <span i18n-content="socksHost"></span> + <span>$i18n{socksHost}</span> </td> <td> <input id="socks-host" type="text" size="25" pref="cros.session.proxy.socks" disabled> </td> <td> - <span i18n-content="proxyPort"></span> + <span>$i18n{proxyPort}</span> </td> <td> <input id="socks-port" size="4" @@ -666,16 +658,16 @@ </div> <div id="advanced-config"> <div class="option vbox flex"> - <div i18n-content="proxyBypass"></div> + <div>$i18n{proxyBypass}</div> <list id="ignored-host-list"></list> <input id="new-host" type="url" size="30"> - <button id="add-host" i18n-content="addHost"></button> - <button id="remove-host" i18n-content="removeHost"></button> + <button id="add-host">$i18n{addHost}</button> + <button id="remove-host">$i18n{removeHost}</button> </div> </div> </div> <div class="proxy-subsection" id="web-proxy-auto-discovery"> - <span i18n-content="webProxyAutoDiscoveryUrl"></span> + <span>$i18n{webProxyAutoDiscoveryUrl}</span> <input id="web-proxy-auto-discovery-url" type="url" disabled> </div> </section> @@ -684,18 +676,14 @@ <div class="action-area"> <div class="button-strip"> <!-- TODO(dbeam): Clarify style guide regarding tag wrap. --> - <button id="details-internet-dismiss" class="default-button" - i18n-content="detailsInternetDismiss"> + <button id="details-internet-dismiss" class="default-button"> + $i18n{detailsInternetDismiss} </button> - <button id="details-internet-login" i18n-content="connectButton"> - </button> - <button id="details-internet-disconnect" i18n-content="disconnectButton"> - </button> - <button id="details-internet-configure" i18n-content="configureButton"> - </button> - <button id="activate-details" i18n-content="activateButton"></button> - <button id="view-account-details" i18n-content="viewAccountButton"> - </button> + <button id="details-internet-login">$i18n{connectButton}</button> + <button id="details-internet-disconnect">$i18n{disconnectButton}</button> + <button id="details-internet-configure">$i18n{configureButton}</button> + <button id="activate-details">$i18n{activateButton}</button> + <button id="view-account-details">$i18n{viewAccountButton}</button> </div> </div> </div>
diff --git a/chrome/browser/resources/options/chromeos/keyboard_overlay.html b/chrome/browser/resources/options/chromeos/keyboard_overlay.html index 9e316ebc..b5a33c1 100644 --- a/chrome/browser/resources/options/chromeos/keyboard_overlay.html +++ b/chrome/browser/resources/options/chromeos/keyboard_overlay.html
@@ -1,11 +1,11 @@ <div id="keyboard-overlay" class="page" hidden> <div class="close-button"></div> - <h1 i18n-content="keyboardOverlay"></h1> + <h1>$i18n{keyboardOverlay}</h1> <div class="content-area"> <table class="option-control-table"> <tr> - <td class="option-name" id="remap-search-key-to-label" - i18n-content="remapSearchKeyToContent"> + <td class="option-name" id="remap-search-key-to-label"> + $i18n{remapSearchKeyToContent} </td> <td class="option-value"> <select class="control" @@ -17,8 +17,8 @@ </td> </tr> <tr> - <td class="option-name" id="remap-control-key-to-label" - i18n-content="remapControlKeyToContent"> + <td class="option-name" id="remap-control-key-to-label"> + $i18n{remapControlKeyToContent} </td> <td class="option-value"> <select class="control" @@ -30,8 +30,8 @@ </td> </tr> <tr> - <td class="option-name" id="remap-alt-key-to-label" - i18n-content="remapAltKeyToContent"> + <td class="option-name" id="remap-alt-key-to-label"> + $i18n{remapAltKeyToContent} </td> <td class="option-value"> <select class="control" data-type="number" @@ -44,8 +44,8 @@ <!-- The caps lock section is hidden by default. This is only visible when --has-chromeos-keyboard flag is not passed. --> <tr id="caps-lock-remapping-section" hidden> - <td class="option-name" id="remap-caps-lock-key-to-label" - i18n-content="remapCapsLockKeyToContent"> + <td class="option-name" id="remap-caps-lock-key-to-label"> + $i18n{remapCapsLockKeyToContent} </td> <td class="option-value"> <select class="control" @@ -60,8 +60,8 @@ <!-- The diamond key section is hidden by default. This is only visible when --has-chromeos-diamond-key flag is passed. --> <tr id="diamond-key-remapping-section" hidden> - <td class="option-name" id="remap-diamond-key-to-label" - i18n-content="remapDiamondKeyToContent"> + <td class="option-name" id="remap-diamond-key-to-label"> + $i18n{remapDiamondKeyToContent} </td> <td class="option-value"> <select class="control" @@ -74,8 +74,8 @@ </td> </tr> <tr> - <td class="option-name" id="remap-backspace-key-to-label" - i18n-content="remapBackspaceKeyToContent"> + <td class="option-name" id="remap-backspace-key-to-label"> + $i18n{remapBackspaceKeyToContent} </td> <td class="option-value"> <select class="control" data-type="number" @@ -87,8 +87,8 @@ </td> </tr> <tr> - <td class="option-name" id="remap-escape-key-to-label" - i18n-content="remapEscapeKeyToContent"> + <td class="option-name" id="remap-escape-key-to-label"> + $i18n{remapEscapeKeyToContent} </td> <td class="option-value"> <select class="control" data-type="number" @@ -106,14 +106,15 @@ pref="settings.language.send_function_keys" aria-describedby="send-function-keys-description" dialog-pref> <span> - <span i18n-content="sendFunctionKeys"></span> + <span>$i18n{sendFunctionKeys}</span> <span class="bubble-button controlled-setting-indicator" pref="settings.language.send_function_keys"></span> </span> </label> </div> - <span id="send-function-keys-description" - i18n-content="sendFunctionKeysDescription"></span> + <span id="send-function-keys-description"> + $i18n{sendFunctionKeysDescription} + </span> </div> <div class="settings-row"> <div class="checkbox"> @@ -121,39 +122,41 @@ <input id="enable-auto-repeat" type="checkbox" pref="settings.language.xkb_auto_repeat_enabled_r2" metric="Options_KeyboardAutoRepeat" dialog-pref> - <span i18n-content="enableAutoRepeat"></span> + <span>$i18n{enableAutoRepeat}</span> </label> </div> <div id="auto-repeat-settings-section"> <div class="row"> - <span class="option-name" i18n-content="autoRepeatDelay"></span> - <span i18n-content="autoRepeatDelayLong"></span> + <span class="option-name">$i18n{autoRepeatDelay}</span> + <span>$i18n{autoRepeatDelayLong}</span> <input id="auto-repeat-delay-range" type="range" class="touch-slider" metric="Options_KeyboardAutoRepeat_Delay" pref="settings.language.xkb_auto_repeat_delay_r2" dialog-pref> - <span i18n-content="autoRepeatDelayShort"></span> + <span>$i18n{autoRepeatDelayShort}</span> </div> <div class="row"> - <span class="option-name" i18n-content="autoRepeatRate"></span> - <span i18n-content="autoRepeatRateSlow"></span> + <span class="option-name">$i18n{autoRepeatRate}</span> + <span>$i18n{autoRepeatRateSlow}</span> <input id="auto-repeat-interval-range" type="range" class="touch-slider" pref="settings.language.xkb_auto_repeat_interval_r2" metric="Options_KeyboardAutoRepeat_Interval" dialog-pref> - <span i18n-content="autoRepeatRateFast"></span> + <span>$i18n{autoRepeatRateFast}</span> </div> </div> </div> - <a is="action-link" id="keyboard-shortcuts" class="settings-row" - i18n-content="showKeyboardShortcuts"></a> - <a is="action-link" id="languages-and-input-settings" class="settings-row" - i18n-content="changeLanguageAndInputSettings"></a> + <a is="action-link" id="keyboard-shortcuts" class="settings-row"> + $i18n{showKeyboardShortcuts} + </a> + <a is="action-link" id="languages-and-input-settings" class="settings-row"> + $i18n{changeLanguageAndInputSettings} + </a> </div> <div class="action-area"> <div class="button-strip"> - <button id="keyboard-cancel" type="reset" i18n-content="cancel"></button> - <button id="keyboard-confirm" class="default-button" type="submit" - i18n-content="ok"> + <button id="keyboard-cancel" type="reset">$i18n{cancel}</button> + <button id="keyboard-confirm" class="default-button" type="submit"> + $i18n{ok} </button> </div> </div>
diff --git a/chrome/browser/resources/options/chromeos/pointer_overlay.html b/chrome/browser/resources/options/chromeos/pointer_overlay.html index 562522e..1462249 100644 --- a/chrome/browser/resources/options/chromeos/pointer_overlay.html +++ b/chrome/browser/resources/options/chromeos/pointer_overlay.html
@@ -2,12 +2,12 @@ <div class="close-button"></div> <div class="content-area"> <section id="pointer-section-touchpad" hidden> - <h3 i18n-content="pointerOverlaySectionTitleTouchpad"></h3> + <h3>$i18n{pointerOverlaySectionTitleTouchpad}</h3> <div class="checkbox"> <label> <input type="checkbox" metric="Options_TouchpadTapToClick" pref="settings.touchpad.enable_tap_to_click" dialog-pref> - <span i18n-content="enableTapToClick"></span> + <span>$i18n{enableTapToClick}</span> </label> </div> <div class="radio" id="touchpad-scroll-direction"> @@ -15,7 +15,7 @@ <input type="radio" name="touchpad-scroll-direction" value="false" metric="Options_TouchpadNaturalScroll" pref="settings.touchpad.natural_scroll" dialog-pref> - <span i18n-content="traditionalScroll"></span> + <span>$i18n{traditionalScroll}</span> </label> </div> <div class="radio"> @@ -23,27 +23,26 @@ <input type="radio" name="touchpad-scroll-direction" value="true" metric="Options_TouchpadNaturalScroll" pref="settings.touchpad.natural_scroll" dialog-pref> - <span i18n-values=".innerHTML:naturalScroll"></span> + <span>$i18nRaw{naturalScroll}</span> </label> </div> </section> <section id="pointer-section-mouse" hidden> - <h3 i18n-content="pointerOverlaySectionTitleMouse"></h3> + <h3>$i18n{pointerOverlaySectionTitleMouse}</h3> <div class="checkbox"> <label> <input type="checkbox" metric="Options_MousePrimaryRight" pref="settings.mouse.primary_right" dialog-pref> - <span i18n-content="primaryMouseRight"></span> + <span>$i18n{primaryMouseRight}</span> </label> </div> </section> </div> <div class="action-area"> <div class="button-strip"> - <button id="pointer-overlay-cancel" type="reset" i18n-content="cancel"> - </button> - <button id="pointer-overlay-confirm" class="default-button" type="submit" - i18n-content="ok"> + <button id="pointer-overlay-cancel" type="reset">$i18n{cancel}</button> + <button id="pointer-overlay-confirm" class="default-button" type="submit"> + $i18n{ok} </button> </div> </div>
diff --git a/chrome/browser/resources/options/chromeos/power_overlay.html b/chrome/browser/resources/options/chromeos/power_overlay.html index d6c628a..f4b637c 100644 --- a/chrome/browser/resources/options/chromeos/power_overlay.html +++ b/chrome/browser/resources/options/chromeos/power_overlay.html
@@ -1,18 +1,16 @@ <div id="power-overlay" class="page" hidden> <div class="close-button"></div> - <h1 i18n-content="powerOverlay"></h1> + <h1>$i18n{powerOverlay}</h1> <div class="content-area"> <table> <tr> - <td class="option-name" i18n-content="batteryStatusLabel"> - </td> + <td class="option-name">$i18n{batteryStatusLabel}</td> <td id="battery-status-value" class="option-value"> </td> </tr> <tr id="power-sources" hidden> <td class="option-name"> - <label id="power-source-label" i18n-content="powerSourceLabel"> - </label> + <label id="power-source-label">$i18n{powerSourceLabel}</label> </td> <td class="option-value"> <select id="power-source-dropdown" @@ -20,8 +18,7 @@ </td> </tr> <tr id="power-source-charger" hidden> - <td class="option-name" i18n-content="powerSourceLabel"> - </td> + <td class="option-name">$i18n{powerSourceLabel}</td> <td id="power-source-charger-type" class="option-value"> </td> </tr> @@ -29,8 +26,8 @@ </div> <div class="action-area"> <div class="button-strip"> - <button id="power-confirm" class="default-button" type="submit" - i18n-content="done"> + <button id="power-confirm" class="default-button" type="submit"> + $i18n{done} </button> </div> </div>
diff --git a/chrome/browser/resources/options/chromeos/preferred_networks.html b/chrome/browser/resources/options/chromeos/preferred_networks.html index 47b0d120..75b373e 100644 --- a/chrome/browser/resources/options/chromeos/preferred_networks.html +++ b/chrome/browser/resources/options/chromeos/preferred_networks.html
@@ -1,7 +1,6 @@ <div id="preferredNetworksPage" class="page" hidden> <div class="close-button"></div> - <h1 id="preferred-networks-page-title" - i18n-content="preferredNetworksPage"></h1> + <h1 id="preferred-networks-page-title" >$i18n{preferredNetworksPage}</h1> <div class="content-area"> <div class="settings-list"> <list id="remembered-network-list"></list> @@ -9,8 +8,8 @@ </div> <div class="action-area"> <div class="button-strip"> - <button id="preferred-networks-confirm" class="default-button" - i18n-content="done"> + <button id="preferred-networks-confirm" class="default-button"> + $i18n{done} </button> </div> </div>
diff --git a/chrome/browser/resources/options/chromeos/quick_unlock_configure_overlay.html b/chrome/browser/resources/options/chromeos/quick_unlock_configure_overlay.html index 07904cc..f0c54b1 100644 --- a/chrome/browser/resources/options/chromeos/quick_unlock_configure_overlay.html +++ b/chrome/browser/resources/options/chromeos/quick_unlock_configure_overlay.html
@@ -1,6 +1,6 @@ <div id="quick-unlock-configure-overlay" class="page" hidden> <div class="close-button"></div> - <h1 i18n-content="lockScreenTitle"></h1> + <h1>$i18n{lockScreenTitle}</h1> <settings-lock-screen prefs="{{prefs}}" tabindex=0> </settings-lock-screen>
diff --git a/chrome/browser/resources/options/chromeos/storage_clear_drive_cache_overlay.html b/chrome/browser/resources/options/chromeos/storage_clear_drive_cache_overlay.html index adc2fa5..3ef1c80 100644 --- a/chrome/browser/resources/options/chromeos/storage_clear_drive_cache_overlay.html +++ b/chrome/browser/resources/options/chromeos/storage_clear_drive_cache_overlay.html
@@ -1,14 +1,13 @@ <div id="clear-drive-cache-overlay-page" class="page" role="dialog" hidden> <div class="close-button"></div> - <h1 i18n-content="storageClearDriveCacheDialogTitle"></h1> + <h1>$i18n{storageClearDriveCacheDialogTitle}</h1> <div class="content-area"> - <div i18n-content="storageClearDriveCacheDescription"></div> + <div>$i18n{storageClearDriveCacheDescription}</div> </div> <div class="action-area button-strip"> - <button id="clear-drive-cache-overlay-cancel-button" i18n-content="cancel"> - </button> - <button id="clear-drive-cache-overlay-delete-button" class="default-button" - i18n-content="storageDeleteAllButtonTitle"> + <button id="clear-drive-cache-overlay-cancel-button">$i18n{cancel}</button> + <button id="clear-drive-cache-overlay-delete-button" class="default-button"> + $i18n{storageDeleteAllButtonTitle} </button> </div> </div>
diff --git a/chrome/browser/resources/options/chromeos/storage_manager.html b/chrome/browser/resources/options/chromeos/storage_manager.html index 8ca8fa5..faca73db 100644 --- a/chrome/browser/resources/options/chromeos/storage_manager.html +++ b/chrome/browser/resources/options/chromeos/storage_manager.html
@@ -1,31 +1,32 @@ <div id="storageManagerPage" class="page" hidden> <div class="close-button"></div> - <h1 i18n-content="storageManagerPage"></h1> + <h1>$i18n{storageManagerPage}</h1> <div id="storage-manager-message-low-space" class="storage-manager-message-area"> <div class="storage-manager-message-title"> <img src="space_low.svg"></img> - <span i18n-content="storageLowMessageTitle"></span> + <span>$i18n{storageLowMessageTitle}</span> </div> - <p i18n-content="storageLowMessageLine1"></p> - <p i18n-content="storageLowMessageLine2"></p> + <p>$i18n{storageLowMessageLine1}</p> + <p>$i18n{storageLowMessageLine2}</p> </div> <div id="storage-manager-message-critically-low-space" class="storage-manager-message-area"> <div class="storage-manager-message-title"> <img src="space_critically_low.svg"></img> - <span i18n-content="storageCriticallyLowMessageTitle"></span> + <span>$i18n{storageCriticallyLowMessageTitle}</span> </div> - <p i18n-content="storageCriticallyLowMessageLine1"></p> - <p i18n-content="storageCriticallyLowMessageLine2"></p> + <p>$i18n{storageCriticallyLowMessageLine1}</p> + <p>$i18n{storageCriticallyLowMessageLine2}</p> </div> <div class="content-area"> <div id="storage-manager-section-capacity" class="storage-manager-section"> <div class="storage-manager-item"> - <span i18n-content="storageItemLabelCapacity" - class="storage-manager-item-label"></span> + <span class="storage-manager-item-label"> + $i18n{storageItemLabelCapacity} + </span> <span id="storage-manager-size-capacity" class="storage-manager-item-size"></span> </div> @@ -33,58 +34,64 @@ </div> <div id="storage-manager-section-in-use" class="storage-manager-section"> <div class="storage-manager-item"> - <span i18n-content="storageItemLabelInUse" - class="storage-manager-item-label"></span> + <span class="storage-manager-item-label"> + $i18n{storageItemLabelInUse} + </span> <span id="storage-manager-size-in-use" class="storage-manager-item-size"></span> </div> <div class="storage-manager-subitem"> - <a is="action-link" - id="storage-manager-label-downloads" - i18n-content="storageSubitemLabelDownloads"></a> + <a is="action-link" id="storage-manager-label-downloads"> + $i18n{storageSubitemLabelDownloads} + </a> <span id="storage-manager-size-downloads" - class="storage-manager-item-size" - i18n-content="storageSizeCalculating"></span> + class="storage-manager-item-size"> + $i18n{storageSizeCalculating} + </span> </div> <div id="storage-manager-item-drive-cache" class="storage-manager-subitem" hidden> - <a is="action-link" - id="storage-manager-label-drive-cache" - i18n-content="storageSubitemLabelDriveCache"></a> + <a is="action-link" id="storage-manager-label-drive-cache"> + $i18n{storageSubitemLabelDriveCache} + </a> <span id="storage-manager-size-drive-cache" - class="storage-manager-item-size" - i18n-content="storageSizeCalculating"></span> + class="storage-manager-item-size"> + $i18n{storageSizeCalculating} + </span> </div> <div class="storage-manager-subitem"> - <a is="action-link" - id="storage-manager-label-browsing-data" - i18n-content="storageSubitemLabelBrowsingData"></a> + <a is="action-link" id="storage-manager-label-browsing-data"> + $i18n{storageSubitemLabelBrowsingData} + </a> <span id="storage-manager-size-browsing-data" - class="storage-manager-item-size" - i18n-content="storageSizeCalculating"></span> + class="storage-manager-item-size"> + $i18n{storageSizeCalculating} + </span> </div> <div id="storage-manager-item-arc" class="storage-manager-subitem" hidden> - <a is="action-link" - id="storage-manager-label-arc" - i18n-content="storageSubitemLabelArc"></a> - <span id="storage-manager-size-arc" - class="storage-manager-item-size" - i18n-content="storageSizeCalculating"></span> + <a is="action-link" id="storage-manager-label-arc"> + $i18n{storageSubitemLabelArc} + </a> + <span id="storage-manager-size-arc" class="storage-manager-item-size"> + $i18n{storageSizeCalculating} + </span> </div> <div class="storage-manager-subitem"> - <a is="action-link" - id="storage-manager-label-other-users" - i18n-content="storageSubitemLabelOtherUsers"></a> + <a is="action-link" id="storage-manager-label-other-users"> + $i18n{storageSubitemLabelOtherUsers} + </a> <span id="storage-manager-size-other-users" - class="storage-manager-item-size" - i18n-content="storageSizeCalculating"></span> + class="storage-manager-item-size"> + $i18n{storageSizeCalculating} + </span> </div> </div> <div id="storage-manager-section-available" class="storage-manager-section"> <div class="storage-manager-item"> - <span i18n-content="storageItemLabelAvailable" - class="storage-manager-item-label"></span> + <span class="storage-manager-item-label"> + $i18n{storageItemLabelAvailable} + </span> <span id="storage-manager-size-available" class="storage-manager-item-size"></span> </div> @@ -93,9 +100,7 @@ <div class="action-area"> <div class="button-strip"> - <button id="storage-confirm" class="default-button" - i18n-content="done"> - </button> + <button id="storage-confirm" class="default-button">$i18n{done}</button> </div> </div> </div>
diff --git a/chrome/browser/resources/options/chromeos/stylus_overlay.html b/chrome/browser/resources/options/chromeos/stylus_overlay.html index bc955bbe..af93cc6 100644 --- a/chrome/browser/resources/options/chromeos/stylus_overlay.html +++ b/chrome/browser/resources/options/chromeos/stylus_overlay.html
@@ -1,6 +1,6 @@ <div id="stylus-overlay" class="page" hidden> <div class="close-button"></div> - <h1 i18n-content="stylusOverlay"></h1> + <h1>$i18n{stylusOverlay}</h1> <div class="content-area"> <div class="option-control-table"> <div class="option-name"> @@ -8,7 +8,7 @@ <label> <input pref="settings.enable_stylus_tools" type="checkbox" dialog-pref> - <span i18n-content="stylusEnableStylusTools"></span> + <span>$i18n{stylusEnableStylusTools}</span> </label> </div> <div class="checkbox controlled-setting-with-label"> @@ -16,15 +16,14 @@ <input id="launch-palette-on-eject-input" pref="settings.launch_palette_on_eject_event" type="checkbox" dialog-pref> - <span i18n-content="stylusAutoOpenStylusTools"></span> + <span>$i18n{stylusAutoOpenStylusTools}</span> </label> </div> </div> <div class="settings-row"> <div class="controlled-setting-with-label"> <label> - <span class="option-name" - i18n-content="stylusNoteTakingApp"></span> + <span class="option-name">$i18n{stylusNoteTakingApp}</span> <select id="stylus-note-taking-app-select" class="option-value"> </select> </label> @@ -32,16 +31,17 @@ </div> </div> <div class="settings-row"> - <a is="action-link" i18n-content="stylusFindMoreApps" - id='stylus-find-more-link'></a> + <a is="action-link" id='stylus-find-more-link'> + $i18n{stylusFindMoreApps} + </a> </div> </div> <div class="action-area"> <div class="button-strip"> - <button id="stylus-cancel" type="reset" i18n-content="cancel"></button> - <button id="stylus-confirm" class="default-button" type="submit" - i18n-content="ok"> + <button id="stylus-cancel" type="reset">$i18n{cancel}</button> + <button id="stylus-confirm" class="default-button" type="submit"> + $i18n{ok} </button> </div> </div>
diff --git a/chrome/browser/resources/options/chromeos/third_party_ime_confirm_overlay.html b/chrome/browser/resources/options/chromeos/third_party_ime_confirm_overlay.html index 6308443..4664e52 100644 --- a/chrome/browser/resources/options/chromeos/third_party_ime_confirm_overlay.html +++ b/chrome/browser/resources/options/chromeos/third_party_ime_confirm_overlay.html
@@ -1,19 +1,19 @@ <div id="third-party-ime-confirm-overlay" class="page" hidden> <div class="close-button"></div> - <h1 i18n-content="thirdPartyImeConfirmOverlay"></h1> + <h1>$i18n{thirdPartyImeConfirmOverlay}</h1> <div class="content-area"> - <span id="third-party-ime-confirm-text" - i18n-content="thirdPartyImeConfirmMessage"> + <span id="third-party-ime-confirm-text"> + $i18n{thirdPartyImeConfirmMessage} </span> </div> <div class="action-area"> <div class="action-area-right"> <div class="button-strip"> - <button id="third-party-ime-confirm-cancel" - i18n-content="thirdPartyImeConfirmDisable"> + <button id="third-party-ime-confirm-cancel"> + $i18n{thirdPartyImeConfirmDisable} </button> - <button id="third-party-ime-confirm-ok" class="default-button" - i18n-content="thirdPartyImeConfirmEnable"> + <button id="third-party-ime-confirm-ok" class="default-button"> + $i18n{thirdPartyImeConfirmEnable} </button> </div> </div>
diff --git a/chrome/browser/resources/options/clear_browser_data_history_notice_overlay.html b/chrome/browser/resources/options/clear_browser_data_history_notice_overlay.html index 5de4a32..f77e4b5 100644 --- a/chrome/browser/resources/options/clear_browser_data_history_notice_overlay.html +++ b/chrome/browser/resources/options/clear_browser_data_history_notice_overlay.html
@@ -1,12 +1,12 @@ <div id="clear-browser-data-history-notice" class="page" hidden> - <h1 i18n-content="clearBrowserDataHistoryNoticeTitle"></h1> + <h1>$i18n{clearBrowserDataHistoryNoticeTitle}</h1> <div class="content-area"> - <p i18n-values=".innerHTML:clearBrowserDataHistoryNotice"></p> + <p>$i18nRaw{clearBrowserDataHistoryNotice}</p> </div> <div class="action-area"> <div class="button-strip"> - <button id="clear-browser-data-history-notice-ok" class="default-button" - i18n-content="clearBrowserDataHistoryNoticeOk"> + <button id="clear-browser-data-history-notice-ok" class="default-button"> + $i18n{clearBrowserDataHistoryNoticeOk} </button> </div> </div>
diff --git a/chrome/browser/resources/options/clear_browser_data_overlay.html b/chrome/browser/resources/options/clear_browser_data_overlay.html index a36ef906..ec5faef 100644 --- a/chrome/browser/resources/options/clear_browser_data_overlay.html +++ b/chrome/browser/resources/options/clear_browser_data_overlay.html
@@ -1,11 +1,11 @@ <div id="clear-browser-data-overlay" class="page not-resizable" hidden> <div class="close-button"></div> - <h1 i18n-content="clearBrowserDataOverlay"></h1> + <h1>$i18n{clearBrowserDataOverlay}</h1> <!-- NOTE: Make sure there's not whitespace between <div></div> for #clear-browser-data-info-banner as it's styled with :empty. --> <div id="clear-browser-data-info-banner"></div> <div id="cbd-content-area" class="content-area"> - <span i18n-content="clearBrowserDataLabel"></span> + <span>$i18n{clearBrowserDataLabel}</span> <select id="clear-browser-data-time-period" i18n-options="clearBrowserDataTimeList" pref="browser.clear_data.time_period" @@ -18,7 +18,7 @@ pref="browser.clear_data.browsing_history" type="checkbox" aria-controls="delete-browsing-history-counter"> <span> - <span i18n-content="deleteBrowsingHistoryCheckbox"></span> + <span>$i18n{deleteBrowsingHistoryCheckbox}</span> <span class="controlled-setting-indicator" pref="history.deleting_enabled"> </span> @@ -31,7 +31,7 @@ <label> <input id="delete-download-history-checkbox" pref="browser.clear_data.download_history" type="checkbox"> - <span i18n-content="deleteDownloadHistoryCheckbox"></span> + <span>$i18n{deleteDownloadHistoryCheckbox}</span> <span class="controlled-setting-indicator" pref="history.deleting_enabled"> </span> @@ -41,10 +41,12 @@ <label> <input id="delete-cookies-checkbox" pref="browser.clear_data.cookies" type="checkbox"> - <span i18n-content="deleteCookiesFlashCheckbox" - class="clear-plugin-lso-data-enabled"></span> - <span i18n-content="deleteCookiesCheckbox" - class="clear-plugin-lso-data-disabled"></span> + <span class="clear-plugin-lso-data-enabled"> + $i18n{deleteCookiesFlashCheckbox} + </span> + <span class="clear-plugin-lso-data-disabled"> + $i18n{deleteCookiesCheckbox} + </span> </label> </div> <div id="delete-cache-container" class="checkbox"> @@ -53,7 +55,7 @@ pref="browser.clear_data.cache" type="checkbox" aria-controls="delete-cache-counter"> <span> - <span i18n-content="deleteCacheCheckbox"></span> + <span>$i18n{deleteCacheCheckbox}</span> <span class="clear-browser-data-counter" role="note" aria-live="polite" id="delete-cache-counter"></span> </span> @@ -65,7 +67,7 @@ pref="browser.clear_data.passwords" type="checkbox" aria-controls="delete-passwords-counter"> <span> - <span i18n-content="deletePasswordsCheckbox"></span> + <span>$i18n{deletePasswordsCheckbox}</span> <span class="clear-browser-data-counter" role="note" aria-live="polite" id="delete-passwords-counter"></span> </span> @@ -77,7 +79,7 @@ pref="browser.clear_data.form_data" type="checkbox" aria-controls="delete-form-data-counter"> <span> - <span i18n-content="deleteFormDataCheckbox"></span> + <span>$i18n{deleteFormDataCheckbox}</span> <span class="clear-browser-data-counter" role="note" aria-live="polite" id="delete-form-data-counter"></span> </span> @@ -87,7 +89,7 @@ <label> <input id="delete-hosted-apps-data-checkbox" pref="browser.clear_data.hosted_apps_data" type="checkbox"> - <span i18n-content="deleteHostedAppsDataCheckbox"></span> + <span>$i18n{deleteHostedAppsDataCheckbox}</span> </label> </div> <div id="delete-media-licenses-container" class="checkbox"> @@ -96,7 +98,7 @@ pref="browser.clear_data.media_licenses" type="checkbox" aria-controls="delete-media-licenses-counter"> <span> - <span i18n-content="deleteMediaLicensesCheckbox"></span> + <span>$i18n{deleteMediaLicensesCheckbox}</span> <span class="clear-browser-data-counter" role="note" aria-live="polite" id="delete-media-licenses-counter"></span> </span> @@ -104,34 +106,33 @@ </div> </div> <div id="flash-storage-settings" class="flash-plugin-area"> - <a target="_blank" i18n-content="flashStorageSettings" - i18n-values="href:flashStorageUrl"></a> + <a target="_blank" + href="$i18nRaw{flashStorageUrl}">$i18n{flashStorageSettings}</a> </div> </div> <div class="action-area"> <div class="hbox stretch"> - <a id="clear-browser-data-old-learn-more-link" hidden - target="_blank" i18n-content="learnMore" - i18n-values="href:clearBrowsingDataLearnMoreUrl"></a> + <a id="clear-browser-data-old-learn-more-link" hidden target="_blank" + href="$i18nRaw{clearBrowsingDataLearnMoreUrl}">$i18n{learnMore}</a> </div> <div class="action-area-right"> <div id="cbd-throbber" class="throbber"></div> <div class="button-strip"> - <button id="clear-browser-data-dismiss" i18n-content="cancel"></button> - <button id="clear-browser-data-commit" class="default-button" - i18n-content="clearBrowserDataCommit"> + <button id="clear-browser-data-dismiss">$i18n{cancel}</button> + <button id="clear-browser-data-commit" class="default-button"> + $i18n{clearBrowserDataCommit} </button> </div> </div> </div> <div id="some-stuff-remains-footer" class="gray-bottom-bar"> - <p id="clear-browser-data-history-footer" - i18n-values=".innerHTML:clearBrowserDataHistoryFooter" hidden></p> + <p id="clear-browser-data-history-footer" hidden> + $i18nRaw{clearBrowserDataHistoryFooter} + </p> <p id="clear-browser-data-general-footer"> <span><!--This is filled by JavaScript--></span> - <a id="clear-browser-data-footer-learn-more-link" hidden - target="_blank" i18n-content="learnMore" - i18n-values="href:clearBrowsingDataLearnMoreUrl"></a> + <a id="clear-browser-data-footer-learn-more-link" hidden target="_blank" + href="$i18nRaw{clearBrowsingDataLearnMoreUrl}">$i18n{learnMore}</a> </p> </div> </div>
diff --git a/chrome/browser/resources/options/content_settings.html b/chrome/browser/resources/options/content_settings.html index c66fc23e..db50994 100644 --- a/chrome/browser/resources/options/content_settings.html +++ b/chrome/browser/resources/options/content_settings.html
@@ -1,16 +1,16 @@ <div id="content-settings-page" class="page" hidden> <div class="close-button"></div> - <h1 i18n-content="contentSettingsPage"></h1> + <h1>$i18n{contentSettingsPage}</h1> <div class="content-area"> <!-- Cookie filter tab contents --> <section> - <h3 i18n-content="cookiesTabLabel"></h3> + <h3>$i18n{cookiesTabLabel}</h3> <div> <div class="radio controlled-setting-with-label"> <label> <input type="radio" name="cookies" value="allow"> <span> - <span i18n-content="cookiesAllow"></span> + <span>$i18n{cookiesAllow}</span> <span class="controlled-setting-indicator" content-setting="cookies" value="allow"></span> </span> @@ -20,7 +20,7 @@ <label> <input type="radio" name="cookies" value="session_only"> <span> - <span i18n-content="cookiesSessionOnly"></span> + <span>$i18n{cookiesSessionOnly}</span> <span class="controlled-setting-indicator" content-setting="cookies" value="session_only"></span> </span> @@ -30,7 +30,7 @@ <label> <input type="radio" name="cookies" value="block"> <span> - <span i18n-content="cookiesBlock"></span> + <span>$i18n{cookiesBlock}</span> <span class="controlled-setting-indicator" content-setting="cookies" value="block"></span> </span> @@ -40,28 +40,28 @@ <label> <input pref="profile.block_third_party_cookies" type="checkbox"> <span> - <span i18n-content="cookiesBlock3rdParty"></span> + <span>$i18n{cookiesBlock3rdParty}</span> <span class="controlled-setting-indicator" pref="profile.block_third_party_cookies"></span> </label> </div> <div class="settings-row"> - <button class="exceptions-list-button" contentType="cookies" - i18n-content="manageExceptions"></button> - <button id="show-cookies-button" - i18n-content="cookiesShowCookies"></button> + <button class="exceptions-list-button" contentType="cookies"> + $i18n{manageExceptions} + </button> + <button id="show-cookies-button">$i18n{cookiesShowCookies}</button> </div> </div> </section> <!-- Image filter --> <section> - <h3 i18n-content="imagesTabLabel"></h3> + <h3>$i18n{imagesTabLabel}</h3> <div> <div class="radio controlled-setting-with-label"> <label> <input type="radio" name="images" value="allow"> <span> - <span i18n-content="imagesAllow"></span> + <span>$i18n{imagesAllow}</span> <span class="controlled-setting-indicator" content-setting="images" value="allow"></span> </span> @@ -71,27 +71,28 @@ <label> <input type="radio" name="images" value="block"> <span> - <span i18n-content="imagesBlock"></span> + <span>$i18n{imagesBlock}</span> <span class="controlled-setting-indicator" content-setting="images" value="block"></span> </span> </label> </div> <div class="settings-row"> - <button class="exceptions-list-button" contentType="images" - i18n-content="manageExceptions"></button> + <button class="exceptions-list-button" contentType="images"> + $i18n{manageExceptions} + </button> </div> </div> </section> <!-- JavaScript filter --> <section> - <h3 i18n-content="javascriptTabLabel"></h3> + <h3>$i18n{javascriptTabLabel}</h3> <div> <div class="radio controlled-setting-with-label"> <label> <input type="radio" name="javascript" value="allow"> <span> - <span i18n-content="javascriptAllow"></span> + <span>$i18n{javascriptAllow}</span> <span class="controlled-setting-indicator" content-setting="javascript" value="allow"></span> </span> @@ -101,52 +102,54 @@ <label> <input type="radio" name="javascript" value="block"> <span> - <span i18n-content="javascriptBlock"></span> + <span>$i18n{javascriptBlock}</span> <span class="controlled-setting-indicator" content-setting="javascript" value="block"></span> </span> </label> </div> <div class="settings-row"> - <button class="exceptions-list-button" contentType="javascript" - i18n-content="manageExceptions"></button> + <button class="exceptions-list-button" contentType="javascript"> + $i18n{manageExceptions} + </button> </div> </div> </section> <!-- Handlers settings --> <section id="handlers-section"> - <h3 i18n-content="handlersTabLabel"></h3> + <h3>$i18n{handlersTabLabel}</h3> <div> <div class="radio"> <label> <input type="radio" name="handlers" value="allow" class="handler-radio"> - <span i18n-content="handlersAllow"></span> + <span>$i18n{handlersAllow}</span> </label> </div> <div class="radio"> <label> <input type="radio" name="handlers" value="block" class="handler-radio"> - <span i18n-content="handlersBlock"></span> + <span>$i18n{handlersBlock}</span> </label> </div> <div class="settings-row"> - <button id="manage-handlers-button" contentType="handlers" - i18n-content="manageHandlers"></button> + <button id="manage-handlers-button" contentType="handlers"> + $i18n{manageHandlers} + </button> </div> </div> </section> <!-- Plugins filter --> <section> - <h3 i18n-content="pluginsTabLabel"></h3> + <h3>$i18n{pluginsTabLabel}</h3> <div> <div class="radio controlled-setting-with-label"> <label> <input id="plugins-allow-radio" type="radio" name="plugins" value="allow"> <span> - <span i18n-content="pluginsAllow"></span> + <span>$i18n{pluginsAllow}</span> <span class="controlled-setting-indicator" content-setting="plugins" value="allow"></span> </span> @@ -156,9 +159,10 @@ <label> <input type="radio" name="plugins" value="detect_important_content"> <span> - <span i18n-content="pluginsDetectImportantContent"></span> + <span>$i18n{pluginsDetectImportantContent}</span> <span class="controlled-setting-indicator" - content-setting="plugins" value="detect_important_content"></span> + content-setting="plugins" value="detect_important_content"> + </span> </span> </label> </div> @@ -166,27 +170,28 @@ <label> <input type="radio" name="plugins" value="block"> <span> - <span i18n-content="pluginsBlock"></span> + <span>$i18n{pluginsBlock}</span> <span class="controlled-setting-indicator" content-setting="plugins" value="block"></span> </span> </label> </div> <div class="settings-row"> - <button class="exceptions-list-button" contentType="plugins" - i18n-content="manageExceptions"></button> + <button class="exceptions-list-button" contentType="plugins"> + $i18n{manageExceptions} + </button> </div> </div> </section> <!-- Pop-ups filter --> <section> - <h3 i18n-content="popupsTabLabel" class="content-settings-header"></h3> + <h3 class="content-settings-header">$i18n{popupsTabLabel}</h3> <div> <div class="radio controlled-setting-with-label"> <label> <input type="radio" name="popups" value="allow"> <span> - <span i18n-content="popupsAllow"></span> + <span>$i18n{popupsAllow}</span> <span class="controlled-setting-indicator" content-setting="popups" value="allow"></span> </span> @@ -196,27 +201,28 @@ <label> <input type="radio" name="popups" value="block"> <span> - <span i18n-content="popupsBlock"></span> + <span>$i18n{popupsBlock}</span> <span class="controlled-setting-indicator" content-setting="popups" value="block"></span> </span> </label> </div> <div class="settings-row"> - <button class="exceptions-list-button" contentType="popups" - i18n-content="manageExceptions"></button> + <button class="exceptions-list-button" contentType="popups"> + $i18n{manageExceptions} + </button> </div> </div> </section> <!-- Location filter --> <section> - <h3 i18n-content="locationTabLabel"></h3> + <h3>$i18n{locationTabLabel}</h3> <div> <div class="radio controlled-setting-with-label"> <label> <input type="radio" name="location" value="allow"> <span> - <span i18n-content="locationAllow"></span> + <span>$i18n{locationAllow}</span> <span class="controlled-setting-indicator" content-setting="location" value="allow"></span> </span> @@ -226,7 +232,7 @@ <label> <input type="radio" name="location" value="ask"> <span> - <span i18n-content="locationAsk"></span> + <span>$i18n{locationAsk}</span> <span class="controlled-setting-indicator" content-setting="location" value="ask"></span> </span> @@ -237,7 +243,7 @@ <input type="radio" name="location" value="block"> <span> - <span i18n-content="locationBlock"></span> + <span>$i18n{locationBlock}</span> <span class="controlled-setting-indicator" content-setting="location" value="block"></span> </span> @@ -251,7 +257,7 @@ metric="Options_GoogleGeolocationAccessCheckbox" type="checkbox"> <span> - <span i18n-content="googleGeolocationAccessEnable"></span> + <span>$i18n{googleGeolocationAccessEnable}</span> <span class="controlled-setting-indicator" pref="googlegeolocationaccess.enabled"></span> </span> @@ -259,20 +265,21 @@ </div> </if> <div class="settings-row"> - <button class="exceptions-list-button" contentType="location" - i18n-content="manageExceptions"></button> + <button class="exceptions-list-button" contentType="location"> + $i18n{manageExceptions} + </button> </div> </div> </section> <!-- Notifications filter tab contents --> <section id="notifications-section"> - <h3 i18n-content="notificationsTabLabel"></h3> + <h3>$i18n{notificationsTabLabel}</h3> <div> <div class="radio controlled-setting-with-label"> <label> <input type="radio" name="notifications" value="allow"> <span> - <span i18n-content="notificationsAllow"></span> + <span>$i18n{notificationsAllow}</span> <span class="controlled-setting-indicator" content-setting="notifications" value="allow"></span> </span> @@ -282,7 +289,7 @@ <label> <input type="radio" name="notifications" value="ask"> <span> - <span i18n-content="notificationsAsk"></span> + <span>$i18n{notificationsAsk}</span> <span class="controlled-setting-indicator" content-setting="notifications" value="ask"></span> </span> @@ -292,64 +299,65 @@ <label> <input type="radio" name="notifications" value="block"> <span> - <span i18n-content="notificationsBlock"></span> + <span>$i18n{notificationsBlock}</span> <span class="controlled-setting-indicator" content-setting="notifications" value="block"></span> </span> </label> </div> <div class="settings-row"> - <button class="exceptions-list-button" contentType="notifications" - i18n-content="manageExceptions"></button> + <button class="exceptions-list-button" contentType="notifications"> + $i18n{manageExceptions} + </button> </div> </div> </section> <!-- Protected Content filter --> <section guest-visibility="disabled"> - <h3 i18n-content="protectedContentTabLabel" - class="content-settings-header"></h3> + <h3 class="content-settings-header">$i18n{protectedContentTabLabel}</h3> <div> <div class="checkbox"> <label> <input pref="webkit.webprefs.encrypted_media_enabled" type="checkbox"> - <span i18n-content="protectedContentEnableCheckbox"></span> + <span>$i18n{protectedContentEnableCheckbox}</span> </label> </div> <if expr="chromeos or is_win"> <div class="settings-row"> - <p i18n-content="protectedContentInfo"></p> + <p>$i18n{protectedContentInfo}</p> </div> <div class="checkbox"> <label> <input pref="settings.privacy.drm_enabled" type="checkbox"> - <span i18n-content="protectedContentEnableIdentifiersCheckbox"> - </span> + <span>$i18n{protectedContentEnableIdentifiersCheckbox}</span> </label> </div> </if> <if expr="chromeos"> <div class="settings-row"> <button id="protected-content-exceptions" - class="exceptions-list-button" contentType="protectedContent" - i18n-content="manageExceptions"></button> + class="exceptions-list-button" contentType="protectedContent"> + $i18n{manageExceptions} + </button> </div> </if> </div> </section> <!-- Microphone filter --> <section id="media-stream-mic"> - <h3 i18n-content="mediaStreamMicTabLabel"></h3> + <h3>$i18n{mediaStreamMicTabLabel}</h3> <div> - <span id="media-select-mic-label" - i18n-content="mediaSelectMicLabel" hidden></span> + <span id="media-select-mic-label" hidden> + $i18n{mediaSelectMicLabel} + </span> <select id="media-select-mic" class="weakrtl media-device-control" aria-labelledby="media-select-mic-label"></select> <div class="radio controlled-setting-with-label"> <label> <input type="radio" name="media-stream-mic" value="ask"> <span> - <span i18n-content="mediaStreamMicAsk"></span> + <span>$i18n{mediaStreamMicAsk}</span> <span class="controlled-setting-indicator" content-setting="media-stream-mic" value="ask"></span> </span> @@ -359,36 +367,39 @@ <label> <input type="radio" name="media-stream-mic" value="block"> <span> - <span i18n-content="mediaStreamMicBlock"></span> + <span>$i18n{mediaStreamMicBlock}</span> <span class="controlled-setting-indicator" content-setting="media-stream-mic" value="block"></span> </span> </label> </div> <div class="settings-row"> - <button class="exceptions-list-button" contentType="media-stream-mic" - i18n-content="manageExceptions"></button> + <button class="exceptions-list-button" contentType="media-stream-mic"> + $i18n{manageExceptions} + </button> </div> <div id="media-pepper-flash-default-mic" class="pepper-flash-settings"> - <span i18n-content="mediaPepperFlashMicDefaultDivergedLabel"></span> - <a target="_blank" i18n-content="mediaPepperFlashChangeLink" - i18n-values="href:mediaPepperFlashGlobalPrivacyURL"></a> + <span>$i18n{mediaPepperFlashMicDefaultDivergedLabel}</span> + <a target="_blank" href="$i18nRaw{mediaPepperFlashGlobalPrivacyURL}"> + $i18n{mediaPepperFlashChangeLink} + </a> </div> </div> </section> <!-- Camera filter --> <section id="media-stream-camera"> - <h3 i18n-content="mediaStreamCameraTabLabel"></h3> + <h3>$i18n{mediaStreamCameraTabLabel}</h3> <div> - <span id="media-select-camera-label" - i18n-content="mediaSelectCameraLabel" hidden></span> + <span id="media-select-camera-label" hidden> + $i18n{mediaSelectCameraLabel} + </span> <select id="media-select-camera" class="weakrtl media-device-control" aria-labelledby="media-select-camera-label"></select> <div class="radio controlled-setting-with-label"> <label> <input type="radio" name="media-stream-camera" value="ask"> <span> - <span i18n-content="mediaStreamCameraAsk"></span> + <span>$i18n{mediaStreamCameraAsk}</span> <span class="controlled-setting-indicator" content-setting="media-stream-camera" value="ask"></span> </span> @@ -398,7 +409,7 @@ <label> <input type="radio" name="media-stream-camera" value="block"> <span> - <span i18n-content="mediaStreamCameraBlock"></span> + <span>$i18n{mediaStreamCameraBlock}</span> <span class="controlled-setting-indicator" content-setting="media-stream-camera" value="block"></span> </span> @@ -406,27 +417,28 @@ </div> <div class="settings-row"> <button class="exceptions-list-button" - contentType="media-stream-camera" i18n-content="manageExceptions"> + contentType="media-stream-camera"> + $i18n{manageExceptions} </button> </div> <div id="media-pepper-flash-default-camera" class="pepper-flash-settings"> - <span i18n-content="mediaPepperFlashCameraDefaultDivergedLabel"> - </span> - <a target="_blank" i18n-content="mediaPepperFlashChangeLink" - i18n-values="href:mediaPepperFlashGlobalPrivacyURL"></a> + <span>$i18n{mediaPepperFlashCameraDefaultDivergedLabel}</span> + <a target="_blank" href="$i18nRaw{mediaPepperFlashGlobalPrivacyURL}"> + $i18n{mediaPepperFlashChangeLink} + </a> </div> </div> </section> <!-- PPAPI broker --> <section> - <h3 i18n-content="ppapiBrokerTabLabel"></h3> + <h3>$i18n{ppapiBrokerTabLabel}</h3> <div> <div class="radio"> <label> <input type="radio" name="ppapi-broker" value="allow"> <span> - <span i18n-content="ppapiBrokerAllow"></span> + <span>$i18n{ppapiBrokerAllow}</span> <span class="controlled-setting-indicator" content-setting="ppapi-broker" value="allow"></span> </span> @@ -436,7 +448,7 @@ <label> <input type="radio" name="ppapi-broker" value="ask"> <span> - <span i18n-content="ppapiBrokerAsk"></span> + <span>$i18n{ppapiBrokerAsk}</span> <span class="controlled-setting-indicator" content-setting="ppapi-broker" value="ask"></span> </span> @@ -446,28 +458,29 @@ <label> <input type="radio" name="ppapi-broker" value="block"> <span> - <span i18n-content="ppapiBrokerBlock"></span> + <span>$i18n{ppapiBrokerBlock}</span> <span class="controlled-setting-indicator" content-setting="ppapi-broker" value="block"></span> </span> </label> </div> <div class="settings-row"> - <button class="exceptions-list-button" contentType="ppapi-broker" - i18n-content="manageExceptions"></button> + <button class="exceptions-list-button" contentType="ppapi-broker"> + $i18n{manageExceptions} + </button> </div> </div> </section> <!-- Automatic Downloads filter --> <section> - <h3 i18n-content="multipleAutomaticDownloadsTabLabel"></h3> + <h3>$i18n{multipleAutomaticDownloadsTabLabel}</h3> <div> <div class="radio controlled-setting-with-label"> <label> <input type="radio" name="multiple-automatic-downloads" value="allow"> <span> - <span i18n-content="multipleAutomaticDownloadsAllow"></span> + <span>$i18n{multipleAutomaticDownloadsAllow}</span> <span class="controlled-setting-indicator" content-setting="multiple-automatic-downloads" value="allow"> </span> @@ -478,7 +491,7 @@ <label> <input type="radio" name="multiple-automatic-downloads" value="ask"> <span> - <span i18n-content="multipleAutomaticDownloadsAsk"></span> + <span>$i18n{multipleAutomaticDownloadsAsk}</span> <span class="controlled-setting-indicator" content-setting="multiple-automatic-downloads" value="ask"> </span> @@ -490,7 +503,7 @@ <input type="radio" name="multiple-automatic-downloads" value="block"> <span> - <span i18n-content="multipleAutomaticDownloadsBlock"></span> + <span>$i18n{multipleAutomaticDownloadsBlock}</span> <span class="controlled-setting-indicator" content-setting="multiple-automatic-downloads" value="block"> </span> @@ -499,118 +512,124 @@ </div> <div class="settings-row"> <button class="exceptions-list-button" - contentType="multiple-automatic-downloads" - i18n-content="manageExceptions"></button> + contentType="multiple-automatic-downloads"> + $i18n{manageExceptions} + </button> </div> </div> </section> <!-- MIDI system exclusive messages filter --> <section> - <h3 i18n-content="midiSysexHeader"></h3> + <h3>$i18n{midiSysexHeader}</h3> <div> <div class="radio"> <label> <input type="radio" name="midi-sysex" value="allow"> - <span i18n-content="midiSysExAllow"></span> + <span>$i18n{midiSysExAllow}</span> </label> </div> <div class="radio"> <label> <input type="radio" name="midi-sysex" value="ask"> - <span i18n-content="midiSysExAsk"></span> + <span>$i18n{midiSysExAsk}</span> </label> </div> <div class="radio"> <label> <input type="radio" name="midi-sysex" value="block"> - <span i18n-content="midiSysExBlock"></span> + <span>$i18n{midiSysExBlock}</span> </label> </div> <div class="settings-row"> - <button class="exceptions-list-button" contentType="midi-sysex" - i18n-content="manageExceptions"></button> + <button class="exceptions-list-button" contentType="midi-sysex"> + $i18n{manageExceptions} + </button> </div> </div> </section> <!-- Push messaging filter --> <section id="experimental-push-messaging-settings" hidden="true"> - <h3 i18n-content="pushMessagingHeader"></h3> + <h3>$i18n{pushMessagingHeader}</h3> <div> <div class="radio"> <label> <input type="radio" name="push-messaging" value="allow"> - <span i18n-content="pushMessagingAllow"></span> + <span>$i18n{pushMessagingAllow}</span> </label> </div> <div class="radio"> <label> <input type="radio" name="push-messaging" value="ask"> - <span i18n-content="pushMessagingAsk"></span> + <span>$i18n{pushMessagingAsk}</span> </label> </div> <div class="radio"> <label> <input type="radio" name="push-messaging" value="block"> - <span i18n-content="pushMessagingBlock"></span> + <span>$i18n{pushMessagingBlock}</span> </label> </div> <div class="settings-row"> - <button class="exceptions-list-button" contentType="push-messaging" - i18n-content="manageExceptions"></button> + <button class="exceptions-list-button" contentType="push-messaging"> + $i18n{manageExceptions} + </button> </div> </div> </section> <!-- USB devices --> <section> - <h3 i18n-content="usbDevicesHeader"></h3> + <h3>$i18n{usbDevicesHeader}</h3> <div> <div class="settings-row"> - <button class="exceptions-list-button" contentType="usb-devices" - i18n-content="usbDevicesManage"></button> + <button class="exceptions-list-button" contentType="usb-devices"> + $i18n{usbDevicesManage} + </button> </div> </div> </section> <!-- Background sync --> <section> - <h3 i18n-content="backgroundSyncHeader"></h3> + <h3>$i18n{backgroundSyncHeader}</h3> <div> <div class="radio"> <label> <input type="radio" name="background-sync" value="allow"> - <span i18n-content="backgroundSyncAllow"></span> + <span>$i18n{backgroundSyncAllow}</span> </label> </div> <div class="radio"> <label> <input type="radio" name="background-sync" value="block"> - <span i18n-content="backgroundSyncBlock"></span> + <span>$i18n{backgroundSyncBlock}</span> </label> </div> <div class="settings-row"> - <button class="exceptions-list-button" contentType="background-sync" - i18n-content="manageExceptions"></button> + <button class="exceptions-list-button" contentType="background-sync"> + $i18n{manageExceptions} + </button> </div> </div> </section> <!-- Page zoom levels --> <section id="page-zoom-levels"> - <h3 i18n-content="zoomlevelsHeader"></h3> + <h3>$i18n{zoomlevelsHeader}</h3> <div> <div class="settings-row"> - <button class="exceptions-list-button" contentType="zoomlevels" - i18n-content="zoomLevelsManage"></button> + <button class="exceptions-list-button" contentType="zoomlevels"> + $i18n{zoomLevelsManage} + </button> </div> </div> </section> <!-- PDF Plugin filter --> <section id="pdf-section"> - <h3 i18n-content="pdfTabLabel" class="content-settings-header"></h3> + <h3 class="content-settings-header">$i18n{pdfTabLabel}</h3> <div> <div class="checkbox"> <label> <input pref="plugins.always_open_pdf_externally" type="checkbox"> <span> - <span i18n-content="pdfEnable"></span> + <span>$i18n{pdfEnable}</span> <span class="controlled-setting-indicator" pref="plugins.always_open_pdf_externally"> </span> @@ -622,8 +641,8 @@ </div> <div class="action-area"> <div class="button-strip"> - <button id="content-settings-overlay-confirm" class="default-button" - i18n-content="done"> + <button id="content-settings-overlay-confirm" class="default-button"> + $i18n{done} </button> </div> </div>
diff --git a/chrome/browser/resources/options/content_settings_exceptions_area.html b/chrome/browser/resources/options/content_settings_exceptions_area.html index 079080f..c6b5efd 100644 --- a/chrome/browser/resources/options/content_settings_exceptions_area.html +++ b/chrome/browser/resources/options/content_settings_exceptions_area.html
@@ -3,63 +3,56 @@ <h1></h1> <div class="content-area"> <div id="exception-column-headers"> - <div id="exception-pattern-column" i18n-content="exceptionPatternHeader"> + <div id="exception-pattern-column">$i18n{exceptionPatternHeader}</div> + <div id="exception-behavior-column" class="exception-value-column-header"> + $i18n{exceptionBehaviorHeader} </div> - <div id="exception-behavior-column" - i18n-content="exceptionBehaviorHeader" - class="exception-value-column-header"> - </div> - <div id="exception-zoom-column" - i18n-content="exceptionZoomHeader" - class="exception-value-column-header" hidden> + <div id="exception-zoom-column" class="exception-value-column-header" + hidden> + $i18n{exceptionZoomHeader} </div> <div id="exception-usb-device-column" - i18n-content="exceptionUsbDeviceHeader" class="exception-value-column-header" hidden> + $i18n{exceptionUsbDeviceHeader} </div> </div> <div contentType="cookies"> <list mode="normal"></list> <div> - <span class="otr-explanation" i18n-content="otrExceptionsExplanation"> - </span> + <span class="otr-explanation">$i18n{otrExceptionsExplanation}</span> <list mode="otr"></list> </div> <div class="flash-plugin-area"> - <a i18n-values="href:flashStorageUrl" target="_blank" - i18n-content="flashStorageSettings"> + <a href="$i18nRaw{flashStorageUrl}" target="_blank"> + $i18n{flashStorageSettings} </a> </div> </div> <div contentType="images"> <list mode="normal"></list> <div> - <span class="otr-explanation" i18n-content="otrExceptionsExplanation"> - </span> + <span class="otr-explanation">$i18n{otrExceptionsExplanation}</span> <list mode="otr"></list> </div> </div> <div contentType="javascript"> <list mode="normal"></list> <div> - <span class="otr-explanation" i18n-content="otrExceptionsExplanation"> - </span> + <span class="otr-explanation">$i18n{otrExceptionsExplanation}</span> <list mode="otr"></list> </div> </div> <div contentType="plugins"> <list mode="normal"></list> <div> - <span class="otr-explanation" i18n-content="otrExceptionsExplanation"> - </span> + <span class="otr-explanation">$i18n{otrExceptionsExplanation}</span> <list mode="otr"></list> </div> </div> <div contentType="popups"> <list mode="normal"></list> <div> - <span class="otr-explanation" i18n-content="otrExceptionsExplanation"> - </span> + <span class="otr-explanation">$i18n{otrExceptionsExplanation}</span> <list mode="otr"></list> </div> </div> @@ -72,44 +65,41 @@ <div contentType="protectedContent"> <list mode="normal"></list> <div> - <span class="otr-explanation" i18n-content="otrExceptionsExplanation"> - </span> + <span class="otr-explanation">$i18n{otrExceptionsExplanation}</span> <list mode="otr"></list> </div> </div> <div contentType="media-stream-mic"> <list mode="normal"></list> <div> - <span class="otr-explanation" i18n-content="otrExceptionsExplanation"> - </span> + <span class="otr-explanation">$i18n{otrExceptionsExplanation}</span> <list mode="otr"></list> </div> <div id="media-pepper-flash-exceptions-mic" class="pepper-flash-settings"> - <span i18n-content="mediaPepperFlashMicExceptionsDivergedLabel"></span> - <a target="_blank" i18n-content="mediaPepperFlashChangeLink" - i18n-values="href:mediaPepperFlashWebsitePrivacyURL"></a> + <span>$i18n{mediaPepperFlashMicExceptionsDivergedLabel}</span> + <a target="_blank" href="$i18nRaw{mediaPepperFlashWebsitePrivacyURL}"> + $i18n{mediaPepperFlashChangeLink} + </a> </div> </div> <div contentType="media-stream-camera"> <list mode="normal"></list> <div> - <span class="otr-explanation" i18n-content="otrExceptionsExplanation"> - </span> + <span class="otr-explanation">$i18n{otrExceptionsExplanation}</span> <list mode="otr"></list> </div> <div id="media-pepper-flash-exceptions-camera" class="pepper-flash-settings"> - <span i18n-content="mediaPepperFlashCameraExceptionsDivergedLabel"> - </span> - <a target="_blank" i18n-content="mediaPepperFlashChangeLink" - i18n-values="href:mediaPepperFlashWebsitePrivacyURL"></a> + <span>$i18n{mediaPepperFlashCameraExceptionsDivergedLabel}</span> + <a target="_blank" href="$i18nRaw{mediaPepperFlashWebsitePrivacyURL}"> + $i18n{mediaPepperFlashChangeLink} + </a> </div> </div> <div contentType="ppapi-broker"> <list mode="normal"></list> <div> - <span class="otr-explanation" i18n-content="otrExceptionsExplanation"> - </span> + <span class="otr-explanation">$i18n{otrExceptionsExplanation}</span> <list mode="otr"></list> </div> </div> @@ -119,24 +109,21 @@ <div contentType="midi-sysex"> <list mode="normal"></list> <div> - <span class="otr-explanation" i18n-content="otrExceptionsExplanation"> - </span> + <span class="otr-explanation">$i18n{otrExceptionsExplanation}</span> <list mode="otr"></list> </div> </div> <div contentType="push-messaging"> <list mode="normal"></list> <div> - <span class="otr-explanation" i18n-content="otrExceptionsExplanation"> - </span> + <span class="otr-explanation">$i18n{otrExceptionsExplanation}</span> <list mode="otr"></list> </div> </div> <div contentType="usb-devices"> <list mode="normal"></list> <div> - <span class="otr-explanation" i18n-content="otrExceptionsExplanation"> - </span> + <span class="otr-explanation">$i18n{otrExceptionsExplanation}</span> <list mode="otr"></list> </div> </div> @@ -146,21 +133,21 @@ <div contentType="zoomlevels"> <list mode="normal"></list> <div> - <span class="otr-explanation" i18n-content="otrExceptionsExplanation"> - </span> + <span class="otr-explanation">$i18n{otrExceptionsExplanation}</span> <list mode="otr"></list> </div> </div> </div> <div class="action-area"> <div class="hbox stretch"> - <a target="_blank" i18n-content="learnMore" - i18n-values="href:exceptionsLearnMoreUrl"></a> + <a target="_blank" + href="$i18nRaw{exceptionsLearnMoreUrl}">$i18n{learnMore}</a> </div> <div class="action-area-right"> <div class="button-strip"> <button id="content-settings-exceptions-overlay-confirm" - class="default-button" i18n-content="done"> + class="default-button"> + $i18n{done} </button> </div> </div>
diff --git a/chrome/browser/resources/options/cookies_view.html b/chrome/browser/resources/options/cookies_view.html index 0cc136b..8176c3b 100644 --- a/chrome/browser/resources/options/cookies_view.html +++ b/chrome/browser/resources/options/cookies_view.html
@@ -1,27 +1,28 @@ <div id="cookies-view-page" class="page cookies-view-page" hidden> <div class="close-button"></div> - <h1 i18n-content="cookiesViewPage"></h1> + <h1>$i18n{cookiesViewPage}</h1> <div class="content-area cookies-list-content-area"> <div class="cookies-column-headers"> <div class="cookies-site-column"> - <h3 i18n-content="cookie_domain"></h3> + <h3>$i18n{cookie_domain}</h3> </div> <div class="cookies-data-column"> - <h3 i18n-content="cookie_local_data"></h3> + <h3>$i18n{cookie_local_data}</h3> </div> <div class="cookies-header-controls"> - <button class="remove-all-cookies-button" - i18n-content="remove_all_cookie"></button> + <button class="remove-all-cookies-button"> + $i18n{remove_all_cookie} + </button> <input type="search" class="cookies-search-box" - i18n-values="placeholder:search_cookies" incremental> + placeholder="$i18n{search_cookies}" incremental> </div> </div> <list id="cookies-list" class="cookies-list"></list> </div> <div class="action-area"> <div class="button-strip"> - <button class="cookies-view-overlay-confirm default-button" - i18n-content="done"> + <button class="cookies-view-overlay-confirm default-button"> + $i18n{done} </button> </div> </div>
diff --git a/chrome/browser/resources/options/do_not_track_confirm_overlay.html b/chrome/browser/resources/options/do_not_track_confirm_overlay.html index 666865f..3116968 100644 --- a/chrome/browser/resources/options/do_not_track_confirm_overlay.html +++ b/chrome/browser/resources/options/do_not_track_confirm_overlay.html
@@ -1,24 +1,21 @@ <div id="do-not-track-confirm-overlay" class="page" hidden> <div class="close-button"></div> - <h1 i18n-content="doNotTrackConfirmOverlay"></h1> + <h1>$i18n{doNotTrackConfirmOverlay}</h1> <div class="content-area"> - <span id="do-not-track-confirm-text" - i18n-content="doNotTrackConfirmMessage"> - </span> + <span id="do-not-track-confirm-text">$i18n{doNotTrackConfirmMessage}</span> </div> <div class="action-area"> <div class="hbox stretch"> - <a target="_blank" i18n-content="learnMore" - i18n-values="href:doNotTrackLearnMoreURL"> - </a> + <a target="_blank" + href="$i18nRaw{doNotTrackLearnMoreURL}">$i18n{learnMore}</a> </div> <div class="action-area-right"> <div class="button-strip"> - <button id="do-not-track-confirm-cancel" - i18n-content="doNotTrackConfirmDisable"> + <button id="do-not-track-confirm-cancel"> + $i18n{doNotTrackConfirmDisable} </button> - <button id="do-not-track-confirm-ok" class="default-button" - i18n-content="doNotTrackConfirmEnable"> + <button id="do-not-track-confirm-ok" class="default-button"> + $i18n{doNotTrackConfirmEnable} </button> </div> </div>
diff --git a/chrome/browser/resources/options/easy_unlock_turn_off_overlay.html b/chrome/browser/resources/options/easy_unlock_turn_off_overlay.html index 84d9218..8a2db2e 100644 --- a/chrome/browser/resources/options/easy_unlock_turn_off_overlay.html +++ b/chrome/browser/resources/options/easy_unlock_turn_off_overlay.html
@@ -1,16 +1,15 @@ <div id="easy-unlock-turn-off-overlay" class="page" hidden> <div class="close-button"></div> - <h1 id="easy-unlock-turn-off-title" - i18n-content="easyUnlockTurnOffTitle"></h1> + <h1 id="easy-unlock-turn-off-title">$i18n{easyUnlockTurnOffTitle}</h1> <div class="content-area"> - <p id="easy-unlock-turn-off-messagee" class="settings-row" - i18n-content="easyUnlockTurnOffDescription"></p> + <p id="easy-unlock-turn-off-messagee" class="settings-row"> + $i18n{easyUnlockTurnOffDescription} + </p> </div> <div class="action-area button-strip"> - <button id="easy-unlock-turn-off-dismiss" i18n-content="cancel"> - </button> - <button id="easy-unlock-turn-off-confirm" class="default-button" - i18n-content="easyUnlockTurnOffButton"> + <button id="easy-unlock-turn-off-dismiss">$i18n{cancel}</button> + <button id="easy-unlock-turn-off-confirm" class="default-button"> + $i18n{easyUnlockTurnOffButton} </button> <div class="stretch"></div> <div id="easy-unlock-turn-off-spinner" class="spinner" hidden></div>
diff --git a/chrome/browser/resources/options/factory_reset_overlay.html b/chrome/browser/resources/options/factory_reset_overlay.html index 21df28f9..3c0a0f0 100644 --- a/chrome/browser/resources/options/factory_reset_overlay.html +++ b/chrome/browser/resources/options/factory_reset_overlay.html
@@ -1,16 +1,15 @@ <div id="factory-reset-overlay" class="page" hidden> <div class="close-button"></div> - <h1 i18n-content="factoryResetHeading"></h1> + <h1>$i18n{factoryResetHeading}</h1> <div class="content-area"> - <span i18n-content="factoryResetWarning"></span> - <a i18n-values="href:factoryResetHelpUrl" - i18n-content="errorLearnMore" target="_blank"></a> + <span>$i18n{factoryResetWarning}</span> + <a href="$i18nRaw{factoryResetHelpUrl}" + target="_blank">$i18n{errorLearnMore}</a> </div> <div class="action-area button-strip"> - <button id="factory-reset-data-dismiss" i18n-content="cancel"> - </button> - <button id="factory-reset-data-restart" class="default-button" - i18n-content="factoryResetDataRestart"> + <button id="factory-reset-data-dismiss">$i18n{cancel}</button> + <button id="factory-reset-data-restart" class="default-button"> + $i18n{factoryResetDataRestart} </button> </div> </div>
diff --git a/chrome/browser/resources/options/font_settings.html b/chrome/browser/resources/options/font_settings.html index 6da0cef..f22c3dc 100644 --- a/chrome/browser/resources/options/font_settings.html +++ b/chrome/browser/resources/options/font_settings.html
@@ -1,9 +1,9 @@ <div id="font-settings" class="page" hidden> <div class="close-button"></div> - <h1 i18n-content="fontSettingsPage"></h1> + <h1>$i18n{fontSettingsPage}</h1> <div class="content-area"> <section> - <h3 i18n-content="fontSettingsStandard"></h3> + <h3>$i18n{fontSettingsStandard}</h3> <div class="font-setting-container"> <div class="font-input-div"> <div> @@ -16,9 +16,9 @@ <input id="standard-font-size" type="range" min="0" max="24" pref="webkit.webprefs.default_font_size"> <div> - <span i18n-content="fontSettingsSizeTiny"></span> - <span i18n-content="fontSettingsSizeHuge" - class="font-settings-huge"> + <span>$i18n{fontSettingsSizeTiny}</span> + <span class="font-settings-huge"> + $i18n{fontSettingsSizeHuge} </span> </div> </div> @@ -27,7 +27,7 @@ </div> </section> <section> - <h3 i18n-content="fontSettingsSerif"></h3> + <h3>$i18n{fontSettingsSerif}</h3> <div class="font-setting-container"> <div class="font-input-div"> <div> @@ -41,7 +41,7 @@ </div> </section> <section> - <h3 i18n-content="fontSettingsSansSerif"></h3> + <h3>$i18n{fontSettingsSansSerif}</h3> <div class="font-setting-container"> <div class="font-input-div"> <div> @@ -55,7 +55,7 @@ </div> </section> <section> - <h3 i18n-content="fontSettingsFixedWidth"></h3> + <h3>$i18n{fontSettingsFixedWidth}</h3> <div class="font-setting-container"> <div class="font-input-div"> <div> @@ -69,16 +69,16 @@ </div> </section> <section> - <h3 i18n-content="fontSettingsMinimumSize"></h3> + <h3>$i18n{fontSettingsMinimumSize}</h3> <div class="font-setting-container"> <div class="font-input-div"> <div> <input id="minimum-font-size" type="range" min="0" max="15" pref="webkit.webprefs.minimum_font_size"> <div> - <span i18n-content="fontSettingsSizeTiny"></span> - <span i18n-content="fontSettingsSizeHuge" - class="font-settings-huge"> + <span>$i18n{fontSettingsSizeTiny}</span> + <span class="font-settings-huge"> + $i18n{fontSettingsSizeHuge} </span> </div> </div> @@ -89,13 +89,15 @@ </div> <div class="action-area"> <div class="button-strip"> - <span id="advanced-font-settings-install" hidden - i18n-values=".innerHTML:advancedFontSettingsInstall"></span> - <a is="action-link" id="advanced-font-settings-options" - i18n-content="advancedFontSettingsOptions" hidden></a> + <span id="advanced-font-settings-install" hidden> + $i18nRaw{advancedFontSettingsInstall} + </span> + <a is="action-link" id="advanced-font-settings-options" hidden> + $i18n{advancedFontSettingsOptions} + </a> <span class="spacer"></span> - <button id="font-settings-confirm" class="default-button" - i18n-content="done"> + <button id="font-settings-confirm" class="default-button"> + $i18n{done} </button> </div> </div>
diff --git a/chrome/browser/resources/options/handler_options.html b/chrome/browser/resources/options/handler_options.html index bfe856b..fb4f576 100644 --- a/chrome/browser/resources/options/handler_options.html +++ b/chrome/browser/resources/options/handler_options.html
@@ -1,27 +1,27 @@ <div id="handler-options" class="page" hidden> <div class="close-button"></div> - <h1 i18n-content="handlersPage"></h1> + <h1>$i18n{handlersPage}</h1> <div class="content-area"> - <h3 i18n-content="handlersActiveHeading"></h3> + <h3>$i18n{handlersActiveHeading}</h3> <div class="handlers-column-headers"> <div class="handlers-type-column"> - <div i18n-content="handlersTypeColumnHeader"></div> + <div>$i18n{handlersTypeColumnHeader}</div> </div> <div class="handlers-site-column"> - <div i18n-content="handlersSiteColumnHeader"></div> + <div>$i18n{handlersSiteColumnHeader}</div> </div> <div class="handlers-remove-column"></div> </div> <list id="handlers-list"></list> <div id="ignored-handlers-section"> - <h3 i18n-content="handlersIgnoredHeading"></h3> + <h3>$i18n{handlersIgnoredHeading}</h3> <div class="handlers-column-headers"> <div class="handlers-type-column"> - <h3 i18n-content="handlersTypeColumnHeader"></h3> + <h3>$i18n{handlersTypeColumnHeader}</h3> </div> <div class="handlers-site-column"> - <h3 i18n-content="handlersSiteColumnHeader"></h3> + <h3>$i18n{handlersSiteColumnHeader}</h3> </div> <div class="handlers-remove-column"></div> </div> @@ -30,13 +30,13 @@ </div> <div class="action-area"> <div class="hbox stretch"> - <a target="_blank" i18n-content="learnMore" - i18n-values="href:handlersLearnMoreUrl"></a> + <a target="_blank" + href="$i18nRaw{handlersLearnMoreUrl}">$i18n{learnMore}</a> </div> <div class="action-area-right"> <div class="button-strip"> - <button id="handler-options-overlay-confirm" class="default-button" - i18n-content="done"> + <button id="handler-options-overlay-confirm" class="default-button"> + $i18n{done} </button> </div> </div>
diff --git a/chrome/browser/resources/options/home_page_overlay.html b/chrome/browser/resources/options/home_page_overlay.html index b1b6edd..d73b0f5 100644 --- a/chrome/browser/resources/options/home_page_overlay.html +++ b/chrome/browser/resources/options/home_page_overlay.html
@@ -1,6 +1,6 @@ <div id="home-page-overlay" class="page" role="dialog" hidden> <div class="close-button"></div> - <h1 i18n-content="homePageOverlay"></h1> + <h1>$i18n{homePageOverlay}</h1> <div class="content-area"> <div class="radio controlled-setting-with-label"> <label> @@ -8,7 +8,7 @@ pref="homepage_is_newtabpage" value="true" metric="Options_Homepage_IsNewTabPage" dialog-pref> <span> - <span i18n-content="homePageUseNewTab"></span> + <span>$i18n{homePageUseNewTab}</span> <span class="controlled-setting-indicator" pref="homepage_is_newtabpage" value="true" dialog-pref></span> </span> @@ -20,8 +20,7 @@ pref="homepage_is_newtabpage" value="false" metric="Options_Homepage_IsNewTabPage" dialog-pref> <span> - <span id="homepage-use-url-label" i18n-content="homePageUseURL"> - </span> + <span id="homepage-use-url-label">$i18n{homePageUseURL}</span> <span class="controlled-setting-indicator" pref="homepage_is_newtabpage" value="false" dialog-pref></span> </span> @@ -39,11 +38,8 @@ </div> <div class="action-area"> <div class="button-strip"> - <button id="home-page-cancel" type="reset" i18n-content="cancel"> - </button> - <button id="home-page-confirm" class="default-button" - i18n-content="ok"> - </button> + <button id="home-page-cancel" type="reset">$i18n{cancel}</button> + <button id="home-page-confirm" class="default-button">$i18n{ok}</button> </div> </div> </div>
diff --git a/chrome/browser/resources/options/hotword_confirm_overlay.html b/chrome/browser/resources/options/hotword_confirm_overlay.html index 11103ef..5733921 100644 --- a/chrome/browser/resources/options/hotword_confirm_overlay.html +++ b/chrome/browser/resources/options/hotword_confirm_overlay.html
@@ -1,23 +1,21 @@ <div id="hotword-confirm-overlay" class="page" hidden> <div class="close-button"></div> - <h1 i18n-content="hotwordConfirmOverlay"></h1> + <h1>$i18n{hotwordConfirmOverlay}</h1> <div class="content-area"> - <span id="hotword-confirm-text" i18n-content="hotwordConfirmMessage"> - </span> + <span id="hotword-confirm-text">$i18n{hotwordConfirmMessage}</span> </div> <div class="action-area"> <div class="hbox stretch"> - <a target="_blank" i18n-content="learnMore" - i18n-values="href:hotwordLearnMoreURL"> - </a> + <a target="_blank" + href="$i18nRaw{hotwordLearnMoreURL}">$i18n{learnMore}</a> </div> <div class="action-area-right"> <div class="button-strip"> - <button id="hotword-confirm-cancel" - i18n-content="hotwordConfirmDisable"> + <button id="hotword-confirm-cancel"> + $i18n{hotwordConfirmDisable} </button> - <button id="hotword-confirm-ok" class="default-button" - i18n-content="hotwordConfirmEnable"> + <button id="hotword-confirm-ok" class="default-button"> + $i18n{hotwordConfirmEnable} </button> </div> </div> @@ -28,7 +26,7 @@ pref="hotword.audio_logging_enabled" metric="Options_Hotword_AudioLogging_Checkbox" type="checkbox" dialog-pref checked> - <span i18n-content="hotwordAudioLoggingEnable"></span> + <span>$i18n{hotwordAudioLoggingEnable}</span> </label> </div> </div>
diff --git a/chrome/browser/resources/options/import_data_overlay.html b/chrome/browser/resources/options/import_data_overlay.html index 7524577..7d604146 100644 --- a/chrome/browser/resources/options/import_data_overlay.html +++ b/chrome/browser/resources/options/import_data_overlay.html
@@ -1,23 +1,23 @@ <div id="import-data-overlay" class="page" hidden> <div class="close-button"></div> - <h1 i18n-content="importDataOverlay"></h1> + <h1>$i18n{importDataOverlay}</h1> <div class="content-area"> <div class="import-data-configure"> <div id="import-from-div"> - <span i18n-content="importFromLabel"></span> + <span>$i18n{importFromLabel}</span> <select id="import-browsers"> - <option i18n-content="importLoading"></option> + <option>$i18n{importLoading}</option> </select> </div> <div id="import-checkboxes"> - <div i18n-content="importDescription"></div> + <div>$i18n{importDescription}</div> <div class="checkbox controlled-setting-with-label" id="import-history-with-label"> <label> <input id="import-history" type="checkbox" pref="import_dialog_history"> <span> - <span i18n-content="importHistory"></span> + <span>$i18n{importHistory}</span> <span class="controlled-setting-indicator" pref="import_dialog_history"> </span> @@ -30,7 +30,7 @@ <input id="import-favorites" type="checkbox" pref="import_dialog_bookmarks"> <span> - <span i18n-content="importFavorites"></span> + <span>$i18n{importFavorites}</span> <span class="controlled-setting-indicator" pref="import_dialog_bookmarks"></span> </span> @@ -42,7 +42,7 @@ <input id="import-passwords" type="checkbox" pref="import_dialog_saved_passwords"> <span> - <span i18n-content="importPasswords"></span> + <span>$i18n{importPasswords}</span> <span class="controlled-setting-indicator" pref="import_dialog_saved_passwords"></span> </span> @@ -54,7 +54,7 @@ <input id="import-search" type="checkbox" pref="import_dialog_search_engine"> <span> - <span i18n-content="importSearch"></span> + <span>$i18n{importSearch}</span> <span class="controlled-setting-indicator" pref="import_dialog_search_engine"></span> </span> @@ -65,7 +65,7 @@ <label> <input id="import-autofill-form-data" type="checkbox" pref="import_dialog_autofill_form_data"> - <span i18n-content="importAutofillFormData"></span> + <span>$i18n{importAutofillFormData}</span> </label> <span class="controlled-setting-indicator" pref="import_dialog_autofill_form_data"></span> @@ -74,18 +74,18 @@ </div> <div class="import-data-success" hidden> <div id="import-success-header"> - <strong i18n-content="importSucceeded"></strong> + <strong>$i18n{importSucceeded}</strong> </div> <div id="import-success-image"></div> <div id="import-find-your-bookmarks"> - <span i18n-content="findYourImportedBookmarks"></span> + <span>$i18n{findYourImportedBookmarks}</span> <div class="checkbox controlled-setting-with-label"> <label> <input id="import-data-show-bookmarks-bar" pref="bookmark_bar.show_on_all_tabs" metric="Options_ShowBookmarksBar" type="checkbox"> <span> - <span i18n-content="toolbarShowBookmarksBar"></span> + <span>$i18n{toolbarShowBookmarksBar}</span> <span class="controlled-setting-indicator" pref="bookmark_bar.show_on_all_tabs"></span> </span> @@ -99,11 +99,10 @@ <div class="action-area-right"> <div id="import-throbber" class="throbber"></div> <div class="button-strip"> - <button id="import-data-cancel" i18n-content="cancel"></button> - <button id="import-choose-file" i18n-content="importChooseFile"> - </button> - <button id="import-data-commit" class="default-button" - i18n-content="importCommit"> + <button id="import-data-cancel">$i18n{cancel}</button> + <button id="import-choose-file">$i18n{importChooseFile}</button> + <button id="import-data-commit" class="default-button"> + $i18n{importCommit} </button> </div> </div> @@ -111,8 +110,8 @@ <div class="import-data-success" hidden> <div class="action-area-right"> <div class="button-strip"> - <button id="import-data-confirm" class="default-button" - i18n-content="done"> + <button id="import-data-confirm" class="default-button"> + $i18n{done} </button> </div> </div>
diff --git a/chrome/browser/resources/options/language_add_language_overlay.html b/chrome/browser/resources/options/language_add_language_overlay.html index 0cbf1b60..c95a56a 100644 --- a/chrome/browser/resources/options/language_add_language_overlay.html +++ b/chrome/browser/resources/options/language_add_language_overlay.html
@@ -1,17 +1,17 @@ <div id="add-language-overlay-page" class="page" role="dialog" hidden> <div class="close-button"></div> - <h1 i18n-content="addLanguageTitle"></h1> + <h1>$i18n{addLanguageTitle}</h1> <div class="content-area"> - <label id="add-language-overlay-language-list-label" - i18n-content="addLanguageSelectLabel"></label> + <label id="add-language-overlay-language-list-label"> + $i18n{addLanguageSelectLabel} + </label> <select id="add-language-overlay-language-list" aria-labelledby="add-language-overlay-language-list-label"></select> </div> <div class="action-area button-strip"> - <button id="add-language-overlay-cancel-button" i18n-content="cancel"> - </button> - <button id="add-language-overlay-ok-button" class="default-button" - i18n-content="ok"> + <button id="add-language-overlay-cancel-button">$i18n{cancel}</button> + <button id="add-language-overlay-ok-button" class="default-button"> + $i18n{ok} </button> </div> </div>
diff --git a/chrome/browser/resources/options/language_dictionary_overlay.html b/chrome/browser/resources/options/language_dictionary_overlay.html index 34b6405..9e1a67f 100644 --- a/chrome/browser/resources/options/language_dictionary_overlay.html +++ b/chrome/browser/resources/options/language_dictionary_overlay.html
@@ -1,20 +1,21 @@ <div id="language-dictionary-overlay-page" class="page" hidden> <div class="close-button"></div> - <h1 i18n-content="languageDictionaryOverlayTitle"></h1> + <h1>$i18n{languageDictionaryOverlayTitle}</h1> <input id="language-dictionary-overlay-search-field" type="search" - i18n-values="placeholder:languageDictionaryOverlaySearchPlaceholder; - aria-label:languageDictionaryOverlaySearchPlaceholder" + placeholder="$i18n{languageDictionaryOverlaySearchPlaceholder}" + aria-label="$i18n{languageDictionaryOverlaySearchPlaceholder}" incremental> <div class="content-area"> <div class="settings-list"> - <p id="language-dictionary-overlay-no-matches" - i18n-content="languageDictionaryOverlayNoMatches" hidden></p> + <p id="language-dictionary-overlay-no-matches" hidden> + $i18n{languageDictionaryOverlayNoMatches} + </p> <list id="language-dictionary-overlay-word-list"></list> </div> </div> <div class="action-area button-strip"> - <button id="language-dictionary-overlay-done-button" class="default-button" - i18n-content="done"> + <button id="language-dictionary-overlay-done-button" class="default-button"> + $i18n{done} </button> </div> </div>
diff --git a/chrome/browser/resources/options/language_options.html b/chrome/browser/resources/options/language_options.html index 83ede8f..7f9f33a 100644 --- a/chrome/browser/resources/options/language_options.html +++ b/chrome/browser/resources/options/language_options.html
@@ -1,27 +1,25 @@ <div id="languagePage" class="page" hidden> <div class="close-button"></div> - <h1 i18n-content="languagePage"></h1> + <h1>$i18n{languagePage}</h1> <div class="content-area"> <div id="notification"> <span> </span> <span class="link"><span class="link-color"></span></span> </div> <div class="language-options-header"> - <span i18n-content="addLanguageInstructions"></span> + <span>$i18n{addLanguageInstructions}</span> <if expr="chromeos"> - <span i18n-content="inputMethodInstructions"></span> + <span>$i18n{inputMethodInstructions}</span> </if> - <a target="_blank" i18n-content="learnMore" - i18n-values="href:languagesLearnMoreURL"></a> + <a target="_blank" + href="$i18nRaw{languagesLearnMoreURL}">$i18n{learnMore}</a> </div> <div class="language-options"> <div id="language-options-languages"> - <h3 i18n-content="languages"></h3> + <h3>$i18n{languages}</h3> <list id="language-options-list"></list> <div class="language-options-lower-left"> - <button id="language-options-add-button" - i18n-content="addButton"> - </button> + <button id="language-options-add-button">$i18n{addButton}</button> </div> <div id="language-options-list-dropmarker"></div> </div> @@ -30,8 +28,8 @@ <if expr="os == 'win32' or chromeos"> <div id="language-options-ui-language-section" class="language-options-contents"> - <button id="language-options-ui-language-button" - i18n-content="displayInThisLanguage"> + <button id="language-options-ui-language-button"> + $i18n{displayInThisLanguage} </button> <span class="controlled-setting-indicator"></span> <span id="language-options-ui-language-message" hidden></span> @@ -44,30 +42,31 @@ <div class="checkbox" id="spellcheck-language-checkbox-container"> <label> <input type="checkbox" id="spellcheck-language-checkbox"> - <span i18n-content="useThisForSpellChecking"></span> + <span>$i18n{useThisForSpellChecking}</span> </label> </div> <span id="spellcheck-language-message" hidden></span> - <span id="language-options-dictionary-downloading-message" - i18n-content="downloadingDictionary" hidden> + <span id="language-options-dictionary-downloading-message" hidden> + $i18n{downloadingDictionary} </span> </div> <div id="language-options-dictionary-download-failed-message" class="language-options-notification" hidden> - <div i18n-content="downloadFailed"></div> + <div>$i18n{downloadFailed}</div> <div id="language-options-dictionary-download-fail-help-message" - i18n-content="downloadFailHelp" hidden> + hidden> + $i18n{downloadFailHelp} </div> - <button id="dictionary-download-retry-button" - i18n-content="retryButton"> + <button id="dictionary-download-retry-button"> + $i18n{retryButton} </button> </div> <div id="language-options-ui-notification-bar" class="language-options-notification" hidden> - <div i18n-content="restartRequired"></div> + <div>$i18n{restartRequired}</div> <if expr="chromeos"> - <button id="language-options-ui-restart-button" - i18n-content="restartButton"> + <button id="language-options-ui-restart-button"> + $i18n{restartButton} </button> </if> </div> @@ -77,15 +76,17 @@ <div class="checkbox"> <label> <input type="checkbox" id="offer-to-translate-in-this-language"> - <span class="offer-to-translate-label" - i18n-content="offerToTranslateInThisLanguage"></span> + <span class="offer-to-translate-label"> + $i18n{offerToTranslateInThisLanguage} + </span> </label> </div> - <span id="cannot-translate-in-this-language" - i18n-content="cannotTranslateInThisLanguage" hidden></span> + <span id="cannot-translate-in-this-language" hidden> + $i18n{cannotTranslateInThisLanguage} + </span> </div> <if expr="chromeos"> - <h3 i18n-content="inputMethod"></h3> + <h3>$i18n{inputMethod}</h3> <div id="language-options-input-method-template" class="input-method" hidden> <div class="checkbox"> @@ -97,8 +98,8 @@ </div> <div id="language-options-input-method-list" class="language-options-contents"> - <span id="language-options-input-method-none" - i18n-content="noInputMethods" hidden> + <span id="language-options-input-method-none" hidden> + $i18n{noInputMethods} </span> </div> </if> @@ -106,15 +107,16 @@ </div> <div class="language-options-footer"> <if expr="chromeos"> - <div i18n-content="switchInputMethodsHint"></div> - <div i18n-content="selectPreviousInputMethodHint"></div> + <div>$i18n{switchInputMethodsHint}</div> + <div>$i18n{selectPreviousInputMethodHint}</div> <a is="action-link" id="edit-custom-dictionary-button" - class="standalone-action-link" - i18n-content="languageDictionaryOverlayTitle"></a> + class="standalone-action-link"> + $i18n{languageDictionaryOverlayTitle} + </a> <div id="language-options-ime-menu-template" class="checkbox" hidden> <label> <input type="checkbox" id="activate-ime-menu"> - <span i18n-content="activateImeMenu"></span> + <span>$i18n{activateImeMenu}</span> </label> </div> </if> @@ -123,18 +125,18 @@ <label id="enable-spellcheck-container"> <input id="enable-spellcheck" pref="browser.enable_spellchecking" metric="Options_SpellCheck" type="checkbox"> - <span i18n-content="enableSpellCheck"></span> + <span>$i18n{enableSpellCheck}</span> </label> - <a is="action-link" id="edit-custom-dictionary-button" - i18n-content="languageDictionaryOverlayTitle" hidden></a> + <a is="action-link" id="edit-custom-dictionary-button" hidden> + $i18n{languageDictionaryOverlayTitle} + </a> </div> </if> </div> </div> <div class="action-area"> <div class="button-strip"> - <button id="language-confirm" class="default-button" i18n-content="done"> - </button> + <button id="language-confirm" class="default-button">$i18n{done}</button> </div> </div> </div>
diff --git a/chrome/browser/resources/options/manage_profile_overlay.html b/chrome/browser/resources/options/manage_profile_overlay.html index 688d2496..f72093c0 100644 --- a/chrome/browser/resources/options/manage_profile_overlay.html +++ b/chrome/browser/resources/options/manage_profile_overlay.html
@@ -2,15 +2,13 @@ <div class="close-button"></div> <!-- Dialog for managing profiles. --> <div id="manage-profile-overlay-manage" hidden> - <h1 i18n-content="manageProfile"></h1> + <h1>$i18n{manageProfile}</h1> <div id="manage-profile-content" class="content-area"> - <div id="manage-profile-icon-label" - i18n-content="manageProfilesIconLabel"> - </div> + <div id="manage-profile-icon-label">$i18n{manageProfilesIconLabel}</div> <grid id="manage-profile-icon-grid"></grid> <div id="manage-profile-name-input-container"> <label> - <span i18n-content="manageProfilesNameLabel"></span> + <span>$i18n{manageProfilesNameLabel}</span> <input id="manage-profile-name" type="text" pattern=".*\S.*" required> </label> </div> @@ -18,71 +16,75 @@ </div> <div class="action-area"> <div class="action-area-shortcut-container"> - <button id="remove-shortcut-button" - i18n-content="removeProfileShortcutButton" hidden> + <button id="remove-shortcut-button" hidden> + $i18n{removeProfileShortcutButton} </button> - <button id="add-shortcut-button" - i18n-content="createProfileShortcutButton" hidden> + <button id="add-shortcut-button" hidden> + $i18n{createProfileShortcutButton} </button> </div> <div class="button-strip"> - <button id="manage-profile-cancel" i18n-content="cancel"></button> - <button id="manage-profile-ok" i18n-content="manageProfilesConfirm" - class="default-button"></button> + <button id="manage-profile-cancel">$i18n{cancel}</button> + <button id="manage-profile-ok" class="default-button"> + $i18n{manageProfilesConfirm} + </button> </div> </div> </div> <!-- Dialog for deleting profiles. --> <div id="manage-profile-overlay-delete" hidden> - <h1 i18n-content="deleteProfileTitle"></h1> + <h1>$i18n{deleteProfileTitle}</h1> <div class="content-area"> <div id="delete-profile-message"> <img id="delete-profile-icon" class="profile-icon"> <div id="delete-profile-text"></div> </div> - <div id="delete-supervised-profile-addendum" - i18n-values=".innerHTML:deleteSupervisedProfileAddendum" hidden> + <div id="delete-supervised-profile-addendum" hidden> + $i18nRaw{deleteSupervisedProfileAddendum} </div> </div> <div class="action-area button-strip"> - <button id="delete-profile-ok" i18n-content="deleteProfileOK"></button> - <button id="delete-profile-cancel" i18n-content="cancel" - class="default-button"></button> + <button id="delete-profile-ok">$i18n{deleteProfileOK}</button> + <button id="delete-profile-cancel" class="default-button"> + $i18n{cancel} + </button> </div> </div> <!-- Dialog for disconnecting enterprise managed profiles. --> <div id="manage-profile-overlay-disconnect-managed" hidden> - <h1 i18n-content="disconnectManagedProfileTitle"></h1> + <h1>$i18n{disconnectManagedProfileTitle}</h1> <div class="content-area" - id="disconnect-managed-profile-domain-information" - i18n-values=".innerHTML:disconnectManagedProfileDomainInformation"> + id="disconnect-managed-profile-domain-information"> + $i18nRaw{disconnectManagedProfileDomainInformation} </div> <div class="content-area"> <div id="disconnect-managed-profile-message"> - <div id="disconnect-managed-profile-text" - i18n-values=".innerHTML:disconnectManagedProfileText"> + <div id="disconnect-managed-profile-text"> + $i18nRaw{disconnectManagedProfileText} </div> </div> </div> <div class="action-area"> <div class="button-strip"> - <button id="disconnect-managed-profile-ok" - i18n-content="disconnectManagedProfileOK"></button> - <button id="disconnect-managed-profile-cancel" class="default-button" - i18n-content="cancel"></button> + <button id="disconnect-managed-profile-ok"> + $i18n{disconnectManagedProfileOK} + </button> + <button id="disconnect-managed-profile-cancel" class="default-button"> + $i18n{cancel} + </button> </div> </div> </div> <!-- Dialog for creating profiles. --> <div id="manage-profile-overlay-create" hidden> - <h1 i18n-content="createProfileTitle"></h1> + <h1>$i18n{createProfileTitle}</h1> <div id="create-profile-content" class="content-area"> <div id="create-profile-instructions"></div> <grid id="create-profile-icon-grid"></grid> <div id="create-profile-name-input-container"> <label> - <span id="create-profile-name-label" - i18n-content="manageProfilesNameLabel"> + <span id="create-profile-name-label"> + $i18n{manageProfilesNameLabel} </span> <input id="create-profile-name" type="text" pattern=".*\S.*" required> </label> @@ -92,7 +94,7 @@ <div id="create-shortcut-container" class="checkbox" hidden> <label> <input id="create-shortcut" type="checkbox"> - <span i18n-content="createProfileShortcutCheckbox"></span> + <span>$i18n{createProfileShortcutCheckbox}</span> </label> </div> <div id="create-profile-supervised-container" class="checkbox"> @@ -100,19 +102,21 @@ <input id="create-profile-supervised" type="checkbox"> <span id="create-profile-supervised-signed-in"> <span id="create-profile-supervised-signed-in-label"></span> - <span id="create-profile-supervised-account-details-out-of-date-label" + <span + id="create-profile-supervised-account-details-out-of-date-label" hidden> </span> <a id="create-profile-supervised-signed-in-learn-more-link" - is="action-link" i18n-content="learnMore"></a> + is="action-link"> + $i18n{learnMore} + </a> <a id="create-profile-supervised-sign-in-again-link" - is="action-link" - i18n-content="manageProfilesSupervisedSignInAgainLink" - hidden></a> + is="action-link" hidden> + $i18n{manageProfilesSupervisedSignInAgainLink} + </a> </span> - <span id="create-profile-supervised-not-signed-in" - i18n-values=".innerHTML:manageProfilesSupervisedNotSignedIn" - hidden> + <span id="create-profile-supervised-not-signed-in" hidden> + $i18nRaw{manageProfilesSupervisedNotSignedIn} </span> </label> <span id="create-profile-supervised-indicator" @@ -123,12 +127,13 @@ </div> <div class="action-area"> <div id="create-profile-throbber" class="throbber"></div> - <a is="action-link" id="import-existing-supervised-user-link" - i18n-content="importExistingSupervisedUserLink" hidden></a> + <a is="action-link" id="import-existing-supervised-user-link" hidden> + $i18n{importExistingSupervisedUserLink} + </a> <div class="button-strip"> - <button id="create-profile-cancel" i18n-content="cancel"></button> - <button id="create-profile-ok" i18n-content="createProfileConfirm" - class="default-button"> + <button id="create-profile-cancel">$i18n{cancel}</button> + <button id="create-profile-ok" class="default-button"> + $i18n{createProfileConfirm} </button> </div> </div>
diff --git a/chrome/browser/resources/options/options.html b/chrome/browser/resources/options/options.html index 948096d..95936d5 100644 --- a/chrome/browser/resources/options/options.html +++ b/chrome/browser/resources/options/options.html
@@ -1,8 +1,8 @@ <!doctype html> -<html id="t" i18n-values="dir:textdirection;lang:language"> +<html id="t" dir="$i18n{textdirection}" lang="$i18n{language}"> <head> <meta charset="utf-8"> -<title i18n-content="optionsPageTitle"></title> +<title>$i18n{optionsPageTitle}</title> <link rel="stylesheet" href="chrome://resources/css/bubble.css"> <link rel="stylesheet" href="chrome://resources/css/bubble_button.css"> <link rel="stylesheet" href="chrome://resources/css/chrome_shared.css"> @@ -183,17 +183,19 @@ <div class="controlled-setting-bubble-extension-name"></div> </div> <div class="controlled-setting-bubble-content-row"> - <a is="action-link" class="controlled-setting-bubble-extension-manage-link" - i18n-content="controlledSettingManageExtension"></a> - <button class='controlled-setting-bubble-extension-disable-button' - i18n-content="controlledSettingDisableExtension"></button> + <a is="action-link" class="controlled-setting-bubble-extension-manage-link"> + $i18n{controlledSettingManageExtension} + </a> + <button class='controlled-setting-bubble-extension-disable-button'> + $i18n{controlledSettingDisableExtension} + </button> </div> </div> <div id="extension-controlled-warning-template" class="extension-controlled-warning-box settings-row" hidden> <div class="extension-controlled-warning"></div> - <button i18n-content="extensionDisable"></button> + <button>$i18n{extensionDisable}</button> </div> <div id="main-content"
diff --git a/chrome/browser/resources/options/password_manager.html b/chrome/browser/resources/options/password_manager.html index 6bc11a6..c128a3b 100644 --- a/chrome/browser/resources/options/password_manager.html +++ b/chrome/browser/resources/options/password_manager.html
@@ -1,65 +1,67 @@ <div id="password-manager" class="page" hidden> <div class="close-button"></div> - <h1 i18n-content="passwordsPage"></h1> + <h1>$i18n{passwordsPage}</h1> <div class="content-area"> <div class="password-manager-home"> <div id="auto-signin-block" class="checkbox"> <label> <input pref="credentials_enable_autosignin" type="checkbox"> - <span i18n-content="autoSigninTitle"></span> + <span>$i18n{autoSigninTitle}</span> </label> <div class="setting-extra-description"> - <span i18n-content="autoSigninDescription"></span> + <span>$i18n{autoSigninDescription}</span> </div> </div> <div id="password-list-headers"> <div id="passwords-title"> - <h3 i18n-content="savedPasswordsTitle"></h3> + <h3>$i18n{savedPasswordsTitle}</h3> </div> <div id="password-search-column"> <input id="password-search-box" type="search" - i18n-values="placeholder:passwordSearchPlaceholder" incremental> + placeholder="$i18n{passwordSearchPlaceholder}" incremental> </div> </div> <list id="saved-passwords-list" class="settings-list"></list> <div id="saved-passwords-list-empty-placeholder" class="settings-list-empty" hidden> - <span i18n-content="passwordsNoPasswordsDescription"></span> - <a target="_blank" i18n-content="learnMore" - i18n-values="href:passwordManagerLearnMoreURL"></a> + <span>$i18n{passwordsNoPasswordsDescription}</span> + <a target="_blank" + href="$i18nRaw{passwordManagerLearnMoreURL}">$i18n{learnMore}</a> </div> <div id="password-manager-import-export" class="action-area" hidden> <div class="button-strip"> - <button id="password-manager-import" class="password-manager-home" - i18n-content="passwordManagerImportPasswordButtonText"> + <button id="password-manager-import" class="password-manager-home"> + $i18n{passwordManagerImportPasswordButtonText} </button> - <button id="password-manager-export" class="password-manager-home" - i18n-content="passwordManagerExportPasswordButtonText"> + <button id="password-manager-export" class="password-manager-home"> + $i18n{passwordManagerExportPasswordButtonText} </button> </div> </div> - <h3 i18n-content="passwordExceptionsTitle"></h3> + <h3>$i18n{passwordExceptionsTitle}</h3> <list id="password-exceptions-list" class="settings-list"></list> <div id="password-exceptions-list-empty-placeholder" hidden class="settings-list-empty"> - <span i18n-content="passwordsNoExceptionsDescription"></span> - <a id="exceptions-learn-more" target="_blank" i18n-content="learnMore" - i18n-values="href:passwordManagerLearnMoreURL"></a> + <span>$i18n{passwordsNoExceptionsDescription}</span> + <a id="exceptions-learn-more" target="_blank" + href="$i18nRaw{passwordManagerLearnMoreURL}">$i18n{learnMore}</a> </div> </div> </div> <div class="action-area"> <span id="manage-passwords-span"> - <span i18n-content="passwordsManagePasswordsBeforeLinkText"></span> + <span>$i18n{passwordsManagePasswordsBeforeLinkText}</span> <a id="manage-passwords-link" target="_blank" - i18n-content="passwordsManagePasswordsLinkText" - i18n-values="href:passwordsManagePasswordsLink"></a> - <span i18n-content="passwordsManagePasswordsAfterLinkText"></span> + href="$i18nRaw{passwordsManagePasswordsLink}"> + $i18n{passwordsManagePasswordsLinkText} + </a> + <span>$i18n{passwordsManagePasswordsAfterLinkText}</span> </span> <div class="spacer-div"></div> <div class="button-strip"> - <button id="password-manager-confirm" class="password-manager-home" - i18n-content="done"></button> + <button id="password-manager-confirm" class="password-manager-home"> + $i18n{done} + </button> </div> </div> </div>
diff --git a/chrome/browser/resources/options/reset_profile_settings_overlay.html b/chrome/browser/resources/options/reset_profile_settings_overlay.html index 504661f..07ba372 100644 --- a/chrome/browser/resources/options/reset_profile_settings_overlay.html +++ b/chrome/browser/resources/options/reset_profile_settings_overlay.html
@@ -8,17 +8,15 @@ </div> <div class="action-area"> <div class="hbox stretch"> - <a target="_blank" i18n-content="learnMore" - i18n-values="href:resetProfileSettingsLearnMoreUrl"> - </a> + <a target="_blank" + href="$i18nRaw{resetProfileSettingsLearnMoreUrl}">$i18n{learnMore}</a> </div> <div class="action-area-right"> <div id="reset-profile-settings-throbber" class="throbber"></div> <div class="button-strip"> - <button id="reset-profile-settings-dismiss" i18n-content="cancel"> - </button> - <button id="reset-profile-settings-commit" - i18n-content="resetProfileSettingsCommit"> + <button id="reset-profile-settings-dismiss">$i18n{cancel}</button> + <button id="reset-profile-settings-commit"> + $i18n{resetProfileSettingsCommit} </button> </div> </div> @@ -28,7 +26,7 @@ <label> <input id="send-settings" type="checkbox" checked> <span> - <span i18n-content="resetProfileSettingsFeedback"></span> + <span>$i18n{resetProfileSettingsFeedback}</span> <span id="expand-feedback"></span> </span> </label>
diff --git a/chrome/browser/resources/options/search_box.html b/chrome/browser/resources/options/search_box.html index d723885..854538e5 100644 --- a/chrome/browser/resources/options/search_box.html +++ b/chrome/browser/resources/options/search_box.html
@@ -2,11 +2,10 @@ <header > <span id="browser-options-search-field-container" class="search-field-container"> - <a is="action-link" id="about-button" i18n-content="aboutButton" - hidden></a> + <a is="action-link" id="about-button" hidden>$i18n{aboutButton}</a> <input id="search-field" type="search" - i18n-values="placeholder:searchPlaceholder; - aria-label:searchPlaceholder" incremental> + placeholder="$i18n{searchPlaceholder}" + aria-label="$i18n{searchPlaceholder}" incremental> </span> </header> </div>
diff --git a/chrome/browser/resources/options/search_engine_manager.html b/chrome/browser/resources/options/search_engine_manager.html index 0f9d8566..9d76000 100644 --- a/chrome/browser/resources/options/search_engine_manager.html +++ b/chrome/browser/resources/options/search_engine_manager.html
@@ -1,16 +1,17 @@ <div id="search-engine-manager-page" class="page" hidden> <div class="close-button"></div> - <h1 i18n-content="searchEngineManagerPage"></h1> + <h1>$i18n{searchEngineManagerPage}</h1> <div class="content-area"> - <h3 i18n-content="defaultSearchEngineListTitle"></h3> + <h3>$i18n{defaultSearchEngineListTitle}</h3> <list id="default-search-engine-list" class="search-engine-list settings-list"></list> - <h3 i18n-content="otherSearchEngineListTitle"></h3> + <h3>$i18n{otherSearchEngineListTitle}</h3> <list id="other-search-engine-list" class="search-engine-list settings-list"></list> <div id="extension-keyword-div" hidden> - <h3 id="extension-keyword-list-title" - i18n-content="extensionKeywordsListTitle"></h3> + <h3 id="extension-keyword-list-title"> + $i18n{extensionKeywordsListTitle} + </h3> <list id="extension-keyword-list" class="search-engine-list settings-list"></list> </div> @@ -18,7 +19,8 @@ <div class="action-area"> <div class="button-strip"> <button id="search-engine-manager-confirm" type="submit" - class="default-button" i18n-content="done"> + class="default-button"> + $i18n{done} </button> </div> </div>
diff --git a/chrome/browser/resources/options/search_page.html b/chrome/browser/resources/options/search_page.html index 073c505..dcc9ed70 100644 --- a/chrome/browser/resources/options/search_page.html +++ b/chrome/browser/resources/options/search_page.html
@@ -1,12 +1,12 @@ <div id="searchPage" class="page" hidden> <header> - <h1 i18n-content="searchPage"></h1> + <h1>$i18n{searchPage}</h1> </header> <div id="searchPageNoMatches" hidden> - <p i18n-content="searchPageNoMatches"></p> - <p><span i18n-content="searchPageHelpLabel"></span> - <a target="_blank" i18n-content="searchPageHelpTitle" - i18n-values="href:searchPageHelpURL"></a> + <p>$i18n{searchPageNoMatches}</p> + <p><span>$i18n{searchPageHelpLabel}</span> + <a target="_blank" + href="$i18nRaw{searchPageHelpURL}">$i18n{searchPageHelpTitle}</a> </p> </div> </div>
diff --git a/chrome/browser/resources/options/secondary_user_banner.html b/chrome/browser/resources/options/secondary_user_banner.html index 84da427..f609d07 100644 --- a/chrome/browser/resources/options/secondary_user_banner.html +++ b/chrome/browser/resources/options/secondary_user_banner.html
@@ -3,8 +3,7 @@ <div class="badge"></div> <div class="text"> <p> - <span i18n-values=".innerHTML:secondaryUserBannerText"> - </span> + <span>$i18nRaw{secondaryUserBannerText}</span> </p> </div> </div>
diff --git a/chrome/browser/resources/options/spelling_confirm_overlay.html b/chrome/browser/resources/options/spelling_confirm_overlay.html index b4070df..a8c977a 100644 --- a/chrome/browser/resources/options/spelling_confirm_overlay.html +++ b/chrome/browser/resources/options/spelling_confirm_overlay.html
@@ -1,18 +1,18 @@ <div id="spelling-confirm-overlay" class="page" hidden> <div class="close-button"></div> - <h1 i18n-content="spellingConfirmOverlay"></h1> + <h1>$i18n{spellingConfirmOverlay}</h1> <div class="content-area"> - <span id="spelling-confirm-text" i18n-content="spellingConfirmMessage"> - </span> - <a id="spelling-confirm-learn-more" target="_blank" i18n-content="learnMore" - i18n-values="href:privacyLearnMoreURL"></a> + <span id="spelling-confirm-text">$i18n{spellingConfirmMessage}</span> + <a id="spelling-confirm-learn-more" target="_blank" + href="$i18nRaw{privacyLearnMoreURL}">$i18n{learnMore}</a> </div> <div class="action-area"> <div class="button-strip"> - <button id="spelling-confirm-cancel" - i18n-content="spellingConfirmDisable"></button> - <button id="spelling-confirm-ok" class="default-button" - i18n-content="spellingConfirmEnable"> + <button id="spelling-confirm-cancel"> + $i18n{spellingConfirmDisable} + </button> + <button id="spelling-confirm-ok" class="default-button"> + $i18n{spellingConfirmEnable} </button> </div> </div>
diff --git a/chrome/browser/resources/options/startup_overlay.html b/chrome/browser/resources/options/startup_overlay.html index 645bb7c..7864b70 100644 --- a/chrome/browser/resources/options/startup_overlay.html +++ b/chrome/browser/resources/options/startup_overlay.html
@@ -1,6 +1,6 @@ <div id="startup-overlay" class="page" hidden> <div class="close-button"></div> - <h1 i18n-content="startupPagesOverlay"></h1> + <h1>$i18n{startupPagesOverlay}</h1> <!-- This <input> element is always hidden. It needs to be here so that its 'controlled-by' attribute will get set when the urls preference is managed by a policy, so that the managed prefs bar will show up. @@ -11,13 +11,12 @@ </div> <div class="action-area"> <span class="hbox stretch"> - <button id="startupUseCurrentButton" - i18n-content="startupUseCurrent"></button> + <button id="startupUseCurrentButton">$i18n{startupUseCurrent}</button> </span> <div class="button-strip"> - <button id="startup-overlay-cancel" i18n-content="cancel"></button> - <button id="startup-overlay-confirm" class="default-button" - i18n-content="ok"> + <button id="startup-overlay-cancel">$i18n{cancel}</button> + <button id="startup-overlay-confirm" class="default-button"> + $i18n{ok} </button> </div> </div>
diff --git a/chrome/browser/resources/options/startup_section.html b/chrome/browser/resources/options/startup_section.html index 0d429a8..764f63a 100644 --- a/chrome/browser/resources/options/startup_section.html +++ b/chrome/browser/resources/options/startup_section.html
@@ -1,5 +1,5 @@ <section id="startup-section" guest-visibility="hidden"> - <h3 i18n-content="sectionTitleStartup"></h3> + <h3>$i18n{sectionTitleStartup}</h3> <div id="startup-section-content"> <div class="radio controlled-setting-with-label" id="newtab-section-content"> @@ -8,7 +8,7 @@ pref="session.restore_on_startup" metric="Options_Startup_NewTab"> <span> - <span i18n-content="startupShowNewTab"></span> + <span>$i18n{startupShowNewTab}</span> <span class="controlled-setting-indicator" pref="session.restore_on_startup" value="5"></span> </span> @@ -20,7 +20,7 @@ value="1" pref="session.restore_on_startup" metric="Options_Startup_LastSession"> <span> - <span i18n-content="startupRestoreLastSession"></span> + <span>$i18n{startupRestoreLastSession}</span> <span class="controlled-setting-indicator" pref="session.restore_on_startup" value="1"></span> </span> @@ -32,13 +32,12 @@ pref="session.restore_on_startup" value="4" metric="Options_Startup_Custom"> <span> - <span i18n-content="startupShowPages"></span> + <span>$i18n{startupShowPages}</span> <span class="controlled-setting-indicator" pref="session.restore_on_startup" value="4"></span> </span> </label> - <a is="action-link" id="startup-set-pages" - i18n-content="startupSetPages"></a> + <a is="action-link" id="startup-set-pages">$i18n{startupSetPages}</a> <span class="controlled-setting-indicator" pref="session.startup_urls"></span> </div>
diff --git a/chrome/browser/resources/options/supervised_user_create_confirm.html b/chrome/browser/resources/options/supervised_user_create_confirm.html index 3ccd8c7..ae4076a 100644 --- a/chrome/browser/resources/options/supervised_user_create_confirm.html +++ b/chrome/browser/resources/options/supervised_user_create_confirm.html
@@ -4,9 +4,10 @@ <div id="supervised-user-created-image"></div> <h1 id="supervised-user-created-title"></h1> <div id="supervised-user-created-text" class="content-area"></div> - <div id="supervised-user-created-action-area" class="action-area button-strip"> - <button id="supervised-user-created-done" - i18n-content="supervisedUserCreatedDone"> + <div id="supervised-user-created-action-area" + class="action-area button-strip"> + <button id="supervised-user-created-done"> + $i18n{supervisedUserCreatedDone} </button> <button id="supervised-user-created-switch"></button> </div>
diff --git a/chrome/browser/resources/options/supervised_user_import.html b/chrome/browser/resources/options/supervised_user_import.html index 72cd4c3a..9fd806d 100644 --- a/chrome/browser/resources/options/supervised_user_import.html +++ b/chrome/browser/resources/options/supervised_user_import.html
@@ -1,19 +1,19 @@ <div id="supervised-user-import" class="page" hidden> <div class="close-button"></div> <!-- Overlay to import an existing supervised user during user creation --> - <h1 id="supervised-user-import-title" i18n-content="supervisedUserImportTitle" - class="supervised-user-import"> + <h1 id="supervised-user-import-title" class="supervised-user-import"> + $i18n{supervisedUserImportTitle} </h1> <h1 id="supervised-user-select-avatar-title" - i18n-content="supervisedUserSelectAvatarTitle" class="supervised-user-select-avatar" hidden> + $i18n{supervisedUserSelectAvatarTitle} </h1> - <div id="supervised-user-import-text" i18n-content="supervisedUserImportText" - class="supervised-user-import"> + <div id="supervised-user-import-text" class="supervised-user-import"> + $i18n{supervisedUserImportText} </div> <div id="supervised-user-select-avatar-text" - i18n-content="supervisedUserSelectAvatarText" class="supervised-user-select-avatar" hidden> + $i18n{supervisedUserSelectAvatarText} </div> <div id="supervised-user-import-content-area" class="content-area"> <list id="supervised-user-list" @@ -26,15 +26,14 @@ <div id="supervised-user-import-action-area" class="action-area"> <div class="button-strip"> <div id="supervised-user-import-throbber" class="throbber"></div> - <button id="supervised-user-import-cancel" i18n-content="cancel"> - </button> + <button id="supervised-user-import-cancel">$i18n{cancel}</button> <button id="supervised-user-import-ok" - i18n-content="supervisedUserImportOk" class="default-button supervised-user-import"> + $i18n{supervisedUserImportOk} </button> <button id="supervised-user-select-avatar-ok" - i18n-content="supervisedUserSelectAvatarOk" class="default-button supervised-user-select-avatar" hidden> + $i18n{supervisedUserSelectAvatarOk} </button> </div> </div>
diff --git a/chrome/browser/resources/options/sync_section.html b/chrome/browser/resources/options/sync_section.html index f43b440a5..375601e2 100644 --- a/chrome/browser/resources/options/sync_section.html +++ b/chrome/browser/resources/options/sync_section.html
@@ -1,23 +1,22 @@ <if expr="not chromeos"> <section id="sync-section"> - <h3 i18n-content="sectionTitleSync"></h3> + <h3>$i18n{sectionTitleSync}</h3> </if> <if expr="chromeos"> <div id="sync-section"> </if> <div id="sync-overview" class="settings-row" hidden> - <p i18n-content="syncOverview"></p> - <a i18n-values="href:syncLearnMoreURL" i18n-content="learnMore" - target="_blank"></a> + <p>$i18n{syncOverview}</p> + <a href="$i18nRaw{syncLearnMoreURL}" target="_blank">$i18n{learnMore}</a> </div> <if expr="chromeos"> <div id="account-picture-wrapper"> <div id="account-picture-control"> - <input type="image" id="account-picture" tabindex="0" - alt="" i18n-values="aria-label:changePicture"> - <div id="change-picture-caption" i18n-content="changePicture"></div> + <input type="image" id="account-picture" tabindex="0" alt="" + aria-label="$i18n{changePicture}"> + <div id="change-picture-caption">$i18n{changePicture}</div> </div> <span id="account-picture-indicator" class="controlled-setting-indicator"> </span> @@ -39,14 +38,14 @@ metric="Options_ScreenLock" pref="settings.enable_screen_lock"> <span> - <span i18n-content="enableScreenlock"></span> + <span>$i18n{enableScreenlock}</span> <span class="controlled-setting-indicator" - i18n-values="textshared:screenLockShared" - pref="settings.enable_screen_lock"></span> + textshared="$i18n{screenLockShared}" + pref="settings.enable_screen_lock"></span> </span> </label> - <a is="action-link" id="manage-screenlock" - i18n-content="manageScreenlock" hidden> + <a is="action-link" id="manage-screenlock" hidden> + $i18n{manageScreenlock} </a> </div> </div> @@ -57,13 +56,12 @@ <span id="start-stop-sync-indicator" class="controlled-setting-indicator" hidden> </span> - <button id="customize-sync" i18n-content="customizeSync" - pref="sync.managed" hidden> + <button id="customize-sync" pref="sync.managed" hidden> + $i18n{customizeSync} </button> <if expr="chromeos"> - <button id="manage-accounts-button" - public-account-visibility="hidden" - i18n-content="manageAccountsButtonTitle"> + <button id="manage-accounts-button" public-account-visibility="hidden"> + $i18n{manageAccountsButtonTitle} </button> </if> <!-- chromeos --> </div>
diff --git a/chrome/browser/resources/settings/internet_page/internet_detail_page.js b/chrome/browser/resources/settings/internet_page/internet_detail_page.js index 6acf65d..81b3add 100644 --- a/chrome/browser/resources/settings/internet_page/internet_detail_page.js +++ b/chrome/browser/resources/settings/internet_page/internet_detail_page.js
@@ -143,7 +143,7 @@ * network properties have been fetched in networkPropertiesChanged_(). * @private {boolean} */ - shoudlShowConfigureWhenNetworkLoaded_: false, + shouldShowConfigureWhenNetworkLoaded_: false, /** * Whether the previous route was also the network detail page. @@ -182,7 +182,7 @@ var type = /** @type {!chrome.networkingPrivate.NetworkType} */ ( queryParams.get('type')) || CrOnc.Type.WI_FI; - this.shoudlShowConfigureWhenNetworkLoaded_ = + this.shouldShowConfigureWhenNetworkLoaded_ = queryParams.get('showConfigure') == 'true'; this.wasPreviousRouteNetworkDetailPage_ = oldRoute == settings.Route.NETWORK_DETAIL; @@ -242,7 +242,7 @@ button.focus(); } - if (this.shoudlShowConfigureWhenNetworkLoaded_ && + if (this.shouldShowConfigureWhenNetworkLoaded_ && this.networkProperties.Tether) { this.showTetherDialog_(); }
diff --git a/chrome/browser/resources/settings/internet_page/internet_page.html b/chrome/browser/resources/settings/internet_page/internet_page.html index 839f12b..a213bc6 100644 --- a/chrome/browser/resources/settings/internet_page/internet_page.html +++ b/chrome/browser/resources/settings/internet_page/internet_page.html
@@ -65,9 +65,9 @@ <template is="dom-repeat" items="[[thirdPartyVpnProviders_]]"> <div actionable class="list-item" on-tap="onAddThirdPartyVpnTap_" provider="[[item]]"> - <div class="start">[[getAddThirdParrtyVpnLabel_(item)]]</div> + <div class="start">[[getAddThirdPartyVpnLabel_(item)]]</div> <button class="icon-external" is="paper-icon-button-light" - aria-label$="[[getAddThirdParrtyVpnLabel_(item)]]"> + aria-label$="[[getAddThirdPartyVpnLabel_(item)]]"> </button> </div> </template> @@ -88,7 +88,7 @@ </settings-internet-config> </settings-subpage> </template> - + <template is="dom-if" route-path="/networkDetail" no-search> <settings-subpage page-title="$i18n{internetDetailPageTitle}"> <settings-internet-detail-page prefs="{{prefs}}" @@ -98,7 +98,7 @@ </settings-internet-detail-page> </settings-subpage> </template> - + <template is="dom-if" route-path="/knownNetworks" no-search> <settings-subpage page-title="$i18n{internetKnownNetworksPageTitle}"> <settings-internet-known-networks-page @@ -111,7 +111,7 @@ <template is="dom-if" route-path="/networks" no-search> <settings-subpage page-title="[[getNetworksPageTitle_(subpageType_)]]" show-spinner="[[showSpinner_]]"> - <settings-internet-subpage + <settings-internet-subpage default-network="[[defaultNetwork]]" device-state="[[getDeviceState_(subpageType_, deviceStates)]]" tether-device-state="[[get('Tether', deviceStates)]]"
diff --git a/chrome/browser/resources/settings/internet_page/internet_page.js b/chrome/browser/resources/settings/internet_page/internet_page.js index c4a809e..a4d148e3 100644 --- a/chrome/browser/resources/settings/internet_page/internet_page.js +++ b/chrome/browser/resources/settings/internet_page/internet_page.js
@@ -428,7 +428,7 @@ * @param {!chrome.networkingPrivate.ThirdPartyVPNProperties} provider * @return {string} */ - getAddThirdParrtyVpnLabel_: function(provider) { + getAddThirdPartyVpnLabel_: function(provider) { return this.i18n('internetAddThirdPartyVPN', provider.ProviderName); },
diff --git a/chrome/browser/resources/settings/internet_page/network_property_list.html b/chrome/browser/resources/settings/internet_page/network_property_list.html index 01a09c9..b3778cf 100644 --- a/chrome/browser/resources/settings/internet_page/network_property_list.html +++ b/chrome/browser/resources/settings/internet_page/network_property_list.html
@@ -33,7 +33,7 @@ <template is="dom-repeat" items="[[fields]]" filter="[[computeFilter_(prefix, propertyDict, editFieldTypes)]]"> <div class="settings-box single-column two-line"> - <!-- Propety label --> + <!-- Property label --> <div>[[getPropertyLabel_(item, prefix)]]</div> <!-- Uneditable property value --> <div class="layout horizontal"
diff --git a/chrome/browser/resources/settings/internet_page/network_proxy.js b/chrome/browser/resources/settings/internet_page/network_proxy.js index 0812388..1579b0b 100644 --- a/chrome/browser/resources/settings/internet_page/network_proxy.js +++ b/chrome/browser/resources/settings/internet_page/network_proxy.js
@@ -199,7 +199,7 @@ proxy.PAC = /** @type {string|undefined} */ ( CrOnc.getActiveValue(proxySettings.PAC)); } - // Use saved ExcludeDomanains and Manual if not defined. + // Use saved ExcludeDomains and Manual if not defined. proxy.ExcludeDomains = proxy.ExcludeDomains || this.savedExcludeDomains_; proxy.Manual = proxy.Manual || this.savedManual_;
diff --git a/chrome/browser/resources/settings/internet_page/network_summary.js b/chrome/browser/resources/settings/internet_page/network_summary.js index b1e607f..3f83c7af 100644 --- a/chrome/browser/resources/settings/internet_page/network_summary.js +++ b/chrome/browser/resources/settings/internet_page/network_summary.js
@@ -312,7 +312,7 @@ if (!device) continue; // The technology for this device type is unavailable. - // If both 'Tether' and 'Cellular' technoligies exist, merge the network + // If both 'Tether' and 'Cellular' technologies exist, merge the network // lists and do not add an active network for 'Tether' so that there is // only one 'Mobile data' section / subpage. if (type == CrOnc.Type.TETHER && newDeviceStates[CrOnc.Type.CELLULAR]) {
diff --git a/chrome/browser/resources/settings/on_startup_page/compiled_resources2.gyp b/chrome/browser/resources/settings/on_startup_page/compiled_resources2.gyp index d29ed565..725d084 100644 --- a/chrome/browser/resources/settings/on_startup_page/compiled_resources2.gyp +++ b/chrome/browser/resources/settings/on_startup_page/compiled_resources2.gyp
@@ -14,7 +14,7 @@ { 'target_name': 'on_startup_page', 'dependencies': [ - 'on_startup_browser_proxy', + '../compiled_resources2.gyp:route', ], 'includes': ['../../../../../third_party/closure_compiler/compile_js2.gypi'], }, @@ -27,6 +27,7 @@ '<(DEPTH)/ui/webui/resources/js/cr/ui/compiled_resources2.gyp:focus_without_ink', '<(DEPTH)/ui/webui/resources/cr_elements/compiled_resources2.gyp:cr_scrollable_behavior', '<(EXTERNS_GYP):settings_private', + 'on_startup_browser_proxy', 'startup_urls_page_browser_proxy', 'startup_url_entry', ],
diff --git a/chrome/browser/resources/settings/on_startup_page/on_startup_page.html b/chrome/browser/resources/settings/on_startup_page/on_startup_page.html index e0ce1da9..e5cac20 100644 --- a/chrome/browser/resources/settings/on_startup_page/on_startup_page.html +++ b/chrome/browser/resources/settings/on_startup_page/on_startup_page.html
@@ -1,51 +1,34 @@ <link rel="import" href="chrome://resources/html/polymer.html"> -<link rel="import" href="../controls/controlled_radio_button.html"> -<link rel="import" href="../controls/extension_controlled_indicator.html"> -<link rel="import" href="../controls/settings_radio_group.html"> -<link rel="import" href="on_startup_browser_proxy.html"> -<link rel="import" href="startup_urls_page.html"> <link rel="import" href="../settings_shared_css.html"> +<link rel="import" href="startup_urls_page.html"> <dom-module id="settings-on-startup-page"> <template> - <style include="settings-shared"> - .block { - display: block; - } - </style> - <div class="settings-box block first"> - <settings-radio-group id="onStartupRadioGroup" - pref="{{prefs.session.restore_on_startup}}"> - <controlled-radio-button name="[[prefValues_.OPEN_NEW_TAB]]" - pref="[[prefs.session.restore_on_startup]]" - label="$i18n{onStartupOpenNewTab}" - no-extension-indicator> - </controlled-radio-button> - <template is="dom-if" if="[[showIndicator_( - ntpExtension_, prefs.session.restore_on_startup.value)]]"> - <extension-controlled-indicator - extension-id="[[ntpExtension_.id]]" - extension-name="[[ntpExtension_.name]]" - extension-can-be-disabled="[[ntpExtension_.canBeDisabled]]" - on-extension-disable="getNtpExtension_"> - </extension-controlled-indicator> - </template> - <controlled-radio-button name="[[prefValues_.CONTINUE]]" - pref="[[prefs.session.restore_on_startup]]" - label="$i18n{onStartupContinue}"> - </controlled-radio-button> - <controlled-radio-button name="[[prefValues_.OPEN_SPECIFIC]]" - pref="[[prefs.session.restore_on_startup]]" - label="$i18n{onStartupOpenSpecific}"> - </controlled-radio-button> - </settings-radio-group> - </div> - <template is="dom-if" - if="[[showStartupUrls_(prefs.session.restore_on_startup.value)]]"> - <settings-startup-urls-page prefs="[[prefs]]"> - </settings-startup-urls-page> - </template> + <style include="settings-shared"></style> + <settings-animated-pages id="pages" section="onStartup" + focus-config="[[focusConfig_]]"> + <neon-animatable route-path="default"> + <div class="settings-box first two-line" + id="manage-startup-urls-subpage-trigger" + on-tap="onManageStartupUrls_" actionable> + <div class="start"> + $i18n{onStartupManage} + <div class="secondary">$i18n{onStartupDescription}</div> + </div> + <button class="subpage-arrow" is="paper-icon-button-light" + aria-label="$i18n{onStartupManage}"></button> + </div> + </neon-animatable> + <template is="dom-if" route-path="/startupUrls"> + <settings-subpage + associated-control="[[$$('#manage-startup-urls-subpage-trigger')]]" + page-title="$i18n{onStartupManage}"> + <settings-startup-urls-page prefs="{{prefs}}"> + </settings-startup-urls-page> + </settings-subpage> + </template> + </settings-animated-pages> </template> <script src="on_startup_page.js"></script> </dom-module>
diff --git a/chrome/browser/resources/settings/on_startup_page/on_startup_page.js b/chrome/browser/resources/settings/on_startup_page/on_startup_page.js index c02d05c..70445ed2 100644 --- a/chrome/browser/resources/settings/on_startup_page/on_startup_page.js +++ b/chrome/browser/resources/settings/on_startup_page/on_startup_page.js
@@ -5,72 +5,16 @@ /** * @fileoverview * 'settings-on-startup-page' is a settings page. - * - * Example: - * - * <neon-animated-pages> - * <settings-on-startup-page prefs="{{prefs}}"> - * </settings-on-startup-page> - * ... other pages ... - * </neon-animated-pages> */ Polymer({ is: 'settings-on-startup-page', properties: { - prefs: { - type: Object, - notify: true, - }, - - /** @private {?NtpExtension} */ - ntpExtension_: Object, - - /** - * Enum values for the 'session.restore_on_startup' preference. - * @private {!Object<string, number>} - */ - prefValues_: { - readOnly: true, - type: Object, - value: { - CONTINUE: 1, - OPEN_NEW_TAB: 5, - OPEN_SPECIFIC: 4, - }, - }, - }, - - /** @override */ - attached: function() { - this.getNtpExtension_(); + prefs: Object, }, /** @private */ - getNtpExtension_: function() { - settings.OnStartupBrowserProxyImpl.getInstance().getNtpExtension().then( - function(ntpExtension) { - this.ntpExtension_ = ntpExtension; - }.bind(this)); - }, - - /** - * @param {?NtpExtension} ntpExtension - * @param {number} restoreOnStartup Value of prefs.session.restore_on_startup. - * @return {boolean} - * @private - */ - showIndicator_: function(ntpExtension, restoreOnStartup) { - return !!ntpExtension && restoreOnStartup == this.prefValues_.OPEN_NEW_TAB; - }, - - /** - * Determine whether to show the user defined startup pages. - * @param {number} restoreOnStartup Enum value from prefValues_. - * @return {boolean} Whether the open specific pages is selected. - * @private - */ - showStartupUrls_: function(restoreOnStartup) { - return restoreOnStartup == this.prefValues_.OPEN_SPECIFIC; + onManageStartupUrls_: function() { + settings.navigateTo(settings.Route.STARTUP_URLS); }, });
diff --git a/chrome/browser/resources/settings/on_startup_page/startup_urls_page.html b/chrome/browser/resources/settings/on_startup_page/startup_urls_page.html index e66cbb3d..d1f8e9a3 100644 --- a/chrome/browser/resources/settings/on_startup_page/startup_urls_page.html +++ b/chrome/browser/resources/settings/on_startup_page/startup_urls_page.html
@@ -8,8 +8,11 @@ <link rel="import" href="chrome://resources/polymer/v1_0/iron-list/iron-list.html"> <link rel="import" href="chrome://resources/html/web_ui_listener_behavior.html"> <link rel="import" href="chrome://resources/cr_elements/cr_scrollable_behavior.html"> +<link rel="import" href="../controls/controlled_radio_button.html"> <link rel="import" href="../controls/extension_controlled_indicator.html"> +<link rel="import" href="../controls/settings_radio_group.html"> <link rel="import" href="../settings_shared_css.html"> +<link rel="import" href="on_startup_browser_proxy.html"> <link rel="import" href="startup_url_dialog.html"> <link rel="import" href="startup_url_entry.html"> <link rel="import" href="startup_urls_page_browser_proxy.html"> @@ -30,44 +33,79 @@ cursor: default; } </style> - <div id="outer" class="layout vertical flex vertical-list"> - <div id="container" class="scroll-container" scrollable> - <iron-list items="[[startupPages_]]" scroll-target="container" - preserve-focus> - <template> - <settings-startup-url-entry model="[[item]]" - tabindex$="[[tabIndex]]" iron-list-tab-index="[[tabIndex]]" - last-focused="{{lastFocused_}}" - editable="[[shouldAllowUrlsEdit_( - prefs.session.startup_urls.enforcement)]]"> - </settings-startup-url-entry> - </template> - </iron-list> - </div> - <template is="dom-if" if="[[shouldAllowUrlsEdit_( - prefs.session.startup_urls.enforcement)]]" restamp> - <div class="list-item" id="addPage"> - <a is="action-link" class="list-button" on-tap="onAddPageTap_"> - $i18n{onStartupAddNewPage} - </a> - </div> - <div class="list-item" id="useCurrentPages"> - <a is="action-link" class="list-button" - on-tap="onUseCurrentPagesTap_"> - $i18n{onStartupUseCurrent} - </a> - </div> - </template> - <template is="dom-if" if="[[prefs.session.startup_urls.extensionId]]" - restamp> - <extension-controlled-indicator - extension-id="[[prefs.session.startup_urls.extensionId]]" - extension-name="[[prefs.session.startup_urls.controlledByName]]" - extension-can-be-disabled="[[ - prefs.session.startup_urls.extensionCanBeDisabled]]"> - </extension-controlled-indicator> - </template> + <div class="settings-box first"> + <h2>$i18n{onStartupPages}</h2> </div> + <div class="settings-box first"> + <div class="start"> + <settings-radio-group id="onStartupRadioGroup" + pref="{{prefs.session.restore_on_startup}}"> + <controlled-radio-button name="[[prefValues_.OPEN_NEW_TAB]]" + pref="[[prefs.session.restore_on_startup]]" + label="$i18n{onStartupOpenNewTab}" + no-extension-indicator> + </controlled-radio-button> + <template is="dom-if" if="[[showIndicator_( + ntpExtension_, prefs.session.restore_on_startup.value)]]"> + <extension-controlled-indicator + extension-id="[[ntpExtension_.id]]" + extension-name="[[ntpExtension_.name]]" + extension-can-be-disabled="[[ntpExtension_.canBeDisabled]]" + on-extension-disable="getNtpExtension_"> + </extension-controlled-indicator> + </template> + <controlled-radio-button name="[[prefValues_.CONTINUE]]" + pref="[[prefs.session.restore_on_startup]]" + label="$i18n{onStartupContinue}"> + </controlled-radio-button> + <controlled-radio-button name="[[prefValues_.OPEN_SPECIFIC]]" + pref="[[prefs.session.restore_on_startup]]" + label="$i18n{onStartupOpenSpecific}"> + </controlled-radio-button> + </settings-radio-group> + </div> + </div> + <template is="dom-if" + if="[[showStartupUrls_(prefs.session.restore_on_startup.value)]]"> + <div id="outer" class="layout vertical flex vertical-list"> + <div id="container" class="scroll-container" scrollable> + <iron-list items="[[startupPages_]]" scroll-target="container" + preserve-focus> + <template> + <settings-startup-url-entry model="[[item]]" + tabindex$="[[tabIndex]]" iron-list-tab-index="[[tabIndex]]" + last-focused="{{lastFocused_}}" + editable="[[shouldAllowUrlsEdit_( + prefs.session.startup_urls.enforcement)]]"> + </settings-startup-url-entry> + </template> + </iron-list> + </div> + <template is="dom-if" if="[[shouldAllowUrlsEdit_( + prefs.session.startup_urls.enforcement)]]" restamp> + <div class="list-item" id="addPage"> + <a is="action-link" class="list-button" on-tap="onAddPageTap_"> + $i18n{onStartupAddNewPage} + </a> + </div> + <div class="list-item" id="useCurrentPages"> + <a is="action-link" class="list-button" + on-tap="onUseCurrentPagesTap_"> + $i18n{onStartupUseCurrent} + </a> + </div> + </template> + <template is="dom-if" if="[[prefs.session.startup_urls.extensionId]]" + restamp> + <extension-controlled-indicator + extension-id="[[prefs.session.startup_urls.extensionId]]" + extension-name="[[prefs.session.startup_urls.controlledByName]]" + extension-can-be-disabled="[[ + prefs.session.startup_urls.extensionCanBeDisabled]]"> + </extension-controlled-indicator> + </template> + </div> + </template> <template is="dom-if" if="[[showStartupUrlDialog_]]" restamp> <settings-startup-url-dialog model="[[startupUrlDialogModel_]]" on-close="destroyUrlDialog_">
diff --git a/chrome/browser/resources/settings/on_startup_page/startup_urls_page.js b/chrome/browser/resources/settings/on_startup_page/startup_urls_page.js index 38451be..02ab24e 100644 --- a/chrome/browser/resources/settings/on_startup_page/startup_urls_page.js +++ b/chrome/browser/resources/settings/on_startup_page/startup_urls_page.js
@@ -13,7 +13,10 @@ behaviors: [CrScrollableBehavior, WebUIListenerBehavior], properties: { - prefs: Object, + prefs: { + type: Object, + notify: true, + }, /** * Pages to load upon browser startup. @@ -29,6 +32,23 @@ /** @private {Object}*/ lastFocused_: Object, + + /** @private {?NtpExtension} */ + ntpExtension_: Object, + + /** + * Enum values for the 'session.restore_on_startup' preference. + * @private {!Object<string, number>} + */ + prefValues_: { + readOnly: true, + type: Object, + value: { + CONTINUE: 1, + OPEN_NEW_TAB: 5, + OPEN_SPECIFIC: 4, + }, + }, }, /** @private {?settings.StartupUrlsPageBrowserProxy} */ @@ -42,6 +62,11 @@ /** @override */ attached: function() { + settings.OnStartupBrowserProxyImpl.getInstance().getNtpExtension().then( + function(ntpExtension) { + this.ntpExtension_ = ntpExtension; + }.bind(this)); + this.browserProxy_ = settings.StartupUrlsPageBrowserProxyImpl.getInstance(); this.addWebUIListener('update-startup-pages', function(startupPages) { // If an "edit" URL dialog was open, close it, because the underlying page @@ -96,4 +121,24 @@ return this.get('prefs.session.startup_urls.enforcement') != chrome.settingsPrivate.Enforcement.ENFORCED; }, + + /** + * @param {?NtpExtension} ntpExtension + * @param {number} restoreOnStartup Value of prefs.session.restore_on_startup. + * @return {boolean} + * @private + */ + showIndicator_: function(ntpExtension, restoreOnStartup) { + return !!ntpExtension && restoreOnStartup == this.prefValues_.OPEN_NEW_TAB; + }, + + /** + * Determine whether to show the user defined startup pages. + * @param {number} restoreOnStartup Enum value from prefValues_. + * @return {boolean} Whether the open specific pages is selected. + * @private + */ + showStartupUrls_: function(restoreOnStartup) { + return restoreOnStartup == this.prefValues_.OPEN_SPECIFIC; + }, });
diff --git a/chrome/browser/resources/settings/route.js b/chrome/browser/resources/settings/route.js index 1d3496b..ed960c6 100644 --- a/chrome/browser/resources/settings/route.js +++ b/chrome/browser/resources/settings/route.js
@@ -138,6 +138,7 @@ // </if> r.ON_STARTUP = r.BASIC.createSection('/onStartup', 'onStartup'); + r.STARTUP_URLS = r.ON_STARTUP.createChild('/startupUrls'); r.PEOPLE = r.BASIC.createSection('/people', 'people'); r.SYNC = r.PEOPLE.createChild('/syncSetup');
diff --git a/chrome/browser/safe_browsing/download_protection_service.cc b/chrome/browser/safe_browsing/download_protection_service.cc index d2764d21..822e3353 100644 --- a/chrome/browser/safe_browsing/download_protection_service.cc +++ b/chrome/browser/safe_browsing/download_protection_service.cc
@@ -157,6 +157,19 @@ DOWNLOAD_CHECKS_MAX }; +void AddEventUrlToReferrerChain(const content::DownloadItem& item, + ReferrerChain* out_referrer_chain) { + ReferrerChainEntry* event_url_entry = out_referrer_chain->Add(); + event_url_entry->set_url(item.GetURL().spec()); + event_url_entry->set_type(ReferrerChainEntry::EVENT_URL); + event_url_entry->set_referrer_url( + item.GetWebContents()->GetLastCommittedURL().spec()); + event_url_entry->set_is_retargeting(false); + event_url_entry->set_navigation_time_msec(base::Time::Now().ToJavaTime()); + for (const GURL& url : item.GetUrlChain()) + event_url_entry->add_server_redirect_chain()->set_url(url.spec()); +} + } // namespace const char DownloadProtectionService::kDownloadRequestUrl[] = @@ -298,10 +311,9 @@ if (!item_) return; - item_->SetUserData( - kDownloadReferrerChainDataKey, - base::MakeUnique<ReferrerChainData>(service_->IdentifyReferrerChain( - item_->GetURL(), item_->GetWebContents()))); + item_->SetUserData(kDownloadReferrerChainDataKey, + base::MakeUnique<ReferrerChainData>( + service_->IdentifyReferrerChain(*item_))); } void UpdateDownloadCheckStats(SBStatsType stat_type) { @@ -1958,8 +1970,7 @@ } std::unique_ptr<ReferrerChain> DownloadProtectionService::IdentifyReferrerChain( - const GURL& download_url, - content::WebContents* web_contents) { + const content::DownloadItem& item) { // If navigation_observer_manager_ is null, return immediately. This could // happen in tests. if (!navigation_observer_manager_) @@ -1967,6 +1978,7 @@ std::unique_ptr<ReferrerChain> referrer_chain = base::MakeUnique<ReferrerChain>(); + content::WebContents* web_contents = item.GetWebContents(); int download_tab_id = SessionTabHelper::IdForTab(web_contents); UMA_HISTOGRAM_BOOLEAN( "SafeBrowsing.ReferrerHasInvalidTabID.DownloadAttribution", @@ -1974,7 +1986,7 @@ // We look for the referrer chain that leads to the download url first. SafeBrowsingNavigationObserverManager::AttributionResult result = navigation_observer_manager_->IdentifyReferrerChainByEventURL( - download_url, download_tab_id, kDownloadAttributionUserGestureLimit, + item.GetURL(), download_tab_id, kDownloadAttributionUserGestureLimit, referrer_chain.get()); // If no navigation event is found, this download is not triggered by regular @@ -1983,6 +1995,7 @@ if (result == SafeBrowsingNavigationObserverManager::NAVIGATION_EVENT_NOT_FOUND && web_contents && web_contents->GetLastCommittedURL().is_valid()) { + AddEventUrlToReferrerChain(item, referrer_chain.get()); result = navigation_observer_manager_->IdentifyReferrerChainByWebContents( web_contents, kDownloadAttributionUserGestureLimit, referrer_chain.get());
diff --git a/chrome/browser/safe_browsing/download_protection_service.h b/chrome/browser/safe_browsing/download_protection_service.h index a0c6e51..7acc56ef 100644 --- a/chrome/browser/safe_browsing/download_protection_service.h +++ b/chrome/browser/safe_browsing/download_protection_service.h
@@ -253,6 +253,8 @@ PPAPIDownloadRequest_InvalidResponse); FRIEND_TEST_ALL_PREFIXES(DownloadProtectionServiceTest, PPAPIDownloadRequest_Timeout); + FRIEND_TEST_ALL_PREFIXES(DownloadProtectionServiceTest, + VerifyReferrerChainWithEmptyNavigationHistory); FRIEND_TEST_ALL_PREFIXES(DownloadProtectionServiceFlagTest, CheckClientDownloadOverridenByFlag); @@ -300,8 +302,7 @@ // a download. This function also records UMA stats of download attribution // result. std::unique_ptr<ReferrerChain> IdentifyReferrerChain( - const GURL& download_url, - content::WebContents* web_contents); + const content::DownloadItem& item); // If kDownloadAttribution feature is enabled, identify referrer chain of the // PPAPI download based on the frame URL where the download is initiated.
diff --git a/chrome/browser/safe_browsing/download_protection_service_unittest.cc b/chrome/browser/safe_browsing/download_protection_service_unittest.cc index d42213e..0976d6e 100644 --- a/chrome/browser/safe_browsing/download_protection_service_unittest.cc +++ b/chrome/browser/safe_browsing/download_protection_service_unittest.cc
@@ -50,6 +50,7 @@ #include "content/public/test/mock_download_item.h" #include "content/public/test/test_browser_thread_bundle.h" #include "content/public/test/test_utils.h" +#include "content/public/test/web_contents_tester.h" #include "net/base/url_util.h" #include "net/cert/x509_certificate.h" #include "net/http/http_status_code.h" @@ -2386,6 +2387,37 @@ EXPECT_EQ(".sdF", request.alternate_extensions(2)); } +TEST_F(DownloadProtectionServiceTest, + VerifyReferrerChainWithEmptyNavigationHistory) { + // Setup a web_contents with "http://example.com" as its last committed url. + content::WebContents* web_contents = + content::WebContentsTester::CreateTestWebContents(profile_.get(), + nullptr); + content::WebContentsTester* web_contents_tester = + content::WebContentsTester::For(web_contents); + web_contents_tester->SetLastCommittedURL(GURL("http://example.com")); + + NiceMockDownloadItem item; + PrepareBasicDownloadItem( + &item, {"http://referrer.com", "http://www.evil.com/a.exe"}, // url_chain + "http://example.com/", // referrer + FILE_PATH_LITERAL("a.tmp"), // tmp_path + FILE_PATH_LITERAL("a.exe")); // final_path + ON_CALL(item, GetWebContents()).WillByDefault(Return(web_contents)); + + std::unique_ptr<ReferrerChain> referrer_chain = + download_service_->IdentifyReferrerChain(item); + + ASSERT_EQ(1, referrer_chain->size()); + EXPECT_EQ(item.GetUrlChain().back(), referrer_chain->Get(0).url()); + EXPECT_EQ(web_contents->GetLastCommittedURL().spec(), + referrer_chain->Get(0).referrer_url()); + EXPECT_EQ(ReferrerChainEntry::EVENT_URL, referrer_chain->Get(0).type()); + EXPECT_EQ(static_cast<int>(item.GetUrlChain().size()), + referrer_chain->Get(0).server_redirect_chain_size()); + EXPECT_FALSE(referrer_chain->Get(0).is_retargeting()); +} + // ------------ class DownloadProtectionServiceFlagTest ---------------- class DownloadProtectionServiceFlagTest : public DownloadProtectionServiceTest { protected:
diff --git a/chrome/browser/safe_browsing/safe_browsing_navigation_observer.cc b/chrome/browser/safe_browsing/safe_browsing_navigation_observer.cc index 1be3c994..d2c47cb 100644 --- a/chrome/browser/safe_browsing/safe_browsing_navigation_observer.cc +++ b/chrome/browser/safe_browsing/safe_browsing_navigation_observer.cc
@@ -7,10 +7,13 @@ #include "base/memory/ptr_util.h" #include "base/time/time.h" #include "chrome/browser/browser_process.h" +#include "chrome/browser/content_settings/host_content_settings_map_factory.h" #include "chrome/browser/profiles/profile.h" #include "chrome/browser/safe_browsing/safe_browsing_navigation_observer_manager.h" #include "chrome/browser/safe_browsing/safe_browsing_service.h" #include "chrome/browser/sessions/session_tab_helper.h" +#include "chrome/browser/ui/page_info/page_info_ui.h" +#include "components/content_settings/core/browser/host_content_settings_map.h" #include "content/public/browser/navigation_handle.h" #include "content/public/browser/render_frame_host.h" #include "content/public/browser/render_process_host.h" @@ -98,7 +101,11 @@ : content::WebContentsObserver(contents), manager_(manager), has_user_gesture_(false), - last_user_gesture_timestamp_(base::Time()) {} + last_user_gesture_timestamp_(base::Time()), + content_settings_observer_(this) { + content_settings_observer_.Add(HostContentSettingsMapFactory::GetForProfile( + Profile::FromBrowserContext(web_contents()->GetBrowserContext()))); +} SafeBrowsingNavigationObserver::~SafeBrowsingNavigationObserver() {} @@ -256,4 +263,17 @@ renderer_initiated); } +void SafeBrowsingNavigationObserver::OnContentSettingChanged( + const ContentSettingsPattern& primary_pattern, + const ContentSettingsPattern& secondary_pattern, + ContentSettingsType content_type, + std::string resource_identifier) { + // For all the content settings that can be changed via page info UI, we + // assume there is a user gesture associated with the content setting change. + if (primary_pattern.Matches(web_contents()->GetLastCommittedURL()) && + PageInfoUI::ContentSettingsTypeInPageInfo(content_type)) { + DidGetUserInteraction(blink::WebInputEvent::kMouseDown); + } +} + } // namespace safe_browsing
diff --git a/chrome/browser/safe_browsing/safe_browsing_navigation_observer.h b/chrome/browser/safe_browsing/safe_browsing_navigation_observer.h index 15030a6..0f80f5e 100644 --- a/chrome/browser/safe_browsing/safe_browsing_navigation_observer.h +++ b/chrome/browser/safe_browsing/safe_browsing_navigation_observer.h
@@ -5,7 +5,10 @@ #ifndef CHROME_BROWSER_SAFE_BROWSING_SAFE_BROWSING_NAVIGATION_OBSERVER_H_ #define CHROME_BROWSER_SAFE_BROWSING_SAFE_BROWSING_NAVIGATION_OBSERVER_H_ +#include "base/scoped_observer.h" #include "base/supports_user_data.h" +#include "components/content_settings/core/browser/content_settings_observer.h" +#include "components/content_settings/core/common/content_settings.h" #include "content/public/browser/web_contents_observer.h" #include "url/gurl.h" @@ -13,6 +16,8 @@ class NavigationHandle; } +class HostContentSettingsMap; + namespace safe_browsing { class SafeBrowsingNavigationObserverManager; @@ -68,7 +73,8 @@ // Observes the navigation events for a single WebContents (both main-frame // and sub-frame navigations). class SafeBrowsingNavigationObserver : public base::SupportsUserData::Data, - public content::WebContentsObserver { + public content::WebContentsObserver, + public content_settings::Observer { public: static void MaybeCreateForWebContents( content::WebContents* web_contents); @@ -83,6 +89,7 @@ ~SafeBrowsingNavigationObserver() override; private: + FRIEND_TEST_ALL_PREFIXES(SBNavigationObserverTest, TestContentSettingChange); typedef std::unordered_map<content::NavigationHandle*, std::unique_ptr<NavigationEvent>> NavigationHandleMap; @@ -107,6 +114,12 @@ bool started_from_context_menu, bool renderer_initiated) override; + // content_settings::Observer overrides. + void OnContentSettingChanged(const ContentSettingsPattern& primary_pattern, + const ContentSettingsPattern& secondary_pattern, + ContentSettingsType content_type, + std::string resource_identifier) override; + // Map keyed on NavigationHandle* to keep track of all the ongoing navigation // events. NavigationHandle pointers are owned by RenderFrameHost. Since a // NavigationHandle object will be destructed after navigation is done, @@ -121,6 +134,8 @@ bool has_user_gesture_; base::Time last_user_gesture_timestamp_; + ScopedObserver<HostContentSettingsMap, content_settings::Observer> + content_settings_observer_; DISALLOW_COPY_AND_ASSIGN(SafeBrowsingNavigationObserver); };
diff --git a/chrome/browser/safe_browsing/safe_browsing_navigation_observer_unittest.cc b/chrome/browser/safe_browsing/safe_browsing_navigation_observer_unittest.cc index 1a51004c..ef5f3ab 100644 --- a/chrome/browser/safe_browsing/safe_browsing_navigation_observer_unittest.cc +++ b/chrome/browser/safe_browsing/safe_browsing_navigation_observer_unittest.cc
@@ -347,4 +347,33 @@ EXPECT_EQ("9.9.9.9", host_to_ip_map()->at(host_1).at(0).ip); } +TEST_F(SBNavigationObserverTest, TestContentSettingChange) { + user_gesture_map()->clear(); + ASSERT_EQ(0U, user_gesture_map()->size()); + + content::WebContents* web_content = + browser()->tab_strip_model()->GetWebContentsAt(0); + + // Simulate content setting change via page info UI. + navigation_observer_->OnContentSettingChanged( + ContentSettingsPattern::FromURL(web_content->GetLastCommittedURL()), + ContentSettingsPattern::Wildcard(), CONTENT_SETTINGS_TYPE_NOTIFICATIONS, + std::string()); + + // A user gesture should be recorded. + ASSERT_EQ(1U, user_gesture_map()->size()); + EXPECT_NE(user_gesture_map()->end(), user_gesture_map()->find(web_content)); + + user_gesture_map()->clear(); + ASSERT_EQ(0U, user_gesture_map()->size()); + + // Simulate content setting change that cannot be changed via page info UI. + navigation_observer_->OnContentSettingChanged( + ContentSettingsPattern::FromURL(web_content->GetLastCommittedURL()), + ContentSettingsPattern::Wildcard(), CONTENT_SETTINGS_TYPE_SITE_ENGAGEMENT, + std::string()); + // No user gesture should be recorded. + EXPECT_EQ(0U, user_gesture_map()->size()); +} + } // namespace safe_browsing
diff --git a/chrome/browser/sessions/session_data_deleter.cc b/chrome/browser/sessions/session_data_deleter.cc index 72af6aa..e4b2d263 100644 --- a/chrome/browser/sessions/session_data_deleter.cc +++ b/chrome/browser/sessions/session_data_deleter.cc
@@ -3,6 +3,7 @@ // found in the LICENSE file. #include <stddef.h> +#include <stdint.h> #include "base/bind.h" #include "base/command_line.h" @@ -26,8 +27,8 @@ namespace { -void CookieDeleted(int num_cookies_deleted) { - DCHECK_EQ(1, num_cookies_deleted); +void CookieDeleted(uint32_t num_cookies_deleted) { + DCHECK_EQ(1u, num_cookies_deleted); } class SessionDataDeleter @@ -59,7 +60,7 @@ // Called when all session-only cookies have been deleted. void DeleteSessionCookiesDone(net::CookieStore* cookie_store, - int num_deleted); + uint32_t num_deleted); // Deletes the cookies in |cookies| that are for origins which are // session-only. @@ -134,7 +135,7 @@ void SessionDataDeleter::DeleteSessionCookiesDone( net::CookieStore* cookie_store, - int num_deleted) { + uint32_t num_deleted) { // If these callbacks are invoked, |cookie_store| is gauranteed to still // exist, since deleting the CookieStore will cancel pending callbacks. cookie_store->GetAllCookiesAsync(
diff --git a/chrome/browser/subresource_filter/subresource_filter_browsertest.cc b/chrome/browser/subresource_filter/subresource_filter_browsertest.cc index bbd058e..0e3c700 100644 --- a/chrome/browser/subresource_filter/subresource_filter_browsertest.cc +++ b/chrome/browser/subresource_filter/subresource_filter_browsertest.cc
@@ -16,9 +16,11 @@ #include "base/memory/ptr_util.h" #include "base/path_service.h" #include "base/strings/pattern.h" +#include "base/strings/string16.h" #include "base/strings/string_piece.h" #include "base/strings/string_util.h" #include "base/strings/stringprintf.h" +#include "base/strings/utf_string_conversions.h" #include "base/test/histogram_tester.h" #include "base/test/simple_test_clock.h" #include "chrome/browser/browser_process.h" @@ -69,6 +71,7 @@ #include "content/public/browser/render_frame_host.h" #include "content/public/browser/web_contents.h" #include "content/public/common/browser_side_navigation_policy.h" +#include "content/public/common/content_features.h" #include "content/public/common/content_switches.h" #include "content/public/common/referrer.h" #include "content/public/test/browser_test_utils.h" @@ -212,12 +215,13 @@ protected: void SetUpCommandLine(base::CommandLine* command_line) override { - command_line->AppendSwitchASCII( - switches::kEnableFeatures, - base::JoinString( - {kSafeBrowsingSubresourceFilter.name, "SafeBrowsingV4OnlyEnabled", - kSafeBrowsingSubresourceFilterExperimentalUI.name}, - ",")); + command_line->AppendSwitchASCII(switches::kEnableFeatures, + base::JoinString(RequiredFeatures(), ",")); + } + + std::vector<base::StringPiece> RequiredFeatures() const { + return {kSafeBrowsingSubresourceFilter.name, "SafeBrowsingV4OnlyEnabled", + kSafeBrowsingSubresourceFilterExperimentalUI.name}; } void SetUp() override { @@ -469,6 +473,41 @@ std::unique_ptr<net::SpawnedTestServer> websocket_test_server_; }; +enum class OffMainThreadFetchPolicy { + kEnabled, + kDisabled, +}; + +class SubresourceFilterWorkerFetchBrowserTest + : public SubresourceFilterBrowserTest, + public ::testing::WithParamInterface<OffMainThreadFetchPolicy> { + public: + SubresourceFilterWorkerFetchBrowserTest() {} + ~SubresourceFilterWorkerFetchBrowserTest() override {} + + protected: + void SetUpCommandLine(base::CommandLine* command_line) override { + std::vector<base::StringPiece> features = + SubresourceFilterBrowserTest::RequiredFeatures(); + if (GetParam() == OffMainThreadFetchPolicy::kEnabled) { + features.push_back(features::kOffMainThreadFetch.name); + } else { + command_line->AppendSwitchASCII(switches::kDisableFeatures, + features::kOffMainThreadFetch.name); + } + command_line->AppendSwitchASCII(switches::kEnableFeatures, + base::JoinString(features, ",")); + } + + void ClearTitle() { + ASSERT_TRUE(content::ExecuteScript(web_contents()->GetMainFrame(), + "document.title = \"\";")); + } + + private: + DISALLOW_COPY_AND_ASSIGN(SubresourceFilterWorkerFetchBrowserTest); +}; + // Tests ----------------------------------------------------------------------- IN_PROC_BROWSER_TEST_F(SubresourceFilterBrowserTest, MainFrameActivation) { @@ -1401,6 +1440,52 @@ ::testing::Values(WebSocketCreationPolicy::IN_WORKER, WebSocketCreationPolicy::IN_MAIN_FRAME)); +IN_PROC_BROWSER_TEST_P(SubresourceFilterWorkerFetchBrowserTest, WorkerFetch) { + const base::string16 fetch_succeeded_title = + base::ASCIIToUTF16("FetchSucceeded"); + const base::string16 fetch_failed_title = base::ASCIIToUTF16("FetchFailed"); + GURL url(GetTestUrl("subresource_filter/worker_fetch.html")); + ConfigureAsPhishingURL(url); + + ASSERT_NO_FATAL_FAILURE(SetRulesetToDisallowURLsWithPathSuffix( + "suffix-that-does-not-match-anything")); + { + content::TitleWatcher title_watcher( + browser()->tab_strip_model()->GetActiveWebContents(), + fetch_succeeded_title); + title_watcher.AlsoWaitForTitle(fetch_failed_title); + ui_test_utils::NavigateToURL(browser(), url); + EXPECT_EQ(fetch_succeeded_title, title_watcher.WaitAndGetTitle()); + } + ClearTitle(); + ASSERT_NO_FATAL_FAILURE( + SetRulesetToDisallowURLsWithPathSuffix("worker_fetch_data.txt")); + { + content::TitleWatcher title_watcher( + browser()->tab_strip_model()->GetActiveWebContents(), + fetch_succeeded_title); + title_watcher.AlsoWaitForTitle(fetch_failed_title); + ui_test_utils::NavigateToURL(browser(), url); + EXPECT_EQ(fetch_failed_title, title_watcher.WaitAndGetTitle()); + } + ClearTitle(); + // The main frame document should never be filtered. + SetRulesetToDisallowURLsWithPathSuffix("worker_fetch.html"); + { + content::TitleWatcher title_watcher( + browser()->tab_strip_model()->GetActiveWebContents(), + fetch_succeeded_title); + title_watcher.AlsoWaitForTitle(fetch_failed_title); + ui_test_utils::NavigateToURL(browser(), url); + EXPECT_EQ(fetch_succeeded_title, title_watcher.WaitAndGetTitle()); + } +} + +INSTANTIATE_TEST_CASE_P(/* no prefix */, + SubresourceFilterWorkerFetchBrowserTest, + ::testing::Values(OffMainThreadFetchPolicy::kEnabled, + OffMainThreadFetchPolicy::kDisabled)); + // Tests checking how histograms are recorded. --------------------------------- namespace {
diff --git a/chrome/browser/task_manager/providers/arc/arc_process_filter.cc b/chrome/browser/task_manager/providers/arc/arc_process_filter.cc index c7e3bc72..0d0202ba 100644 --- a/chrome/browser/task_manager/providers/arc/arc_process_filter.cc +++ b/chrome/browser/task_manager/providers/arc/arc_process_filter.cc
@@ -6,6 +6,7 @@ #include <utility> +#include "base/logging.h" #include "components/arc/common/process.mojom.h" namespace task_manager { @@ -35,14 +36,32 @@ // ProcessState::TOP: Process is hosting the current top activities // ProcessState::IMPORTANT_FOREGROUND: Process is important to the user // ProcessState::TOP_SLEEPING: Same as TOP, but while the device is sleeping + // ProcessState::LAST_ACTIVITY: The last activity - see crbug.com/738651. + // ProcessState::FOREGROUND_SERVICE: Foreground service - in Android, the user + // is made aware of these via a notification. switch (process.process_state()) { case arc::mojom::ProcessState::TOP: // Fallthrough. case arc::mojom::ProcessState::IMPORTANT_FOREGROUND: case arc::mojom::ProcessState::TOP_SLEEPING: + case arc::mojom::ProcessState::LAST_ACTIVITY: + case arc::mojom::ProcessState::FOREGROUND_SERVICE: return true; - default: - break; + case arc::mojom::ProcessState::NONEXISTENT: // Fallthrough. + case arc::mojom::ProcessState::PERSISTENT: + case arc::mojom::ProcessState::PERSISTENT_UI: + case arc::mojom::ProcessState::BOUND_FOREGROUND_SERVICE: + case arc::mojom::ProcessState::IMPORTANT_BACKGROUND: + case arc::mojom::ProcessState::BACKUP: + case arc::mojom::ProcessState::HEAVY_WEIGHT: + case arc::mojom::ProcessState::SERVICE: + case arc::mojom::ProcessState::RECEIVER: + case arc::mojom::ProcessState::HOME: + case arc::mojom::ProcessState::CACHED_ACTIVITY: + case arc::mojom::ProcessState::CACHED_ACTIVITY_CLIENT: + case arc::mojom::ProcessState::CACHED_EMPTY: + return false; } + NOTREACHED(); return false; }
diff --git a/chrome/browser/task_manager/providers/arc/arc_process_filter.h b/chrome/browser/task_manager/providers/arc/arc_process_filter.h index d1f1d89..8b0b9932 100644 --- a/chrome/browser/task_manager/providers/arc/arc_process_filter.h +++ b/chrome/browser/task_manager/providers/arc/arc_process_filter.h
@@ -8,6 +8,7 @@ #include <set> #include <string> +#include "base/macros.h" #include "chrome/browser/chromeos/arc/process/arc_process.h" namespace task_manager {
diff --git a/chrome/browser/ui/BUILD.gn b/chrome/browser/ui/BUILD.gn index f535d5c9e..c137a8fd 100644 --- a/chrome/browser/ui/BUILD.gn +++ b/chrome/browser/ui/BUILD.gn
@@ -2374,8 +2374,6 @@ "webui/offline/offline_internals_ui.h", "webui/offline/offline_internals_ui_message_handler.cc", "webui/offline/offline_internals_ui_message_handler.h", - "webui/popular_sites_internals_ui.cc", - "webui/popular_sites_internals_ui.h", "webui/snippets_internals_message_handler.cc", "webui/snippets_internals_message_handler.h", "webui/snippets_internals_ui.cc",
diff --git a/chrome/browser/ui/page_info/page_info_ui.cc b/chrome/browser/ui/page_info/page_info_ui.cc index 524be75..ac53c088 100644 --- a/chrome/browser/ui/page_info/page_info_ui.cc +++ b/chrome/browser/ui/page_info/page_info_ui.cc
@@ -451,3 +451,12 @@ return base::CommandLine::ForCurrentProcess()->HasSwitch( switches::kShowCertLink); } + +// static +bool PageInfoUI::ContentSettingsTypeInPageInfo(ContentSettingsType type) { + for (const PermissionsUIInfo& info : kPermissionsUIInfo) { + if (info.type == type) + return true; + } + return false; +}
diff --git a/chrome/browser/ui/page_info/page_info_ui.h b/chrome/browser/ui/page_info/page_info_ui.h index 8e69da1e..4c85e88 100644 --- a/chrome/browser/ui/page_info/page_info_ui.h +++ b/chrome/browser/ui/page_info/page_info_ui.h
@@ -195,6 +195,9 @@ // Returns true if the Certificate Viewer link should be shown. static bool ShouldShowCertificateLink(); + // Return true if the given ContentSettingsType is in PageInfoUI. + static bool ContentSettingsTypeInPageInfo(ContentSettingsType type); + // Sets cookie information. virtual void SetCookieInfo(const CookieInfoList& cookie_info_list) = 0;
diff --git a/chrome/browser/ui/views/frame/browser_window_property_manager_browsertest_win.cc b/chrome/browser/ui/views/frame/browser_window_property_manager_browsertest_win.cc index 79aa8d6..8a6bfcfb 100644 --- a/chrome/browser/ui/views/frame/browser_window_property_manager_browsertest_win.cc +++ b/chrome/browser/ui/views/frame/browser_window_property_manager_browsertest_win.cc
@@ -248,5 +248,6 @@ ASSERT_TRUE(app_browser != browser()); WaitAndValidateBrowserWindowProperties( - base::Bind(&ValidateHostedAppWindowProperties, app_browser, extension)); + base::Bind(&ValidateHostedAppWindowProperties, app_browser, + base::RetainedRef(extension))); }
diff --git a/chrome/browser/ui/webui/OWNERS b/chrome/browser/ui/webui/OWNERS index 731bdc43..909e06d 100644 --- a/chrome/browser/ui/webui/OWNERS +++ b/chrome/browser/ui/webui/OWNERS
@@ -12,7 +12,6 @@ per-file snippets_internals*=file://components/ntp_snippets/OWNERS per-file ntp_tiles_internals_ui.*=file://components/ntp_tiles/OWNERS -per-file popular_sites_internals_ui.*=file://components/ntp_tiles/OWNERS per-file net_export_ui.*=file://net/OWNERS # Maintaining ownership from this file's original Chrome OS location.
diff --git a/chrome/browser/ui/webui/chrome_web_ui_controller_factory.cc b/chrome/browser/ui/webui/chrome_web_ui_controller_factory.cc index baced5d..2e1dd19 100644 --- a/chrome/browser/ui/webui/chrome_web_ui_controller_factory.cc +++ b/chrome/browser/ui/webui/chrome_web_ui_controller_factory.cc
@@ -112,7 +112,6 @@ #if defined(OS_ANDROID) #include "chrome/browser/ui/webui/offline/offline_internals_ui.h" -#include "chrome/browser/ui/webui/popular_sites_internals_ui.h" #include "chrome/browser/ui/webui/snippets_internals_ui.h" #include "chrome/browser/ui/webui/webapks_ui.h" #else @@ -495,8 +494,6 @@ #if defined(OS_ANDROID) if (url.host_piece() == chrome::kChromeUIOfflineInternalsHost) return &NewWebUI<OfflineInternalsUI>; - if (url.host_piece() == chrome::kChromeUIPopularSitesInternalsHost) - return &NewWebUI<PopularSitesInternalsUI>; if (url.host_piece() == chrome::kChromeUISnippetsInternalsHost && !profile->IsOffTheRecord()) return &NewWebUI<SnippetsInternalsUI>;
diff --git a/chrome/browser/ui/webui/popular_sites_internals_ui.cc b/chrome/browser/ui/webui/popular_sites_internals_ui.cc deleted file mode 100644 index 88e0779..0000000 --- a/chrome/browser/ui/webui/popular_sites_internals_ui.cc +++ /dev/null
@@ -1,96 +0,0 @@ -// Copyright 2015 The Chromium Authors. All rights reserved. -// Use of this source code is governed by a BSD-style license that can be -// found in the LICENSE file. - -#include "chrome/browser/ui/webui/popular_sites_internals_ui.h" - -#include "base/memory/ptr_util.h" -#include "chrome/browser/ntp_tiles/chrome_popular_sites_factory.h" -#include "chrome/browser/profiles/profile.h" -#include "chrome/common/url_constants.h" -#include "components/grit/components_resources.h" -#include "components/ntp_tiles/popular_sites.h" -#include "components/ntp_tiles/webui/popular_sites_internals_message_handler.h" -#include "components/ntp_tiles/webui/popular_sites_internals_message_handler_client.h" -#include "content/public/browser/browser_thread.h" -#include "content/public/browser/web_ui.h" -#include "content/public/browser/web_ui_data_source.h" -#include "content/public/browser/web_ui_message_handler.h" - -namespace { - -// The implementation for the chrome://popular-sites-internals page. -class ChromePopularSitesInternalsMessageHandlerBridge - : public content::WebUIMessageHandler, - public ntp_tiles::PopularSitesInternalsMessageHandlerClient { - public: - ChromePopularSitesInternalsMessageHandlerBridge() : handler_(this) {} - - private: - // content::WebUIMessageHandler: - void RegisterMessages() override; - - // ntp_tiles::PopularSitesInternalsMessageHandlerClient - std::unique_ptr<ntp_tiles::PopularSites> MakePopularSites() override; - PrefService* GetPrefs() override; - void RegisterMessageCallback( - const std::string& message, - const base::Callback<void(const base::ListValue*)>& callback) override; - void CallJavascriptFunctionVector( - const std::string& name, - const std::vector<const base::Value*>& values) override; - - ntp_tiles::PopularSitesInternalsMessageHandler handler_; - - DISALLOW_COPY_AND_ASSIGN(ChromePopularSitesInternalsMessageHandlerBridge); -}; - -void ChromePopularSitesInternalsMessageHandlerBridge::RegisterMessages() { - handler_.RegisterMessages(); -} - -std::unique_ptr<ntp_tiles::PopularSites> -ChromePopularSitesInternalsMessageHandlerBridge::MakePopularSites() { - return ChromePopularSitesFactory::NewForProfile(Profile::FromWebUI(web_ui())); -} - -PrefService* ChromePopularSitesInternalsMessageHandlerBridge::GetPrefs() { - return Profile::FromWebUI(web_ui())->GetPrefs(); -} - -void ChromePopularSitesInternalsMessageHandlerBridge::RegisterMessageCallback( - const std::string& message, - const base::Callback<void(const base::ListValue*)>& callback) { - web_ui()->RegisterMessageCallback(message, callback); -} - -void ChromePopularSitesInternalsMessageHandlerBridge:: - CallJavascriptFunctionVector( - const std::string& name, - const std::vector<const base::Value*>& values) { - web_ui()->CallJavascriptFunctionUnsafe(name, values); -} - -} // namespace - -content::WebUIDataSource* CreatePopularSitesInternalsHTMLSource() { - content::WebUIDataSource* source = content::WebUIDataSource::Create( - chrome::kChromeUIPopularSitesInternalsHost); - - source->AddResourcePath("popular_sites_internals.js", - IDR_POPULAR_SITES_INTERNALS_JS); - source->AddResourcePath("popular_sites_internals.css", - IDR_POPULAR_SITES_INTERNALS_CSS); - source->SetDefaultResource(IDR_POPULAR_SITES_INTERNALS_HTML); - return source; -} - -PopularSitesInternalsUI::PopularSitesInternalsUI(content::WebUI* web_ui) - : WebUIController(web_ui) { - content::WebUIDataSource::Add(Profile::FromWebUI(web_ui), - CreatePopularSitesInternalsHTMLSource()); - web_ui->AddMessageHandler( - base::MakeUnique<ChromePopularSitesInternalsMessageHandlerBridge>()); -} - -PopularSitesInternalsUI::~PopularSitesInternalsUI() {}
diff --git a/chrome/browser/ui/webui/popular_sites_internals_ui.h b/chrome/browser/ui/webui/popular_sites_internals_ui.h deleted file mode 100644 index 89955366..0000000 --- a/chrome/browser/ui/webui/popular_sites_internals_ui.h +++ /dev/null
@@ -1,21 +0,0 @@ -// Copyright 2015 The Chromium Authors. All rights reserved. -// Use of this source code is governed by a BSD-style license that can be -// found in the LICENSE file. - -#ifndef CHROME_BROWSER_UI_WEBUI_POPULAR_SITES_INTERNALS_UI_H_ -#define CHROME_BROWSER_UI_WEBUI_POPULAR_SITES_INTERNALS_UI_H_ - -#include "base/macros.h" -#include "content/public/browser/web_ui_controller.h" - -// The implementation for the chrome://popular-sites-internals page. -class PopularSitesInternalsUI : public content::WebUIController { - public: - explicit PopularSitesInternalsUI(content::WebUI* web_ui); - ~PopularSitesInternalsUI() override; - - private: - DISALLOW_COPY_AND_ASSIGN(PopularSitesInternalsUI); -}; - -#endif // CHROME_BROWSER_UI_WEBUI_POPULAR_SITES_INTERNALS_UI_H_
diff --git a/chrome/browser/ui/webui/settings/md_settings_localized_strings_provider.cc b/chrome/browser/ui/webui/settings/md_settings_localized_strings_provider.cc index 5c9dce3..d43ee64 100644 --- a/chrome/browser/ui/webui/settings/md_settings_localized_strings_provider.cc +++ b/chrome/browser/ui/webui/settings/md_settings_localized_strings_provider.cc
@@ -1186,6 +1186,9 @@ void AddOnStartupStrings(content::WebUIDataSource* html_source) { LocalizedString localized_strings[] = { {"onStartup", IDS_SETTINGS_ON_STARTUP}, + {"onStartupDescription", IDS_SETTINGS_ON_STARTUP_DESCRIPTION}, + {"onStartupManage", IDS_SETTINGS_ON_STARTUP_MANAGE}, + {"onStartupPages", IDS_SETTINGS_ON_STARTUP_PAGES}, {"onStartupOpenNewTab", IDS_SETTINGS_ON_STARTUP_OPEN_NEW_TAB}, {"onStartupContinue", IDS_SETTINGS_ON_STARTUP_CONTINUE}, {"onStartupOpenSpecific", IDS_SETTINGS_ON_STARTUP_OPEN_SPECIFIC},
diff --git a/chrome/common/chrome_features.cc b/chrome/common/chrome_features.cc index 1b66b34..5c046f4 100644 --- a/chrome/common/chrome_features.cc +++ b/chrome/common/chrome_features.cc
@@ -270,6 +270,9 @@ #endif #endif // BUILDFLAG(ENABLE_NATIVE_NOTIFICATIONS) +const base::Feature kNetworkPrediction{"NetworkPrediction", + base::FEATURE_ENABLED_BY_DEFAULT}; + // If enabled, the list of content suggestions on the New Tab page will contain // pages that the user downloaded for later use. const base::Feature kOfflinePageDownloadSuggestionsFeature{
diff --git a/chrome/common/chrome_features.h b/chrome/common/chrome_features.h index f96568db..2c1caeea 100644 --- a/chrome/common/chrome_features.h +++ b/chrome/common/chrome_features.h
@@ -137,6 +137,8 @@ extern const base::Feature kNativeNotifications; #endif +extern const base::Feature kNetworkPrediction; + extern const base::Feature kOfflinePageDownloadSuggestionsFeature; #if !defined(OS_ANDROID)
diff --git a/chrome/common/url_constants.cc b/chrome/common/url_constants.cc index 5303894..56aad7b3 100644 --- a/chrome/common/url_constants.cc +++ b/chrome/common/url_constants.cc
@@ -294,7 +294,6 @@ const char kChromeUIContextualSearchPromoHost[] = "contextual-search-promo"; const char kChromeUIOfflineInternalsHost[] = "offline-internals"; const char kChromeUIPhysicalWebDiagnosticsHost[] = "physical-web-diagnostics"; -const char kChromeUIPopularSitesInternalsHost[] = "popular-sites-internals"; const char kChromeUISnippetsInternalsHost[] = "snippets-internals"; const char kChromeUIWebApksHost[] = "webapks"; #endif @@ -715,7 +714,6 @@ #if defined(OS_ANDROID) kChromeUINetExportHost, kChromeUIOfflineInternalsHost, - kChromeUIPopularSitesInternalsHost, kChromeUISnippetsInternalsHost, kChromeUIWebApksHost, #endif
diff --git a/chrome/common/url_constants.h b/chrome/common/url_constants.h index 38e1188..9ba18fdc 100644 --- a/chrome/common/url_constants.h +++ b/chrome/common/url_constants.h
@@ -278,7 +278,6 @@ extern const char kChromeUIContextualSearchPromoHost[]; extern const char kChromeUIOfflineInternalsURL[]; extern const char kChromeUIPhysicalWebDiagnosticsHost[]; -extern const char kChromeUIPopularSitesInternalsHost[]; extern const char kChromeUISnippetsInternalsHost[]; extern const char kChromeUIWebApksHost[]; #endif
diff --git a/chrome/gpu/BUILD.gn b/chrome/gpu/BUILD.gn index ee90a75..93bdd8a 100644 --- a/chrome/gpu/BUILD.gn +++ b/chrome/gpu/BUILD.gn
@@ -25,6 +25,8 @@ "chrome_arc_video_decode_accelerator.h", "gpu_arc_video_decode_accelerator.cc", "gpu_arc_video_decode_accelerator.h", + "gpu_arc_video_encode_accelerator.cc", + "gpu_arc_video_encode_accelerator.h", ] } }
diff --git a/chrome/gpu/DEPS b/chrome/gpu/DEPS index c076b70..094dd23 100644 --- a/chrome/gpu/DEPS +++ b/chrome/gpu/DEPS
@@ -7,6 +7,7 @@ "+content/public/gpu", "+media/video", "+media/base/video_frame.h", + "+media/base/video_types.h", "+media/gpu", "+mojo/edk/embedder", "+services/service_manager/public/cpp",
diff --git a/chrome/gpu/chrome_content_gpu_client.cc b/chrome/gpu/chrome_content_gpu_client.cc index 05cfc43f..e5815dd 100644 --- a/chrome/gpu/chrome_content_gpu_client.cc +++ b/chrome/gpu/chrome_content_gpu_client.cc
@@ -21,6 +21,7 @@ #if defined(OS_CHROMEOS) #include "chrome/gpu/gpu_arc_video_decode_accelerator.h" +#include "chrome/gpu/gpu_arc_video_encode_accelerator.h" #include "content/public/common/service_manager_connection.h" #include "services/service_manager/public/cpp/binder_registry.h" #endif @@ -68,6 +69,10 @@ base::Bind(&ChromeContentGpuClient::CreateArcVideoDecodeAccelerator, base::Unretained(this)), base::ThreadTaskRunnerHandle::Get()); + registry->AddInterface( + base::Bind(&ChromeContentGpuClient::CreateArcVideoEncodeAccelerator, + base::Unretained(this)), + base::ThreadTaskRunnerHandle::Get()); #endif } @@ -95,4 +100,12 @@ std::move(request)); } +void ChromeContentGpuClient::CreateArcVideoEncodeAccelerator( + const service_manager::BindSourceInfo& source_info, + ::arc::mojom::VideoEncodeAcceleratorRequest request) { + mojo::MakeStrongBinding( + base::MakeUnique<chromeos::arc::GpuArcVideoEncodeAccelerator>( + gpu_preferences_), + std::move(request)); +} #endif
diff --git a/chrome/gpu/chrome_content_gpu_client.h b/chrome/gpu/chrome_content_gpu_client.h index 768f3a7..f3e9e89d 100644 --- a/chrome/gpu/chrome_content_gpu_client.h +++ b/chrome/gpu/chrome_content_gpu_client.h
@@ -13,7 +13,9 @@ #include "content/public/gpu/content_gpu_client.h" #if defined(OS_CHROMEOS) -#include "chrome/gpu/gpu_arc_video_decode_accelerator.h" +#include "components/arc/common/video_decode_accelerator.mojom.h" +#include "components/arc/common/video_encode_accelerator.mojom.h" +#include "gpu/command_buffer/service/gpu_preferences.h" namespace service_manager { struct BindSourceInfo; @@ -37,6 +39,10 @@ void CreateArcVideoDecodeAccelerator( const service_manager::BindSourceInfo& source_info, ::arc::mojom::VideoDecodeAcceleratorRequest request); + + void CreateArcVideoEncodeAccelerator( + const service_manager::BindSourceInfo& source_info, + ::arc::mojom::VideoEncodeAcceleratorRequest request); #endif std::unique_ptr<variations::ChildProcessFieldTrialSyncer> field_trial_syncer_;
diff --git a/chrome/gpu/gpu_arc_video_encode_accelerator.cc b/chrome/gpu/gpu_arc_video_encode_accelerator.cc new file mode 100644 index 0000000..192f5942a --- /dev/null +++ b/chrome/gpu/gpu_arc_video_encode_accelerator.cc
@@ -0,0 +1,218 @@ +// Copyright 2017 The Chromium Authors. All rights reserved. +// Use of this source code is governed by a BSD-style license that can be +// found in the LICENSE file. + +#include "chrome/gpu/gpu_arc_video_encode_accelerator.h" + +#include <utility> + +#include "base/logging.h" +#include "base/sys_info.h" +#include "media/base/video_types.h" +#include "media/gpu/gpu_video_encode_accelerator_factory.h" +#include "mojo/public/cpp/bindings/strong_binding.h" +#include "mojo/public/cpp/bindings/type_converter.h" +#include "mojo/public/cpp/system/platform_handle.h" + +#define DVLOGF(x) DVLOG(x) << __func__ << "(): " + +namespace chromeos { +namespace arc { + +GpuArcVideoEncodeAccelerator::GpuArcVideoEncodeAccelerator( + const gpu::GpuPreferences& gpu_preferences) + : gpu_preferences_(gpu_preferences) {} + +GpuArcVideoEncodeAccelerator::~GpuArcVideoEncodeAccelerator() = default; + +// VideoEncodeAccelerator::Client implementation. +void GpuArcVideoEncodeAccelerator::RequireBitstreamBuffers( + unsigned int input_count, + const gfx::Size& coded_size, + size_t output_buffer_size) { + DVLOGF(2) << "input_count=" << input_count + << ", coded_size=" << coded_size.ToString() + << ", output_buffer_size=" << output_buffer_size; + DCHECK(client_); + coded_size_ = coded_size; + client_->RequireBitstreamBuffers(input_count, coded_size, output_buffer_size); +} + +void GpuArcVideoEncodeAccelerator::BitstreamBufferReady( + int32_t bitstream_buffer_id, + size_t payload_size, + bool key_frame, + base::TimeDelta timestamp) { + DVLOGF(2) << "id=" << bitstream_buffer_id; + DCHECK(client_); + client_->BitstreamBufferReady(bitstream_buffer_id, payload_size, key_frame, + timestamp.InMicroseconds()); +} + +void GpuArcVideoEncodeAccelerator::NotifyError(Error error) { + DVLOGF(2) << "error=" << error; + DCHECK(client_); + client_->NotifyError(error); +} + +// ::arc::mojom::VideoEncodeAccelerator implementation. +void GpuArcVideoEncodeAccelerator::GetSupportedProfiles( + const GetSupportedProfilesCallback& callback) { + callback.Run(media::GpuVideoEncodeAcceleratorFactory::GetSupportedProfiles( + gpu_preferences_)); +} + +void GpuArcVideoEncodeAccelerator::Initialize( + VideoPixelFormat input_format, + const gfx::Size& visible_size, + VideoEncodeAccelerator::StorageType input_storage, + VideoCodecProfile output_profile, + uint32_t initial_bitrate, + VideoEncodeClientPtr client, + const InitializeCallback& callback) { + DVLOGF(2) << "visible_size=" << visible_size.ToString() + << ", profile=" << output_profile; + + input_pixel_format_ = input_format; + visible_size_ = visible_size; + accelerator_ = media::GpuVideoEncodeAcceleratorFactory::CreateVEA( + input_pixel_format_, visible_size_, output_profile, initial_bitrate, this, + gpu_preferences_); + if (accelerator_ == nullptr) { + DLOG(ERROR) << "Failed to create a VideoEncodeAccelerator."; + callback.Run(false); + return; + } + client_ = std::move(client); + callback.Run(true); +} + +static void DropSharedMemory(std::unique_ptr<base::SharedMemory> shm) { + // Just let |shm| fall out of scope. +} + +void GpuArcVideoEncodeAccelerator::Encode( + mojo::ScopedHandle handle, + std::vector<::arc::VideoFramePlane> planes, + int64_t timestamp, + bool force_keyframe) { + DVLOGF(2) << "timestamp=" << timestamp; + if (!accelerator_) { + DLOG(ERROR) << "Accelerator is not initialized."; + return; + } + + if (planes.empty()) { // EOS + accelerator_->Encode(media::VideoFrame::CreateEOSFrame(), force_keyframe); + return; + } + + base::ScopedFD fd = UnwrapFdFromMojoHandle(std::move(handle)); + if (!fd.is_valid()) + return; + + size_t allocation_size = + media::VideoFrame::AllocationSize(input_pixel_format_, coded_size_); + + // TODO(rockot): Pass GUIDs through Mojo. https://crbug.com/713763. + // TODO(rockot): This fd comes from a mojo::ScopedHandle in + // GpuArcVideoService::BindSharedMemory. That should be passed through, + // rather than pulling out the fd. https://crbug.com/713763. + // TODO(rockot): Pass through a real size rather than |0|. + base::UnguessableToken guid = base::UnguessableToken::Create(); + base::SharedMemoryHandle shm_handle(base::FileDescriptor(fd.release(), true), + 0u, guid); + auto shm = base::MakeUnique<base::SharedMemory>(shm_handle, true); + + base::CheckedNumeric<off_t> map_offset = planes[0].offset; + base::CheckedNumeric<size_t> map_size = allocation_size; + const uint32_t aligned_offset = + planes[0].offset % base::SysInfo::VMAllocationGranularity(); + map_offset -= aligned_offset; + map_size += aligned_offset; + + if (!map_offset.IsValid() || !map_size.IsValid()) { + DLOG(ERROR) << "Invalid map_offset or map_size"; + client_->NotifyError(Error::kInvalidArgumentError); + return; + } + if (!shm->MapAt(map_offset.ValueOrDie(), map_size.ValueOrDie())) { + DLOG(ERROR) << "Failed to map memory."; + client_->NotifyError(Error::kPlatformFailureError); + return; + } + + uint8_t* shm_memory = reinterpret_cast<uint8_t*>(shm->memory()); + auto frame = media::VideoFrame::WrapExternalSharedMemory( + input_pixel_format_, coded_size_, gfx::Rect(visible_size_), visible_size_, + shm_memory + aligned_offset, allocation_size, shm_handle, + planes[0].offset, base::TimeDelta::FromMicroseconds(timestamp)); + + // Wrap |shm| in a callback and add it as a destruction observer, so it + // stays alive and mapped until |frame| goes out of scope. + frame->AddDestructionObserver( + base::Bind(&DropSharedMemory, base::Passed(&shm))); + accelerator_->Encode(frame, force_keyframe); +} + +void GpuArcVideoEncodeAccelerator::UseOutputBitstreamBuffer( + int32_t bitstream_buffer_id, + mojo::ScopedHandle shmem_fd, + uint32_t offset, + uint32_t size) { + DVLOGF(2) << "id=" << bitstream_buffer_id; + if (!accelerator_) { + DLOG(ERROR) << "Accelerator is not initialized."; + return; + } + + base::ScopedFD fd = UnwrapFdFromMojoHandle(std::move(shmem_fd)); + if (!fd.is_valid()) + return; + + // TODO(rockot): Pass GUIDs through Mojo. https://crbug.com/713763. + // TODO(rockot): This fd comes from a mojo::ScopedHandle in + // GpuArcVideoService::BindSharedMemory. That should be passed through, + // rather than pulling out the fd. https://crbug.com/713763. + // TODO(rockot): Pass through a real size rather than |0|. + base::UnguessableToken guid = base::UnguessableToken::Create(); + base::SharedMemoryHandle shm_handle(base::FileDescriptor(fd.release(), true), + 0u, guid); + accelerator_->UseOutputBitstreamBuffer( + media::BitstreamBuffer(bitstream_buffer_id, shm_handle, size, offset)); +} + +void GpuArcVideoEncodeAccelerator::RequestEncodingParametersChange( + uint32_t bitrate, + uint32_t framerate) { + DVLOGF(2) << "bitrate=" << bitrate << ", framerate=" << framerate; + if (!accelerator_) { + DLOG(ERROR) << "Accelerator is not initialized."; + return; + } + accelerator_->RequestEncodingParametersChange(bitrate, framerate); +} + +base::ScopedFD GpuArcVideoEncodeAccelerator::UnwrapFdFromMojoHandle( + mojo::ScopedHandle handle) { + DCHECK(client_); + if (!handle.is_valid()) { + DLOG(ERROR) << "handle is invalid."; + client_->NotifyError(Error::kInvalidArgumentError); + return base::ScopedFD(); + } + + base::PlatformFile platform_file; + MojoResult mojo_result = + mojo::UnwrapPlatformFile(std::move(handle), &platform_file); + if (mojo_result != MOJO_RESULT_OK) { + DLOG(ERROR) << "UnwrapPlatformFile failed: " << mojo_result; + client_->NotifyError(Error::kPlatformFailureError); + return base::ScopedFD(); + } + + return base::ScopedFD(platform_file); +} + +} // namespace arc +} // namespace chromeos
diff --git a/chrome/gpu/gpu_arc_video_encode_accelerator.h b/chrome/gpu/gpu_arc_video_encode_accelerator.h new file mode 100644 index 0000000..f388d94 --- /dev/null +++ b/chrome/gpu/gpu_arc_video_encode_accelerator.h
@@ -0,0 +1,86 @@ +// Copyright 2017 The Chromium Authors. All rights reserved. +// Use of this source code is governed by a BSD-style license that can be +// found in the LICENSE file. + +#ifndef CHROME_GPU_GPU_ARC_VIDEO_ENCODE_ACCELERATOR_H_ +#define CHROME_GPU_GPU_ARC_VIDEO_ENCODE_ACCELERATOR_H_ + +#include <memory> +#include <vector> + +#include "base/files/scoped_file.h" +#include "base/macros.h" +#include "components/arc/common/video_encode_accelerator.mojom.h" +#include "components/arc/video_accelerator/video_accelerator.h" +#include "gpu/command_buffer/service/gpu_preferences.h" +#include "media/video/video_encode_accelerator.h" + +namespace chromeos { +namespace arc { + +// GpuArcVideoEncodeAccelerator manages life-cycle and IPC message translation +// for media::VideoEncodeAccelerator. +class GpuArcVideoEncodeAccelerator + : public ::arc::mojom::VideoEncodeAccelerator, + public media::VideoEncodeAccelerator::Client { + public: + explicit GpuArcVideoEncodeAccelerator( + const gpu::GpuPreferences& gpu_preferences); + ~GpuArcVideoEncodeAccelerator() override; + + private: + using VideoPixelFormat = media::VideoPixelFormat; + using VideoCodecProfile = media::VideoCodecProfile; + using Error = media::VideoEncodeAccelerator::Error; + using VideoEncodeClientPtr = ::arc::mojom::VideoEncodeClientPtr; + + // VideoEncodeAccelerator::Client implementation. + void RequireBitstreamBuffers(unsigned int input_count, + const gfx::Size& input_coded_size, + size_t output_buffer_size) override; + void BitstreamBufferReady(int32_t bitstream_buffer_id, + size_t payload_size, + bool key_frame, + base::TimeDelta timestamp) override; + void NotifyError(Error error) override; + + // ::arc::mojom::VideoEncodeAccelerator implementation. + void GetSupportedProfiles( + const GetSupportedProfilesCallback& callback) override; + void Initialize(VideoPixelFormat input_format, + const gfx::Size& visible_size, + VideoEncodeAccelerator::StorageType input_storage, + VideoCodecProfile output_profile, + uint32_t initial_bitrate, + VideoEncodeClientPtr client, + const InitializeCallback& callback) override; + void Encode(mojo::ScopedHandle fd, + std::vector<::arc::VideoFramePlane> planes, + int64_t timestamp, + bool force_keyframe) override; + void UseOutputBitstreamBuffer(int32_t bitstream_buffer_id, + mojo::ScopedHandle shmem_fd, + uint32_t offset, + uint32_t size) override; + void RequestEncodingParametersChange(uint32_t bitrate, + uint32_t framerate) override; + + // Unwraps a file descriptor from the given mojo::ScopedHandle. + // If an error is encountered, it returns an invalid base::ScopedFD and + // notifies client about the error via VideoEncodeClient::NotifyError. + base::ScopedFD UnwrapFdFromMojoHandle(mojo::ScopedHandle handle); + + gpu::GpuPreferences gpu_preferences_; + std::unique_ptr<media::VideoEncodeAccelerator> accelerator_; + ::arc::mojom::VideoEncodeClientPtr client_; + gfx::Size coded_size_; + gfx::Size visible_size_; + VideoPixelFormat input_pixel_format_; + + DISALLOW_COPY_AND_ASSIGN(GpuArcVideoEncodeAccelerator); +}; + +} // namespace arc +} // namespace chromeos + +#endif // CHROME_GPU_GPU_ARC_VIDEO_ENCODE_ACCELERATOR_H_
diff --git a/chrome/installer/linux/BUILD.gn b/chrome/installer/linux/BUILD.gn index 292e1e4d..315f8b6 100644 --- a/chrome/installer/linux/BUILD.gn +++ b/chrome/installer/linux/BUILD.gn
@@ -190,6 +190,14 @@ if (!is_chromeos) { public_deps += [ ":rpm_packaging_files" ] } + + # TODO(thomasanderson): Move this variable into a .gni file + # somewhere. It is currently copied from + # buildtools/third_party/libc++/BUILD.gn. + libcpp_is_static = !is_component_build && !using_sanitizer + if (!libcpp_is_static && use_custom_libcxx) { + public_deps += [ "//buildtools/third_party/libc++:libc++" ] + } } # Creates .deb and .rpm (RPM for non-ChromeOS only) installer packages.
diff --git a/chrome/renderer/resources/extensions/browser_action_custom_bindings.js b/chrome/renderer/resources/extensions/browser_action_custom_bindings.js index 4b6ce09a..e844f734 100644 --- a/chrome/renderer/resources/extensions/browser_action_custom_bindings.js +++ b/chrome/renderer/resources/extensions/browser_action_custom_bindings.js
@@ -11,7 +11,12 @@ var sendRequest = bindingUtil ? $Function.bind(bindingUtil.sendRequest, bindingUtil) : require('sendRequest').sendRequest; -var lastError = require('lastError'); + +var jsLastError = bindingUtil ? undefined : require('lastError'); +function hasLastError() { + return bindingUtil ? + bindingUtil.hasLastError() : jsLastError.hasError(chrome); +} binding.registerCustomHook(function(bindingsAPI) { var apiFunctions = bindingsAPI.apiFunctions; @@ -30,7 +35,7 @@ if (!callback) return; - if (lastError.hasError(chrome)) { + if (hasLastError()) { callback(); } else { var views = getExtensionViews(-1, -1, 'POPUP');
diff --git a/chrome/test/BUILD.gn b/chrome/test/BUILD.gn index 22226b8..3a190b1a 100644 --- a/chrome/test/BUILD.gn +++ b/chrome/test/BUILD.gn
@@ -3151,6 +3151,7 @@ "../browser/metrics/chrome_browser_main_extra_parts_metrics_unittest.cc", "../browser/metrics/chrome_metrics_service_accessor_unittest.cc", "../browser/metrics/perf/perf_provider_chromeos_unittest.cc", + "../browser/metrics/process_memory_metrics_emitter_unittest.cc", "../browser/metrics/subprocess_metrics_provider_unittest.cc", "../browser/metrics/thread_watcher_android_unittest.cc", "../browser/metrics/thread_watcher_unittest.cc", @@ -3775,6 +3776,7 @@ "../browser/media/router/discovery/dial/dial_media_sink_service_proxy_unittest.cc", "../browser/media/router/discovery/dial/dial_registry_unittest.cc", "../browser/media/router/discovery/dial/dial_service_unittest.cc", + "../browser/media/router/discovery/mdns/cast_media_sink_service_unittest.cc", "../browser/media/router/discovery/mdns/dns_sd_registry_unittest.cc", "../browser/media/router/discovery/media_sink_service_base_unittest.cc", "../browser/media/router/event_page_request_manager_unittest.cc",
diff --git a/chrome/test/base/in_process_browser_test.cc b/chrome/test/base/in_process_browser_test.cc index 27328e5..7f4fc2a 100644 --- a/chrome/test/base/in_process_browser_test.cc +++ b/chrome/test/base/in_process_browser_test.cc
@@ -41,6 +41,7 @@ #include "chrome/browser/ui/browser_window.h" #include "chrome/browser/ui/tabs/tab_strip_model.h" #include "chrome/common/chrome_constants.h" +#include "chrome/common/chrome_features.h" #include "chrome/common/chrome_paths.h" #include "chrome/common/chrome_switches.h" #include "chrome/common/features.h" @@ -192,11 +193,6 @@ // Browser tests will create their own g_browser_process later. DCHECK(!g_browser_process); - // Clear the FeatureList instance from base/test/test_suite.cc. Since this is - // a browser test, a FeatureList will be registered as part of normal browser - // start up in ChromeBrowserMainParts::SetupMetricsAndFieldTrials(). - base::FeatureList::ClearInstanceForTesting(); - base::CommandLine* command_line = base::CommandLine::ForCurrentProcess(); // Auto-reload breaks many browser tests, which assume error pages won't be @@ -205,6 +201,10 @@ // here. command_line->AppendSwitch(switches::kDisableOfflineAutoReload); + // Turn off preconnects because they break the brittle python webserver; + // see http://crbug.com/60035. + scoped_feature_list_.InitAndDisableFeature(features::kNetworkPrediction); + // Allow subclasses to change the command line before running any tests. SetUpCommandLine(command_line); // Add command line arguments that are used by all InProcessBrowserTests.
diff --git a/chrome/test/base/in_process_browser_test.h b/chrome/test/base/in_process_browser_test.h index 69cf984..5a59a27 100644 --- a/chrome/test/base/in_process_browser_test.h +++ b/chrome/test/base/in_process_browser_test.h
@@ -10,6 +10,7 @@ #include "base/compiler_specific.h" #include "base/files/scoped_temp_dir.h" #include "base/memory/ref_counted.h" +#include "base/test/scoped_feature_list.h" #include "build/build_config.h" #include "content/public/browser/web_contents.h" #include "content/public/test/browser_test.h" @@ -266,6 +267,8 @@ // We use hardcoded quota settings to have a consistent testing environment. storage::QuotaSettings quota_settings_; + base::test::ScopedFeatureList scoped_feature_list_; + #if defined(OS_MACOSX) base::mac::ScopedNSAutoreleasePool* autorelease_pool_; std::unique_ptr<ScopedBundleSwizzlerMac> bundle_swizzler_;
diff --git a/chrome/test/base/test_launcher_utils.cc b/chrome/test/base/test_launcher_utils.cc index 7dd5f92..ea6d614 100644 --- a/chrome/test/base/test_launcher_utils.cc +++ b/chrome/test/base/test_launcher_utils.cc
@@ -26,11 +26,6 @@ namespace test_launcher_utils { void PrepareBrowserCommandLineForTests(base::CommandLine* command_line) { - // Turn off preconnects because they break the brittle python webserver; - // see http://crbug.com/60035. - command_line->AppendSwitchASCII(switches::kDisableFeatures, - "NetworkPrediction"); - // Don't show the first run ui. command_line->AppendSwitch(switches::kNoFirstRun);
diff --git a/chrome/test/base/tracing_browsertest.cc b/chrome/test/base/tracing_browsertest.cc index eae1cd38..5347d14 100644 --- a/chrome/test/base/tracing_browsertest.cc +++ b/chrome/test/base/tracing_browsertest.cc
@@ -101,7 +101,13 @@ } }; -IN_PROC_BROWSER_TEST_F(TracingBrowserTest, TestMemoryInfra) { +// crbug.com/708487. +#if defined(OS_MACOSX) && defined(ADDRESS_SANITIZER) +#define MAYBE_TestMemoryInfra DISABLED_TestMemoryInfra +#else +#define MAYBE_TestMemoryInfra TestMemoryInfra +#endif // defined(OS_MACOSX) && defined(ADDRESS_SANITIZER) +IN_PROC_BROWSER_TEST_F(TracingBrowserTest, MAYBE_TestMemoryInfra) { PerformDumpMemoryTestActions( base::trace_event::TraceConfig( base::trace_event::TraceConfigMemoryTestUtil::
diff --git a/chrome/test/data/subresource_filter/worker_fetch.html b/chrome/test/data/subresource_filter/worker_fetch.html new file mode 100644 index 0000000..4560a02 --- /dev/null +++ b/chrome/test/data/subresource_filter/worker_fetch.html
@@ -0,0 +1,4 @@ +<script> +var worker = new Worker('./worker_fetch.js'); +worker.onmessage = event => { document.title = event.data; }; +</script>
diff --git a/chrome/test/data/subresource_filter/worker_fetch.js b/chrome/test/data/subresource_filter/worker_fetch.js new file mode 100644 index 0000000..31c6d39 --- /dev/null +++ b/chrome/test/data/subresource_filter/worker_fetch.js
@@ -0,0 +1,7 @@ +// Copyright 2017 The Chromium Authors. All rights reserved. +// Use of this source code is governed by a BSD-style license that can be +// found in the LICENSE file. + +fetch('./worker_fetch_data.txt') + .then(_ => postMessage('FetchSucceeded'), + _ => postMessage('FetchFailed'));
diff --git a/chrome/test/data/subresource_filter/worker_fetch_data.txt b/chrome/test/data/subresource_filter/worker_fetch_data.txt new file mode 100644 index 0000000..d424ff1 --- /dev/null +++ b/chrome/test/data/subresource_filter/worker_fetch_data.txt
@@ -0,0 +1 @@ +dummy data
diff --git a/chrome/test/data/webui/settings/android_apps_page_test.js b/chrome/test/data/webui/settings/android_apps_page_test.js index 53ef87f..84dab47 100644 --- a/chrome/test/data/webui/settings/android_apps_page_test.js +++ b/chrome/test/data/webui/settings/android_apps_page_test.js
@@ -98,7 +98,7 @@ assertTrue(!subpage.$$('settings-android-settings-element')); }); - test('ManageAppsOpenReqest', function() { + test('ManageAppsOpenRequest', function() { setAndroidAppsState(true, true); var button = subpage.$$('settings-android-settings-element'). $$('#manageApps'); @@ -178,7 +178,7 @@ $$("#manageApps")); }); - test('ManageAppsOpenReqest', function() { + test('ManageAppsOpenRequest', function() { var button = androidAppsPage.$$('settings-android-settings-element'). $$('#manageApps'); assertTrue(!!button);
diff --git a/chrome/test/data/webui/settings/on_startup_browsertest.js b/chrome/test/data/webui/settings/on_startup_browsertest.js index f026de8a0..b9cb0c4 100644 --- a/chrome/test/data/webui/settings/on_startup_browsertest.js +++ b/chrome/test/data/webui/settings/on_startup_browsertest.js
@@ -7,16 +7,6 @@ GEN_INCLUDE(['settings_page_browsertest.js']); /** - * Radio button enum values for restore on startup. - * @enum - */ -var RestoreOnStartupEnum = { - CONTINUE: 1, - OPEN_NEW_TAB: 5, - OPEN_SPECIFIC: 4, -}; - -/** * Test Polymer On Startup Settings elements. * @constructor * @extends {SettingsPageBrowserTest} @@ -39,45 +29,19 @@ }; TEST_F('OnStartupSettingsBrowserTest', 'uiTests', function() { - /** - * The prefs API that will get a fake implementation. - * @type {!SettingsPrivate} - */ - var settingsPrefs; var self = this; - var restoreOnStartup = function() { - return self.getPageElement('#onStartupRadioGroup').querySelector( - '.iron-selected').label; - }; - suite('OnStartupHandler', function() { suiteSetup(function() { self.basicPage.set('pageVisibility.onStartup', true); - Polymer.dom.flush(); - - settingsPrefs = document.querySelector('settings-ui').$$( - 'settings-prefs'); - assertTrue(!!settingsPrefs); - return CrSettingsPrefs.initialized; }); - test('open-continue', function() { - settingsPrefs.set('prefs.session.restore_on_startup.value', - RestoreOnStartupEnum.CONTINUE); - assertEquals('Continue where you left off', restoreOnStartup()); - }); - - test('open-ntp', function() { - settingsPrefs.set('prefs.session.restore_on_startup.value', - RestoreOnStartupEnum.OPEN_NEW_TAB); - assertEquals('Open the New Tab page', restoreOnStartup()); - }); - - test('open-specific', function() { - settingsPrefs.set('prefs.session.restore_on_startup.value', - RestoreOnStartupEnum.OPEN_SPECIFIC); - assertEquals('Open a specific page or set of pages', restoreOnStartup()); + test('ManageStartupUrls', function() { + /* Test that the manage startup urls button is present on the basic page. + */ + var manageButton = + self.getPageElement('#manage-startup-urls-subpage-trigger'); + assertTrue(!!manageButton); }); }); mocha.run();
diff --git a/chrome/test/data/webui/settings/search_engines_page_test.js b/chrome/test/data/webui/settings/search_engines_page_test.js index 5eb5020..ef05e5c1 100644 --- a/chrome/test/data/webui/settings/search_engines_page_test.js +++ b/chrome/test/data/webui/settings/search_engines_page_test.js
@@ -104,7 +104,7 @@ browserProxy.resetResolver('validateSearchEngineInput'); inputElement.fire('input'); return inputElement.value != '' ? - // Expeting validation only on non-empty values. + // Expecting validation only on non-empty values. browserProxy.whenCalled('validateSearchEngineInput') : Promise.resolve(); };
diff --git a/chrome/test/data/webui/settings/startup_urls_page_test.js b/chrome/test/data/webui/settings/startup_urls_page_test.js index fa2aec6..df53358 100644 --- a/chrome/test/data/webui/settings/startup_urls_page_test.js +++ b/chrome/test/data/webui/settings/startup_urls_page_test.js
@@ -148,7 +148,7 @@ }); /** - * Tests that the appropritae browser proxy method is called when the action + * Tests that the appropriate browser proxy method is called when the action * button is tapped. * @param {string} proxyMethodName */ @@ -202,6 +202,16 @@ }); suite('StartupUrlsPage', function() { + /** + * Radio button enum values for restore on startup. + * @enum + */ + var RestoreOnStartupEnum = { + CONTINUE: 1, + OPEN_NEW_TAB: 5, + OPEN_SPECIFIC: 4, + }; + /** @type {?SettingsStartupUrlsPageElement} */ var page = null; @@ -231,7 +241,39 @@ return browserProxy.whenCalled('loadStartupPages'); }); + function restoreOnStartupLabel() { + return page.$$('#onStartupRadioGroup') + .querySelector('.iron-selected') + .label; + } + + test('open-continue', function() { + page.set( + 'prefs.session.restore_on_startup.value', + RestoreOnStartupEnum.CONTINUE); + assertEquals('Continue where you left off', restoreOnStartupLabel()); + }); + + test('open-ntp', function() { + page.set( + 'prefs.session.restore_on_startup.value', + RestoreOnStartupEnum.OPEN_NEW_TAB); + assertEquals('Open the New Tab page', restoreOnStartupLabel()); + }); + + test('open-specific', function() { + page.set( + 'prefs.session.restore_on_startup.value', + RestoreOnStartupEnum.OPEN_SPECIFIC); + assertEquals( + 'Open a specific page or set of pages', restoreOnStartupLabel()); + }); + test('UseCurrentPages', function() { + page.set( + 'prefs.session.restore_on_startup.value', + RestoreOnStartupEnum.OPEN_SPECIFIC); + Polymer.dom.flush(); var useCurrentPagesButton = page.$$('#useCurrentPages > a'); assertTrue(!!useCurrentPagesButton); MockInteractions.tap(useCurrentPagesButton); @@ -239,6 +281,10 @@ }); test('AddPage_OpensDialog', function() { + page.set( + 'prefs.session.restore_on_startup.value', + RestoreOnStartupEnum.OPEN_SPECIFIC); + Polymer.dom.flush(); var addPageButton = page.$$('#addPage > a'); assertTrue(!!addPageButton); assertFalse(!!page.$$('settings-startup-url-dialog')); @@ -284,7 +330,11 @@ assertFalse(!!page.$$('settings-startup-url-dialog')); }); - test('StarupPages_WhenExtensionControlled', function() { + test('StartupPages_WhenExtensionControlled', function() { + page.set( + 'prefs.session.restore_on_startup.value', + RestoreOnStartupEnum.OPEN_SPECIFIC); + Polymer.dom.flush(); assertFalse(!!page.get('prefs.session.startup_urls.controlledBy')); assertFalse(!!page.$$('extension-controlled-indicator')); assertTrue(!!page.$$('#addPage'));
diff --git a/components/arc/arc_session_runner.cc b/components/arc/arc_session_runner.cc index c9af993..e08cfa6 100644 --- a/components/arc/arc_session_runner.cc +++ b/components/arc/arc_session_runner.cc
@@ -228,12 +228,10 @@ // safe place to start the container for login screen. DCHECK(!arc_session_); DCHECK_EQ(state_, State::STOPPED); - - // TODO(yusukes): Once Chrome OS side is ready, uncomment the following: - // arc_session_ = factory_.Run(); - // arc_session_->AddObserver(this); - // state_ = State::STARTING_FOR_LOGIN_SCREEN; - // arc_session_->StartForLoginScreen(); + arc_session_ = factory_.Run(); + arc_session_->AddObserver(this); + state_ = State::STARTING_FOR_LOGIN_SCREEN; + arc_session_->StartForLoginScreen(); } } // namespace arc
diff --git a/components/arc/arc_session_runner_unittest.cc b/components/arc/arc_session_runner_unittest.cc index 144d0b0b..f8f9cc4 100644 --- a/components/arc/arc_session_runner_unittest.cc +++ b/components/arc/arc_session_runner_unittest.cc
@@ -189,7 +189,7 @@ // Does the same with the mini instance for login screen. // TODO(yusukes): Enable the test once EmitLoginPromptVisibleCalled() is fully // enabled. -TEST_F(ArcSessionRunnerTest, DISABLED_BootFailureForLoginScreen) { +TEST_F(ArcSessionRunnerTest, BootFailureForLoginScreen) { ResetArcSessionFactory( base::Bind(&ArcSessionRunnerTest::CreateBootFailureArcSession, ArcStopReason::CRASH)); @@ -214,7 +214,7 @@ // is called. // TODO(yusukes): Enable the test once EmitLoginPromptVisibleCalled() is fully // enabled. -TEST_F(ArcSessionRunnerTest, DISABLED_StartWithLoginScreenInstance) { +TEST_F(ArcSessionRunnerTest, StartWithLoginScreenInstance) { EXPECT_TRUE(arc_session_runner()->IsStopped()); chromeos::DBusThreadManager::Get()
diff --git a/components/arc/common/typemaps.gni b/components/arc/common/typemaps.gni index f43f9fa..32ca073c 100644 --- a/components/arc/common/typemaps.gni +++ b/components/arc/common/typemaps.gni
@@ -10,5 +10,6 @@ "//components/arc/common/ime.typemap", "//components/arc/common/intent_helper.typemap", "//components/arc/common/video_common.typemap", + "//components/arc/common/video_encode_accelerator.typemap", "//components/arc/common/volume_mounter.typemap", ]
diff --git a/components/arc/common/video_encode_accelerator.typemap b/components/arc/common/video_encode_accelerator.typemap new file mode 100644 index 0000000..61b8db22 --- /dev/null +++ b/components/arc/common/video_encode_accelerator.typemap
@@ -0,0 +1,19 @@ +# Copyright 2017 The Chromium Authors. All rights reserved. +# Use of this source code is governed by a BSD-style license that can be +# found in the LICENSE file. + +mojom = "//components/arc/common/video_encode_accelerator.mojom" +public_headers = [ "//media/video/video_encode_accelerator.h" ] +public_deps = [ + "//media", +] +traits_headers = [ "//components/arc/video_accelerator/video_encode_accelerator_struct_traits.h" ] +sources = [ + "//components/arc/video_accelerator/video_encode_accelerator_struct_traits.cc", +] +type_mappings = [ + "arc.mojom.VideoEncodeAccelerator.Error=media::VideoEncodeAccelerator::Error", + "arc.mojom.VideoPixelFormat=media::VideoPixelFormat", + "arc.mojom.VideoCodecProfile=media::VideoCodecProfile", + "arc.mojom.VideoEncodeProfile=media::VideoEncodeAccelerator::SupportedProfile", +]
diff --git a/components/arc/video_accelerator/DEPS b/components/arc/video_accelerator/DEPS new file mode 100644 index 0000000..04dd5ab --- /dev/null +++ b/components/arc/video_accelerator/DEPS
@@ -0,0 +1,3 @@ +include_rules = [ + "+media/video/video_encode_accelerator.h", +]
diff --git a/components/arc/video_accelerator/video_encode_accelerator_struct_traits.cc b/components/arc/video_accelerator/video_encode_accelerator_struct_traits.cc new file mode 100644 index 0000000..32a5737 --- /dev/null +++ b/components/arc/video_accelerator/video_encode_accelerator_struct_traits.cc
@@ -0,0 +1,163 @@ +// Copyright 2017 The Chromium Authors. All rights reserved. +// Use of this source code is governed by a BSD-style license that can be +// found in the LICENSE file. + +#include "components/arc/video_accelerator/video_encode_accelerator_struct_traits.h" + +namespace mojo { + +// Make sure values in arc::mojom::VideoEncodeAccelerator::Error and +// media::VideoEncodeAccelerator::Error match. +#define CHECK_ERROR_ENUM(value) \ + static_assert( \ + static_cast<int>(arc::mojom::VideoEncodeAccelerator::Error::value) == \ + media::VideoEncodeAccelerator::Error::value, \ + "enum ##value mismatch") + +CHECK_ERROR_ENUM(kIllegalStateError); +CHECK_ERROR_ENUM(kInvalidArgumentError); +CHECK_ERROR_ENUM(kPlatformFailureError); +CHECK_ERROR_ENUM(kErrorMax); + +#undef CHECK_ERROR_ENUM + +// static +arc::mojom::VideoEncodeAccelerator::Error +EnumTraits<arc::mojom::VideoEncodeAccelerator::Error, + media::VideoEncodeAccelerator::Error>:: + ToMojom(media::VideoEncodeAccelerator::Error input) { + return static_cast<arc::mojom::VideoEncodeAccelerator::Error>(input); +} + +// static +bool EnumTraits<arc::mojom::VideoEncodeAccelerator::Error, + media::VideoEncodeAccelerator::Error>:: + FromMojom(arc::mojom::VideoEncodeAccelerator::Error input, + media::VideoEncodeAccelerator::Error* output) { + NOTIMPLEMENTED(); + return false; +} + +// Make sure values in arc::mojom::VideoPixelFormat match to the values in +// media::VideoPixelFormat. The former is a subset of the later. +#define CHECK_PIXEL_FORMAT_ENUM(value) \ + static_assert( \ + static_cast<int>(arc::mojom::VideoPixelFormat::value) == media::value, \ + "enum ##value mismatch") + +CHECK_PIXEL_FORMAT_ENUM(PIXEL_FORMAT_I420); + +#undef CHECK_PXIEL_FORMAT_ENUM + +// static +arc::mojom::VideoPixelFormat +EnumTraits<arc::mojom::VideoPixelFormat, media::VideoPixelFormat>::ToMojom( + media::VideoPixelFormat input) { + NOTIMPLEMENTED(); + return arc::mojom::VideoPixelFormat::PIXEL_FORMAT_I420; +} + +// static +bool EnumTraits<arc::mojom::VideoPixelFormat, media::VideoPixelFormat>:: + FromMojom(arc::mojom::VideoPixelFormat input, + media::VideoPixelFormat* output) { + switch (input) { + case arc::mojom::VideoPixelFormat::PIXEL_FORMAT_I420: + *output = static_cast<media::VideoPixelFormat>(input); + return true; + default: + DLOG(ERROR) << "Unknown VideoPixelFormat: " << input; + return false; + } +} + +// Make sure values in arc::mojom::VideoCodecProfile match to the values in +// media::VideoCodecProfile. +#define CHECK_PROFILE_ENUM(value) \ + static_assert( \ + static_cast<int>(arc::mojom::VideoCodecProfile::value) == media::value, \ + "enum ##value mismatch") + +CHECK_PROFILE_ENUM(VIDEO_CODEC_PROFILE_UNKNOWN); +CHECK_PROFILE_ENUM(VIDEO_CODEC_PROFILE_MIN); +CHECK_PROFILE_ENUM(H264PROFILE_MIN); +CHECK_PROFILE_ENUM(H264PROFILE_BASELINE); +CHECK_PROFILE_ENUM(H264PROFILE_MAIN); +CHECK_PROFILE_ENUM(H264PROFILE_EXTENDED); +CHECK_PROFILE_ENUM(H264PROFILE_HIGH); +CHECK_PROFILE_ENUM(H264PROFILE_HIGH10PROFILE); +CHECK_PROFILE_ENUM(H264PROFILE_HIGH422PROFILE); +CHECK_PROFILE_ENUM(H264PROFILE_HIGH444PREDICTIVEPROFILE); +CHECK_PROFILE_ENUM(H264PROFILE_SCALABLEBASELINE); +CHECK_PROFILE_ENUM(H264PROFILE_SCALABLEHIGH); +CHECK_PROFILE_ENUM(H264PROFILE_STEREOHIGH); +CHECK_PROFILE_ENUM(H264PROFILE_MULTIVIEWHIGH); +CHECK_PROFILE_ENUM(H264PROFILE_MAX); +CHECK_PROFILE_ENUM(VP8PROFILE_MIN); +CHECK_PROFILE_ENUM(VP8PROFILE_ANY); +CHECK_PROFILE_ENUM(VP8PROFILE_MAX); +CHECK_PROFILE_ENUM(VP9PROFILE_MIN); +CHECK_PROFILE_ENUM(VP9PROFILE_PROFILE0); +CHECK_PROFILE_ENUM(VP9PROFILE_PROFILE1); +CHECK_PROFILE_ENUM(VP9PROFILE_PROFILE2); +CHECK_PROFILE_ENUM(VP9PROFILE_PROFILE3); +CHECK_PROFILE_ENUM(VP9PROFILE_MAX); +CHECK_PROFILE_ENUM(HEVCPROFILE_MIN); +CHECK_PROFILE_ENUM(HEVCPROFILE_MAIN); +CHECK_PROFILE_ENUM(HEVCPROFILE_MAIN10); +CHECK_PROFILE_ENUM(HEVCPROFILE_MAIN_STILL_PICTURE); +CHECK_PROFILE_ENUM(HEVCPROFILE_MAX); +CHECK_PROFILE_ENUM(DOLBYVISION_MIN); +CHECK_PROFILE_ENUM(DOLBYVISION_PROFILE0); +CHECK_PROFILE_ENUM(DOLBYVISION_PROFILE4); +CHECK_PROFILE_ENUM(DOLBYVISION_PROFILE5); +CHECK_PROFILE_ENUM(DOLBYVISION_PROFILE7); +CHECK_PROFILE_ENUM(DOLBYVISION_MAX); +CHECK_PROFILE_ENUM(VIDEO_CODEC_PROFILE_MAX); + +#undef CHECK_PROFILE_ENUM + +// static +arc::mojom::VideoCodecProfile +EnumTraits<arc::mojom::VideoCodecProfile, media::VideoCodecProfile>::ToMojom( + media::VideoCodecProfile input) { + return static_cast<arc::mojom::VideoCodecProfile>(input); +} + +// static +bool EnumTraits<arc::mojom::VideoCodecProfile, media::VideoCodecProfile>:: + FromMojom(arc::mojom::VideoCodecProfile input, + media::VideoCodecProfile* output) { + switch (input) { + case arc::mojom::VideoCodecProfile::VIDEO_CODEC_PROFILE_UNKNOWN: + case arc::mojom::VideoCodecProfile::H264PROFILE_BASELINE: + case arc::mojom::VideoCodecProfile::H264PROFILE_MAIN: + case arc::mojom::VideoCodecProfile::H264PROFILE_EXTENDED: + case arc::mojom::VideoCodecProfile::H264PROFILE_HIGH: + case arc::mojom::VideoCodecProfile::H264PROFILE_HIGH10PROFILE: + case arc::mojom::VideoCodecProfile::H264PROFILE_HIGH422PROFILE: + case arc::mojom::VideoCodecProfile::H264PROFILE_HIGH444PREDICTIVEPROFILE: + case arc::mojom::VideoCodecProfile::H264PROFILE_SCALABLEBASELINE: + case arc::mojom::VideoCodecProfile::H264PROFILE_SCALABLEHIGH: + case arc::mojom::VideoCodecProfile::H264PROFILE_STEREOHIGH: + case arc::mojom::VideoCodecProfile::H264PROFILE_MULTIVIEWHIGH: + case arc::mojom::VideoCodecProfile::VP8PROFILE_ANY: + case arc::mojom::VideoCodecProfile::VP9PROFILE_PROFILE0: + case arc::mojom::VideoCodecProfile::VP9PROFILE_PROFILE1: + case arc::mojom::VideoCodecProfile::VP9PROFILE_PROFILE2: + case arc::mojom::VideoCodecProfile::VP9PROFILE_PROFILE3: + case arc::mojom::VideoCodecProfile::HEVCPROFILE_MAIN: + case arc::mojom::VideoCodecProfile::HEVCPROFILE_MAIN10: + case arc::mojom::VideoCodecProfile::HEVCPROFILE_MAIN_STILL_PICTURE: + case arc::mojom::VideoCodecProfile::DOLBYVISION_PROFILE0: + case arc::mojom::VideoCodecProfile::DOLBYVISION_PROFILE4: + case arc::mojom::VideoCodecProfile::DOLBYVISION_PROFILE5: + case arc::mojom::VideoCodecProfile::DOLBYVISION_PROFILE7: + *output = static_cast<media::VideoCodecProfile>(input); + return true; + } + DLOG(ERROR) << "unknown profile: " << input; + return false; +} + +} // namespace mojo
diff --git a/components/arc/video_accelerator/video_encode_accelerator_struct_traits.h b/components/arc/video_accelerator/video_encode_accelerator_struct_traits.h new file mode 100644 index 0000000..c3b39e1 --- /dev/null +++ b/components/arc/video_accelerator/video_encode_accelerator_struct_traits.h
@@ -0,0 +1,68 @@ +// Copyright 2017 The Chromium Authors. All rights reserved. +// Use of this source code is governed by a BSD-style license that can be +// found in the LICENSE file. + +#ifndef COMPONENTS_ARC_VIDEO_ACCELERATOR_VIDEO_ENCODE_ACCELERATOR_STRUCT_TRAITS_H_ +#define COMPONENTS_ARC_VIDEO_ACCELERATOR_VIDEO_ENCODE_ACCELERATOR_STRUCT_TRAITS_H_ + +#include "components/arc/common/video_encode_accelerator.mojom.h" +#include "media/video/video_encode_accelerator.h" + +namespace mojo { + +template <> +struct EnumTraits<arc::mojom::VideoEncodeAccelerator::Error, + media::VideoEncodeAccelerator::Error> { + static arc::mojom::VideoEncodeAccelerator::Error ToMojom( + media::VideoEncodeAccelerator::Error input); + + static bool FromMojom(arc::mojom::VideoEncodeAccelerator::Error input, + media::VideoEncodeAccelerator::Error* output); +}; + +template <> +struct EnumTraits<arc::mojom::VideoPixelFormat, media::VideoPixelFormat> { + static arc::mojom::VideoPixelFormat ToMojom(media::VideoPixelFormat input); + + static bool FromMojom(arc::mojom::VideoPixelFormat input, + media::VideoPixelFormat* output); +}; + +template <> +struct EnumTraits<arc::mojom::VideoCodecProfile, media::VideoCodecProfile> { + static arc::mojom::VideoCodecProfile ToMojom(media::VideoCodecProfile input); + + static bool FromMojom(arc::mojom::VideoCodecProfile input, + media::VideoCodecProfile* output); +}; + +template <> +struct StructTraits<arc::mojom::VideoEncodeProfileDataView, + media::VideoEncodeAccelerator::SupportedProfile> { + static media::VideoCodecProfile profile( + const media::VideoEncodeAccelerator::SupportedProfile& r) { + return r.profile; + } + static const gfx::Size& max_resolution( + const media::VideoEncodeAccelerator::SupportedProfile& r) { + return r.max_resolution; + } + static uint32_t max_framerate_numerator( + const media::VideoEncodeAccelerator::SupportedProfile& r) { + return r.max_framerate_numerator; + } + static uint32_t max_framerate_denominator( + const media::VideoEncodeAccelerator::SupportedProfile& r) { + return r.max_framerate_denominator; + } + + static bool Read(arc::mojom::VideoEncodeProfileDataView data, + media::VideoEncodeAccelerator::SupportedProfile* out) { + NOTIMPLEMENTED(); + return false; + } +}; + +} // namespace mojo + +#endif // COMPONENTS_ARC_VIDEO_ACCELERATOR_VIDEO_ENCODE_ACCELERATOR_STRUCT_TRAITS_H_
diff --git a/components/autofill/content/renderer/form_autofill_util.cc b/components/autofill/content/renderer/form_autofill_util.cc index 2a32103..bf662aa 100644 --- a/components/autofill/content/renderer/form_autofill_util.cc +++ b/components/autofill/content/renderer/form_autofill_util.cc
@@ -111,9 +111,7 @@ return false; const WebFormControlElement form_control_element = element.ToConst<WebFormControlElement>(); - return std::find(control_elements.begin(), - control_elements.end(), - form_control_element) != control_elements.end(); + return base::ContainsValue(control_elements, form_control_element); } bool IsElementInsideFormOrFieldSet(const WebElement& element) {
diff --git a/components/autofill/content/renderer/password_generation_agent.cc b/components/autofill/content/renderer/password_generation_agent.cc index b4ab0cb2..3f833da 100644 --- a/components/autofill/content/renderer/password_generation_agent.cc +++ b/components/autofill/content/renderer/password_generation_agent.cc
@@ -10,6 +10,7 @@ #include "base/command_line.h" #include "base/logging.h" +#include "base/stl_util.h" #include "base/threading/thread_task_runner_handle.h" #include "components/autofill/content/renderer/form_autofill_util.h" #include "components/autofill/content/renderer/form_classifier.h" @@ -58,7 +59,7 @@ } bool ContainsURL(const std::vector<GURL>& urls, const GURL& url) { - return std::find(urls.begin(), urls.end(), url) != urls.end(); + return base::ContainsValue(urls, url); } // Calculates the signature of |form| and searches it in |forms|.
diff --git a/components/autofill/core/browser/address.cc b/components/autofill/core/browser/address.cc index 3a44121..c950f69c 100644 --- a/components/autofill/core/browser/address.cc +++ b/components/autofill/core/browser/address.cc
@@ -9,6 +9,7 @@ #include "base/i18n/case_conversion.h" #include "base/logging.h" +#include "base/stl_util.h" #include "base/strings/string_split.h" #include "base/strings/string_util.h" #include "base/strings/utf_string_conversions.h" @@ -199,8 +200,7 @@ // There's a good chance that this formatting is not intentional, but it's // also not obviously safe to just strip the newlines. if (storable_type == ADDRESS_HOME_STREET_ADDRESS && - std::find(street_address_.begin(), street_address_.end(), - base::string16()) != street_address_.end()) { + base::ContainsValue(street_address_, base::string16())) { street_address_.clear(); return false; }
diff --git a/components/autofill/core/browser/personal_data_manager.cc b/components/autofill/core/browser/personal_data_manager.cc index 1ed3ce5..4f3bef1 100644 --- a/components/autofill/core/browser/personal_data_manager.cc +++ b/components/autofill/core/browser/personal_data_manager.cc
@@ -16,6 +16,7 @@ #include "base/i18n/timezone.h" #include "base/memory/ptr_util.h" #include "base/profiler/scoped_tracker.h" +#include "base/stl_util.h" #include "base/strings/string_number_conversions.h" #include "base/strings/string_util.h" #include "base/strings/utf_string_conversions.h" @@ -1115,8 +1116,7 @@ AutofillCountry::CountryCodeForLocale(app_locale()))); } - return std::find(country_codes.begin(), country_codes.end(), - base::ToLowerASCII(country_code)) != country_codes.end(); + return base::ContainsValue(country_codes, base::ToLowerASCII(country_code)); } const std::string& PersonalDataManager::GetDefaultCountryCodeForNewAddress() @@ -1384,8 +1384,7 @@ std::string country_code = base::ToUpperASCII(base::UTF16ToASCII( profiles[i]->GetRawInfo(ADDRESS_HOME_COUNTRY))); - if (std::find(country_codes.begin(), country_codes.end(), country_code) != - country_codes.end()) { + if (base::ContainsValue(country_codes, country_code)) { // Verified profiles count 100x more than unverified ones. votes[country_code] += profiles[i]->IsVerified() ? 100 : 1; }
diff --git a/components/cast_channel/cast_socket_service.h b/components/cast_channel/cast_socket_service.h index eea0aee..bb465e9 100644 --- a/components/cast_channel/cast_socket_service.h +++ b/components/cast_channel/cast_socket_service.h
@@ -37,7 +37,7 @@ // Returns the socket corresponding to |channel_id| if one exists, or nullptr // otherwise. - CastSocket* GetSocket(int channel_id) const; + virtual CastSocket* GetSocket(int channel_id) const; CastSocket* GetSocket(const net::IPEndPoint& ip_endpoint) const; @@ -72,10 +72,10 @@ // |open_cb|: OnOpenCallback invoked when cast socket is opened. // |observer|: Observer handles messages and errors on newly opened socket. // Does not take ownership of |observer|. - int OpenSocket(const net::IPEndPoint& ip_endpoint, - net::NetLog* net_log, - const CastSocket::OnOpenCallback& open_cb, - CastSocket::Observer* observer); + virtual int OpenSocket(const net::IPEndPoint& ip_endpoint, + net::NetLog* net_log, + const CastSocket::OnOpenCallback& open_cb, + CastSocket::Observer* observer); // Returns an observer corresponding to |id|. CastSocket::Observer* GetObserver(const std::string& id); @@ -89,9 +89,10 @@ // Allow test to inject a mock cast socket. void SetSocketForTest(std::unique_ptr<CastSocket> socket_for_test); - private: + protected: ~CastSocketService() override; + private: // RefcountedKeyedService implementation. void ShutdownOnUIThread() override;
diff --git a/components/cdm/browser/media_drm_storage_impl.cc b/components/cdm/browser/media_drm_storage_impl.cc index 800c6275..2f9ee4f 100644 --- a/components/cdm/browser/media_drm_storage_impl.cc +++ b/components/cdm/browser/media_drm_storage_impl.cc
@@ -123,13 +123,13 @@ initialized_ = true; } -void MediaDrmStorageImpl::OnProvisioned(const OnProvisionedCallback& callback) { +void MediaDrmStorageImpl::OnProvisioned(OnProvisionedCallback callback) { DVLOG(1) << __func__; DCHECK(thread_checker_.CalledOnValidThread()); if (!initialized_) { DVLOG(1) << __func__ << ": Not initialized."; - callback.Run(false); + std::move(callback).Run(false); return; } @@ -144,19 +144,19 @@ storage_dict->SetWithoutPathExpansion(origin_string_, CreateOriginDictionary()); - callback.Run(true); + std::move(callback).Run(true); } void MediaDrmStorageImpl::SavePersistentSession( const std::string& session_id, media::mojom::SessionDataPtr session_data, - const SavePersistentSessionCallback& callback) { + SavePersistentSessionCallback callback) { DVLOG(2) << __func__; DCHECK(thread_checker_.CalledOnValidThread()); if (!initialized_) { DVLOG(1) << __func__ << ": Not initialized."; - callback.Run(false); + std::move(callback).Run(false); return; } @@ -196,18 +196,18 @@ session_id, CreateSessionDictionary(session_data->key_set_id, session_data->mime_type)); - callback.Run(true); + std::move(callback).Run(true); } void MediaDrmStorageImpl::LoadPersistentSession( const std::string& session_id, - const LoadPersistentSessionCallback& callback) { + LoadPersistentSessionCallback callback) { DVLOG(2) << __func__; DCHECK(thread_checker_.CalledOnValidThread()); if (!initialized_) { DVLOG(1) << __func__ << ": Not initialized."; - callback.Run(nullptr); + std::move(callback).Run(nullptr); return; } @@ -221,14 +221,14 @@ DVLOG(1) << __func__ << ": Failed to save persistent session data; entry for origin " << origin_ << " does not exist."; - callback.Run(nullptr); + std::move(callback).Run(nullptr); return; } const base::DictionaryValue* sessions_dict = nullptr; if (!origin_dict->GetDictionary(kSessions, &sessions_dict)) { DVLOG(2) << __func__ << ": Sessions dictionary does not exist."; - callback.Run(nullptr); + std::move(callback).Run(nullptr); return; } @@ -236,7 +236,7 @@ if (!sessions_dict->GetDictionaryWithoutPathExpansion(session_id, &session_dict)) { DVLOG(2) << __func__ << ": Session dictionary does not exist."; - callback.Run(nullptr); + std::move(callback).Run(nullptr); return; } @@ -244,22 +244,23 @@ std::string mime_type; if (!GetSessionData(session_dict, &key_set_id, &mime_type)) { DVLOG(2) << __func__ << ": Failed to read session data."; - callback.Run(nullptr); + std::move(callback).Run(nullptr); return; } - callback.Run(media::mojom::SessionData::New(key_set_id, mime_type)); + std::move(callback).Run( + media::mojom::SessionData::New(key_set_id, mime_type)); } void MediaDrmStorageImpl::RemovePersistentSession( const std::string& session_id, - const RemovePersistentSessionCallback& callback) { + RemovePersistentSessionCallback callback) { DVLOG(2) << __func__; DCHECK(thread_checker_.CalledOnValidThread()); if (!initialized_) { DVLOG(1) << __func__ << ": Not initialized."; - callback.Run(false); + std::move(callback).Run(false); return; } @@ -273,19 +274,19 @@ if (!origin_dict) { DVLOG(1) << __func__ << ": Entry for rigin " << origin_string_ << " does not exist."; - callback.Run(true); + std::move(callback).Run(true); return; } base::DictionaryValue* sessions_dict = nullptr; if (!origin_dict->GetDictionary(kSessions, &sessions_dict)) { DVLOG(2) << __func__ << ": Sessions dictionary does not exist."; - callback.Run(true); + std::move(callback).Run(true); return; } sessions_dict->RemoveWithoutPathExpansion(session_id, nullptr); - callback.Run(true); + std::move(callback).Run(true); } void MediaDrmStorageImpl::RenderFrameDeleted(
diff --git a/components/cdm/browser/media_drm_storage_impl.h b/components/cdm/browser/media_drm_storage_impl.h index a581cb6..f6970f6 100644 --- a/components/cdm/browser/media_drm_storage_impl.h +++ b/components/cdm/browser/media_drm_storage_impl.h
@@ -37,17 +37,14 @@ // media::mojom::MediaDrmStorage implementation. void Initialize(const url::Origin& origin) final; - void OnProvisioned(const OnProvisionedCallback& callback) final; - void SavePersistentSession( - const std::string& session_id, - media::mojom::SessionDataPtr session_data, - const SavePersistentSessionCallback& callback) final; - void LoadPersistentSession( - const std::string& session_id, - const LoadPersistentSessionCallback& callback) final; - void RemovePersistentSession( - const std::string& session_id, - const RemovePersistentSessionCallback& callback) final; + void OnProvisioned(OnProvisionedCallback callback) final; + void SavePersistentSession(const std::string& session_id, + media::mojom::SessionDataPtr session_data, + SavePersistentSessionCallback callback) final; + void LoadPersistentSession(const std::string& session_id, + LoadPersistentSessionCallback callback) final; + void RemovePersistentSession(const std::string& session_id, + RemovePersistentSessionCallback callback) final; // content::WebContentsObserver implementation. void RenderFrameDeleted(content::RenderFrameHost* render_frame_host) final;
diff --git a/components/cronet/android/cronet_url_request_context_adapter.cc b/components/cronet/android/cronet_url_request_context_adapter.cc index d62729b6..d9342555 100644 --- a/components/cronet/android/cronet_url_request_context_adapter.cc +++ b/components/cronet/android/cronet_url_request_context_adapter.cc
@@ -1027,7 +1027,7 @@ if (net_log_file_observer_) return; net_log_file_observer_ = net::FileNetLogObserver::CreateUnbounded( - GetFileThread()->task_runner(), file_path, /*constants=*/nullptr); + file_path, /*constants=*/nullptr); CreateNetLogEntriesForActiveObjects({context_.get()}, net_log_file_observer_.get()); net::NetLogCaptureMode capture_mode = @@ -1052,8 +1052,7 @@ DCHECK(base::PathIsWritable(file_path)); net_log_file_observer_ = net::FileNetLogObserver::CreateBounded( - GetFileThread()->task_runner(), file_path, size, kNumNetLogEventFiles, - /*constants=*/nullptr); + file_path, size, kNumNetLogEventFiles, /*constants=*/nullptr); CreateNetLogEntriesForActiveObjects({context_.get()}, net_log_file_observer_.get());
diff --git a/components/exo/DEPS b/components/exo/DEPS index 6971866..c58c382 100644 --- a/components/exo/DEPS +++ b/components/exo/DEPS
@@ -2,6 +2,7 @@ "+ash", "+cc", "+chromeos/audio/chromeos_sounds.h", + "+components/viz/common/quads", "+device/gamepad", "+gpu", "+mojo/public/cpp",
diff --git a/components/exo/buffer.cc b/components/exo/buffer.cc index 5e6b918..dc0977c 100644 --- a/components/exo/buffer.cc +++ b/components/exo/buffer.cc
@@ -25,6 +25,7 @@ #include "cc/resources/single_release_callback.h" #include "cc/resources/texture_mailbox.h" #include "components/exo/layer_tree_frame_sink_holder.h" +#include "components/viz/common/quads/resource_format.h" #include "gpu/command_buffer/client/context_support.h" #include "gpu/command_buffer/client/gles2_interface.h" #include "ui/aura/env.h" @@ -439,7 +440,7 @@ } resource->id = resource_id; - resource->format = cc::RGBA_8888; + resource->format = viz::RGBA_8888; resource->filter = GL_LINEAR; resource->size = gpu_memory_buffer_->GetSize();
diff --git a/components/exo/surface_tree_host.cc b/components/exo/surface_tree_host.cc index 8ca3a7c..36442f58 100644 --- a/components/exo/surface_tree_host.cc +++ b/components/exo/surface_tree_host.cc
@@ -31,7 +31,7 @@ bool EventLocationInsideBounds(aura::Window* window, const ui::LocatedEvent& event) const override { if (window != surface_tree_host_->host_window()) - return false; + return aura::WindowTargeter::EventLocationInsideBounds(window, event); Surface* surface = surface_tree_host_->root_surface(); if (!surface) @@ -49,7 +49,8 @@ ui::EventTarget* FindTargetForEvent(ui::EventTarget* root, ui::Event* event) override { aura::Window* window = static_cast<aura::Window*>(root); - DCHECK_EQ(window, surface_tree_host_->host_window()); + if (window != surface_tree_host_->host_window()) + return aura::WindowTargeter::FindTargetForEvent(root, event); ui::EventTarget* target = aura::WindowTargeter::FindTargetForEvent(root, event); // Do not accept events in SurfaceTreeHost window.
diff --git a/components/favicon/core/large_icon_service.cc b/components/favicon/core/large_icon_service.cc index 043678a..bb99ce88 100644 --- a/components/favicon/core/large_icon_service.cc +++ b/components/favicon/core/large_icon_service.cc
@@ -267,18 +267,31 @@ UMA_HISTOGRAM_COUNTS_1000("Favicons.LargeIconService.DownloadedSize", size); } +void OnSetOnDemandFaviconComplete( + const favicon_base::GoogleFaviconServerCallback& callback, + bool success) { + callback.Run( + success + ? favicon_base::GoogleFaviconServerRequestStatus::SUCCESS + : favicon_base::GoogleFaviconServerRequestStatus::FAILURE_ON_WRITE); +} + void OnFetchIconFromGoogleServerComplete( FaviconService* favicon_service, const GURL& page_url, - const base::Callback<void(bool success)>& callback, + const favicon_base::GoogleFaviconServerCallback& callback, const std::string& server_request_url, const gfx::Image& image, const image_fetcher::RequestMetadata& metadata) { if (image.IsEmpty()) { DLOG(WARNING) << "large icon server fetch empty " << server_request_url; favicon_service->UnableToDownloadFavicon(GURL(server_request_url)); - base::ThreadTaskRunnerHandle::Get()->PostTask(FROM_HERE, - base::Bind(callback, false)); + callback.Run(metadata.http_response_code == + net::URLFetcher::RESPONSE_CODE_INVALID + ? favicon_base::GoogleFaviconServerRequestStatus:: + FAILURE_CONNECTION_ERROR + : favicon_base::GoogleFaviconServerRequestStatus:: + FAILURE_HTTP_ERROR); ReportDownloadedSize(0); return; } @@ -297,9 +310,9 @@ // something else could've been written). By marking the icons initially // expired (out-of-date), they will be refetched when we visit the original // page any time in the future. - favicon_service->SetOnDemandFavicons(page_url, GURL(original_icon_url), - favicon_base::IconType::TOUCH_ICON, - image, callback); + favicon_service->SetOnDemandFavicons( + page_url, GURL(original_icon_url), favicon_base::IconType::TOUCH_ICON, + image, base::Bind(&OnSetOnDemandFaviconComplete, callback)); } } // namespace @@ -351,7 +364,7 @@ int desired_size_in_pixel, bool may_page_url_be_private, const net::NetworkTrafficAnnotationTag& traffic_annotation, - const base::Callback<void(bool success)>& callback) { + const favicon_base::GoogleFaviconServerCallback& callback) { DCHECK_LE(0, min_source_size_in_pixel); const GURL trimmed_page_url = TrimPageUrlForGoogleServer(page_url); @@ -359,13 +372,23 @@ trimmed_page_url, min_source_size_in_pixel, desired_size_in_pixel, may_page_url_be_private); - // Do not download if the URL is invalid after trimming, or there is a - // previous cache miss recorded for |server_request_url|. if (!server_request_url.is_valid() || !trimmed_page_url.is_valid() || - !image_fetcher_ || - favicon_service_->WasUnableToDownloadFavicon(server_request_url)) { - base::ThreadTaskRunnerHandle::Get()->PostTask(FROM_HERE, - base::Bind(callback, false)); + !image_fetcher_) { + base::ThreadTaskRunnerHandle::Get()->PostTask( + FROM_HERE, + base::Bind( + callback, + favicon_base::GoogleFaviconServerRequestStatus::FAILURE_INVALID)); + return; + } + + // Do not download if there is a previous cache miss recorded for + // |server_request_url|. + if (favicon_service_->WasUnableToDownloadFavicon(server_request_url)) { + base::ThreadTaskRunnerHandle::Get()->PostTask( + FROM_HERE, + base::Bind(callback, favicon_base::GoogleFaviconServerRequestStatus:: + FAILURE_HTTP_ERROR_CACHED)); return; }
diff --git a/components/favicon/core/large_icon_service.h b/components/favicon/core/large_icon_service.h index 0501625..d44ace6 100644 --- a/components/favicon/core/large_icon_service.h +++ b/components/favicon/core/large_icon_service.h
@@ -100,7 +100,7 @@ int desired_size_in_pixel, bool may_page_url_be_private, const net::NetworkTrafficAnnotationTag& traffic_annotation, - const base::Callback<void(bool success)>& callback); + const favicon_base::GoogleFaviconServerCallback& callback); private: base::CancelableTaskTracker::TaskId GetLargeIconOrFallbackStyleImpl(
diff --git a/components/favicon/core/large_icon_service_unittest.cc b/components/favicon/core/large_icon_service_unittest.cc index 23a2a67..e048504 100644 --- a/components/favicon/core/large_icon_service_unittest.cc +++ b/components/favicon/core/large_icon_service_unittest.cc
@@ -151,7 +151,7 @@ EXPECT_CALL(mock_favicon_service_, UnableToDownloadFavicon(_)).Times(0); - base::MockCallback<base::Callback<void(bool success)>> callback; + base::MockCallback<favicon_base::GoogleFaviconServerCallback> callback; EXPECT_CALL(*mock_image_fetcher_, StartOrQueueNetworkRequest(_, kExpectedServerUrl, _, _)) .WillOnce(PostFetchReply(gfx::Image::CreateFrom1xBitmap( @@ -167,7 +167,8 @@ /*desired_size_in_pixel=*/61, /*may_page_url_be_private=*/true, TRAFFIC_ANNOTATION_FOR_TESTS, callback.Get()); - EXPECT_CALL(callback, Run(true)); + EXPECT_CALL(callback, + Run(favicon_base::GoogleFaviconServerRequestStatus::SUCCESS)); base::RunLoop().RunUntilIdle(); histogram_tester_.ExpectUniqueSample( "Favicons.LargeIconService.DownloadedSize", 64, /*expected_count=*/1); @@ -188,7 +189,7 @@ EXPECT_CALL(mock_favicon_service_, UnableToDownloadFavicon(_)).Times(0); - base::MockCallback<base::Callback<void(bool success)>> callback; + base::MockCallback<favicon_base::GoogleFaviconServerCallback> callback; EXPECT_CALL(*mock_image_fetcher_, StartOrQueueNetworkRequest(_, kExpectedServerUrl, _, _)) .WillOnce(PostFetchReply(gfx::Image::CreateFrom1xBitmap( @@ -204,7 +205,8 @@ /*desired_size_in_pixel=*/61, /*may_page_url_be_private=*/true, TRAFFIC_ANNOTATION_FOR_TESTS, callback.Get()); - EXPECT_CALL(callback, Run(true)); + EXPECT_CALL(callback, + Run(favicon_base::GoogleFaviconServerRequestStatus::SUCCESS)); base::RunLoop().RunUntilIdle(); } @@ -228,14 +230,15 @@ favicon_base::IconType::TOUCH_ICON, _, _)) .WillOnce(PostBoolReply(true)); - base::MockCallback<base::Callback<void(bool success)>> callback; + base::MockCallback<favicon_base::GoogleFaviconServerCallback> callback; large_icon_service_ .GetLargeIconOrFallbackStyleFromGoogleServerSkippingLocalCache( GURL(kDummyUrl), /*min_source_size_in_pixel=*/42, /*desired_size_in_pixel=*/61, /*may_page_url_be_private=*/true, TRAFFIC_ANNOTATION_FOR_TESTS, callback.Get()); - EXPECT_CALL(callback, Run(true)); + EXPECT_CALL(callback, + Run(favicon_base::GoogleFaviconServerRequestStatus::SUCCESS)); base::RunLoop().RunUntilIdle(); } @@ -258,7 +261,8 @@ .GetLargeIconOrFallbackStyleFromGoogleServerSkippingLocalCache( GURL(kDummyUrlWithQuery), /*min_source_size_in_pixel=*/42, /*desired_size_in_pixel=*/61, /*may_page_url_be_private=*/true, - TRAFFIC_ANNOTATION_FOR_TESTS, base::Callback<void(bool success)>()); + TRAFFIC_ANNOTATION_FOR_TESTS, + favicon_base::GoogleFaviconServerCallback()); base::RunLoop().RunUntilIdle(); } @@ -271,7 +275,7 @@ _, Property(&GURL::query, Not(HasSubstr("check_seen=true"))), _, _)) .WillOnce(PostFetchReply(gfx::Image())); - base::MockCallback<base::Callback<void(bool success)>> callback; + base::MockCallback<favicon_base::GoogleFaviconServerCallback> callback; large_icon_service_ .GetLargeIconOrFallbackStyleFromGoogleServerSkippingLocalCache( @@ -279,7 +283,8 @@ /*desired_size_in_pixel=*/61, /*may_page_url_be_private=*/false, TRAFFIC_ANNOTATION_FOR_TESTS, callback.Get()); - EXPECT_CALL(callback, Run(false)); + EXPECT_CALL(callback, Run(favicon_base::GoogleFaviconServerRequestStatus:: + FAILURE_CONNECTION_ERROR)); base::RunLoop().RunUntilIdle(); } @@ -289,7 +294,7 @@ EXPECT_CALL(*mock_image_fetcher_, StartOrQueueNetworkRequest(_, _, _, _)) .Times(0); - base::MockCallback<base::Callback<void(bool success)>> callback; + base::MockCallback<favicon_base::GoogleFaviconServerCallback> callback; large_icon_service_ .GetLargeIconOrFallbackStyleFromGoogleServerSkippingLocalCache( @@ -297,7 +302,9 @@ /*desired_size_in_pixel=*/61, /*may_page_url_be_private=*/true, TRAFFIC_ANNOTATION_FOR_TESTS, callback.Get()); - EXPECT_CALL(callback, Run(false)); + EXPECT_CALL( + callback, + Run(favicon_base::GoogleFaviconServerRequestStatus::FAILURE_INVALID)); base::RunLoop().RunUntilIdle(); EXPECT_THAT(histogram_tester_.GetAllSamples( "Favicons.LargeIconService.DownloadedSize"), @@ -314,7 +321,7 @@ EXPECT_CALL(mock_favicon_service_, SetOnDemandFavicons(_, _, _, _, _)) .Times(0); - base::MockCallback<base::Callback<void(bool success)>> callback; + base::MockCallback<favicon_base::GoogleFaviconServerCallback> callback; EXPECT_CALL(*mock_image_fetcher_, StartOrQueueNetworkRequest(_, kExpectedServerUrl, _, _)) .WillOnce(PostFetchReply(gfx::Image())); @@ -327,7 +334,8 @@ /*desired_size_in_pixel=*/61, /*may_page_url_be_private=*/true, TRAFFIC_ANNOTATION_FOR_TESTS, callback.Get()); - EXPECT_CALL(callback, Run(false)); + EXPECT_CALL(callback, Run(favicon_base::GoogleFaviconServerRequestStatus:: + FAILURE_CONNECTION_ERROR)); base::RunLoop().RunUntilIdle(); // Verify that download failure gets recorded. histogram_tester_.ExpectUniqueSample( @@ -349,14 +357,15 @@ EXPECT_CALL(mock_favicon_service_, SetOnDemandFavicons(_, _, _, _, _)) .Times(0); - base::MockCallback<base::Callback<void(bool success)>> callback; + base::MockCallback<favicon_base::GoogleFaviconServerCallback> callback; large_icon_service_ .GetLargeIconOrFallbackStyleFromGoogleServerSkippingLocalCache( GURL(kDummyUrl), /*min_source_size_in_pixel=*/42, /*desired_size_in_pixel=*/61, /*may_page_url_be_private=*/true, TRAFFIC_ANNOTATION_FOR_TESTS, callback.Get()); - EXPECT_CALL(callback, Run(false)); + EXPECT_CALL(callback, Run(favicon_base::GoogleFaviconServerRequestStatus:: + FAILURE_HTTP_ERROR_CACHED)); base::RunLoop().RunUntilIdle(); EXPECT_THAT(histogram_tester_.GetAllSamples( "Favicons.LargeIconService.DownloadedSize"),
diff --git a/components/favicon_base/favicon_callback.h b/components/favicon_base/favicon_callback.h index 28ad5b3..318f64c 100644 --- a/components/favicon_base/favicon_callback.h +++ b/components/favicon_base/favicon_callback.h
@@ -15,6 +15,7 @@ struct FaviconImageResult; struct LargeIconResult; struct LargeIconImageResult; +enum class GoogleFaviconServerRequestStatus; // Callback for functions that can be used to return a |gfx::Image| and the // |GURL| it is loaded from. They are returned as a |FaviconImageResult| object. @@ -44,6 +45,9 @@ typedef base::Callback<void(const LargeIconImageResult&)> LargeIconImageCallback; +typedef base::Callback<void(GoogleFaviconServerRequestStatus)> + GoogleFaviconServerCallback; + } // namespace favicon_base #endif // COMPONENTS_FAVICON_BASE_FAVICON_CALLBACK_H_
diff --git a/components/favicon_base/favicon_types.h b/components/favicon_base/favicon_types.h index 7ad22ff..4afec6f 100644 --- a/components/favicon_base/favicon_types.h +++ b/components/favicon_base/favicon_types.h
@@ -119,6 +119,28 @@ std::unique_ptr<FallbackIconStyle> fallback_icon_style; }; +// Enumeration listing all possible outcomes for fetch attempts from Google +// favicon server. Used for UMA enum GoogleFaviconServerRequestStatus, so do not +// change existing values. Insert new values at the end, and update the +// histogram definition. +enum class GoogleFaviconServerRequestStatus { + // Request sent out and the favicon successfully fetched. + SUCCESS = 0, + // Request sent out and a connection error occurred (no valid HTTP response + // recevied). + FAILURE_CONNECTION_ERROR = 1, + // Request sent out and a HTTP error received. + FAILURE_HTTP_ERROR = 2, + // Request not sent out (previous HTTP error in cache). + FAILURE_HTTP_ERROR_CACHED = 3, + // Request sent out and favicon fetched but writing to database failed. + FAILURE_ON_WRITE = 4, + // Request not sent out (the request or the fetcher was invalid). + FAILURE_INVALID = 5, + // Insert new values here. + COUNT +}; + } // namespace favicon_base #endif // COMPONENTS_FAVICON_BASE_FAVICON_TYPES_H_
diff --git a/components/gcm_driver/gcm_client_impl.cc b/components/gcm_driver/gcm_client_impl.cc index 9cd3eb9..f18900d 100644 --- a/components/gcm_driver/gcm_client_impl.cc +++ b/components/gcm_driver/gcm_client_impl.cc
@@ -80,7 +80,6 @@ RESET_STORE_ERROR_COUNT }; -const char kGCMScope[] = "GCM"; const int kMaxRegistrationRetries = 5; const int kMaxUnregistrationRetries = 5; const char kDeletedCountKey[] = "total_deleted"; @@ -1394,65 +1393,16 @@ bool was_subtype, const mcs_proto::DataMessageStanza& data_message_stanza, MessageData& message_data) { - std::string sender = data_message_stanza.from(); + UMA_HISTOGRAM_BOOLEAN("GCM.DataMessageReceived", true); - // Drop the message when the app is not registered for the sender of the - // message. - bool registered = false; + bool has_collapse_key = + data_message_stanza.has_token() && !data_message_stanza.token().empty(); + UMA_HISTOGRAM_BOOLEAN("GCM.DataMessageReceivedHasCollapseKey", + has_collapse_key); - // First, find among all GCM registrations. - std::unique_ptr<GCMRegistrationInfo> gcm_registration( - new GCMRegistrationInfo); - gcm_registration->app_id = app_id; - auto gcm_registration_iter = registrations_.find( - make_linked_ptr<RegistrationInfo>(gcm_registration.release())); - if (gcm_registration_iter != registrations_.end()) { - GCMRegistrationInfo* cached_gcm_registration = - GCMRegistrationInfo::FromRegistrationInfo( - gcm_registration_iter->first.get()); - if (cached_gcm_registration && - std::find(cached_gcm_registration->sender_ids.begin(), - cached_gcm_registration->sender_ids.end(), - sender) != cached_gcm_registration->sender_ids.end()) { - if (was_subtype) - DLOG(ERROR) << "GCM message for non-IID " << app_id << " used subtype"; - else - registered = true; - } - } - - // Then, find among all InstanceID registrations. - if (!registered) { - std::unique_ptr<InstanceIDTokenInfo> instance_id_token( - new InstanceIDTokenInfo); - instance_id_token->app_id = app_id; - instance_id_token->authorized_entity = sender; - instance_id_token->scope = kGCMScope; - auto instance_id_token_iter = registrations_.find( - make_linked_ptr<RegistrationInfo>(instance_id_token.release())); - if (instance_id_token_iter != registrations_.end()) { - if (was_subtype != InstanceIDUsesSubtypeForAppId(app_id)) { - DLOG(ERROR) << "GCM message for " << app_id - << " incorrectly had was_subtype = " << was_subtype; - } else { - registered = true; - } - } - } - - UMA_HISTOGRAM_BOOLEAN("GCM.DataMessageReceivedHasRegisteredApp", registered); - if (registered) { - UMA_HISTOGRAM_BOOLEAN("GCM.DataMessageReceived", true); - bool has_collapse_key = - data_message_stanza.has_token() && !data_message_stanza.token().empty(); - UMA_HISTOGRAM_BOOLEAN("GCM.DataMessageReceivedHasCollapseKey", - has_collapse_key); - } - recorder_.RecordDataMessageReceived(app_id, sender, - data_message_stanza.ByteSize(), registered, - GCMStatsRecorder::DATA_MESSAGE); - if (!registered) - return; + recorder_.RecordDataMessageReceived(app_id, data_message_stanza.from(), + data_message_stanza.ByteSize(), + GCMStatsRecorder::DATA_MESSAGE); IncomingMessage incoming_message; incoming_message.sender_id = data_message_stanza.from(); @@ -1478,7 +1428,6 @@ recorder_.RecordDataMessageReceived(app_id, data_message_stanza.from(), data_message_stanza.ByteSize(), - true /* to_registered_app */, GCMStatsRecorder::DELETED_MESSAGES); delegate_->OnMessagesDeleted(app_id); }
diff --git a/components/gcm_driver/gcm_client_impl_unittest.cc b/components/gcm_driver/gcm_client_impl_unittest.cc index 827a605..7486c1c 100644 --- a/components/gcm_driver/gcm_client_impl_unittest.cc +++ b/components/gcm_driver/gcm_client_impl_unittest.cc
@@ -65,7 +65,6 @@ const char kSubtypeAppId[] = "app_id"; const char kSender[] = "project_id"; const char kSender2[] = "project_id2"; -const char kSender3[] = "project_id3"; const char kRegistrationResponsePrefix[] = "token="; const char kUnregistrationResponsePrefix[] = "deleted="; const char kRawData[] = "example raw data"; @@ -926,18 +925,6 @@ EXPECT_EQ(expected_data.size(), last_message().data.size()); EXPECT_EQ(expected_data, last_message().data); EXPECT_EQ(kSender2, last_message().sender_id); - - reset_last_event(); - - // Message from kSender3 will be dropped. - MCSMessage message3(BuildDownstreamMessage( - kSender3, kExtensionAppId, std::string() /* subtype */, expected_data, - std::string() /* raw_data */)); - EXPECT_TRUE(message3.IsValid()); - ReceiveMessageFromMCS(message3); - - EXPECT_NE(MESSAGE_RECEIVED, last_event()); - EXPECT_NE(kExtensionAppId, last_app_id()); } TEST_F(GCMClientImplTest, DispatchDownstreamMessageRawData) { @@ -1775,122 +1762,40 @@ AddInstanceID(kExtensionAppId, kInstanceID); GetToken(kExtensionAppId, kSender, kScope); ASSERT_NO_FATAL_FAILURE(CompleteRegistration("token1")); - GetToken(kExtensionAppId, kSender2, kScope); - ASSERT_NO_FATAL_FAILURE(CompleteRegistration("token2")); std::map<std::string, std::string> expected_data; - // Message for kSender with a subtype will be dropped. - MCSMessage message0(BuildDownstreamMessage( - kSender, kProductCategoryForSubtypes, kExtensionAppId /* subtype */, - expected_data, std::string() /* raw_data */)); - EXPECT_TRUE(message0.IsValid()); - ReceiveMessageFromMCS(message0); - - EXPECT_NE(MESSAGE_RECEIVED, last_event()); - - reset_last_event(); - - // Message for kSender will be received. - MCSMessage message1(BuildDownstreamMessage( + MCSMessage message(BuildDownstreamMessage( kSender, kExtensionAppId, std::string() /* subtype */, expected_data, std::string() /* raw_data */)); - EXPECT_TRUE(message1.IsValid()); - ReceiveMessageFromMCS(message1); + EXPECT_TRUE(message.IsValid()); + ReceiveMessageFromMCS(message); EXPECT_EQ(MESSAGE_RECEIVED, last_event()); EXPECT_EQ(kExtensionAppId, last_app_id()); EXPECT_EQ(expected_data.size(), last_message().data.size()); EXPECT_EQ(expected_data, last_message().data); EXPECT_EQ(kSender, last_message().sender_id); - - reset_last_event(); - - // Message for kSender2 will be received. - MCSMessage message2(BuildDownstreamMessage( - kSender2, kExtensionAppId, std::string() /* subtype */, expected_data, - std::string() /* raw_data */)); - EXPECT_TRUE(message2.IsValid()); - ReceiveMessageFromMCS(message2); - - EXPECT_EQ(MESSAGE_RECEIVED, last_event()); - EXPECT_EQ(kExtensionAppId, last_app_id()); - EXPECT_EQ(expected_data.size(), last_message().data.size()); - EXPECT_EQ(expected_data, last_message().data); - EXPECT_EQ(kSender2, last_message().sender_id); - - reset_last_event(); - - // Message from kSender3 will be dropped. - MCSMessage message3(BuildDownstreamMessage( - kSender3, kExtensionAppId, std::string() /* subtype */, expected_data, - std::string() /* raw_data */)); - EXPECT_TRUE(message3.IsValid()); - ReceiveMessageFromMCS(message3); - - EXPECT_NE(MESSAGE_RECEIVED, last_event()); - EXPECT_NE(kExtensionAppId, last_app_id()); } TEST_F(GCMClientInstanceIDTest, DispatchDownstreamMessageWithSubtype) { AddInstanceID(kSubtypeAppId, kInstanceID); GetToken(kSubtypeAppId, kSender, kScope); ASSERT_NO_FATAL_FAILURE(CompleteRegistration("token1")); - GetToken(kSubtypeAppId, kSender2, kScope); - ASSERT_NO_FATAL_FAILURE(CompleteRegistration("token2")); std::map<std::string, std::string> expected_data; - // Message for kSender without a subtype will be dropped. - MCSMessage message0(BuildDownstreamMessage( - kSender, kSubtypeAppId, std::string() /* subtype */, expected_data, - std::string() /* raw_data */)); - EXPECT_TRUE(message0.IsValid()); - ReceiveMessageFromMCS(message0); - - EXPECT_NE(MESSAGE_RECEIVED, last_event()); - - reset_last_event(); - - // Message for kSender will be received. - MCSMessage message1(BuildDownstreamMessage( + MCSMessage message(BuildDownstreamMessage( kSender, kProductCategoryForSubtypes, kSubtypeAppId /* subtype */, expected_data, std::string() /* raw_data */)); - EXPECT_TRUE(message1.IsValid()); - ReceiveMessageFromMCS(message1); + EXPECT_TRUE(message.IsValid()); + ReceiveMessageFromMCS(message); EXPECT_EQ(MESSAGE_RECEIVED, last_event()); EXPECT_EQ(kSubtypeAppId, last_app_id()); EXPECT_EQ(expected_data.size(), last_message().data.size()); EXPECT_EQ(expected_data, last_message().data); EXPECT_EQ(kSender, last_message().sender_id); - - reset_last_event(); - - // Message for kSender2 will be received. - MCSMessage message2(BuildDownstreamMessage( - kSender2, kProductCategoryForSubtypes, kSubtypeAppId /* subtype */, - expected_data, std::string() /* raw_data */)); - EXPECT_TRUE(message2.IsValid()); - ReceiveMessageFromMCS(message2); - - EXPECT_EQ(MESSAGE_RECEIVED, last_event()); - EXPECT_EQ(kSubtypeAppId, last_app_id()); - EXPECT_EQ(expected_data.size(), last_message().data.size()); - EXPECT_EQ(expected_data, last_message().data); - EXPECT_EQ(kSender2, last_message().sender_id); - - reset_last_event(); - - // Message from kSender3 will be dropped. - MCSMessage message3(BuildDownstreamMessage( - kSender3, kProductCategoryForSubtypes, kSubtypeAppId /* subtype */, - expected_data, std::string() /* raw_data */)); - EXPECT_TRUE(message3.IsValid()); - ReceiveMessageFromMCS(message3); - - EXPECT_NE(MESSAGE_RECEIVED, last_event()); - EXPECT_NE(kSubtypeAppId, last_app_id()); } TEST_F(GCMClientInstanceIDTest, DispatchDownstreamMessageWithFakeSubtype) {
diff --git a/components/gcm_driver/gcm_stats_recorder_impl.cc b/components/gcm_driver/gcm_stats_recorder_impl.cc index cf511d8..e3a2711 100644 --- a/components/gcm_driver/gcm_stats_recorder_impl.cc +++ b/components/gcm_driver/gcm_stats_recorder_impl.cc
@@ -415,7 +415,6 @@ const std::string& app_id, const std::string& from, int message_byte_size, - bool to_registered_app, ReceivedMessageType message_type) { base::TimeTicks new_timestamp = base::TimeTicks::Now(); if (last_received_data_message_burst_start_time_.is_null()) { @@ -449,23 +448,16 @@ if (!is_recording_) return; - if (!to_registered_app) { - RecordReceiving(app_id, - from, - message_byte_size, - "Data msg received", - "No such registered app found"); - } else { - switch (message_type) { - case GCMStatsRecorderImpl::DATA_MESSAGE: - RecordReceiving(app_id, from, message_byte_size, "Data msg received", - std::string()); - break; - case GCMStatsRecorderImpl::DELETED_MESSAGES: - RecordReceiving(app_id, from, message_byte_size, "Data msg received", - "Message has been deleted on server"); - break; - } + + switch (message_type) { + case GCMStatsRecorderImpl::DATA_MESSAGE: + RecordReceiving(app_id, from, message_byte_size, "Data msg received", + std::string()); + break; + case GCMStatsRecorderImpl::DELETED_MESSAGES: + RecordReceiving(app_id, from, message_byte_size, "Data msg received", + "Message has been deleted on server"); + break; } }
diff --git a/components/gcm_driver/gcm_stats_recorder_impl.h b/components/gcm_driver/gcm_stats_recorder_impl.h index 77af2970..30f3e73 100644 --- a/components/gcm_driver/gcm_stats_recorder_impl.h +++ b/components/gcm_driver/gcm_stats_recorder_impl.h
@@ -78,7 +78,6 @@ void RecordDataMessageReceived(const std::string& app_id, const std::string& from, int message_byte_size, - bool to_registered_app, ReceivedMessageType message_type) override; void RecordDataSentToWire(const std::string& app_id, const std::string& receiver_id,
diff --git a/components/gcm_driver/gcm_stats_recorder_impl_unittest.cc b/components/gcm_driver/gcm_stats_recorder_impl_unittest.cc index a73a78b..03fe0963 100644 --- a/components/gcm_driver/gcm_stats_recorder_impl_unittest.cc +++ b/components/gcm_driver/gcm_stats_recorder_impl_unittest.cc
@@ -86,9 +86,6 @@ static const char kDataReceivedEvent[] = "Data msg received"; static const char kDataReceivedDetails[] = ""; -static const char kDataReceivedNotRegisteredEvent[] = "Data msg received"; -static const char kDataReceivedNotRegisteredDetails[] = - "No such registered app found"; static const char kDataDeletedMessageEvent[] = "Data msg received"; static const char kDataDeletedMessageDetails[] = "Message has been deleted on server"; @@ -270,13 +267,6 @@ remark); } - void VerifyDataMessageReceivedNotRegistered(const std::string& remark) { - VerifyReceivingData(recorder_.receiving_activities(), - kDataReceivedNotRegisteredEvent, - kDataReceivedNotRegisteredDetails, - remark); - } - void VerifyDataSentToWire(const std::string& remark) { VerifySendingData(recorder_.sending_activities(), kDataSentToWireEvent, @@ -410,12 +400,10 @@ recorder_.RecordUnregistrationRetryDelayed(kAppId, source_, kDelay, kRetries); VerifyAllActivityQueueEmpty("no unregistration"); - recorder_.RecordDataMessageReceived(kAppId, kFrom, kByteSize, true, + recorder_.RecordDataMessageReceived(kAppId, kFrom, kByteSize, GCMStatsRecorder::DATA_MESSAGE); - recorder_.RecordDataMessageReceived(kAppId, kFrom, kByteSize, true, + recorder_.RecordDataMessageReceived(kAppId, kFrom, kByteSize, GCMStatsRecorder::DELETED_MESSAGES); - recorder_.RecordDataMessageReceived(kAppId, kFrom, kByteSize, false, - GCMStatsRecorder::DATA_MESSAGE); VerifyAllActivityQueueEmpty("no receiving"); recorder_.RecordDataSentToWire(kAppId, kReceiverId, kMessageId, kQueuedSec); @@ -511,20 +499,15 @@ TEST_F(GCMStatsRecorderImplTest, RecordReceivingTest) { recorder_.RecordConnectionInitiated(std::string()); recorder_.RecordConnectionSuccess(); - recorder_.RecordDataMessageReceived(kAppId, kFrom, kByteSize, true, + recorder_.RecordDataMessageReceived(kAppId, kFrom, kByteSize, GCMStatsRecorder::DATA_MESSAGE); VerifyRecordedReceivingCount(1); VerifyDataMessageReceived("1st call"); - recorder_.RecordDataMessageReceived(kAppId, kFrom, kByteSize, true, + recorder_.RecordDataMessageReceived(kAppId, kFrom, kByteSize, GCMStatsRecorder::DELETED_MESSAGES); VerifyRecordedReceivingCount(2); VerifyDataDeletedMessage("2nd call"); - - recorder_.RecordDataMessageReceived(kAppId, kFrom, kByteSize, false, - GCMStatsRecorder::DATA_MESSAGE); - VerifyRecordedReceivingCount(3); - VerifyDataMessageReceivedNotRegistered("3rd call"); } TEST_F(GCMStatsRecorderImplTest, RecordSendingTest) {
diff --git a/components/metrics/file_metrics_provider.cc b/components/metrics/file_metrics_provider.cc index c3745b1..d6165f2 100644 --- a/components/metrics/file_metrics_provider.cc +++ b/components/metrics/file_metrics_provider.cc
@@ -579,14 +579,6 @@ UMA_HISTOGRAM_COUNTS_10000( "UMA.FileMetricsProvider.EmbeddedProfile.DroppedHistogramCount", histogram_count); - - base::File::Info info; - if (base::GetFileInfo(source->path, &info)) { - UMA_HISTOGRAM_CUSTOM_COUNTS( - "UMA.FileMetricsProvider.EmbeddedProfile.DroppedFileAge", - (base::Time::Now() - info.last_modified).InMinutes(), 1, - base::TimeDelta::FromDays(30).InMinutes(), 50); - } } // Regardless of whether this source was successfully recorded, it is never
diff --git a/components/metrics/proto/BUILD.gn b/components/metrics/proto/BUILD.gn index d8f8c1fd..c224887b 100644 --- a/components/metrics/proto/BUILD.gn +++ b/components/metrics/proto/BUILD.gn
@@ -16,6 +16,7 @@ "omnibox_input_type.proto", "perf_data.proto", "perf_stat.proto", + "printer_event.proto", "profiler_event.proto", "sampled_profile.proto", "system_profile.proto",
diff --git a/components/metrics/proto/chrome_user_metrics_extension.proto b/components/metrics/proto/chrome_user_metrics_extension.proto index 77950f9..aa930da5 100644 --- a/components/metrics/proto/chrome_user_metrics_extension.proto +++ b/components/metrics/proto/chrome_user_metrics_extension.proto
@@ -19,11 +19,12 @@ import "profiler_event.proto"; import "system_profile.proto"; import "translate_event.proto"; +import "printer_event.proto"; import "user_action_event.proto"; import "perf_data.proto"; import "sampled_profile.proto"; -// Next tag: 16 +// Next tag: 17 message ChromeUserMetricsExtension { // The product (i.e. end user application) for a given UMA log. enum Product { @@ -70,6 +71,7 @@ repeated HistogramEventProto histogram_event = 6; repeated ProfilerEventProto profiler_event = 7; repeated TranslateEventProto translate_event = 15; + repeated PrinterEventProto printer_event = 16; // This field is no longer used. Use |sampled_profile| instead. repeated PerfDataProto perf_data = 8 [deprecated=true];
diff --git a/components/metrics/proto/printer_event.proto b/components/metrics/proto/printer_event.proto new file mode 100644 index 0000000..1c49a57 --- /dev/null +++ b/components/metrics/proto/printer_event.proto
@@ -0,0 +1,64 @@ +// Copyright 2017 The Chromium Authors. All rights reserved. +// Use of this source code is governed by a BSD-style license that can be +// found in the LICENSE file. +// +// Stores information about printer configuration attempts. + +syntax = "proto2"; + +option optimize_for = LITE_RUNTIME; +option java_outer_classname = "PrinterEventProtos"; +option java_package = "org.chromium.components.metrics"; + +package metrics; + +// Stores information about a printer that a user is setting up/has attempted to +// set up. +// Next tag: 9 +message PrinterEventProto { + // The detected printer manufacuter name. + optional string usb_printer_manufacturer = 1; + + // The detected printer model name. + optional string usb_printer_model = 2; + + // The usb vendor id of the printer. + optional int32 usb_vendor_id = 3; + + // The usb model id of the printer. + optional int32 usb_model_id = 4; + + // The value reported as a printer's printer-make-and-model attribute. + optional string ipp_make_and_model = 5; + + // A true value means that the user provided their own PPD. + optional bool user_ppd = 6; + + // The identifier for PPDs from our serving system. + optional string ppd_identifier = 7; + + // The action for which the printer was logged. + // Next tag: 5 + enum EventType { + UNKNOWN = 0; + + // Specified printer successfully installed using the detected + // configuration. + SETUP_AUTOMATIC = 1; + + // Specified printer was installed when the user selected the appropriate + // configuration. + SETUP_MANUAL = 2; + + // Setup was started but abandoned when user was prompted to choose a + // configuration. + SETUP_ABANDONED = 3; + + // A printer, which had been successfully installed, was deleted from the + // user's preferences. + PRINTER_DELETED = 4; + } + + // The event for which this was recorded. + optional EventType event_type = 8; +}
diff --git a/components/net_log/chrome_net_log.cc b/components/net_log/chrome_net_log.cc index 509de9d1..8c845413 100644 --- a/components/net_log/chrome_net_log.cc +++ b/components/net_log/chrome_net_log.cc
@@ -4,12 +4,9 @@ #include "components/net_log/chrome_net_log.h" -#include <stdio.h> #include <utility> #include "base/command_line.h" -#include "base/files/scoped_file.h" -#include "base/logging.h" #include "base/memory/ptr_util.h" #include "base/strings/stringprintf.h" #include "base/sys_info.h" @@ -18,9 +15,9 @@ #include "components/data_reduction_proxy/core/common/data_reduction_proxy_event_store.h" #include "components/net_log/net_export_file_writer.h" #include "components/version_info/version_info.h" +#include "net/log/file_net_log_observer.h" #include "net/log/net_log_util.h" #include "net/log/trace_net_log_observer.h" -#include "net/log/write_to_file_net_log_observer.h" namespace net_log { @@ -31,48 +28,22 @@ ChromeNetLog::~ChromeNetLog() { net_export_file_writer_.reset(); - // Remove the observers we own before we're destroyed. - if (write_to_file_observer_) - write_to_file_observer_->StopObserving(nullptr); - if (trace_net_log_observer_) - trace_net_log_observer_->StopWatchForTraceStart(); + ClearFileNetLogObserver(); + trace_net_log_observer_->StopWatchForTraceStart(); } void ChromeNetLog::StartWritingToFile( - const base::FilePath& log_file, - net::NetLogCaptureMode log_file_mode, + const base::FilePath& path, + net::NetLogCaptureMode capture_mode, const base::CommandLine::StringType& command_line_string, const std::string& channel_string) { - DCHECK(!log_file.empty()); + DCHECK(!path.empty()); - // TODO(716570): Use common code to write NetLog to file. + // TODO(739485): The log file does not contain about:flags data. + file_net_log_observer_ = net::FileNetLogObserver::CreateUnbounded( + path, GetConstants(command_line_string, channel_string)); - // Much like logging.h, bypass threading restrictions by using fopen - // directly. Have to write on a thread that's shutdown to handle events on - // shutdown properly, and posting events to another thread as they occur - // would result in an unbounded buffer size, so not much can be gained by - // doing this on another thread. It's only used when debugging Chrome, so - // performance is not a big concern. - base::ScopedFILE file; -#if defined(OS_WIN) - file.reset(_wfopen(log_file.value().c_str(), L"w")); -#elif defined(OS_POSIX) - file.reset(fopen(log_file.value().c_str(), "w")); -#endif - - if (!file) { - LOG(ERROR) << "Could not open file " << log_file.value() - << " for net logging"; - } else { - std::unique_ptr<base::Value> constants( - GetConstants(command_line_string, channel_string)); - write_to_file_observer_.reset(new net::WriteToFileNetLogObserver()); - - write_to_file_observer_->set_capture_mode(log_file_mode); - - write_to_file_observer_->StartObserving(this, std::move(file), - constants.get(), nullptr); - } + file_net_log_observer_->StartObserving(this, capture_mode); } NetExportFileWriter* ChromeNetLog::net_export_file_writer() { @@ -115,4 +86,29 @@ return std::move(constants_dict); } +void ChromeNetLog::ShutDownBeforeTaskScheduler() { + // TODO(eroman): Stop in-progress net_export_file_writer_ or delete its files? + + ClearFileNetLogObserver(); +} + +void ChromeNetLog::ClearFileNetLogObserver() { + if (!file_net_log_observer_) + return; + + // TODO(739487): The log file does not contain any polled data. + // + // TODO(eroman): FileNetLogObserver::StopObserving() posts to the file task + // runner to finish writing the log file. Despite that sequenced task runner + // being marked BLOCK_SHUTDOWN, those tasks are not actually running. + // + // This isn't a big deal when using the unbounded logger since the log + // loading code can handle such truncated logs. But this will need fixing + // if switching to log formats that are not so versatile (also if adding + // polled data). + file_net_log_observer_->StopObserving(nullptr /*polled_data*/, + base::Closure()); + file_net_log_observer_.reset(); +} + } // namespace net_log
diff --git a/components/net_log/chrome_net_log.h b/components/net_log/chrome_net_log.h index 42c0c2a..cfa0298 100644 --- a/components/net_log/chrome_net_log.h +++ b/components/net_log/chrome_net_log.h
@@ -18,7 +18,7 @@ } namespace net { -class WriteToFileNetLogObserver; +class FileNetLogObserver; class TraceNetLogObserver; } @@ -29,6 +29,10 @@ // ChromeNetLog is an implementation of NetLog that manages common observers // (for --log-net-log, chrome://net-export/, tracing), as well as acting as the // entry point for other consumers. +// +// Threading: +// * The methods on net::NetLog are threadsafe +// * The methods defined by ChromeNetLog must be sequenced. class ChromeNetLog : public net::NetLog { public: ChromeNetLog(); @@ -36,11 +40,11 @@ // Starts streaming the NetLog events to a file on disk. This will continue // until the application shuts down. - // * |log_file| - path to write the file. - // * |log_file_mode| - capture mode for event granularity. + // * |path| - destination file path of the log file. + // * |capture_mode| - capture mode for event granularity. void StartWritingToFile( - const base::FilePath& log_file, - net::NetLogCaptureMode log_file_mode, + const base::FilePath& path, + net::NetLogCaptureMode capture_mode, const base::CommandLine::StringType& command_line_string, const std::string& channel_string); @@ -52,9 +56,31 @@ const base::CommandLine::StringType& command_line_string, const std::string& channel_string); + // Notify the ChromeNetLog that things are shutting-down. + // + // If ChromeNetLog does not outlive the TaskScheduler, there is no need to + // call this. + // + // However, if it can outlive the TaskScheduler, this should be called + // before the TaskScheduler is shutdown. This allows for any file writers + // using BLOCK_SHUTDOWN to finish posting their writes. + // + // Not calling this is not a fatal error, however may result in an incomplete + // NetLog file being written to disk. + void ShutDownBeforeTaskScheduler(); + private: - std::unique_ptr<net::WriteToFileNetLogObserver> write_to_file_observer_; + // Deletes file_net_log_observer_. + void ClearFileNetLogObserver(); + + // This observer handles writing NetLogs specified via StartWritingToFile() + // (In Chrome this corresponds to the --log-net-log command line). + std::unique_ptr<net::FileNetLogObserver> file_net_log_observer_; + + // This observer handles writing NetLogs started by chrome://net-export/ std::unique_ptr<NetExportFileWriter> net_export_file_writer_; + + // This observer forwards NetLog events to the chrome://tracing system. std::unique_ptr<net::TraceNetLogObserver> trace_net_log_observer_; DISALLOW_COPY_AND_ASSIGN(ChromeNetLog);
diff --git a/components/net_log/net_export_file_writer.cc b/components/net_log/net_export_file_writer.cc index 07765ee..e20448d 100644 --- a/components/net_log/net_export_file_writer.cc +++ b/components/net_log/net_export_file_writer.cc
@@ -120,7 +120,7 @@ NetExportFileWriter::~NetExportFileWriter() { if (file_net_log_observer_) - file_net_log_observer_->StopObserving(nullptr, base::Bind([] {})); + file_net_log_observer_->StopObserving(nullptr, base::Closure()); } void NetExportFileWriter::AddObserver(StateObserver* observer) { @@ -184,9 +184,9 @@ std::unique_ptr<base::Value> constants( ChromeNetLog::GetConstants(command_line_string, channel_string)); - // Instantiate a FileNetLogObserver in unbounded mode. - file_net_log_observer_ = net::FileNetLogObserver::CreateUnbounded( - file_task_runner_, log_path_, std::move(constants)); + + file_net_log_observer_ = + net::FileNetLogObserver::CreateUnbounded(log_path_, std::move(constants)); net_task_runner_->PostTaskAndReply( FROM_HERE,
diff --git a/components/net_log/net_export_file_writer_unittest.cc b/components/net_log/net_export_file_writer_unittest.cc index 17f3b4b..cf61b07 100644 --- a/components/net_log/net_export_file_writer_unittest.cc +++ b/components/net_log/net_export_file_writer_unittest.cc
@@ -16,8 +16,7 @@ #include "base/files/scoped_temp_dir.h" #include "base/json/json_reader.h" #include "base/json/json_string_value_serializer.h" -#include "base/message_loop/message_loop.h" -#include "base/run_loop.h" +#include "base/test/scoped_task_environment.h" #include "base/threading/thread.h" #include "base/threading/thread_task_runner_handle.h" #include "base/values.h" @@ -437,8 +436,7 @@ TestStateObserver test_state_observer_; private: - // Allows tasks to be posted to the main thread. - base::MessageLoop message_loop_; + base::test::ScopedTaskEnvironment scoped_task_environment_; }; TEST_F(NetExportFileWriterTest, InitFail) {
diff --git a/components/ntp_snippets/content_suggestions_service.cc b/components/ntp_snippets/content_suggestions_service.cc index e5a70bbe..1339cc1 100644 --- a/components/ntp_snippets/content_suggestions_service.cc +++ b/components/ntp_snippets/content_suggestions_service.cc
@@ -285,8 +285,8 @@ int minimum_size_in_pixel, int desired_size_in_pixel, const ImageFetchedCallback& callback, - bool success) { - if (!success) { + favicon_base::GoogleFaviconServerRequestStatus status) { + if (status != favicon_base::GoogleFaviconServerRequestStatus::SUCCESS) { callback.Run(gfx::Image()); RecordFaviconFetchResult(FaviconFetchResult::FAILURE); return;
diff --git a/components/ntp_snippets/content_suggestions_service.h b/components/ntp_snippets/content_suggestions_service.h index bf7b4ab..de03d6b 100644 --- a/components/ntp_snippets/content_suggestions_service.h +++ b/components/ntp_snippets/content_suggestions_service.h
@@ -350,7 +350,7 @@ int minimum_size_in_pixel, int desired_size_in_pixel, const ImageFetchedCallback& callback, - bool success); + favicon_base::GoogleFaviconServerRequestStatus status); // Whether the content suggestions feature is enabled. State state_;
diff --git a/components/ntp_snippets/remote/remote_suggestions_scheduler_impl.cc b/components/ntp_snippets/remote/remote_suggestions_scheduler_impl.cc index c0922eb..8751a33 100644 --- a/components/ntp_snippets/remote/remote_suggestions_scheduler_impl.cc +++ b/components/ntp_snippets/remote/remote_suggestions_scheduler_impl.cc
@@ -186,29 +186,62 @@ return base::TimeDelta::FromSecondsD(value_hours * 3600.0); } -void ReportTimeUntilFirstSoftTrigger(UserClassifier::UserClass user_class, - base::TimeDelta time_until_first_trigger) { +void ReportTimeUntilFirstShownTrigger( + UserClassifier::UserClass user_class, + base::TimeDelta time_until_first_shown_trigger) { switch (user_class) { case UserClassifier::UserClass::RARE_NTP_USER: UMA_HISTOGRAM_CUSTOM_TIMES( - "NewTabPage.ContentSuggestions.TimeUntilFirstSoftTrigger.RareNTPUser", - time_until_first_trigger, base::TimeDelta::FromSeconds(1), + "NewTabPage.ContentSuggestions.TimeUntilFirstShownTrigger." + "RareNTPUser", + time_until_first_shown_trigger, base::TimeDelta::FromSeconds(1), base::TimeDelta::FromDays(7), /*bucket_count=*/50); break; case UserClassifier::UserClass::ACTIVE_NTP_USER: UMA_HISTOGRAM_CUSTOM_TIMES( - "NewTabPage.ContentSuggestions.TimeUntilFirstSoftTrigger." + "NewTabPage.ContentSuggestions.TimeUntilFirstShownTrigger." "ActiveNTPUser", - time_until_first_trigger, base::TimeDelta::FromSeconds(1), + time_until_first_shown_trigger, base::TimeDelta::FromSeconds(1), base::TimeDelta::FromDays(7), /*bucket_count=*/50); break; case UserClassifier::UserClass::ACTIVE_SUGGESTIONS_CONSUMER: UMA_HISTOGRAM_CUSTOM_TIMES( - "NewTabPage.ContentSuggestions.TimeUntilFirstSoftTrigger." + "NewTabPage.ContentSuggestions.TimeUntilFirstShownTrigger." "ActiveSuggestionsConsumer", - time_until_first_trigger, base::TimeDelta::FromSeconds(1), + time_until_first_shown_trigger, base::TimeDelta::FromSeconds(1), + base::TimeDelta::FromDays(7), + /*bucket_count=*/50); + break; + } +} + +void ReportTimeUntilFirstStartupTrigger( + UserClassifier::UserClass user_class, + base::TimeDelta time_until_first_startup_trigger) { + switch (user_class) { + case UserClassifier::UserClass::RARE_NTP_USER: + UMA_HISTOGRAM_CUSTOM_TIMES( + "NewTabPage.ContentSuggestions.TimeUntilFirstStartupTrigger." + "RareNTPUser", + time_until_first_startup_trigger, base::TimeDelta::FromSeconds(1), + base::TimeDelta::FromDays(7), + /*bucket_count=*/50); + break; + case UserClassifier::UserClass::ACTIVE_NTP_USER: + UMA_HISTOGRAM_CUSTOM_TIMES( + "NewTabPage.ContentSuggestions.TimeUntilFirstStartupTrigger." + "ActiveNTPUser", + time_until_first_startup_trigger, base::TimeDelta::FromSeconds(1), + base::TimeDelta::FromDays(7), + /*bucket_count=*/50); + break; + case UserClassifier::UserClass::ACTIVE_SUGGESTIONS_CONSUMER: + UMA_HISTOGRAM_CUSTOM_TIMES( + "NewTabPage.ContentSuggestions.TimeUntilFirstStartupTrigger." + "ActiveSuggestionsConsumer", + time_until_first_startup_trigger, base::TimeDelta::FromSeconds(1), base::TimeDelta::FromDays(7), /*bucket_count=*/50); break; @@ -413,7 +446,8 @@ profile_prefs, RequestThrottler::RequestType:: CONTENT_SUGGESTION_FETCHER_ACTIVE_SUGGESTIONS_CONSUMER), - time_until_first_trigger_reported_(false), + time_until_first_shown_trigger_reported_(false), + time_until_first_startup_trigger_reported_(false), eula_state_(base::MakeUnique<EulaState>(local_state_prefs, this)), profile_prefs_(profile_prefs), clock_(std::move(clock)), @@ -622,17 +656,25 @@ return; } - bool is_soft = trigger != TriggerType::PERSISTENT_SCHEDULER_WAKE_UP; const base::Time last_fetch_attempt_time = base::Time::FromInternalValue( profile_prefs_->GetInt64(prefs::kSnippetLastFetchAttempt)); - if (is_soft && !time_until_first_trigger_reported_) { - time_until_first_trigger_reported_ = true; - ReportTimeUntilFirstSoftTrigger(user_classifier_->GetUserClass(), - clock_->Now() - last_fetch_attempt_time); + if (trigger == TriggerType::NTP_OPENED && + !time_until_first_shown_trigger_reported_) { + time_until_first_shown_trigger_reported_ = true; + ReportTimeUntilFirstShownTrigger(user_classifier_->GetUserClass(), + clock_->Now() - last_fetch_attempt_time); } - if (is_soft && + if ((trigger == TriggerType::BROWSER_FOREGROUNDED || + trigger == TriggerType::BROWSER_COLD_START) && + !time_until_first_startup_trigger_reported_) { + time_until_first_startup_trigger_reported_ = true; + ReportTimeUntilFirstStartupTrigger(user_classifier_->GetUserClass(), + clock_->Now() - last_fetch_attempt_time); + } + + if (trigger != TriggerType::PERSISTENT_SCHEDULER_WAKE_UP && !ShouldRefetchInTheBackgroundNow(last_fetch_attempt_time, trigger)) { return; } @@ -736,7 +778,8 @@ void RemoteSuggestionsSchedulerImpl::OnFetchCompleted(Status fetch_status) { profile_prefs_->SetInt64(prefs::kSnippetLastFetchAttempt, clock_->Now().ToInternalValue()); - time_until_first_trigger_reported_ = false; + time_until_first_shown_trigger_reported_ = false; + time_until_first_startup_trigger_reported_ = false; // Reschedule after a fetch. The persistent schedule is applied only after a // successful fetch. After a failed fetch, we want to keep the previous
diff --git a/components/ntp_snippets/remote/remote_suggestions_scheduler_impl.h b/components/ntp_snippets/remote/remote_suggestions_scheduler_impl.h index 3e10362..8ded08f 100644 --- a/components/ntp_snippets/remote/remote_suggestions_scheduler_impl.h +++ b/components/ntp_snippets/remote/remote_suggestions_scheduler_impl.h
@@ -147,8 +147,10 @@ RequestThrottler request_throttler_active_ntp_user_; RequestThrottler request_throttler_active_suggestions_consumer_; - // To make sure we only report the first trigger to UMA. - bool time_until_first_trigger_reported_; + // Variables to make sure we only report the first trigger of each kind to + // UMA. + bool time_until_first_shown_trigger_reported_; + bool time_until_first_startup_trigger_reported_; // We should not fetch in background before EULA gets accepted. std::unique_ptr<EulaState> eula_state_;
diff --git a/components/ntp_tiles/BUILD.gn b/components/ntp_tiles/BUILD.gn index b0784a80..d970418 100644 --- a/components/ntp_tiles/BUILD.gn +++ b/components/ntp_tiles/BUILD.gn
@@ -36,9 +36,6 @@ "webui/ntp_tiles_internals_message_handler.h", "webui/ntp_tiles_internals_message_handler_client.cc", "webui/ntp_tiles_internals_message_handler_client.h", - "webui/popular_sites_internals_message_handler.cc", - "webui/popular_sites_internals_message_handler.h", - "webui/popular_sites_internals_message_handler_client.h", ] public_deps = [
diff --git a/components/ntp_tiles/icon_cacher_impl.cc b/components/ntp_tiles/icon_cacher_impl.cc index 0ae5160..48769f33 100644 --- a/components/ntp_tiles/icon_cacher_impl.cc +++ b/components/ntp_tiles/icon_cacher_impl.cc
@@ -249,10 +249,15 @@ weak_ptr_factory_.GetWeakPtr(), page_url)); } -void IconCacherImpl::OnMostLikelyFaviconDownloaded(const GURL& request_url, - bool success) { - UMA_HISTOGRAM_BOOLEAN("NewTabPage.TileFaviconFetchSuccess.Server", success); - FinishRequestAndNotifyIconAvailable(request_url, success); +void IconCacherImpl::OnMostLikelyFaviconDownloaded( + const GURL& request_url, + favicon_base::GoogleFaviconServerRequestStatus status) { + UMA_HISTOGRAM_ENUMERATION( + "NewTabPage.TileFaviconFetchStatus.Server", status, + favicon_base::GoogleFaviconServerRequestStatus::COUNT); + FinishRequestAndNotifyIconAvailable( + request_url, + status == favicon_base::GoogleFaviconServerRequestStatus::SUCCESS); } bool IconCacherImpl::StartRequest(const GURL& request_url,
diff --git a/components/ntp_tiles/icon_cacher_impl.h b/components/ntp_tiles/icon_cacher_impl.h index a124b2c..e15ceaf 100644 --- a/components/ntp_tiles/icon_cacher_impl.h +++ b/components/ntp_tiles/icon_cacher_impl.h
@@ -25,6 +25,7 @@ namespace favicon_base { struct FaviconImageResult; struct LargeIconResult; +enum class GoogleFaviconServerRequestStatus; } // namespace favicon_base namespace gfx { @@ -83,7 +84,9 @@ const GURL& page_url, const favicon_base::LargeIconResult& result); - void OnMostLikelyFaviconDownloaded(const GURL& request_url, bool success); + void OnMostLikelyFaviconDownloaded( + const GURL& request_url, + favicon_base::GoogleFaviconServerRequestStatus status); bool StartRequest(const GURL& request_url, const base::Closure& icon_available);
diff --git a/components/ntp_tiles/icon_cacher_impl_unittest.cc b/components/ntp_tiles/icon_cacher_impl_unittest.cc index 54f2fc2..2ce20e89 100644 --- a/components/ntp_tiles/icon_cacher_impl_unittest.cc +++ b/components/ntp_tiles/icon_cacher_impl_unittest.cc
@@ -20,6 +20,7 @@ #include "components/favicon/core/favicon_service_impl.h" #include "components/favicon/core/favicon_util.h" #include "components/favicon/core/large_icon_service.h" +#include "components/favicon_base/favicon_types.h" #include "components/history/core/browser/history_database_params.h" #include "components/history/core/browser/history_service.h" #include "components/image_fetcher/core/image_decoder.h" @@ -479,7 +480,7 @@ EXPECT_FALSE(IconIsCachedFor(page_url, favicon_base::FAVICON)); EXPECT_TRUE(IconIsCachedFor(page_url, favicon_base::TOUCH_ICON)); EXPECT_THAT(histogram_tester.GetAllSamples( - "NewTabPage.TileFaviconFetchSuccess.Server"), + "NewTabPage.TileFaviconFetchStatus.Server"), IsEmpty()); } @@ -515,10 +516,12 @@ loop.Run(); EXPECT_FALSE(IconIsCachedFor(page_url, favicon_base::FAVICON)); EXPECT_TRUE(IconIsCachedFor(page_url, favicon_base::TOUCH_ICON)); - EXPECT_THAT( - histogram_tester.GetAllSamples( - "NewTabPage.TileFaviconFetchSuccess.Server"), - ElementsAre(Bucket(/*bucket=*/true, /*count=*/1))); + EXPECT_THAT(histogram_tester.GetAllSamples( + "NewTabPage.TileFaviconFetchStatus.Server"), + ElementsAre(Bucket( + /*bucket=*/static_cast<int>( + favicon_base::GoogleFaviconServerRequestStatus::SUCCESS), + /*count=*/1))); } TEST_F(IconCacherTestMostLikely, NotCachedAndFetchFailed) { @@ -552,10 +555,13 @@ EXPECT_FALSE(IconIsCachedFor(page_url, favicon_base::FAVICON)); EXPECT_FALSE(IconIsCachedFor(page_url, favicon_base::TOUCH_ICON)); - EXPECT_THAT( - histogram_tester.GetAllSamples( - "NewTabPage.TileFaviconFetchSuccess.Server"), - ElementsAre(Bucket(/*bucket=*/false, /*count=*/1))); + EXPECT_THAT(histogram_tester.GetAllSamples( + "NewTabPage.TileFaviconFetchStatus.Server"), + ElementsAre(Bucket( + /*bucket=*/static_cast<int>( + favicon_base::GoogleFaviconServerRequestStatus:: + FAILURE_CONNECTION_ERROR), + /*count=*/1))); } TEST_F(IconCacherTestMostLikely, HandlesEmptyCallbacksNicely) {
diff --git a/components/ntp_tiles/webui/popular_sites_internals_message_handler.cc b/components/ntp_tiles/webui/popular_sites_internals_message_handler.cc deleted file mode 100644 index 68cc2228..0000000 --- a/components/ntp_tiles/webui/popular_sites_internals_message_handler.cc +++ /dev/null
@@ -1,164 +0,0 @@ -// Copyright 2016 The Chromium Authors. All rights reserved. -// Use of this source code is governed by a BSD-style license that can be -// found in the LICENSE file. - -#include "components/ntp_tiles/webui/popular_sites_internals_message_handler.h" - -#include "base/bind.h" -#include "base/callback.h" -#include "base/json/json_writer.h" -#include "base/logging.h" -#include "base/memory/ptr_util.h" -#include "base/values.h" -#include "components/ntp_tiles/popular_sites.h" -#include "components/ntp_tiles/pref_names.h" -#include "components/ntp_tiles/webui/popular_sites_internals_message_handler_client.h" -#include "components/prefs/pref_service.h" -#include "components/url_formatter/url_fixer.h" -#include "url/gurl.h" - -namespace ntp_tiles { - -PopularSitesInternalsMessageHandlerClient:: - PopularSitesInternalsMessageHandlerClient() = default; -PopularSitesInternalsMessageHandlerClient:: - ~PopularSitesInternalsMessageHandlerClient() = default; - -PopularSitesInternalsMessageHandler::PopularSitesInternalsMessageHandler( - PopularSitesInternalsMessageHandlerClient* web_ui) - : web_ui_(web_ui), weak_ptr_factory_(this) {} - -PopularSitesInternalsMessageHandler::~PopularSitesInternalsMessageHandler() = - default; - -void PopularSitesInternalsMessageHandler::RegisterMessages() { - web_ui_->RegisterMessageCallback( - "registerForEvents", - base::Bind(&PopularSitesInternalsMessageHandler::HandleRegisterForEvents, - base::Unretained(this))); - - web_ui_->RegisterMessageCallback( - "update", base::Bind(&PopularSitesInternalsMessageHandler::HandleUpdate, - base::Unretained(this))); - - web_ui_->RegisterMessageCallback( - "viewJson", - base::Bind(&PopularSitesInternalsMessageHandler::HandleViewJson, - base::Unretained(this))); -} - -void PopularSitesInternalsMessageHandler::HandleRegisterForEvents( - const base::ListValue* args) { - DCHECK(args->empty()); - - SendOverrides(); - - popular_sites_ = web_ui_->MakePopularSites(); - SendSites(); -} - -void PopularSitesInternalsMessageHandler::HandleUpdate( - const base::ListValue* args) { - DCHECK_EQ(4u, args->GetSize()); - - PrefService* prefs = web_ui_->GetPrefs(); - - std::string url; - args->GetString(0, &url); - if (url.empty()) - prefs->ClearPref(ntp_tiles::prefs::kPopularSitesOverrideURL); - else - prefs->SetString(ntp_tiles::prefs::kPopularSitesOverrideURL, - url_formatter::FixupURL(url, std::string()).spec()); - - std::string directory; - args->GetString(1, &directory); - if (directory.empty()) - prefs->ClearPref(ntp_tiles::prefs::kPopularSitesOverrideDirectory); - else - prefs->SetString(ntp_tiles::prefs::kPopularSitesOverrideDirectory, - directory); - - std::string country; - args->GetString(2, &country); - if (country.empty()) - prefs->ClearPref(ntp_tiles::prefs::kPopularSitesOverrideCountry); - else - prefs->SetString(ntp_tiles::prefs::kPopularSitesOverrideCountry, country); - - std::string version; - args->GetString(3, &version); - if (version.empty()) - prefs->ClearPref(ntp_tiles::prefs::kPopularSitesOverrideVersion); - else - prefs->SetString(ntp_tiles::prefs::kPopularSitesOverrideVersion, version); - - popular_sites_ = web_ui_->MakePopularSites(); - popular_sites_->MaybeStartFetch( - true, - base::Bind(&PopularSitesInternalsMessageHandler::OnPopularSitesAvailable, - base::Unretained(this))); -} - -void PopularSitesInternalsMessageHandler::HandleViewJson( - const base::ListValue* args) { - DCHECK_EQ(0u, args->GetSize()); - - const base::ListValue* json = popular_sites_->GetCachedJson(); - std::string json_string; - if (json) { - bool success = base::JSONWriter::Write(*json, &json_string); - DCHECK(success); - } - SendJson(json_string); -} - -void PopularSitesInternalsMessageHandler::SendOverrides() { - PrefService* prefs = web_ui_->GetPrefs(); - std::string url = - prefs->GetString(ntp_tiles::prefs::kPopularSitesOverrideURL); - std::string directory = - prefs->GetString(ntp_tiles::prefs::kPopularSitesOverrideDirectory); - std::string country = - prefs->GetString(ntp_tiles::prefs::kPopularSitesOverrideCountry); - std::string version = - prefs->GetString(ntp_tiles::prefs::kPopularSitesOverrideVersion); - web_ui_->CallJavascriptFunction( - "chrome.popular_sites_internals.receiveOverrides", base::Value(url), - base::Value(directory), base::Value(country), base::Value(version)); -} - -void PopularSitesInternalsMessageHandler::SendDownloadResult(bool success) { - base::Value result(success ? "Success" : "Fail"); - web_ui_->CallJavascriptFunction( - "chrome.popular_sites_internals.receiveDownloadResult", result); -} - -void PopularSitesInternalsMessageHandler::SendSites() { - auto sites_list = base::MakeUnique<base::ListValue>(); - for (const PopularSites::Site& site : popular_sites_->sites()) { - auto entry = base::MakeUnique<base::DictionaryValue>(); - entry->SetString("title", site.title); - entry->SetString("url", site.url.spec()); - sites_list->Append(std::move(entry)); - } - - base::DictionaryValue result; - result.Set("sites", std::move(sites_list)); - result.SetString("url", popular_sites_->GetLastURLFetched().spec()); - web_ui_->CallJavascriptFunction("chrome.popular_sites_internals.receiveSites", - result); -} - -void PopularSitesInternalsMessageHandler::SendJson(const std::string& json) { - web_ui_->CallJavascriptFunction("chrome.popular_sites_internals.receiveJson", - base::Value(json)); -} - -void PopularSitesInternalsMessageHandler::OnPopularSitesAvailable( - bool success) { - SendDownloadResult(success); - SendSites(); -} - -} // namespace ntp_tiles
diff --git a/components/ntp_tiles/webui/popular_sites_internals_message_handler.h b/components/ntp_tiles/webui/popular_sites_internals_message_handler.h deleted file mode 100644 index c0e05d0..0000000 --- a/components/ntp_tiles/webui/popular_sites_internals_message_handler.h +++ /dev/null
@@ -1,64 +0,0 @@ -// Copyright 2016 The Chromium Authors. All rights reserved. -// Use of this source code is governed by a BSD-style license that can be -// found in the LICENSE file. - -#ifndef COMPONENTS_NTP_TILES_WEBUI_POPULAR_SITES_HANDLER_H_ -#define COMPONENTS_NTP_TILES_WEBUI_POPULAR_SITES_HANDLER_H_ - -#include <memory> -#include <string> - -#include "base/macros.h" -#include "base/memory/weak_ptr.h" - -namespace base { -class ListValue; -} // namespace base - -namespace ntp_tiles { - -class PopularSites; -class PopularSitesInternalsMessageHandlerClient; - -// Implements the WebUI message handler for chrome://popular-sites-internals/ -// -// Because content and iOS use different implementations of WebUI, this class -// implements the generic portion and depends on the embedder to inject a bridge -// to the embedder's API. It cannot itself implement either API directly. -class PopularSitesInternalsMessageHandler { - public: - explicit PopularSitesInternalsMessageHandler( - PopularSitesInternalsMessageHandlerClient* web_ui); - ~PopularSitesInternalsMessageHandler(); - - // Called when the WebUI page's JavaScript has loaded and it is ready to - // receive RegisterMessageCallback() calls. - void RegisterMessages(); - - private: - // Callbacks registered in RegisterMessages(). - void HandleRegisterForEvents(const base::ListValue* args); - void HandleUpdate(const base::ListValue* args); - void HandleViewJson(const base::ListValue* args); - - void SendOverrides(); - void SendDownloadResult(bool success); - void SendSites(); - void SendJson(const std::string& json); - - // Completion handler for popular_sites_->StartFetch(). - void OnPopularSitesAvailable(bool success); - - // Bridge to embedder's API. - PopularSitesInternalsMessageHandlerClient* web_ui_; - - std::unique_ptr<PopularSites> popular_sites_; - - base::WeakPtrFactory<PopularSitesInternalsMessageHandler> weak_ptr_factory_; - - DISALLOW_COPY_AND_ASSIGN(PopularSitesInternalsMessageHandler); -}; - -} // namespace ntp_tiles - -#endif // COMPONENTS_NTP_TILES_WEBUI_POPULAR_SITES_HANDLER_H_
diff --git a/components/ntp_tiles/webui/popular_sites_internals_message_handler_client.h b/components/ntp_tiles/webui/popular_sites_internals_message_handler_client.h deleted file mode 100644 index 43368f8..0000000 --- a/components/ntp_tiles/webui/popular_sites_internals_message_handler_client.h +++ /dev/null
@@ -1,61 +0,0 @@ -// Copyright 2016 The Chromium Authors. All rights reserved. -// Use of this source code is governed by a BSD-style license that can be -// found in the LICENSE file. - -#ifndef COMPONENTS_NTP_TILES_WEBUI_POPULAR_SITES_HANDLER_CLIENT_H_ -#define COMPONENTS_NTP_TILES_WEBUI_POPULAR_SITES_HANDLER_CLIENT_H_ - -#include <memory> -#include <string> -#include <vector> - -#include "base/callback_forward.h" -#include "base/macros.h" - -class PrefService; - -namespace base { -class Value; -class ListValue; -} // namespace base - -namespace ntp_tiles { - -class PopularSites; - -// Implemented by embedders to hook up PopularSitesInternalsMessageHandler. -class PopularSitesInternalsMessageHandlerClient { - public: - // Returns the PrefService for the embedder and containing WebUI page. - virtual PrefService* GetPrefs() = 0; - - // Creates a new PopularSites based on the context pf the WebUI page. - virtual std::unique_ptr<ntp_tiles::PopularSites> MakePopularSites() = 0; - - // Registers a callback in Javascript. See content::WebUI and web::WebUIIOS. - virtual void RegisterMessageCallback( - const std::string& message, - const base::Callback<void(const base::ListValue*)>& callback) = 0; - - // Invokes a function in Javascript. See content::WebUI and web::WebUIIOS. - virtual void CallJavascriptFunctionVector( - const std::string& name, - const std::vector<const base::Value*>& values) = 0; - - // Helper function for CallJavascriptFunctionVector(). - template <typename... Arg> - void CallJavascriptFunction(const std::string& name, const Arg&... arg) { - CallJavascriptFunctionVector(name, {&arg...}); - } - - protected: - PopularSitesInternalsMessageHandlerClient(); - virtual ~PopularSitesInternalsMessageHandlerClient(); - - private: - DISALLOW_COPY_AND_ASSIGN(PopularSitesInternalsMessageHandlerClient); -}; - -} // namespace ntp_tiles - -#endif // COMPONENTS_NTP_TILES_WEBUI_POPULAR_SITES_HANDLER_CLIENT_H_
diff --git a/components/ntp_tiles/webui/resources/popular_sites_internals.css b/components/ntp_tiles/webui/resources/popular_sites_internals.css deleted file mode 100644 index ee4c1d4..0000000 --- a/components/ntp_tiles/webui/resources/popular_sites_internals.css +++ /dev/null
@@ -1,48 +0,0 @@ -/* Copyright 2015 The Chromium Authors. All rights reserved. - * Use of this source code is governed by a BSD-style license that can be - * found in the LICENSE file. */ - -html { - font-size: 20px; -} - -#info > div { - width: 100%; -} - -#info h2 { - color: rgb(74, 142, 230); - font-size: 100%; - margin-bottom: 0; -} - -#info .err { - color: red; -} - -#info .section { - display: inline-block; - margin-left: auto; - margin-right: auto; -} - -#info .section.hidden { - display: none; -} - -.section-details { - width: 100%; -} - -.section-details .detail, -.section-details .value { - width: 50%; -} - -.section-details tr:nth-child(odd) { - background: rgb(239, 243, 255); -} - -#json-value { - font-size: 75%; -}
diff --git a/components/ntp_tiles/webui/resources/popular_sites_internals.html b/components/ntp_tiles/webui/resources/popular_sites_internals.html deleted file mode 100644 index 5ce97bcf..0000000 --- a/components/ntp_tiles/webui/resources/popular_sites_internals.html +++ /dev/null
@@ -1,86 +0,0 @@ -<!-- -Copyright 2015 The Chromium Authors. All rights reserved. -Use of this source code is governed by a BSD-style license that can be -found in the LICENSE file. ---> -<!DOCTYPE html> -<html> -<head> -<meta charset="utf-8"> -<if expr="is_android or is_ios"> -<meta name="viewport" content="width=device-width, initial-scale=1.0"> -</if> -<title>Popular Sites Internals</title> -<link rel="stylesheet" href="chrome://resources/css/text_defaults.css"> -<link rel="stylesheet" href="chrome://resources/css/list.css"> -<link rel="stylesheet" href="popular_sites_internals.css"> -<script src="chrome://resources/js/cr.js"></script> -<script src="chrome://resources/js/jstemplate_compiled.js"></script> -<script src="chrome://resources/js/load_time_data.js"></script> -<script src="chrome://resources/js/util.js"></script> -<if expr="is_ios"> -<!-- TODO(crbug.com/487000): Remove this once injected by web. --> -<script src="chrome://resources/js/ios/web_ui.js"></script> -</if> -<script src="popular_sites_internals.js"></script> -</head> - -<body> -<div id="info"> - <div class="section" jsskip="true"> - <h2>Download</h2> - <table class="section-details"> - <tr> - <td class="detail">URL (takes precedence over Directory, Country and Version)</td> - <td class="value"><input id="override-url" type="text"></td> - </tr> - <tr> - <td class="detail">Override Directory</td> - <td class="value"><input id="override-directory" type="text"></td> - </tr> - <tr> - <td class="detail">Override Country</td> - <td class="value"><input id="override-country" type="text"></td> - </tr> - <tr> - <td class="detail">Override Version</td> - <td class="value"><input id="override-version" type="text"></td> - </tr> - <tr> - <td class="detail"> - <input id="submit-update" type="submit" value="Update"> - </td> - <td id="download-result" class="value"></td> - </tr> - </table> - </div> - - <div class="section"> - <h2>Info</h2> - <table class="section-details"> - <tr> - <td class="detail">URL</td> - <td class="value" jscontent="url"></td> - </tr> - </table> - </div> - - <div class="section"> - <h2>Sites</h2> - <table class="section-details"> - <tr jsselect="sites"> - <td class="detail" jscontent="title"></td> - <td class="value" jscontent="url"></td> - </tr> - <tr jsskip="true"> - <td class="detail"> - <input id="view-json" type="submit" value="View JSON"> - </td> - <td class="value"><pre id="json-value"></pre></td> - </tr> - </table> - </div> -</div> - -</body> -</html>
diff --git a/components/ntp_tiles/webui/resources/popular_sites_internals.js b/components/ntp_tiles/webui/resources/popular_sites_internals.js deleted file mode 100644 index 3bfcf8b..0000000 --- a/components/ntp_tiles/webui/resources/popular_sites_internals.js +++ /dev/null
@@ -1,63 +0,0 @@ -// Copyright 2015 The Chromium Authors. All rights reserved. -// Use of this source code is governed by a BSD-style license that can be -// found in the LICENSE file. - -cr.define('chrome.popular_sites_internals', function() { - 'use strict'; - - function initialize() { - function submitUpdate(event) { - $('download-result').textContent = ''; - chrome.send('update', [$('override-url').value, - $('override-directory').value, - $('override-country').value, - $('override-version').value]); - event.preventDefault(); - } - - $('submit-update').addEventListener('click', submitUpdate); - - function viewJson(event) { - $('json-value').textContent = ''; - chrome.send('viewJson'); - event.preventDefault(); - } - - $('view-json').addEventListener('click', viewJson); - - chrome.send('registerForEvents'); - } - - function receiveOverrides(url, directory, country, version) { - $('override-url').value = url; - $('override-directory').value = directory; - $('override-country').value = country; - $('override-version').value = version; - } - - function receiveDownloadResult(result) { - $('download-result').textContent = result; - } - - function receiveSites(sites) { - jstProcess(new JsEvalContext(sites), $('info')); - // Also clear the json string, since it's likely stale now. - $('json-value').textContent = ''; - } - - function receiveJson(json) { - $('json-value').textContent = json; - } - - // Return an object with all of the exports. - return { - initialize: initialize, - receiveOverrides: receiveOverrides, - receiveDownloadResult: receiveDownloadResult, - receiveSites: receiveSites, - receiveJson: receiveJson, - }; -}); - -document.addEventListener('DOMContentLoaded', - chrome.popular_sites_internals.initialize);
diff --git a/components/resources/ntp_tiles_resources.grdp b/components/resources/ntp_tiles_resources.grdp index 7d8d6c0a..9367081 100644 --- a/components/resources/ntp_tiles_resources.grdp +++ b/components/resources/ntp_tiles_resources.grdp
@@ -1,9 +1,6 @@ <?xml version="1.0" encoding="utf-8"?> <grit-part> <if expr="is_android or is_ios"> - <include name="IDR_POPULAR_SITES_INTERNALS_HTML" file="../ntp_tiles/webui/resources/popular_sites_internals.html" flattenhtml="true" allowexternalscript="true" type="BINDATA" /> - <include name="IDR_POPULAR_SITES_INTERNALS_JS" file="../ntp_tiles/webui/resources/popular_sites_internals.js" type="BINDATA" /> - <include name="IDR_POPULAR_SITES_INTERNALS_CSS" file="../ntp_tiles/webui/resources/popular_sites_internals.css" type="BINDATA" /> <if expr="_google_chrome"> <then> <include name="IDR_DEFAULT_POPULAR_SITES_JSON" file="../ntp_tiles/resources/internal/default_popular_sites.json" type="BINDATA" />
diff --git a/components/search_provider_logos/BUILD.gn b/components/search_provider_logos/BUILD.gn index da7b796..7b9909e1 100644 --- a/components/search_provider_logos/BUILD.gn +++ b/components/search_provider_logos/BUILD.gn
@@ -4,6 +4,8 @@ static_library("search_provider_logos") { sources = [ + "features.cc", + "features.h", "fixed_logo_api.cc", "fixed_logo_api.h", "google_logo_api.cc", @@ -34,6 +36,7 @@ source_set("unit_tests") { testonly = true sources = [ + "google_logo_api_unittest.cc", "logo_cache_unittest.cc", "logo_tracker_unittest.cc", ]
diff --git a/components/search_provider_logos/features.cc b/components/search_provider_logos/features.cc new file mode 100644 index 0000000..1326c7f --- /dev/null +++ b/components/search_provider_logos/features.cc
@@ -0,0 +1,14 @@ +// Copyright 2017 The Chromium Authors. All rights reserved. +// Use of this source code is governed by a BSD-style license that can be +// found in the LICENSE file. + +#include "components/search_provider_logos/features.h" + +namespace search_provider_logos { +namespace features { + +const base::Feature kUseDdljsonApi{"UseDdljsonApi", + base::FEATURE_DISABLED_BY_DEFAULT}; + +} // namespace features +} // namespace search_provider_logos
diff --git a/components/search_provider_logos/features.h b/components/search_provider_logos/features.h new file mode 100644 index 0000000..05c46e5e --- /dev/null +++ b/components/search_provider_logos/features.h
@@ -0,0 +1,18 @@ +// Copyright 2017 The Chromium Authors. All rights reserved. +// Use of this source code is governed by a BSD-style license that can be +// found in the LICENSE file. + +#ifndef COMPONENTS_SEARCH_PROVIDER_LOGOS_FEATURES_H_ +#define COMPONENTS_SEARCH_PROVIDER_LOGOS_FEATURES_H_ + +#include "base/feature_list.h" + +namespace search_provider_logos { +namespace features { + +extern const base::Feature kUseDdljsonApi; + +} // namespace features +} // namespace search_provider_logos + +#endif // COMPONENTS_SEARCH_PROVIDER_LOGOS_FEATURES_H_
diff --git a/components/search_provider_logos/google_logo_api.cc b/components/search_provider_logos/google_logo_api.cc index 91d8218d..2750c90 100644 --- a/components/search_provider_logos/google_logo_api.cc +++ b/components/search_provider_logos/google_logo_api.cc
@@ -9,21 +9,51 @@ #include <algorithm> #include "base/base64.h" +#include "base/bind.h" +#include "base/callback.h" +#include "base/feature_list.h" #include "base/json/json_reader.h" +#include "base/memory/ptr_util.h" +#include "base/memory/ref_counted.h" #include "base/memory/ref_counted_memory.h" #include "base/strings/string_piece.h" #include "base/strings/string_util.h" #include "base/values.h" +#include "components/search_provider_logos/features.h" +#include "url/url_constants.h" namespace search_provider_logos { +GURL GetGoogleDoodleURL(const GURL& google_base_url) { + GURL::Replacements replacements; + replacements.SetPathStr(base::FeatureList::IsEnabled(features::kUseDdljsonApi) + ? "async/ddljson" + : "async/newtab_mobile"); + return google_base_url.ReplaceComponents(replacements); +} + +AppendQueryparamsToLogoURL GetGoogleAppendQueryparamsCallback( + bool gray_background) { + if (base::FeatureList::IsEnabled(features::kUseDdljsonApi)) + return base::Bind(&GoogleNewAppendQueryparamsToLogoURL, gray_background); + + return base::Bind(&GoogleLegacyAppendQueryparamsToLogoURL, gray_background); +} + +ParseLogoResponse GetGoogleParseLogoResponseCallback(const GURL& base_url) { + if (base::FeatureList::IsEnabled(features::kUseDdljsonApi)) + return base::Bind(&GoogleNewParseLogoResponse, base_url); + + return base::Bind(&GoogleLegacyParseLogoResponse); +} + namespace { const char kResponsePreamble[] = ")]}'"; } -GURL GoogleAppendQueryparamsToLogoURL(bool gray_background, - const GURL& logo_url, - const std::string& fingerprint) { +GURL GoogleLegacyAppendQueryparamsToLogoURL(bool gray_background, + const GURL& logo_url, + const std::string& fingerprint) { // Note: we can't just use net::AppendQueryParameter() because it escapes // ":" to "%3A", but the server requires the colon not to be escaped. // See: http://crbug.com/413845 @@ -55,7 +85,7 @@ return logo_url.ReplaceComponents(replacements); } -std::unique_ptr<EncodedLogo> GoogleParseLogoResponse( +std::unique_ptr<EncodedLogo> GoogleLegacyParseLogoResponse( std::unique_ptr<std::string> response, base::Time response_time, bool* parsing_failed) { @@ -147,4 +177,158 @@ return logo; } +GURL GoogleNewAppendQueryparamsToLogoURL(bool gray_background, + const GURL& logo_url, + const std::string& fingerprint) { + // Note: we can't just use net::AppendQueryParameter() because it escapes + // ":" to "%3A", but the server requires the colon not to be escaped. + // See: http://crbug.com/413845 + + std::string query(logo_url.query()); + if (!query.empty()) + query += "&"; + + query += "async="; + + std::vector<base::StringPiece> params; + params.push_back("ntp:1"); + if (gray_background) { + params.push_back("graybg:1"); + } + if (!fingerprint.empty()) { + params.push_back("es_dfp:" + fingerprint); + } + query += base::JoinString(params, ","); + + GURL::Replacements replacements; + replacements.SetQueryStr(query); + return logo_url.ReplaceComponents(replacements); +} + +namespace { + +GURL ParseUrl(const base::DictionaryValue& parent_dict, + const std::string& key, + const GURL& base_url) { + std::string url_str; + if (!parent_dict.GetString(key, &url_str) || url_str.empty()) { + return GURL(); + } + return base_url.Resolve(url_str); +} + +} // namespace + +std::unique_ptr<EncodedLogo> GoogleNewParseLogoResponse( + const GURL& base_url, + std::unique_ptr<std::string> response, + base::Time response_time, + bool* parsing_failed) { + // The response may start with )]}'. Ignore this. + base::StringPiece response_sp(*response); + if (response_sp.starts_with(kResponsePreamble)) + response_sp.remove_prefix(strlen(kResponsePreamble)); + + // Default parsing failure to be true. + *parsing_failed = true; + + int error_code; + std::string error_string; + int error_line; + int error_col; + std::unique_ptr<base::Value> value = base::JSONReader::ReadAndReturnError( + response_sp, 0, &error_code, &error_string, &error_line, &error_col); + if (!value) { + LOG(WARNING) << error_string << " at " << error_line << ":" << error_col; + return nullptr; + } + + std::unique_ptr<base::DictionaryValue> config = + base::DictionaryValue::From(std::move(value)); + if (!config) + return nullptr; + + const base::DictionaryValue* ddljson = nullptr; + if (!config->GetDictionary("ddljson", &ddljson)) + return nullptr; + + // If there is no logo today, the "ddljson" dictionary will be empty. + if (ddljson->empty()) { + *parsing_failed = false; + return nullptr; + } + + auto logo = base::MakeUnique<EncodedLogo>(); + + // Check if the main image is animated. + bool is_animated = false; + const base::DictionaryValue* image = nullptr; + if (ddljson->GetDictionary("large_image", &image)) { + image->GetBoolean("is_animated", &is_animated); + + // If animated, get the URL for the animated image. + if (is_animated) { + GURL animated_url = ParseUrl(*image, "url", base_url); + if (!animated_url.is_valid()) + return nullptr; + logo->metadata.animated_url = animated_url.spec(); + } + } + + // Data is optional, since we may be revalidating a cached logo. + // If this is an animated doodle, get the CTA image data. + std::string encoded_image_data; + if (ddljson->GetString(is_animated ? "cta_data_uri" : "data_uri", + &encoded_image_data)) { + GURL encoded_image_uri(encoded_image_data); + if (!encoded_image_uri.is_valid() || + !encoded_image_uri.SchemeIs(url::kDataScheme)) { + return nullptr; + } + std::string content = encoded_image_uri.GetContent(); + // The content should look like this: "image/png;base64,aaa..." (where + // "aaa..." is the base64-encoded image data). + size_t mime_type_end = content.find_first_of(';'); + if (mime_type_end == std::string::npos) + return nullptr; + logo->metadata.mime_type = content.substr(0, mime_type_end); + + size_t base64_begin = mime_type_end + 1; + size_t base64_end = content.find_first_of(',', base64_begin); + if (base64_end == std::string::npos) + return nullptr; + base::StringPiece base64(content.begin() + base64_begin, + content.begin() + base64_end); + if (base64 != "base64") + return nullptr; + + size_t data_begin = base64_end + 1; + base::StringPiece data(content.begin() + data_begin, content.end()); + logo->encoded_image = base::MakeRefCounted<base::RefCountedString>(); + if (!base::Base64Decode(data, &logo->encoded_image->data())) + return nullptr; + } + + logo->metadata.on_click_url = + ParseUrl(*ddljson, "target_url", base_url).spec(); + ddljson->GetString("alt_text", &logo->metadata.alt_text); + + ddljson->GetString("fingerprint", &logo->metadata.fingerprint); + + base::TimeDelta time_to_live; + // The JSON doesn't guarantee the number to fit into an int. + double ttl_ms = 0; // Expires immediately if the parameter is missing. + if (ddljson->GetDouble("time_to_live_ms", &ttl_ms)) { + time_to_live = base::TimeDelta::FromMillisecondsD(ttl_ms); + logo->metadata.can_show_after_expiration = false; + } else { + time_to_live = base::TimeDelta::FromMilliseconds(kMaxTimeToLiveMS); + logo->metadata.can_show_after_expiration = true; + } + logo->metadata.expiration_time = response_time + time_to_live; + + *parsing_failed = false; + return logo; +} + } // namespace search_provider_logos
diff --git a/components/search_provider_logos/google_logo_api.h b/components/search_provider_logos/google_logo_api.h index d5f85c7..3c3929e 100644 --- a/components/search_provider_logos/google_logo_api.h +++ b/components/search_provider_logos/google_logo_api.h
@@ -14,14 +14,40 @@ namespace search_provider_logos { -// Implements AppendFingerprintToLogoURL, defined in logo_tracker.h, for Google -// doodles. -GURL GoogleAppendQueryparamsToLogoURL(bool gray_background, - const GURL& logo_url, - const std::string& fingerprint); +// Returns the URL where the doodle can be downloaded, e.g. +// https://www.google.com/async/newtab_mobile. This depends on the user's +// Google domain. +GURL GetGoogleDoodleURL(const GURL& google_base_url); -// Implements ParseLogoResponse, defined in logo_tracker.h, for Google doodles. -std::unique_ptr<EncodedLogo> GoogleParseLogoResponse( +// These return the correct callbacks for appending queryparams and parsing the +// response ("Legacy" or "New"), based on the value of features::kUseDdljsonApi. +AppendQueryparamsToLogoURL GetGoogleAppendQueryparamsCallback( + bool gray_background); +ParseLogoResponse GetGoogleParseLogoResponseCallback(const GURL& base_url); + +// Implements AppendQueryparamsToLogoURL, defined in logo_tracker.h, for Google +// doodles (old newtab_mobile API). +GURL GoogleLegacyAppendQueryparamsToLogoURL(bool gray_background, + const GURL& logo_url, + const std::string& fingerprint); + +// Implements ParseLogoResponse, defined in logo_tracker.h, for Google doodles +// (old newtab_mobile API). +std::unique_ptr<EncodedLogo> GoogleLegacyParseLogoResponse( + std::unique_ptr<std::string> response, + base::Time response_time, + bool* parsing_failed); + +// Implements AppendQueryparamsToLogoURL, defined in logo_tracker.h, for Google +// doodles (new ddljson API). +GURL GoogleNewAppendQueryparamsToLogoURL(bool gray_background, + const GURL& logo_url, + const std::string& fingerprint); + +// Implements ParseLogoResponse, defined in logo_tracker.h, for Google doodles +// (new ddljson API). +std::unique_ptr<EncodedLogo> GoogleNewParseLogoResponse( + const GURL& base_url, std::unique_ptr<std::string> response, base::Time response_time, bool* parsing_failed);
diff --git a/components/search_provider_logos/google_logo_api_unittest.cc b/components/search_provider_logos/google_logo_api_unittest.cc new file mode 100644 index 0000000..221ee31 --- /dev/null +++ b/components/search_provider_logos/google_logo_api_unittest.cc
@@ -0,0 +1,100 @@ +// Copyright 2017 The Chromium Authors. All rights reserved. +// Use of this source code is governed by a BSD-style license that can be +// found in the LICENSE file. + +#include "components/search_provider_logos/google_logo_api.h" + +#include <memory> +#include <string> + +#include "base/memory/ptr_util.h" +#include "testing/gmock/include/gmock/gmock.h" +#include "testing/gtest/include/gtest/gtest.h" +#include "url/gurl.h" + +using testing::Eq; + +namespace search_provider_logos { + +TEST(GoogleNewLogoApiTest, ResolvesRelativeUrl) { + const GURL base_url("https://base.doo/"); + const std::string json = R"json()]}' +{ + "ddljson": { + "target_url": "/target" + } +})json"; + + bool failed = false; + std::unique_ptr<EncodedLogo> logo = GoogleNewParseLogoResponse( + base_url, base::MakeUnique<std::string>(json), base::Time(), &failed); + + ASSERT_FALSE(failed); + ASSERT_TRUE(logo); + EXPECT_EQ("https://base.doo/target", logo->metadata.on_click_url); +} + +TEST(GoogleNewLogoApiTest, DoesNotResolveAbsoluteUrl) { + const GURL base_url("https://base.doo/"); + const std::string json = R"json()]}' +{ + "ddljson": { + "target_url": "https://www.doodle.com/target" + } +})json"; + + bool failed = false; + std::unique_ptr<EncodedLogo> logo = GoogleNewParseLogoResponse( + base_url, base::MakeUnique<std::string>(json), base::Time(), &failed); + + ASSERT_FALSE(failed); + ASSERT_TRUE(logo); + EXPECT_EQ("https://www.doodle.com/target", logo->metadata.on_click_url); +} + +TEST(GoogleNewLogoApiTest, ParsesStaticImage) { + const GURL base_url("https://base.doo/"); + // Note: The base64 encoding of "abc" is "YWJj". + const std::string json = R"json()]}' +{ + "ddljson": { + "target_url": "/target", + "data_uri": "" + } +})json"; + + bool failed = false; + std::unique_ptr<EncodedLogo> logo = GoogleNewParseLogoResponse( + base_url, base::MakeUnique<std::string>(json), base::Time(), &failed); + + ASSERT_FALSE(failed); + ASSERT_TRUE(logo); + EXPECT_EQ("abc", logo->encoded_image->data()); +} + +TEST(GoogleNewLogoApiTest, ParsesAnimatedImage) { + const GURL base_url("https://base.doo/"); + // Note: The base64 encoding of "abc" is "YWJj". + const std::string json = R"json()]}' +{ + "ddljson": { + "target_url": "/target", + "large_image": { + "is_animated": true, + "url": "https://www.doodle.com/image.gif" + }, + "cta_data_uri": "" + } +})json"; + + bool failed = false; + std::unique_ptr<EncodedLogo> logo = GoogleNewParseLogoResponse( + base_url, base::MakeUnique<std::string>(json), base::Time(), &failed); + + ASSERT_FALSE(failed); + ASSERT_TRUE(logo); + EXPECT_EQ("https://www.doodle.com/image.gif", logo->metadata.animated_url); + EXPECT_EQ("abc", logo->encoded_image->data()); +} + +} // namespace search_provider_logos
diff --git a/components/search_provider_logos/logo_common.h b/components/search_provider_logos/logo_common.h index ce94005f..fbb3a9c 100644 --- a/components/search_provider_logos/logo_common.h +++ b/components/search_provider_logos/logo_common.h
@@ -7,13 +7,17 @@ #include <stdint.h> +#include <memory> #include <string> +#include "base/callback_forward.h" #include "base/memory/ref_counted.h" #include "base/memory/ref_counted_memory.h" #include "base/time/time.h" #include "third_party/skia/include/core/SkBitmap.h" +class GURL; + namespace search_provider_logos { // The maximum number of milliseconds that a logo can be cached. @@ -73,6 +77,18 @@ LogoMetadata metadata; }; +// Parses the response from the server and returns it as an EncodedLogo. Returns +// null if the response is invalid. +using ParseLogoResponse = base::Callback<std::unique_ptr<EncodedLogo>( + std::unique_ptr<std::string> response, + base::Time response_time, + bool* parsing_failed)>; + +// Encodes the fingerprint of the cached logo in the logo URL. This enables the +// server to verify whether the cached logo is up to date. +using AppendQueryparamsToLogoURL = + base::Callback<GURL(const GURL& logo_url, const std::string& fingerprint)>; + } // namespace search_provider_logos #endif // COMPONENTS_SEARCH_PROVIDER_LOGOS_LOGO_COMMON_H_
diff --git a/components/search_provider_logos/logo_tracker.h b/components/search_provider_logos/logo_tracker.h index 1362f75..7a05504 100644 --- a/components/search_provider_logos/logo_tracker.h +++ b/components/search_provider_logos/logo_tracker.h
@@ -67,18 +67,6 @@ base::Callback<void(const SkBitmap&)> image_decoded_callback) = 0; }; -// Parses the response from the server and returns it as an EncodedLogo. Returns -// null if the response is invalid. -using ParseLogoResponse = base::Callback<std::unique_ptr<EncodedLogo>( - std::unique_ptr<std::string> response, - base::Time response_time, - bool* parsing_failed)>; - -// Encodes the fingerprint of the cached logo in the logo URL. This enables the -// server to verify whether the cached logo is up to date. -using AppendQueryparamsToLogoURL = - base::Callback<GURL(const GURL& logo_url, const std::string& fingerprint)>; - // This class provides the logo for a search provider. Logos are downloaded from // the search provider's logo URL and cached on disk. //
diff --git a/components/search_provider_logos/logo_tracker_unittest.cc b/components/search_provider_logos/logo_tracker_unittest.cc index 346ee57..1b634c39 100644 --- a/components/search_provider_logos/logo_tracker_unittest.cc +++ b/components/search_provider_logos/logo_tracker_unittest.cc
@@ -326,8 +326,8 @@ base::ThreadTaskRunnerHandle::Get()), base::MakeUnique<TestLogoDelegate>()); logo_tracker_->SetServerAPI( - logo_url_, base::Bind(&GoogleParseLogoResponse), - base::Bind(&GoogleAppendQueryparamsToLogoURL, false)); + logo_url_, base::Bind(&GoogleLegacyParseLogoResponse), + base::Bind(&GoogleLegacyAppendQueryparamsToLogoURL, false)); logo_tracker_->SetClockForTests(base::WrapUnique(test_clock_)); logo_tracker_->SetLogoCacheForTests(base::WrapUnique(logo_cache_)); } @@ -392,7 +392,7 @@ net::URLRequestStatus::Status request_status, net::HttpStatusCode response_code) { GURL url_with_fp = - GoogleAppendQueryparamsToLogoURL(false, logo_url_, fingerprint); + GoogleLegacyAppendQueryparamsToLogoURL(false, logo_url_, fingerprint); fake_url_fetcher_factory_.SetFakeResponse( url_with_fp, response_when_fingerprint, response_code, request_status); } @@ -405,24 +405,24 @@ // Tests ----------------------------------------------------------------------- TEST_F(LogoTrackerTest, CTAURLHasComma) { - GURL url_with_fp = GoogleAppendQueryparamsToLogoURL( + GURL url_with_fp = GoogleLegacyAppendQueryparamsToLogoURL( false, GURL("http://logourl.com/path"), "abc123"); EXPECT_EQ("http://logourl.com/path?async=es_dfp:abc123,cta:1", url_with_fp.spec()); - url_with_fp = GoogleAppendQueryparamsToLogoURL( + url_with_fp = GoogleLegacyAppendQueryparamsToLogoURL( false, GURL("http://logourl.com/?a=b"), ""); EXPECT_EQ("http://logourl.com/?a=b&async=cta:1", url_with_fp.spec()); } TEST_F(LogoTrackerTest, CTAGrayBackgroundHasCommas) { - GURL url_with_fp = GoogleAppendQueryparamsToLogoURL( + GURL url_with_fp = GoogleLegacyAppendQueryparamsToLogoURL( true, GURL("http://logourl.com/path"), "abc123"); EXPECT_EQ( "http://logourl.com/path?async=es_dfp:abc123,cta:1,transp:1,graybg:1", url_with_fp.spec()); - url_with_fp = GoogleAppendQueryparamsToLogoURL( + url_with_fp = GoogleLegacyAppendQueryparamsToLogoURL( true, GURL("http://logourl.com/?a=b"), ""); EXPECT_EQ("http://logourl.com/?a=b&async=cta:1,transp:1,graybg:1", url_with_fp.spec()); @@ -732,8 +732,8 @@ logo_url_ = GURL("http://example.com/new-logo-url"); logo_tracker_->SetServerAPI( - logo_url_, base::Bind(&GoogleParseLogoResponse), - base::Bind(&GoogleAppendQueryparamsToLogoURL, false)); + logo_url_, base::Bind(&GoogleLegacyParseLogoResponse), + base::Bind(&GoogleLegacyAppendQueryparamsToLogoURL, false)); Logo logo = GetSampleLogo(logo_url_, test_clock_->Now()); SetServerResponse(ServerResponse(logo));
diff --git a/components/subresource_filter/content/common/ruleset_dealer.cc b/components/subresource_filter/content/common/ruleset_dealer.cc index 5977350..04a6fd7 100644 --- a/components/subresource_filter/content/common/ruleset_dealer.cc +++ b/components/subresource_filter/content/common/ruleset_dealer.cc
@@ -44,4 +44,8 @@ return strong_ruleset_ref; } +base::File RulesetDealer::DuplicateRulesetFile() { + return ruleset_file_.Duplicate(); +} + } // namespace subresource_filter
diff --git a/components/subresource_filter/content/common/ruleset_dealer.h b/components/subresource_filter/content/common/ruleset_dealer.h index 14c1723fb..fe5db99 100644 --- a/components/subresource_filter/content/common/ruleset_dealer.h +++ b/components/subresource_filter/content/common/ruleset_dealer.h
@@ -50,6 +50,10 @@ // For testing only. bool has_cached_ruleset() const { return !!weak_cached_ruleset_.get(); } + // Duplicates the ruleset file. This is used to pass the file to another + // thread. + base::File DuplicateRulesetFile(); + protected: bool CalledOnValidSequence() const { return sequence_checker_.CalledOnValidSequence();
diff --git a/components/subresource_filter/content/renderer/subresource_filter_agent.cc b/components/subresource_filter/content/renderer/subresource_filter_agent.cc index 6697771..c3685ee 100644 --- a/components/subresource_filter/content/renderer/subresource_filter_agent.cc +++ b/components/subresource_filter/content/renderer/subresource_filter_agent.cc
@@ -6,6 +6,7 @@ #include <vector> +#include "base/feature_list.h" #include "base/logging.h" #include "base/memory/ptr_util.h" #include "base/memory/ref_counted.h" @@ -19,8 +20,10 @@ #include "components/subresource_filter/core/common/memory_mapped_ruleset.h" #include "components/subresource_filter/core/common/scoped_timers.h" #include "components/subresource_filter/core/common/time_measurements.h" +#include "content/public/common/content_features.h" #include "content/public/renderer/render_frame.h" #include "ipc/ipc_message.h" +#include "third_party/WebKit/public/platform/WebWorkerFetchContext.h" #include "third_party/WebKit/public/web/WebDataSource.h" #include "third_party/WebKit/public/web/WebDocument.h" #include "third_party/WebKit/public/web/WebLocalFrame.h" @@ -191,4 +194,24 @@ return handled; } +void SubresourceFilterAgent::WillCreateWorkerFetchContext( + blink::WebWorkerFetchContext* worker_fetch_context) { + DCHECK(base::FeatureList::IsEnabled(features::kOffMainThreadFetch)); + if (!filter_for_last_committed_load_) + return; + if (!ruleset_dealer_->IsRulesetFileAvailable()) + return; + base::File ruleset_file = ruleset_dealer_->DuplicateRulesetFile(); + if (!ruleset_file.IsValid()) + return; + worker_fetch_context->SetSubresourceFilterBuilder( + base::MakeUnique<WebDocumentSubresourceFilterImpl::BuilderImpl>( + url::Origin(GetDocumentURL()), + filter_for_last_committed_load_->filter().activation_state(), + std::move(ruleset_file), + base::BindOnce(&SubresourceFilterAgent:: + SignalFirstSubresourceDisallowedForCommittedLoad, + AsWeakPtr()))); +} + } // namespace subresource_filter
diff --git a/components/subresource_filter/content/renderer/subresource_filter_agent.h b/components/subresource_filter/content/renderer/subresource_filter_agent.h index 22bc3fc2..a990a1c 100644 --- a/components/subresource_filter/content/renderer/subresource_filter_agent.h +++ b/components/subresource_filter/content/renderer/subresource_filter_agent.h
@@ -69,6 +69,7 @@ void DidFailProvisionalLoad(const blink::WebURLError& error) override; void DidFinishLoad() override; bool OnMessageReceived(const IPC::Message& message) override; + void WillCreateWorkerFetchContext(blink::WebWorkerFetchContext*) override; // Owned by the ChromeContentRendererClient and outlives us. UnverifiedRulesetDealer* ruleset_dealer_;
diff --git a/components/subresource_filter/content/renderer/web_document_subresource_filter_impl.cc b/components/subresource_filter/content/renderer/web_document_subresource_filter_impl.cc index 88d5f1c..0d1e297 100644 --- a/components/subresource_filter/content/renderer/web_document_subresource_filter_impl.cc +++ b/components/subresource_filter/content/renderer/web_document_subresource_filter_impl.cc
@@ -6,7 +6,10 @@ #include <utility> +#include "base/bind.h" +#include "base/memory/ptr_util.h" #include "base/memory/ref_counted.h" +#include "base/message_loop/message_loop.h" #include "components/subresource_filter/core/common/activation_state.h" #include "components/subresource_filter/core/common/load_policy.h" #include "components/subresource_filter/core/common/memory_mapped_ruleset.h" @@ -90,6 +93,11 @@ } } +void ProxyToTaskRunner(scoped_refptr<base::SingleThreadTaskRunner> task_runner, + base::OnceClosure callback) { + task_runner->PostTask(FROM_HERE, std::move(callback)); +} + } // namespace WebDocumentSubresourceFilterImpl::~WebDocumentSubresourceFilterImpl() = default; @@ -138,4 +146,29 @@ return ToWebLoadPolicy(filter_.GetLoadPolicy(GURL(url), element_type)); } +WebDocumentSubresourceFilterImpl::BuilderImpl::BuilderImpl( + url::Origin document_origin, + ActivationState activation_state, + base::File ruleset_file, + base::OnceClosure first_disallowed_load_callback) + : document_origin_(std::move(document_origin)), + activation_state_(std::move(activation_state)), + ruleset_file_(std::move(ruleset_file)), + first_disallowed_load_callback_( + std::move(first_disallowed_load_callback)), + main_task_runner_(base::MessageLoop::current()->task_runner()) {} + +WebDocumentSubresourceFilterImpl::BuilderImpl::~BuilderImpl() {} + +std::unique_ptr<blink::WebDocumentSubresourceFilter> +WebDocumentSubresourceFilterImpl::BuilderImpl::Build() { + DCHECK(ruleset_file_.IsValid()); + DCHECK(!main_task_runner_->BelongsToCurrentThread()); + return base::MakeUnique<WebDocumentSubresourceFilterImpl>( + document_origin_, activation_state_, + base::MakeRefCounted<MemoryMappedRuleset>(std::move(ruleset_file_)), + base::BindOnce(&ProxyToTaskRunner, main_task_runner_, + std::move(first_disallowed_load_callback_))); +} + } // namespace subresource_filter
diff --git a/components/subresource_filter/content/renderer/web_document_subresource_filter_impl.h b/components/subresource_filter/content/renderer/web_document_subresource_filter_impl.h index 179b0de6..606509b 100644 --- a/components/subresource_filter/content/renderer/web_document_subresource_filter_impl.h +++ b/components/subresource_filter/content/renderer/web_document_subresource_filter_impl.h
@@ -6,11 +6,14 @@ #define COMPONENTS_SUBRESOURCE_FILTER_CONTENT_RENDERER_WEB_DOCUMENT_SUBRESOURCE_FILTER_IMPL_H_ #include "base/callback.h" +#include "base/files/file.h" #include "base/macros.h" #include "base/memory/weak_ptr.h" +#include "base/single_thread_task_runner.h" #include "components/subresource_filter/core/common/document_subresource_filter.h" #include "components/url_pattern_index/proto/rules.pb.h" #include "third_party/WebKit/public/platform/WebDocumentSubresourceFilter.h" +#include "url/origin.h" namespace subresource_filter { @@ -21,6 +24,28 @@ : public blink::WebDocumentSubresourceFilter, public base::SupportsWeakPtr<WebDocumentSubresourceFilterImpl> { public: + // This builder class is created on the main thread and passed to a worker + // thread to create the subresource filter for the worker thread. + class BuilderImpl : public blink::WebDocumentSubresourceFilter::Builder { + public: + BuilderImpl(url::Origin document_origin, + ActivationState activation_state, + base::File ruleset_file, + base::OnceClosure first_disallowed_load_callback); + ~BuilderImpl() override; + + std::unique_ptr<blink::WebDocumentSubresourceFilter> Build() override; + + private: + url::Origin document_origin_; + ActivationState activation_state_; + base::File ruleset_file_; + base::OnceClosure first_disallowed_load_callback_; + scoped_refptr<base::SingleThreadTaskRunner> main_task_runner_; + + DISALLOW_COPY_AND_ASSIGN(BuilderImpl); + }; + // See DocumentSubresourceFilter description. // // Invokes |first_disallowed_load_callback|, if it is non-null, on the first
diff --git a/components/update_client/background_downloader_win.cc b/components/update_client/background_downloader_win.cc index fd391de..d383e1a1 100644 --- a/components/update_client/background_downloader_win.cc +++ b/components/update_client/background_downloader_win.cc
@@ -7,8 +7,9 @@ #include <atlbase.h> #include <atlcom.h> #include <objbase.h> -#include <stddef.h> +#include <winerror.h> +#include <stddef.h> #include <stdint.h> #include <functional> #include <iomanip> @@ -27,6 +28,7 @@ #include "base/strings/string_piece.h" #include "base/strings/sys_string_conversions.h" #include "base/win/scoped_co_mem.h" +#include "components/update_client/update_client_errors.h" #include "components/update_client/utils.h" #include "url/gurl.h" @@ -129,9 +131,12 @@ // system restarts, etc. Also, the check to purge stale jobs only happens // at most once a day. If the job clean up code is not running, the BITS // default policy is to cancel jobs after 90 days of inactivity. -const int kPurgeStaleJobsAfterDays = 7; +const int kPurgeStaleJobsAfterDays = 3; const int kPurgeStaleJobsIntervalBetweenChecksDays = 1; +// Number of maximum BITS jobs this downloader can create and queue up. +const int kMaxQueuedJobs = 10; + // Retrieves the singleton instance of GIT for this process. HRESULT GetGit(ComPtr<IGlobalInterfaceTable>* git) { return ::CoCreateInstance(CLSID_StdGlobalInterfaceTable, NULL, @@ -388,51 +393,6 @@ DeleteFileAndEmptyParentDirectory(path); } -// Cleans up incompleted jobs that are too old. -HRESULT CleanupStaleJobs(const ComPtr<IBackgroundCopyManager>& bits_manager) { - if (!bits_manager.Get()) - return E_FAIL; - - static base::Time last_sweep; - - const base::TimeDelta time_delta( - base::TimeDelta::FromDays(kPurgeStaleJobsIntervalBetweenChecksDays)); - const base::Time current_time(base::Time::Now()); - if (last_sweep + time_delta > current_time) - return S_OK; - - last_sweep = current_time; - - std::vector<ComPtr<IBackgroundCopyJob>> jobs; - HRESULT hr = FindBitsJobIf( - std::bind2nd(std::ptr_fun(JobCreationOlderThanDaysPredicate), - kPurgeStaleJobsAfterDays), - bits_manager, &jobs); - - if (FAILED(hr)) - return hr; - - for (const auto& job : jobs) - CleanupJob(job); - - return S_OK; -} - -// Returns the number of jobs in the BITS queue which were created by this -// downloader. -HRESULT GetBackgroundDownloaderJobCount( - const ComPtr<IBackgroundCopyManager>& bits_manager, - size_t* num_jobs) { - std::vector<ComPtr<IBackgroundCopyJob>> jobs; - const HRESULT hr = - FindBitsJobIf([](const ComPtr<IBackgroundCopyJob>&) { return true; }, - bits_manager, &jobs); - if (FAILED(hr)) - return hr; - *num_jobs = jobs.size(); - return S_OK; -} - } // namespace BackgroundDownloader::BackgroundDownloader( @@ -500,11 +460,11 @@ if (FAILED(hr)) return hr; - hr = RegisterInterfaceInGit(git, bits_manager_, &git_cookie_bits_manager_); + hr = QueueBitsJob(url, &job_); if (FAILED(hr)) return hr; - hr = QueueBitsJob(url, &job_); + hr = RegisterInterfaceInGit(git, bits_manager_, &git_cookie_bits_manager_); if (FAILED(hr)) return hr; @@ -597,8 +557,6 @@ if (FAILED(error)) CleanupJob(job_); - CleanupStaleJobs(bits_manager_); - ClearGit(); // Consider the url handled if it has been successfully downloaded or a @@ -724,9 +682,16 @@ DCHECK(task_runner()->RunsTasksInCurrentSequence()); size_t num_jobs = 0; - GetBackgroundDownloaderJobCount(bits_manager_, &num_jobs); + GetBackgroundDownloaderJobCount(&num_jobs); UMA_HISTOGRAM_COUNTS_100("UpdateClient.BackgroundDownloaderJobs", num_jobs); + // Remove some old jobs from the BITS queue before creating new jobs. + CleanupStaleJobs(); + + if (num_jobs >= kMaxQueuedJobs) + return MAKE_HRESULT(SEVERITY_ERROR, FACILITY_ITF, + CrxDownloaderError::BITS_TOO_MANY_JOBS); + ComPtr<IBackgroundCopyJob> local_job; HRESULT hr = CreateOrOpenJob(url, &local_job); if (FAILED(hr)) { @@ -896,4 +861,43 @@ return S_OK; } +HRESULT BackgroundDownloader::GetBackgroundDownloaderJobCount( + size_t* num_jobs) { + DCHECK(task_runner()->RunsTasksInCurrentSequence()); + DCHECK(bits_manager_); + + std::vector<ComPtr<IBackgroundCopyJob>> jobs; + const HRESULT hr = + FindBitsJobIf([](const ComPtr<IBackgroundCopyJob>&) { return true; }, + bits_manager_, &jobs); + if (FAILED(hr)) + return hr; + + *num_jobs = jobs.size(); + return S_OK; +} + +void BackgroundDownloader::CleanupStaleJobs() { + DCHECK(task_runner()->RunsTasksInCurrentSequence()); + DCHECK(bits_manager_); + + static base::Time last_sweep; + + const base::TimeDelta time_delta( + base::TimeDelta::FromDays(kPurgeStaleJobsIntervalBetweenChecksDays)); + const base::Time current_time(base::Time::Now()); + if (last_sweep + time_delta > current_time) + return; + + last_sweep = current_time; + + std::vector<ComPtr<IBackgroundCopyJob>> jobs; + FindBitsJobIf(std::bind2nd(std::ptr_fun(JobCreationOlderThanDaysPredicate), + kPurgeStaleJobsAfterDays), + bits_manager_, &jobs); + + for (const auto& job : jobs) + CleanupJob(job); +} + } // namespace update_client
diff --git a/components/update_client/background_downloader_win.h b/components/update_client/background_downloader_win.h index ca71df0a..be0f26cc 100644 --- a/components/update_client/background_downloader_win.h +++ b/components/update_client/background_downloader_win.h
@@ -115,6 +115,13 @@ // from the thread pool leaves the object to release the interface pointers. void ResetInterfacePointers(); + // Returns the number of jobs in the BITS queue which were created by this + // downloader. + HRESULT GetBackgroundDownloaderJobCount(size_t* num_jobs); + + // Cleans up incompleted jobs that are too old. + void CleanupStaleJobs(); + // Ensures that we are running on the same thread we created the object on. base::ThreadChecker thread_checker_;
diff --git a/components/update_client/update_client_errors.h b/components/update_client/update_client_errors.h index 050ab3c..814f08a 100644 --- a/components/update_client/update_client_errors.h +++ b/components/update_client/update_client_errors.h
@@ -37,6 +37,9 @@ NO_URL = 10, NO_HASH = 11, BAD_HASH = 12, // The downloaded file fails the hash verification. + // The Windows BITS queue contains to many update client jobs. The value is + // chosen so that it can be reported as a custom COM error on this platform. + BITS_TOO_MANY_JOBS = 0x0200, GENERIC_ERROR = -1 };
diff --git a/components/viz/common/BUILD.gn b/components/viz/common/BUILD.gn index fdefcb8..f60c6674 100644 --- a/components/viz/common/BUILD.gn +++ b/components/viz/common/BUILD.gn
@@ -12,9 +12,14 @@ "gl_helper_readback_support.h", "gl_helper_scaling.cc", "gl_helper_scaling.h", + "quads/resource_format.h", + "resources/platform_color.h", + "resources/resource_format_utils.cc", + "resources/resource_format_utils.h", ] deps = [ + "//base", "//gpu/command_buffer/client:gles2_interface", "//skia", "//ui/gfx/geometry", @@ -29,6 +34,7 @@ source_set("unit_tests") { testonly = true sources = [ + "resources/platform_color_unittest.cc", "yuv_readback_unittest.cc", ]
diff --git a/components/viz/common/quads/DEPS b/components/viz/common/quads/DEPS new file mode 100644 index 0000000..b273ae3 --- /dev/null +++ b/components/viz/common/quads/DEPS
@@ -0,0 +1,3 @@ +include_rules = [ + "+ui/gfx", +]
diff --git a/components/viz/common/quads/resource_format.h b/components/viz/common/quads/resource_format.h new file mode 100644 index 0000000..4ae7b06 --- /dev/null +++ b/components/viz/common/quads/resource_format.h
@@ -0,0 +1,35 @@ +// Copyright 2013 The Chromium Authors. All rights reserved. +// Use of this source code is governed by a BSD-style license that can be +// found in the LICENSE file. + +#ifndef COMPONENTS_VIZ_COMMON_QUADS_RESOURCE_FORMAT_H_ +#define COMPONENTS_VIZ_COMMON_QUADS_RESOURCE_FORMAT_H_ + +#include "base/logging.h" +#include "ui/gfx/buffer_types.h" + +// TODO(prashant.n): Including third_party/khronos/GLES2/gl2.h causes +// redefinition errors as macros/functions defined in it conflict with +// macros/functions defined in ui/gl/gl_bindings.h. (http://crbug.com/512833). +typedef unsigned int GLenum; + +namespace viz { + +// Keep in sync with arrays below. +enum ResourceFormat { + RGBA_8888, + RGBA_4444, + BGRA_8888, + ALPHA_8, + LUMINANCE_8, + RGB_565, + ETC1, + RED_8, + LUMINANCE_F16, + RGBA_F16, + RESOURCE_FORMAT_MAX = RGBA_F16, +}; + +} // namespace viz + +#endif // COMPONENTS_VIZ_COMMON_QUADS_RESOURCE_FORMAT_H_
diff --git a/components/viz/common/resources/DEPS b/components/viz/common/resources/DEPS new file mode 100644 index 0000000..90a9806 --- /dev/null +++ b/components/viz/common/resources/DEPS
@@ -0,0 +1,4 @@ +include_rules = [ + "+third_party/khronos/GLES2", + "+ui/gfx", +]
diff --git a/cc/resources/platform_color.h b/components/viz/common/resources/platform_color.h similarity index 83% rename from cc/resources/platform_color.h rename to components/viz/common/resources/platform_color.h index 91f249c..505b6d43 100644 --- a/cc/resources/platform_color.h +++ b/components/viz/common/resources/platform_color.h
@@ -2,22 +2,19 @@ // Use of this source code is governed by a BSD-style license that can be // found in the LICENSE file. -#ifndef CC_RESOURCES_PLATFORM_COLOR_H_ -#define CC_RESOURCES_PLATFORM_COLOR_H_ +#ifndef COMPONENTS_VIZ_COMMON_RESOURCES_PLATFORM_COLOR_H_ +#define COMPONENTS_VIZ_COMMON_RESOURCES_PLATFORM_COLOR_H_ #include "base/logging.h" #include "base/macros.h" -#include "cc/resources/resource_format.h" +#include "components/viz/common/quads/resource_format.h" #include "third_party/skia/include/core/SkTypes.h" -namespace cc { +namespace viz { class PlatformColor { public: - enum SourceDataFormat { - SOURCE_FORMAT_RGBA8, - SOURCE_FORMAT_BGRA8 - }; + enum SourceDataFormat { SOURCE_FORMAT_RGBA8, SOURCE_FORMAT_BGRA8 }; static SourceDataFormat Format() { return SK_B32_SHIFT ? SOURCE_FORMAT_RGBA8 : SOURCE_FORMAT_BGRA8; @@ -75,6 +72,6 @@ DISALLOW_IMPLICIT_CONSTRUCTORS(PlatformColor); }; -} // namespace cc +} // namespace viz -#endif // CC_RESOURCES_PLATFORM_COLOR_H_ +#endif // COMPONENTS_VIZ_COMMON_RESOURCES_PLATFORM_COLOR_H_
diff --git a/cc/resources/platform_color_unittest.cc b/components/viz/common/resources/platform_color_unittest.cc similarity index 90% rename from cc/resources/platform_color_unittest.cc rename to components/viz/common/resources/platform_color_unittest.cc index d0d8036..f8012176 100644 --- a/cc/resources/platform_color_unittest.cc +++ b/components/viz/common/resources/platform_color_unittest.cc
@@ -2,13 +2,13 @@ // Use of this source code is governed by a BSD-style license that can be // found in the LICENSE file. -#include "cc/resources/platform_color.h" +#include "components/viz/common/resources/platform_color.h" #include <stddef.h> #include "testing/gtest/include/gtest/gtest.h" -namespace cc { +namespace viz { namespace { // Verify SameComponentOrder on this platform. @@ -39,4 +39,4 @@ } } // namespace -} // namespace cc +} // namespace viz
diff --git a/cc/resources/resource_format.cc b/components/viz/common/resources/resource_format_utils.cc similarity index 83% rename from cc/resources/resource_format.cc rename to components/viz/common/resources/resource_format_utils.cc index e159f15e..f15ddc7 100644 --- a/cc/resources/resource_format.cc +++ b/components/viz/common/resources/resource_format_utils.cc
@@ -1,14 +1,39 @@ -// Copyright 2013 The Chromium Authors. All rights reserved. +// Copyright 2016 The Chromium Authors. All rights reserved. // Use of this source code is governed by a BSD-style license that can be // found in the LICENSE file. -#include "cc/resources/resource_format.h" +#include "components/viz/common/resources/resource_format_utils.h" #include "third_party/khronos/GLES2/gl2.h" #include "third_party/khronos/GLES2/gl2ext.h" #include "ui/gfx/gpu_memory_buffer.h" -namespace cc { +namespace viz { + +SkColorType ResourceFormatToClosestSkColorType(ResourceFormat format) { + // Use kN32_SkColorType if there is no corresponding SkColorType. + switch (format) { + case RGBA_4444: + return kARGB_4444_SkColorType; + case RGBA_8888: + case BGRA_8888: + return kN32_SkColorType; + case ALPHA_8: + return kAlpha_8_SkColorType; + case RGB_565: + return kRGB_565_SkColorType; + case LUMINANCE_8: + return kGray_8_SkColorType; + case ETC1: + case RED_8: + case LUMINANCE_F16: + return kN32_SkColorType; + case RGBA_F16: + return kRGBA_F16_SkColorType; + } + NOTREACHED(); + return kN32_SkColorType; +} int BitsPerPixel(ResourceFormat format) { switch (format) { @@ -149,4 +174,4 @@ return false; } -} // namespace cc +} // namespace viz
diff --git a/components/viz/common/resources/resource_format_utils.h b/components/viz/common/resources/resource_format_utils.h new file mode 100644 index 0000000..923357e --- /dev/null +++ b/components/viz/common/resources/resource_format_utils.h
@@ -0,0 +1,25 @@ +// Copyright 2016 The Chromium Authors. All rights reserved. +// Use of this source code is governed by a BSD-style license that can be +// found in the LICENSE file. + +#ifndef COMPONENTS_VIZ_COMMON_RESOURCES_RESOURCE_FORMAT_UTILS_H_ +#define COMPONENTS_VIZ_COMMON_RESOURCES_RESOURCE_FORMAT_UTILS_H_ + +#include "components/viz/common/quads/resource_format.h" +#include "third_party/skia/include/core/SkImageInfo.h" + +namespace viz { + +SkColorType ResourceFormatToClosestSkColorType(ResourceFormat format); +int BitsPerPixel(ResourceFormat format); +GLenum GLDataType(ResourceFormat format); +GLenum GLDataFormat(ResourceFormat format); +GLenum GLInternalFormat(ResourceFormat format); +GLenum GLCopyTextureInternalFormat(ResourceFormat format); +gfx::BufferFormat BufferFormat(ResourceFormat format); +bool IsResourceFormatCompressed(ResourceFormat format); +bool DoesResourceFormatSupportAlpha(ResourceFormat format); + +} // namespace viz + +#endif // COMPONENTS_VIZ_COMMON_RESOURCES_RESOURCE_FORMAT_UTILS_H_
diff --git a/components/viz/host/DEPS b/components/viz/host/DEPS index b4d33612..18cdf15 100644 --- a/components/viz/host/DEPS +++ b/components/viz/host/DEPS
@@ -8,10 +8,5 @@ "+gpu/ipc/host", "+mojo/public/cpp/bindings", "+services/ui/gpu/interfaces", + "+ui/gfx", ] - -specific_include_rules = { - "server_gpu_memory_buffer_manager_unittest\.cc": [ - "+ui/gfx", - ] -}
diff --git a/components/viz/host/server_gpu_memory_buffer_manager.cc b/components/viz/host/server_gpu_memory_buffer_manager.cc index 460cbf6..ac36c93 100644 --- a/components/viz/host/server_gpu_memory_buffer_manager.cc +++ b/components/viz/host/server_gpu_memory_buffer_manager.cc
@@ -5,14 +5,22 @@ #include "components/viz/host/server_gpu_memory_buffer_manager.h" #include "base/logging.h" +#include "base/strings/stringprintf.h" #include "base/threading/sequenced_task_runner_handle.h" +#include "base/trace_event/memory_dump_manager.h" +#include "base/trace_event/process_memory_dump.h" #include "gpu/ipc/client/gpu_memory_buffer_impl.h" #include "gpu/ipc/client/gpu_memory_buffer_impl_shared_memory.h" #include "gpu/ipc/common/gpu_memory_buffer_support.h" #include "services/ui/gpu/interfaces/gpu_service.mojom.h" +#include "ui/gfx/buffer_format_util.h" +#include "ui/gfx/gpu_memory_buffer_tracing.h" namespace viz { +ServerGpuMemoryBufferManager::BufferInfo::BufferInfo() = default; +ServerGpuMemoryBufferManager::BufferInfo::~BufferInfo() = default; + ServerGpuMemoryBufferManager::ServerGpuMemoryBufferManager( ui::mojom::GpuService* gpu_service, int client_id) @@ -42,6 +50,7 @@ id, size, format, usage, client_id, surface_handle, base::Bind(&ServerGpuMemoryBufferManager::OnGpuMemoryBufferAllocated, weak_factory_.GetWeakPtr(), client_id, + gfx::BufferSizeForBufferFormat(size, format), base::Passed(std::move(callback)))); return; } @@ -55,6 +64,14 @@ format)) { buffer_handle = gpu::GpuMemoryBufferImplSharedMemory::CreateGpuMemoryBuffer( id, size, format); + BufferInfo buffer_info; + DCHECK_EQ(gfx::SHARED_MEMORY_BUFFER, buffer_handle.type); + buffer_info.type = gfx::SHARED_MEMORY_BUFFER; + buffer_info.buffer_size_in_bytes = + gfx::BufferSizeForBufferFormat(size, format); + buffer_info.shared_memory_guid = buffer_handle.handle.GetGUID(); + allocated_buffers_[client_id].insert( + std::make_pair(buffer_handle.id, buffer_info)); } task_runner_->PostTask(FROM_HERE, @@ -104,26 +121,92 @@ sync_token); } +bool ServerGpuMemoryBufferManager::OnMemoryDump( + const base::trace_event::MemoryDumpArgs& args, + base::trace_event::ProcessMemoryDump* pmd) { + DCHECK(task_runner_->RunsTasksInCurrentSequence()); + for (const auto& pair : allocated_buffers_) { + int client_id = pair.first; + for (const auto& buffer_pair : pair.second) { + gfx::GpuMemoryBufferId buffer_id = buffer_pair.first; + const BufferInfo& buffer_info = buffer_pair.second; + base::trace_event::MemoryAllocatorDump* dump = + pmd->CreateAllocatorDump(base::StringPrintf( + "gpumemorybuffer/client_%d/buffer_%d", client_id, buffer_id.id)); + if (!dump) + return false; + dump->AddScalar(base::trace_event::MemoryAllocatorDump::kNameSize, + base::trace_event::MemoryAllocatorDump::kUnitsBytes, + buffer_info.buffer_size_in_bytes); + + // Create the cross-process ownership edge. If the client creates a + // corresponding dump for the same buffer, this will avoid to + // double-count them in tracing. If, instead, no other process will emit a + // dump with the same guid, the segment will be accounted to the browser. + uint64_t client_tracing_process_id = ClientIdToTracingId(client_id); + + if (buffer_info.type == gfx::SHARED_MEMORY_BUFFER) { + auto shared_buffer_guid = gfx::GetSharedMemoryGUIDForTracing( + client_tracing_process_id, buffer_id); + pmd->CreateSharedMemoryOwnershipEdge(dump->guid(), shared_buffer_guid, + buffer_info.shared_memory_guid, + 0 /* importance */); + } else { + auto shared_buffer_guid = gfx::GetGenericSharedGpuMemoryGUIDForTracing( + client_tracing_process_id, buffer_id); + pmd->CreateSharedGlobalAllocatorDump(shared_buffer_guid); + pmd->AddOwnershipEdge(dump->guid(), shared_buffer_guid); + } + } + } + return true; +} + void ServerGpuMemoryBufferManager::DestroyGpuMemoryBuffer( gfx::GpuMemoryBufferId id, int client_id, const gpu::SyncToken& sync_token) { DCHECK(task_runner_->RunsTasksInCurrentSequence()); - if (native_buffers_[client_id].erase(id)) + auto iter = allocated_buffers_[client_id].find(id); + if (iter == allocated_buffers_[client_id].end()) + return; + DCHECK_NE(gfx::EMPTY_BUFFER, iter->second.type); + allocated_buffers_[client_id].erase(id); + if (iter->second.type != gfx::SHARED_MEMORY_BUFFER) gpu_service_->DestroyGpuMemoryBuffer(id, client_id, sync_token); } void ServerGpuMemoryBufferManager::DestroyAllGpuMemoryBufferForClient( int client_id) { DCHECK(task_runner_->RunsTasksInCurrentSequence()); - for (gfx::GpuMemoryBufferId id : native_buffers_[client_id]) - gpu_service_->DestroyGpuMemoryBuffer(id, client_id, gpu::SyncToken()); - native_buffers_.erase(client_id); + for (auto pair : allocated_buffers_[client_id]) { + DCHECK_NE(gfx::EMPTY_BUFFER, pair.second.type); + if (pair.second.type != gfx::SHARED_MEMORY_BUFFER) { + gpu_service_->DestroyGpuMemoryBuffer(pair.first, client_id, + gpu::SyncToken()); + } + } + allocated_buffers_.erase(client_id); pending_buffers_.erase(client_id); } +uint64_t ServerGpuMemoryBufferManager::ClientIdToTracingId( + int client_id) const { + if (client_id == client_id_) { + return base::trace_event::MemoryDumpManager::GetInstance() + ->GetTracingProcessId(); + } + // TODO(sad|ssid): Find a better way once crbug.com/661257 is resolved. + // The hash value is incremented so that the tracing id is never equal to + // MemoryDumpManager::kInvalidTracingProcessId. + return static_cast<uint64_t>(base::Hash( + reinterpret_cast<const char*>(&client_id), sizeof(client_id))) + + 1; +} + void ServerGpuMemoryBufferManager::OnGpuMemoryBufferAllocated( int client_id, + size_t buffer_size_in_bytes, base::OnceCallback<void(const gfx::GpuMemoryBufferHandle&)> callback, const gfx::GpuMemoryBufferHandle& handle) { DCHECK(task_runner_->RunsTasksInCurrentSequence()); @@ -136,8 +219,13 @@ std::move(callback).Run(gfx::GpuMemoryBufferHandle()); return; } - if (!handle.is_null()) - native_buffers_[client_id].insert(handle.id); + if (!handle.is_null()) { + BufferInfo buffer_info; + buffer_info.type = handle.type; + buffer_info.buffer_size_in_bytes = buffer_size_in_bytes; + allocated_buffers_[client_id].insert( + std::make_pair(handle.id, buffer_info)); + } std::move(callback).Run(handle); }
diff --git a/components/viz/host/server_gpu_memory_buffer_manager.h b/components/viz/host/server_gpu_memory_buffer_manager.h index 2ee15b6..5ae16d95 100644 --- a/components/viz/host/server_gpu_memory_buffer_manager.h +++ b/components/viz/host/server_gpu_memory_buffer_manager.h
@@ -11,6 +11,7 @@ #include "base/memory/weak_ptr.h" #include "base/sequenced_task_runner.h" #include "base/synchronization/waitable_event.h" +#include "base/trace_event/memory_dump_provider.h" #include "components/viz/host/viz_host_export.h" #include "gpu/command_buffer/client/gpu_memory_buffer_manager.h" #include "gpu/ipc/host/gpu_memory_buffer_support.h" @@ -28,7 +29,8 @@ // Note that |CreateGpuMemoryBuffer()| can be called on any thread. All the rest // of the functions must be called on the thread this object is created on. class VIZ_HOST_EXPORT ServerGpuMemoryBufferManager - : public gpu::GpuMemoryBufferManager { + : public gpu::GpuMemoryBufferManager, + public base::trace_event::MemoryDumpProvider { public: ServerGpuMemoryBufferManager(ui::mojom::GpuService* gpu_service, int client_id); @@ -58,9 +60,15 @@ void SetDestructionSyncToken(gfx::GpuMemoryBuffer* buffer, const gpu::SyncToken& sync_token) override; + // Overridden from base::trace_event::MemoryDumpProvider: + bool OnMemoryDump(const base::trace_event::MemoryDumpArgs& args, + base::trace_event::ProcessMemoryDump* pmd) override; + private: + uint64_t ClientIdToTracingId(int client_id) const; void OnGpuMemoryBufferAllocated( int client_id, + size_t buffer_size_in_bytes, base::OnceCallback<void(const gfx::GpuMemoryBufferHandle&)> callback, const gfx::GpuMemoryBufferHandle& handle); @@ -68,10 +76,19 @@ const int client_id_; int next_gpu_memory_id_ = 1; - using NativeBuffers = - std::unordered_set<gfx::GpuMemoryBufferId, + struct BufferInfo { + BufferInfo(); + ~BufferInfo(); + gfx::GpuMemoryBufferType type = gfx::EMPTY_BUFFER; + size_t buffer_size_in_bytes = 0; + base::UnguessableToken shared_memory_guid; + }; + + using AllocatedBuffers = + std::unordered_map<gfx::GpuMemoryBufferId, + BufferInfo, BASE_HASH_NAMESPACE::hash<gfx::GpuMemoryBufferId>>; - std::unordered_map<int, NativeBuffers> native_buffers_; + std::unordered_map<int, AllocatedBuffers> allocated_buffers_; std::unordered_set<int> pending_buffers_; const gpu::GpuMemoryBufferConfigurationSet native_configurations_;
diff --git a/content/browser/BUILD.gn b/content/browser/BUILD.gn index 81f977c..b3c7fa7 100644 --- a/content/browser/BUILD.gn +++ b/content/browser/BUILD.gn
@@ -47,6 +47,8 @@ "//components/metrics:single_sample_metrics", "//components/mime_util", "//components/network_session_configurator/browser", + "//components/offline_pages/core/request_header", + "//components/offline_pages/features:features", "//components/rappor", "//components/tracing", "//components/tracing:startup_tracing", @@ -1932,6 +1934,8 @@ "renderer_host/compositor_impl_android.h", "renderer_host/input/synthetic_gesture_target_android.cc", "renderer_host/input/synthetic_gesture_target_android.h", + "renderer_host/input/touch_selection_controller_client_manager_android.cc", + "renderer_host/input/touch_selection_controller_client_manager_android.h", "renderer_host/native_web_keyboard_event_android.cc", "renderer_host/render_widget_host_view_android.cc", "renderer_host/render_widget_host_view_android.h",
diff --git a/content/browser/DEPS b/content/browser/DEPS index 2aa59bb..13fb093d 100644 --- a/content/browser/DEPS +++ b/content/browser/DEPS
@@ -10,6 +10,8 @@ "+components/metrics:single_sample_metrics", "+components/mime_util", "+components/network_session_configurator/common", + "+components/offline_pages/features/features.h", + "+components/offline_pages/core/request_header", "+components/payments", "+components/profile_service", "+components/rappor/public",
diff --git a/content/browser/child_process_security_policy_impl.cc b/content/browser/child_process_security_policy_impl.cc index e8af7514..779aa5b 100644 --- a/content/browser/child_process_security_policy_impl.cc +++ b/content/browser/child_process_security_policy_impl.cc
@@ -443,10 +443,12 @@ if (!url.is_valid()) return; // Can't grant the capability to request invalid URLs. - if (IsWebSafeScheme(url.scheme())) + const std::string& scheme = url.scheme(); + + if (IsWebSafeScheme(scheme)) return; // The scheme has already been whitelisted for every child process. - if (IsPseudoScheme(url.scheme())) { + if (IsPseudoScheme(scheme)) { return; // Can't grant the capability to request pseudo schemes. } @@ -462,7 +464,7 @@ // When the child process has been commanded to request this scheme, // we grant it the capability to request all URLs of that scheme. - state->second->GrantScheme(url.scheme()); + state->second->GrantScheme(scheme); } } @@ -632,7 +634,9 @@ if (!url.is_valid()) return false; // Can't request invalid URLs. - if (IsPseudoScheme(url.scheme())) { + const std::string& scheme = url.scheme(); + + if (IsPseudoScheme(scheme)) { // Every child process can request <about:blank>, <about:blank?foo>, // <about:blank/#foo> and <about:srcdoc>. if (url.IsAboutBlank() || url == kAboutSrcDocURL) @@ -655,7 +659,7 @@ CanCommitURL(child_id, GURL(origin.Serialize())); } - if (IsWebSafeScheme(url.scheme())) + if (IsWebSafeScheme(scheme)) return true; // If the process can commit the URL, it can request it. @@ -672,9 +676,11 @@ if (!url.is_valid()) return false; // Can't commit invalid URLs. + const std::string& scheme = url.scheme(); + // Of all the pseudo schemes, only about:blank and about:srcdoc are allowed to // commit. - if (IsPseudoScheme(url.scheme())) + if (IsPseudoScheme(scheme)) return url == url::kAboutBlankURL || url == kAboutSrcDocURL; // Blob and filesystem URLs require special treatment; validate the inner @@ -701,7 +707,7 @@ // site, so CanCommitURL will need to rely on explicit, per-process grants. // Note how today, even with extension isolation, the line below does not // enforce that http pages cannot commit in an extension process. - if (base::ContainsKey(schemes_okay_to_commit_in_any_process_, url.scheme())) + if (base::ContainsKey(schemes_okay_to_commit_in_any_process_, scheme)) return true; SecurityStateMap::iterator state = security_state_.find(child_id); @@ -719,10 +725,12 @@ if (!url.is_valid()) return false; // Can't set invalid URLs as origin headers. + const std::string& scheme = url.scheme(); + // Suborigin URLs are a special case and are allowed to be an origin header. - if (url.scheme() == url::kHttpSuboriginScheme || - url.scheme() == url::kHttpsSuboriginScheme) { - DCHECK(IsPseudoScheme(url.scheme())); + if (scheme == url::kHttpSuboriginScheme || + scheme == url::kHttpsSuboriginScheme) { + DCHECK(IsPseudoScheme(scheme)); return true; } @@ -740,8 +748,7 @@ // document origin. { base::AutoLock lock(lock_); - if (base::ContainsKey(schemes_okay_to_appear_as_origin_headers_, - url.scheme())) + if (base::ContainsKey(schemes_okay_to_appear_as_origin_headers_, scheme)) return true; } return false;
diff --git a/content/browser/cocoa/system_hotkey_helper_mac.mm b/content/browser/cocoa/system_hotkey_helper_mac.mm index f2453404..cbac199 100644 --- a/content/browser/cocoa/system_hotkey_helper_mac.mm +++ b/content/browser/cocoa/system_hotkey_helper_mac.mm
@@ -9,6 +9,9 @@ #include "base/mac/foundation_util.h" #include "base/message_loop/message_loop.h" #include "base/metrics/histogram_macros.h" +#include "base/task_scheduler/post_task.h" +#include "base/task_scheduler/task_traits.h" +#include "base/threading/thread_restrictions.h" #include "content/browser/cocoa/system_hotkey_map.h" #include "content/public/browser/browser_thread.h" @@ -30,9 +33,8 @@ } void SystemHotkeyHelperMac::DeferredLoadSystemHotkeys() { - BrowserThread::PostDelayedTask( - BrowserThread::FILE, - FROM_HERE, + base::PostDelayedTaskWithTraits( + FROM_HERE, {base::MayBlock()}, base::Bind(&SystemHotkeyHelperMac::LoadSystemHotkeys, base::Unretained(this)), base::TimeDelta::FromSeconds(kLoadHotkeysDelaySeconds)); @@ -45,7 +47,7 @@ } void SystemHotkeyHelperMac::LoadSystemHotkeys() { - DCHECK_CURRENTLY_ON(BrowserThread::FILE); + base::ThreadRestrictions::AssertIOAllowed(); std::string library_path(base::mac::GetUserLibraryPath().value()); NSString* expanded_file_path =
diff --git a/content/browser/compositor/offscreen_browser_compositor_output_surface.cc b/content/browser/compositor/offscreen_browser_compositor_output_surface.cc index 866e8fbe..c2be00c 100644 --- a/content/browser/compositor/offscreen_browser_compositor_output_surface.cc +++ b/content/browser/compositor/offscreen_browser_compositor_output_surface.cc
@@ -11,6 +11,7 @@ #include "cc/output/output_surface_client.h" #include "cc/output/output_surface_frame.h" #include "cc/resources/resource_provider.h" +#include "components/viz/common/resources/resource_format_utils.h" #include "components/viz/service/display_embedder/compositor_overlay_candidate_validator.h" #include "content/browser/compositor/reflector_impl.h" #include "content/browser/compositor/reflector_texture.h" @@ -26,7 +27,7 @@ namespace content { -static cc::ResourceFormat kFboTextureFormat = cc::RGBA_8888; +static viz::ResourceFormat kFboTextureFormat = viz::RGBA_8888; OffscreenBrowserCompositorOutputSurface:: OffscreenBrowserCompositorOutputSurface(
diff --git a/content/browser/devtools/protocol/network_handler.cc b/content/browser/devtools/protocol/network_handler.cc index 0891103..bff4f04c 100644 --- a/content/browser/devtools/protocol/network_handler.cc +++ b/content/browser/devtools/protocol/network_handler.cc
@@ -5,6 +5,7 @@ #include "content/browser/devtools/protocol/network_handler.h" #include <stddef.h> +#include <stdint.h> #include "base/barrier_closure.h" #include "base/base64.h" @@ -190,7 +191,7 @@ }; void ClearedCookiesOnIO(std::unique_ptr<ClearBrowserCookiesCallback> callback, - int num_deleted) { + uint32_t num_deleted) { DCHECK_CURRENTLY_ON(BrowserThread::IO); BrowserThread::PostTask(BrowserThread::UI, FROM_HERE, base::Bind(&ClearBrowserCookiesCallback::sendSuccess,
diff --git a/content/browser/loader/resource_dispatcher_host_impl.cc b/content/browser/loader/resource_dispatcher_host_impl.cc index 4080c66..164e98b 100644 --- a/content/browser/loader/resource_dispatcher_host_impl.cc +++ b/content/browser/loader/resource_dispatcher_host_impl.cc
@@ -142,7 +142,7 @@ "chrome URLs, resources for installed extensions, as well as " "downloads." trigger: - "Navigating to a URL or downloading a file. A webpage, " + "Navigating to a URL or downloading a file. A webpage, " "ServiceWorker, chrome:// page, or extension may also initiate " "requests in the background." data: "Anything the initiator wants to send." @@ -883,9 +883,11 @@ ResourceRequesterInfo* requester_info, int routing_id, int request_id, - const ResourceRequest& request_data) { - OnRequestResourceInternal(requester_info, routing_id, request_id, - request_data, nullptr, nullptr); + const ResourceRequest& request_data, + net::MutableNetworkTrafficAnnotationTag traffic_annotation) { + OnRequestResourceInternal( + requester_info, routing_id, request_id, request_data, nullptr, nullptr, + net::NetworkTrafficAnnotationTag(traffic_annotation)); } void ResourceDispatcherHostImpl::OnRequestResourceInternal( @@ -894,7 +896,8 @@ int request_id, const ResourceRequest& request_data, mojom::URLLoaderAssociatedRequest mojo_request, - mojom::URLLoaderClientPtr url_loader_client) { + mojom::URLLoaderClientPtr url_loader_client, + const net::NetworkTrafficAnnotationTag& traffic_annotation) { DCHECK(requester_info->IsRenderer() || requester_info->IsNavigationPreload()); // TODO(pkasting): Remove ScopedTracker below once crbug.com/477117 is fixed. tracked_objects::ScopedTracker tracking_profile( @@ -914,7 +917,7 @@ } BeginRequest(requester_info, request_id, request_data, SyncLoadResultCallback(), routing_id, std::move(mojo_request), - std::move(url_loader_client)); + std::move(url_loader_client), traffic_annotation); } // Begins a resource request with the given params on behalf of the specified @@ -934,7 +937,7 @@ base::Bind(&HandleSyncLoadResult, requester_info->filter()->GetWeakPtr(), base::Passed(WrapUnique(sync_result))); BeginRequest(requester_info, request_id, request_data, callback, - sync_result->routing_id(), nullptr, nullptr); + sync_result->routing_id(), nullptr, nullptr, kTrafficAnnotation); } bool ResourceDispatcherHostImpl::IsRequestIDInUse( @@ -1096,7 +1099,8 @@ const SyncLoadResultCallback& sync_result_handler, // only valid for sync int route_id, mojom::URLLoaderAssociatedRequest mojo_request, - mojom::URLLoaderClientPtr url_loader_client) { + mojom::URLLoaderClientPtr url_loader_client, + const net::NetworkTrafficAnnotationTag& traffic_annotation) { DCHECK(requester_info->IsRenderer() || requester_info->IsNavigationPreload()); int child_id = requester_info->child_id(); @@ -1215,7 +1219,7 @@ request_id, request_data, sync_result_handler, route_id, headers, base::Passed(std::move(mojo_request)), base::Passed(std::move(url_loader_client)), - base::Passed(std::move(blob_handles)))); + base::Passed(std::move(blob_handles)), traffic_annotation)); return; } } @@ -1224,7 +1228,8 @@ ContinuePendingBeginRequest( requester_info, request_id, request_data, sync_result_handler, route_id, headers, std::move(mojo_request), std::move(url_loader_client), - std::move(blob_handles), HeaderInterceptorResult::CONTINUE); + std::move(blob_handles), traffic_annotation, + HeaderInterceptorResult::CONTINUE); } void ResourceDispatcherHostImpl::ContinuePendingBeginRequest( @@ -1237,6 +1242,7 @@ mojom::URLLoaderAssociatedRequest mojo_request, mojom::URLLoaderClientPtr url_loader_client, BlobHandles blob_handles, + const net::NetworkTrafficAnnotationTag& traffic_annotation, HeaderInterceptorResult interceptor_result) { DCHECK(requester_info->IsRenderer() || requester_info->IsNavigationPreload()); if (interceptor_result != HeaderInterceptorResult::CONTINUE) { @@ -1282,7 +1288,7 @@ std::unique_ptr<net::URLRequest> new_request = request_context->CreateRequest( is_navigation_stream_request ? request_data.resource_body_stream_url : request_data.url, - request_data.priority, nullptr, kTrafficAnnotation); + request_data.priority, nullptr, traffic_annotation); if (is_navigation_stream_request) { // PlzNavigate: Always set the method to GET when gaining access to the @@ -2255,10 +2261,11 @@ int request_id, const ResourceRequest& request, mojom::URLLoaderAssociatedRequest mojo_request, - mojom::URLLoaderClientPtr url_loader_client) { + mojom::URLLoaderClientPtr url_loader_client, + const net::NetworkTrafficAnnotationTag& traffic_annotation) { OnRequestResourceInternal(requester_info, routing_id, request_id, request, std::move(mojo_request), - std::move(url_loader_client)); + std::move(url_loader_client), traffic_annotation); } void ResourceDispatcherHostImpl::OnSyncLoadWithMojo( @@ -2268,7 +2275,7 @@ const ResourceRequest& request_data, const SyncLoadResultCallback& result_handler) { BeginRequest(requester_info, request_id, request_data, result_handler, - routing_id, nullptr, nullptr); + routing_id, nullptr, nullptr, kTrafficAnnotation); } // static
diff --git a/content/browser/loader/resource_dispatcher_host_impl.h b/content/browser/loader/resource_dispatcher_host_impl.h index 2b95db9..49645a1 100644 --- a/content/browser/loader/resource_dispatcher_host_impl.h +++ b/content/browser/loader/resource_dispatcher_host_impl.h
@@ -41,6 +41,7 @@ #include "ipc/ipc_message.h" #include "net/base/load_states.h" #include "net/base/request_priority.h" +#include "net/traffic_annotation/network_traffic_annotation.h" #include "third_party/WebKit/public/platform/WebMixedContentContextType.h" #include "url/gurl.h" @@ -279,12 +280,14 @@ void OnRenderFrameDeleted(const GlobalFrameRoutingId& global_routing_id); // Called when loading a request with mojo. - void OnRequestResourceWithMojo(ResourceRequesterInfo* requester_info, - int routing_id, - int request_id, - const ResourceRequest& request, - mojom::URLLoaderAssociatedRequest mojo_request, - mojom::URLLoaderClientPtr url_loader_client); + void OnRequestResourceWithMojo( + ResourceRequesterInfo* requester_info, + int routing_id, + int request_id, + const ResourceRequest& request, + mojom::URLLoaderAssociatedRequest mojo_request, + mojom::URLLoaderClientPtr url_loader_client, + const net::NetworkTrafficAnnotationTag& traffic_annotation); void OnSyncLoadWithMojo(ResourceRequesterInfo* requester_info, int routing_id, @@ -530,17 +533,21 @@ const GlobalFrameRoutingId& global_routing_id, bool cancel_requests); - void OnRequestResource(ResourceRequesterInfo* requester_info, - int routing_id, - int request_id, - const ResourceRequest& request_data); + void OnRequestResource( + ResourceRequesterInfo* requester_info, + int routing_id, + int request_id, + const ResourceRequest& request_data, + net::MutableNetworkTrafficAnnotationTag traffic_annotation); - void OnRequestResourceInternal(ResourceRequesterInfo* requester_info, - int routing_id, - int request_id, - const ResourceRequest& request_data, - mojom::URLLoaderAssociatedRequest mojo_request, - mojom::URLLoaderClientPtr url_loader_client); + void OnRequestResourceInternal( + ResourceRequesterInfo* requester_info, + int routing_id, + int request_id, + const ResourceRequest& request_data, + mojom::URLLoaderAssociatedRequest mojo_request, + mojom::URLLoaderClientPtr url_loader_client, + const net::NetworkTrafficAnnotationTag& traffic_annotation); void OnSyncLoad(ResourceRequesterInfo* requester_info, int request_id, @@ -575,7 +582,8 @@ const SyncLoadResultCallback& sync_result_handler, // only valid for sync int route_id, mojom::URLLoaderAssociatedRequest mojo_request, - mojom::URLLoaderClientPtr url_loader_client); + mojom::URLLoaderClientPtr url_loader_client, + const net::NetworkTrafficAnnotationTag& traffic_annotation); // There are requests which need decisions to be made like the following: // Whether the presence of certain HTTP headers like the Origin header are @@ -595,6 +603,7 @@ mojom::URLLoaderAssociatedRequest mojo_request, mojom::URLLoaderClientPtr url_loader_client, BlobHandles blob_handles, + const net::NetworkTrafficAnnotationTag& traffic_annotation, HeaderInterceptorResult interceptor_result); // Creates a ResourceHandler to be used by BeginRequest() for normal resource
diff --git a/content/browser/loader/resource_dispatcher_host_unittest.cc b/content/browser/loader/resource_dispatcher_host_unittest.cc index 35ea64c..6587135 100644 --- a/content/browser/loader/resource_dispatcher_host_unittest.cc +++ b/content/browser/loader/resource_dispatcher_host_unittest.cc
@@ -1155,7 +1155,9 @@ ResourceType type) { ResourceRequest request = CreateResourceRequest("GET", type, url); request.render_frame_id = render_frame_id; - ResourceHostMsg_RequestResource msg(render_view_id, request_id, request); + ResourceHostMsg_RequestResource msg( + render_view_id, request_id, request, + net::MutableNetworkTrafficAnnotationTag(TRAFFIC_ANNOTATION_FOR_TESTS)); OnMessageReceived(msg, filter_.get()); KickOffRequest(); } @@ -1167,7 +1169,9 @@ const GURL& url, ResourceType type) { ResourceRequest request = CreateResourceRequest("GET", type, url); - ResourceHostMsg_RequestResource msg(render_view_id, request_id, request); + ResourceHostMsg_RequestResource msg( + render_view_id, request_id, request, + net::MutableNetworkTrafficAnnotationTag(TRAFFIC_ANNOTATION_FOR_TESTS)); OnMessageReceived(msg, filter); KickOffRequest(); } @@ -1187,7 +1191,8 @@ request.origin_pid = web_contents_->GetRenderProcessHost()->GetID(); request.render_frame_id = web_contents_->GetMainFrame()->GetRoutingID(); ResourceHostMsg_RequestResource msg( - web_contents_->GetRenderViewHost()->GetRoutingID(), request_id, request); + web_contents_->GetRenderViewHost()->GetRoutingID(), request_id, request, + net::MutableNetworkTrafficAnnotationTag(TRAFFIC_ANNOTATION_FOR_TESTS)); OnMessageReceived(msg, web_contents_filter_.get()); KickOffRequest(); } @@ -1209,7 +1214,9 @@ "GET", RESOURCE_TYPE_SUB_RESOURCE, GURL("http://example.com/priority")); request.render_frame_id = render_frame_id; request.priority = priority; - ResourceHostMsg_RequestResource msg(render_view_id, request_id, request); + ResourceHostMsg_RequestResource msg( + render_view_id, request_id, request, + net::MutableNetworkTrafficAnnotationTag(TRAFFIC_ANNOTATION_FOR_TESTS)); OnMessageReceived(msg, filter_.get()); } @@ -1435,7 +1442,9 @@ ResourceRequest request_to_cache = CreateResourceRequest( "GET", RESOURCE_TYPE_IMAGE, net::URLRequestTestJob::test_url_3()); request_to_cache.download_to_network_cache_only = true; - ResourceHostMsg_RequestResource msg_to_cache(0, 2, request_to_cache); + ResourceHostMsg_RequestResource msg_to_cache( + 0, 2, request_to_cache, + net::MutableNetworkTrafficAnnotationTag(TRAFFIC_ANNOTATION_FOR_TESTS)); OnMessageReceived(msg_to_cache, filter_.get()); KickOffRequest(); @@ -1578,9 +1587,13 @@ ResourceRequest request_ping = CreateResourceRequest( "GET", RESOURCE_TYPE_PING, net::URLRequestTestJob::test_url_3()); - ResourceHostMsg_RequestResource msg_prefetch(0, 1, request_prefetch); + ResourceHostMsg_RequestResource msg_prefetch( + 0, 1, request_prefetch, + net::MutableNetworkTrafficAnnotationTag(TRAFFIC_ANNOTATION_FOR_TESTS)); OnMessageReceived(msg_prefetch, filter_.get()); - ResourceHostMsg_RequestResource msg_ping(0, 2, request_ping); + ResourceHostMsg_RequestResource msg_ping( + 0, 2, request_ping, + net::MutableNetworkTrafficAnnotationTag(TRAFFIC_ANNOTATION_FOR_TESTS)); OnMessageReceived(msg_ping, filter_.get()); // Remove the filter before processing the requests by simulating channel @@ -1626,7 +1639,9 @@ "GET", RESOURCE_TYPE_PREFETCH, net::URLRequestTestJob::test_url_redirect_to_url_2()); - ResourceHostMsg_RequestResource msg(0, 1, request); + ResourceHostMsg_RequestResource msg( + 0, 1, request, + net::MutableNetworkTrafficAnnotationTag(TRAFFIC_ANNOTATION_FOR_TESTS)); OnMessageReceived(msg, filter_.get()); // Remove the filter before processing the request by simulating channel @@ -2736,7 +2751,8 @@ request.transferred_request_request_id = request_id; ResourceHostMsg_RequestResource transfer_request_msg( - new_render_view_id, new_request_id, request); + new_render_view_id, new_request_id, request, + net::MutableNetworkTrafficAnnotationTag(TRAFFIC_ANNOTATION_FOR_TESTS)); OnMessageReceived(transfer_request_msg, second_filter.get()); content::RunAllBlockingPoolTasksUntilIdle(); @@ -2805,7 +2821,8 @@ request.transferred_request_request_id = request_id; ResourceHostMsg_RequestResource transfer_request_msg( - new_render_view_id, new_request_id, request); + new_render_view_id, new_request_id, request, + net::MutableNetworkTrafficAnnotationTag(TRAFFIC_ANNOTATION_FOR_TESTS)); OnMessageReceived(transfer_request_msg, second_filter.get()); content::RunAllBlockingPoolTasksUntilIdle(); @@ -2817,7 +2834,8 @@ request.transferred_request_request_id = second_request_id; ResourceHostMsg_RequestResource second_transfer_request_msg( - new_render_view_id, new_second_request_id, second_request); + new_render_view_id, new_second_request_id, second_request, + net::MutableNetworkTrafficAnnotationTag(TRAFFIC_ANNOTATION_FOR_TESTS)); OnMessageReceived(second_transfer_request_msg, second_filter.get()); content::RunAllBlockingPoolTasksUntilIdle(); @@ -2887,7 +2905,8 @@ request.transferred_request_request_id = request_id; ResourceHostMsg_RequestResource transfer_request_msg( - new_render_view_id, new_request_id, request); + new_render_view_id, new_request_id, request, + net::MutableNetworkTrafficAnnotationTag(TRAFFIC_ANNOTATION_FOR_TESTS)); OnMessageReceived(transfer_request_msg, second_filter.get()); content::RunAllBlockingPoolTasksUntilIdle(); @@ -2933,7 +2952,8 @@ "GET", RESOURCE_TYPE_MAIN_FRAME, GURL("http://example.com/blah")); ResourceHostMsg_RequestResource first_request_msg( - render_view_id, request_id, first_request); + render_view_id, request_id, first_request, + net::MutableNetworkTrafficAnnotationTag(TRAFFIC_ANNOTATION_FOR_TESTS)); OnMessageReceived(first_request_msg, first_filter.get()); content::RunAllBlockingPoolTasksUntilIdle(); @@ -2971,7 +2991,8 @@ // For cleanup. child_ids_.insert(second_filter->child_id()); ResourceHostMsg_RequestResource transfer_request_msg( - new_render_view_id, new_request_id, request); + new_render_view_id, new_request_id, request, + net::MutableNetworkTrafficAnnotationTag(TRAFFIC_ANNOTATION_FOR_TESTS)); OnMessageReceived(transfer_request_msg, second_filter.get()); content::RunAllBlockingPoolTasksUntilIdle(); @@ -3048,7 +3069,8 @@ // For cleanup. child_ids_.insert(second_filter->child_id()); ResourceHostMsg_RequestResource transfer_request_msg( - new_render_view_id, new_request_id, request); + new_render_view_id, new_request_id, request, + net::MutableNetworkTrafficAnnotationTag(TRAFFIC_ANNOTATION_FOR_TESTS)); OnMessageReceived(transfer_request_msg, second_filter.get()); // Verify that we update the ResourceRequestInfo. @@ -3399,7 +3421,9 @@ ResourceRequest request = CreateResourceRequest( "GET", RESOURCE_TYPE_SUB_RESOURCE, net::URLRequestTestJob::test_url_1()); request.download_to_file = true; - ResourceHostMsg_RequestResource request_msg(0, 1, request); + ResourceHostMsg_RequestResource request_msg( + 0, 1, request, + net::MutableNetworkTrafficAnnotationTag(TRAFFIC_ANNOTATION_FOR_TESTS)); OnMessageReceived(request_msg, filter_.get()); // Running the message loop until idle does not work because
diff --git a/content/browser/loader/url_loader_factory_impl.cc b/content/browser/loader/url_loader_factory_impl.cc index 2de2e1f..1c761e5 100644 --- a/content/browser/loader/url_loader_factory_impl.cc +++ b/content/browser/loader/url_loader_factory_impl.cc
@@ -10,6 +10,7 @@ #include "content/public/common/resource_request.h" #include "content/public/common/url_loader.mojom.h" #include "mojo/public/cpp/bindings/strong_binding.h" +#include "net/traffic_annotation/network_traffic_annotation.h" namespace content { @@ -85,7 +86,7 @@ ResourceDispatcherHostImpl* rdh = ResourceDispatcherHostImpl::Get(); rdh->OnRequestResourceWithMojo(requester_info, routing_id, request_id, url_request, std::move(request), - std::move(client)); + std::move(client), traffic_annotation); } // static
diff --git a/content/browser/media/capture/desktop_capture_device.cc b/content/browser/media/capture/desktop_capture_device.cc index a38923b..5c82401e 100644 --- a/content/browser/media/capture/desktop_capture_device.cc +++ b/content/browser/media/capture/desktop_capture_device.cc
@@ -10,7 +10,6 @@ #include <utility> #include "base/bind.h" -#include "base/feature_list.h" #include "base/location.h" #include "base/logging.h" #include "base/macros.h" @@ -25,6 +24,7 @@ #include "build/build_config.h" #include "content/browser/media/capture/desktop_capture_device_uma_types.h" #include "content/public/browser/browser_thread.h" +#include "content/public/browser/desktop_capture.h" #include "content/public/browser/desktop_media_id.h" #include "content/public/common/content_switches.h" #include "content/public/common/service_manager_connection.h" @@ -79,11 +79,6 @@ } // namespace -#if defined(OS_WIN) -const base::Feature kDirectXCapturer{"DirectXCapturer", - base::FEATURE_ENABLED_BY_DEFAULT}; -#endif - class DesktopCaptureDevice::Core : public webrtc::DesktopCapturer::Callback { public: Core(scoped_refptr<base::SingleThreadTaskRunner> task_runner, @@ -401,20 +396,7 @@ // static std::unique_ptr<media::VideoCaptureDevice> DesktopCaptureDevice::Create( const DesktopMediaID& source) { - webrtc::DesktopCaptureOptions options = - webrtc::DesktopCaptureOptions::CreateDefault(); - // Leave desktop effects enabled during WebRTC captures. - options.set_disable_effects(false); - -#if defined(OS_WIN) - if (!base::FeatureList::IsEnabled(kDirectXCapturer)) { - options.set_allow_use_magnification_api(true); - } else { - options.set_allow_directx_capturer(true); - options.set_allow_use_magnification_api(false); - } -#endif - + auto options = CreateDesktopCaptureOptions(); std::unique_ptr<webrtc::DesktopCapturer> capturer; switch (source.type) {
diff --git a/content/browser/renderer_host/input/touch_selection_controller_client_manager_android.cc b/content/browser/renderer_host/input/touch_selection_controller_client_manager_android.cc new file mode 100644 index 0000000..c2b3251 --- /dev/null +++ b/content/browser/renderer_host/input/touch_selection_controller_client_manager_android.cc
@@ -0,0 +1,143 @@ +// Copyright 2017 The Chromium Authors. All rights reserved. +// Use of this source code is governed by a BSD-style license that can be +// found in the LICENSE file. + +#include "content/browser/renderer_host/input/touch_selection_controller_client_manager_android.h" + +#include "content/browser/renderer_host/render_widget_host_view_android.h" + +namespace content { + +TouchSelectionControllerClientManagerAndroid:: + TouchSelectionControllerClientManagerAndroid( + RenderWidgetHostViewAndroid* rwhv) + : rwhv_(rwhv), active_client_(rwhv), page_scale_factor_(1.f) { + DCHECK(rwhv_); +} + +TouchSelectionControllerClientManagerAndroid:: + ~TouchSelectionControllerClientManagerAndroid() { + for (auto& observer : observers_) + observer.OnManagerWillDestroy(this); +} + +void TouchSelectionControllerClientManagerAndroid::SetPageScaleFactor( + float page_scale_factor) { + page_scale_factor_ = page_scale_factor; +} + +namespace { + +gfx::SelectionBound ScaleSelectionBound(const gfx::SelectionBound& bound, + float scale) { + gfx::SelectionBound scaled_bound; + gfx::PointF scaled_top = bound.edge_top(); + scaled_top.Scale(scale); + gfx::PointF scaled_bottom = bound.edge_bottom(); + scaled_bottom.Scale(scale); + scaled_bound.SetEdge(scaled_top, scaled_bottom); + scaled_bound.set_type(bound.type()); + scaled_bound.set_visible(bound.visible()); + return scaled_bound; +} +} // namespace + +// TouchSelectionControllerClientManager implementation. +void TouchSelectionControllerClientManagerAndroid::UpdateClientSelectionBounds( + const gfx::SelectionBound& start, + const gfx::SelectionBound& end, + ui::TouchSelectionControllerClient* client, + ui::TouchSelectionMenuClient* menu_client) { + if (client != active_client_ && + (start.type() == gfx::SelectionBound::EMPTY || !start.visible()) && + (end.type() == gfx::SelectionBound::EMPTY || !end.visible()) && + (manager_selection_start_.type() != gfx::SelectionBound::EMPTY || + manager_selection_end_.type() != gfx::SelectionBound::EMPTY)) { + return; + } + + active_client_ = client; + if (active_client_ != rwhv_) { + manager_selection_start_ = ScaleSelectionBound(start, page_scale_factor_); + manager_selection_end_ = ScaleSelectionBound(end, page_scale_factor_); + } else { + manager_selection_start_ = start; + manager_selection_end_ = end; + } + // Notify TouchSelectionController if anything should change here. Only + // update if the client is different and not making a change to empty, or + // is the same client. + GetTouchSelectionController()->OnSelectionBoundsChanged( + manager_selection_start_, manager_selection_end_); +} + +void TouchSelectionControllerClientManagerAndroid::InvalidateClient( + ui::TouchSelectionControllerClient* client) { + if (active_client_ == client) + active_client_ = rwhv_; +} + +ui::TouchSelectionController* +TouchSelectionControllerClientManagerAndroid::GetTouchSelectionController() { + return rwhv_->touch_selection_controller(); +} + +void TouchSelectionControllerClientManagerAndroid::AddObserver( + Observer* observer) { + observers_.AddObserver(observer); +} + +void TouchSelectionControllerClientManagerAndroid::RemoveObserver( + Observer* observer) { + observers_.RemoveObserver(observer); +} + +// TouchSelectionControllerClient implementation. +bool TouchSelectionControllerClientManagerAndroid::SupportsAnimation() const { + return rwhv_->SupportsAnimation(); +} + +void TouchSelectionControllerClientManagerAndroid::SetNeedsAnimate() { + rwhv_->SetNeedsAnimate(); +} + +void TouchSelectionControllerClientManagerAndroid::MoveCaret( + const gfx::PointF& position) { + gfx::PointF scaled_position = position; + if (active_client_ != rwhv_) + scaled_position.Scale(1 / page_scale_factor_); + active_client_->MoveCaret(scaled_position); +} + +void TouchSelectionControllerClientManagerAndroid::MoveRangeSelectionExtent( + const gfx::PointF& extent) { + gfx::PointF scaled_extent = extent; + if (active_client_ != rwhv_) + scaled_extent.Scale(1 / page_scale_factor_); + active_client_->MoveRangeSelectionExtent(scaled_extent); +} + +void TouchSelectionControllerClientManagerAndroid::SelectBetweenCoordinates( + const gfx::PointF& base, + const gfx::PointF& extent) { + gfx::PointF scaled_extent = extent; + gfx::PointF scaled_base = base; + if (active_client_ != rwhv_) { + scaled_extent.Scale(1 / page_scale_factor_); + scaled_base.Scale(1 / page_scale_factor_); + } + active_client_->SelectBetweenCoordinates(scaled_base, scaled_extent); +} + +void TouchSelectionControllerClientManagerAndroid::OnSelectionEvent( + ui::SelectionEventType event) { + // Always defer to the top-level RWHV TSC for this. + rwhv_->OnSelectionEvent(event); +} + +std::unique_ptr<ui::TouchHandleDrawable> +TouchSelectionControllerClientManagerAndroid::CreateDrawable() { + return rwhv_->CreateDrawable(); +} + +} // namespace content
diff --git a/content/browser/renderer_host/input/touch_selection_controller_client_manager_android.h b/content/browser/renderer_host/input/touch_selection_controller_client_manager_android.h new file mode 100644 index 0000000..ff406582 --- /dev/null +++ b/content/browser/renderer_host/input/touch_selection_controller_client_manager_android.h
@@ -0,0 +1,63 @@ +// Copyright 2017 The Chromium Authors. All rights reserved. +// Use of this source code is governed by a BSD-style license that can be +// found in the LICENSE file. + +#ifndef CONTENT_BROWSER_RENDERER_HOST_INPUT_TOUCH_SELECTION_CONTROLLER_CLIENT_MANAGER_ANDROID_H_ +#define CONTENT_BROWSER_RENDERER_HOST_INPUT_TOUCH_SELECTION_CONTROLLER_CLIENT_MANAGER_ANDROID_H_ + +#include "base/macros.h" +#include "base/observer_list.h" +#include "content/public/browser/touch_selection_controller_client_manager.h" +#include "ui/touch_selection/touch_selection_controller.h" + +namespace content { + +class RenderWidgetHostViewAndroid; + +class TouchSelectionControllerClientManagerAndroid + : public TouchSelectionControllerClientManager, + public ui::TouchSelectionControllerClient { + public: + explicit TouchSelectionControllerClientManagerAndroid( + RenderWidgetHostViewAndroid* rwhv); + ~TouchSelectionControllerClientManagerAndroid() override; + void SetPageScaleFactor(float page_scale_factor); + float page_scale_factor() { return page_scale_factor_; } + + // TouchSelectionControllerClientManager implementation. + void UpdateClientSelectionBounds( + const gfx::SelectionBound& start, + const gfx::SelectionBound& end, + ui::TouchSelectionControllerClient* client, + ui::TouchSelectionMenuClient* menu_client) override; + void InvalidateClient(ui::TouchSelectionControllerClient* client) override; + ui::TouchSelectionController* GetTouchSelectionController() override; + + void AddObserver(Observer* observer) override; + void RemoveObserver(Observer* observer) override; + + // TouchSelectionControllerClient implementation. + bool SupportsAnimation() const override; + void SetNeedsAnimate() override; + void MoveCaret(const gfx::PointF& position) override; + void MoveRangeSelectionExtent(const gfx::PointF& extent) override; + void SelectBetweenCoordinates(const gfx::PointF& base, + const gfx::PointF& extent) override; + void OnSelectionEvent(ui::SelectionEventType event) override; + std::unique_ptr<ui::TouchHandleDrawable> CreateDrawable() override; + + private: + RenderWidgetHostViewAndroid* rwhv_; + TouchSelectionControllerClient* active_client_; + float page_scale_factor_; + gfx::SelectionBound manager_selection_start_; + gfx::SelectionBound manager_selection_end_; + base::ObserverList<TouchSelectionControllerClientManager::Observer> + observers_; + + DISALLOW_COPY_AND_ASSIGN(TouchSelectionControllerClientManagerAndroid); +}; + +} // namespace content + +#endif // CONTENT_BROWSER_RENDERER_HOST_INPUT_TOUCH_SELECTION_CONTROLLER_CLIENT_MANAGER_ANDROID_H_
diff --git a/content/browser/renderer_host/render_widget_host_view_android.cc b/content/browser/renderer_host/render_widget_host_view_android.cc index 845d0f8d..c7406682 100644 --- a/content/browser/renderer_host/render_widget_host_view_android.cc +++ b/content/browser/renderer_host/render_widget_host_view_android.cc
@@ -55,6 +55,7 @@ #include "content/browser/renderer_host/frame_metadata_util.h" #include "content/browser/renderer_host/input/input_router.h" #include "content/browser/renderer_host/input/synthetic_gesture_target_android.h" +#include "content/browser/renderer_host/input/touch_selection_controller_client_manager_android.h" #include "content/browser/renderer_host/input/web_input_event_builders_android.h" #include "content/browser/renderer_host/render_process_host_impl.h" #include "content/browser/renderer_host/render_view_host_delegate_view.h" @@ -491,6 +492,8 @@ } host_->SetView(this); + touch_selection_controller_client_manager_ = + base::MakeUnique<TouchSelectionControllerClientManagerAndroid>(this); SetContentViewCore(content_view_core); CreateOverscrollControllerIfPossible(); @@ -1369,6 +1372,19 @@ event, GetSelectionRect(*touch_selection_controller_)); } +ui::TouchSelectionControllerClient* +RenderWidgetHostViewAndroid::GetSelectionControllerClientManagerForTesting() { + return touch_selection_controller_client_manager_.get(); +} + +void RenderWidgetHostViewAndroid::SetSelectionControllerClientForTesting( + std::unique_ptr<ui::TouchSelectionControllerClient> client) { + touch_selection_controller_client_for_test_.swap(client); + + touch_selection_controller_ = CreateSelectionController( + touch_selection_controller_client_for_test_.get(), content_view_core_); +} + std::unique_ptr<ui::TouchHandleDrawable> RenderWidgetHostViewAndroid::CreateDrawable() { DCHECK(content_view_core_); @@ -1457,8 +1473,12 @@ overscroll_controller_->OnFrameMetadataUpdated(frame_metadata); if (touch_selection_controller_) { - touch_selection_controller_->OnSelectionBoundsChanged( - frame_metadata.selection.start, frame_metadata.selection.end); + DCHECK(touch_selection_controller_client_manager_); + touch_selection_controller_client_manager_->UpdateClientSelectionBounds( + frame_metadata.selection.start, frame_metadata.selection.end, this, + nullptr); + touch_selection_controller_client_manager_->SetPageScaleFactor( + frame_metadata.page_scale_factor); // Set parameters for adaptive handle orientation. gfx::SizeF viewport_size(frame_metadata.scrollable_viewport_size); @@ -1667,6 +1687,8 @@ needs_animate |= overscroll_controller_->Animate( frame_time, content_view_core_->GetViewAndroid()->GetLayer()); } + // TODO(wjmaclean): Investigate how animation here does or doesn't affect + // an OOPIF client. if (touch_selection_controller_) needs_animate |= touch_selection_controller_->Animate(frame_time); return needs_animate; @@ -1713,33 +1735,6 @@ InputEventAckState RenderWidgetHostViewAndroid::FilterInputEvent( const blink::WebInputEvent& input_event) { - if (touch_selection_controller_ && - blink::WebInputEvent::IsGestureEventType(input_event.GetType())) { - const blink::WebGestureEvent& gesture_event = - static_cast<const blink::WebGestureEvent&>(input_event); - switch (gesture_event.GetType()) { - case blink::WebInputEvent::kGestureLongPress: - touch_selection_controller_->HandleLongPressEvent( - base::TimeTicks() + - base::TimeDelta::FromSecondsD(input_event.TimeStampSeconds()), - gfx::PointF(gesture_event.x, gesture_event.y)); - break; - - case blink::WebInputEvent::kGestureTap: - touch_selection_controller_->HandleTapEvent( - gfx::PointF(gesture_event.x, gesture_event.y), - gesture_event.data.tap.tap_count); - break; - - case blink::WebInputEvent::kGestureScrollBegin: - touch_selection_controller_->OnScrollBeginEvent(); - break; - - default: - break; - } - } - if (overscroll_controller_ && blink::WebInputEvent::IsGestureEventType(input_event.GetType()) && overscroll_controller_->WillHandleGestureEvent( @@ -1899,6 +1894,33 @@ if (!host_ || !host_->delegate()) return; + // We let the touch selection controller see gesture events here, since they + // may be routed and not make it to FilterInputEvent(). + if (touch_selection_controller_ && + event.source_device == + blink::WebGestureDevice::kWebGestureDeviceTouchscreen) { + switch (event.GetType()) { + case blink::WebInputEvent::kGestureLongPress: + touch_selection_controller_->HandleLongPressEvent( + base::TimeTicks() + + base::TimeDelta::FromSecondsD(event.TimeStampSeconds()), + gfx::PointF(event.x, event.y)); + break; + + case blink::WebInputEvent::kGestureTap: + touch_selection_controller_->HandleTapEvent( + gfx::PointF(event.x, event.y), event.data.tap.tap_count); + break; + + case blink::WebInputEvent::kGestureScrollBegin: + touch_selection_controller_->OnScrollBeginEvent(); + break; + + default: + break; + } + } + ui::LatencyInfo latency_info = ui::WebInputEventTraits::CreateLatencyInfoForWebGestureEvent(event); if (wheel_scroll_latching_enabled()) { @@ -2055,9 +2077,15 @@ if (resize) WasResized(); - if (!touch_selection_controller_) + if (!touch_selection_controller_) { + ui::TouchSelectionControllerClient* client = + touch_selection_controller_client_manager_.get(); + if (touch_selection_controller_client_for_test_) + client = touch_selection_controller_client_for_test_.get(); + touch_selection_controller_ = - CreateSelectionController(this, content_view_core_); + CreateSelectionController(client, content_view_core_); + } if (content_view_core_) CreateOverscrollControllerIfPossible(); @@ -2070,6 +2098,11 @@ } } +TouchSelectionControllerClientManager* +RenderWidgetHostViewAndroid::GetTouchSelectionControllerClientManager() { + return touch_selection_controller_client_manager_.get(); +} + bool RenderWidgetHostViewAndroid::OnTouchEvent( const ui::MotionEventAndroid& event, bool for_touch_handle) {
diff --git a/content/browser/renderer_host/render_widget_host_view_android.h b/content/browser/renderer_host/render_widget_host_view_android.h index df19e6808..c7c18a97 100644 --- a/content/browser/renderer_host/render_widget_host_view_android.h +++ b/content/browser/renderer_host/render_widget_host_view_android.h
@@ -56,6 +56,7 @@ class SelectionPopupController; class SynchronousCompositorHost; class SynchronousCompositorClient; +class TouchSelectionControllerClientManagerAndroid; class WebContentsAccessibilityAndroid; struct NativeWebKeyboardEvent; struct ContextMenuParams; @@ -95,6 +96,10 @@ void AddDestructionObserver(DestructionObserver* connector); void RemoveDestructionObserver(DestructionObserver* connector); + ui::TouchSelectionController* touch_selection_controller() { + return touch_selection_controller_.get(); + } + // RenderWidgetHostView implementation. bool OnMessageReceived(const IPC::Message& msg) override; void InitAsChild(gfx::NativeView parent_view) override; @@ -181,6 +186,8 @@ const gfx::Point& point, RenderWidgetHostViewBase* target_view, gfx::Point* transformed_point) override; + TouchSelectionControllerClientManager* + GetTouchSelectionControllerClientManager() override; // ui::ViewClient implementation. bool OnTouchEvent(const ui::MotionEventAndroid& m, @@ -305,6 +312,11 @@ // Exposed for tests. cc::SurfaceId SurfaceIdForTesting() const override; + ui::TouchSelectionControllerClient* + GetSelectionControllerClientManagerForTesting(); + void SetSelectionControllerClientForTesting( + std::unique_ptr<ui::TouchSelectionControllerClient> client); + private: void RunAckCallbacks(); @@ -414,6 +426,12 @@ // Manages selection handle rendering and manipulation. // This will always be NULL if |content_view_core_| is NULL. std::unique_ptr<ui::TouchSelectionController> touch_selection_controller_; + std::unique_ptr<ui::TouchSelectionControllerClient> + touch_selection_controller_client_for_test_; + // Keeps track of currently active touch selection controller clients (some + // may be representing out-of-process iframes). + std::unique_ptr<TouchSelectionControllerClientManagerAndroid> + touch_selection_controller_client_manager_; // Bounds to use if we have no backing ContentViewCore gfx::Rect default_bounds_;
diff --git a/content/browser/resources/media/client_renderer.js b/content/browser/resources/media/client_renderer.js index 3206ac9..3bdf538 100644 --- a/content/browser/resources/media/client_renderer.js +++ b/content/browser/resources/media/client_renderer.js
@@ -51,7 +51,7 @@ NO_PLAYERS_SELECTED: 'no-players-selected', NO_COMPONENTS_SELECTED: 'no-components-selected', SELECTABLE_BUTTON: 'selectable-button', - DESTRUCTED_PLAYER: 'destructed-player' + DESTRUCTED_PLAYER: 'destructed-player', }; function removeChildren(element) { @@ -60,7 +60,7 @@ } }; - function createSelectableButton(id, groupName, text, select_cb, + function createSelectableButton(id, groupName, buttonLabel, select_cb, isDestructed) { // For CSS styling. var radioButton = document.createElement('input'); @@ -69,12 +69,10 @@ radioButton.id = id; radioButton.name = groupName; - var buttonLabel = document.createElement('label'); buttonLabel.classList.add(ClientRenderer.Css_.SELECTABLE_BUTTON); if (isDestructed) buttonLabel.classList.add(ClientRenderer.Css_.DESTRUCTED_PLAYER); buttonLabel.setAttribute('for', radioButton.id); - buttonLabel.appendChild(document.createTextNode(text)); var fragment = document.createDocumentFragment(); fragment.appendChild(radioButton); @@ -177,14 +175,11 @@ this.drawProperties_(player.properties, this.playerPropertiesTable); this.drawLog_(); } - if (key === 'name' || key === 'url') { - this.redrawPlayerList_(players); - } - if (key === 'event' && value === 'WEBMEDIAPLAYER_DESTROYED') { + if (key === 'event' && value === 'WEBMEDIAPLAYER_DESTROYED') player.destructed = true; - document.querySelector( - "label.selectable-button[for='" + player.id + "']").classList.add( - ClientRenderer.Css_.DESTRUCTED_PLAYER); + if (['url', 'frame_url', 'frame_title', 'audio_codec_name', + 'video_codec_name', 'width', 'height', 'event'].includes(key)) { + this.redrawPlayerList_(players); } }, @@ -307,8 +302,10 @@ var button_cb = this.selectAudioComponent_.bind( this, componentType, id, components[id]); var friendlyName = this.getAudioComponentName_(componentType, id); + var label = document.createElement('label'); + label.appendChild(document.createTextNode(friendlyName)); li.appendChild(createSelectableButton( - id, buttonGroupName, friendlyName, button_cb)); + id, buttonGroupName, label, button_cb)); fragment.appendChild(li); } removeChildren(listElement); @@ -348,14 +345,53 @@ for (var id in players) { hasPlayers = true; var player = players[id]; - var usableName = player.properties.name || - player.properties.url || - 'Player ' + player.id; + var p = player.properties; + var label = document.createElement('label'); + + var name_text = p.url || 'Player ' + player.id; + var name_node = document.createElement('span'); + name_node.appendChild(document.createTextNode(name_text)); + name_node.className = 'player-name'; + label.appendChild(name_node); + + var frame = []; + if (p.frame_title) + frame.push(p.frame_title); + if (p.frame_url) + frame.push(p.frame_url); + var frame_text = frame.join(' - '); + if (frame_text) { + label.appendChild(document.createElement('br')); + var frame_node = document.createElement('span'); + frame_node.className = 'player-frame'; + frame_node.appendChild(document.createTextNode(frame_text)); + label.appendChild(frame_node); + } + + var desc = [] + if (p.width && p.height) + desc.push(p.width + 'x' + p.height); + if (p.video_codec_name) + desc.push(p.video_codec_name); + if (p.video_codec_name && p.audio_codec_name) + desc.push('+'); + if (p.audio_codec_name) + desc.push(p.audio_codec_name); + if (p.event) + desc.push('(' + p.event + ')'); + var desc_text = desc.join(' '); + if (desc_text) { + label.appendChild(document.createElement('br')); + var desc_node = document.createElement('span'); + desc_node.className = 'player-desc'; + desc_node.appendChild(document.createTextNode(desc_text)); + label.appendChild(desc_node); + } var li = document.createElement('li'); var button_cb = this.selectPlayer_.bind(this, player); li.appendChild(createSelectableButton( - id, buttonGroupName, usableName, button_cb, player.destructed)); + id, buttonGroupName, label, button_cb, player.destructed)); fragment.appendChild(li); } removeChildren(this.playerListElement);
diff --git a/content/browser/resources/media/media_internals.css b/content/browser/resources/media/media_internals.css index 372d2a8..72afd8c 100644 --- a/content/browser/resources/media/media_internals.css +++ b/content/browser/resources/media/media_internals.css
@@ -178,10 +178,15 @@ } label.selectable-button { - -webkit-appearance: button; -webkit-user-select: none; - padding: 2px 5px; - margin-bottom: 5px; + display: inline-block; + background: #BDF; + cursor: pointer; + border: solid 1px #999; + border-radius: 3px; + padding: 6px; + margin: 4px 0; + line-height: 1.4; } input.selectable-button { @@ -189,12 +194,25 @@ } input.selectable-button:checked + label.selectable-button { - background-color: #4AA9E4; - color: white; + background-color: #2196F3; + border-color: #666; + color: #FFF; +} + +input.selectable-button:hover + label.selectable-button { + border-color: #666; } label.destructed-player { - background-color: #E4854A; + background-color: #EEE; +} + +.player-name { + font-weight: bold; +} + +.player-frame { + font-style: italic; } .no-players-selected #players .property-wrapper,
diff --git a/content/browser/security_exploit_browsertest.cc b/content/browser/security_exploit_browsertest.cc index 35c121a..be38010 100644 --- a/content/browser/security_exploit_browsertest.cc +++ b/content/browser/security_exploit_browsertest.cc
@@ -46,6 +46,7 @@ #include "net/dns/mock_host_resolver.h" #include "net/test/embedded_test_server/embedded_test_server.h" #include "net/test/url_request/url_request_slow_download_job.h" +#include "net/traffic_annotation/network_traffic_annotation_test_helper.h" #include "third_party/WebKit/public/web/WebTriggeringEventInfo.h" using IPC::IpcSecurityTestUtil; @@ -163,11 +164,15 @@ IPC::IpcSecurityTestUtil::PwnMessageReceived( rfh->GetProcess()->GetChannel(), ResourceHostMsg_RequestResource(rfh->GetRoutingID(), - kRequestIdNotPreviouslyUsed, request)); + kRequestIdNotPreviouslyUsed, request, + net::MutableNetworkTrafficAnnotationTag( + TRAFFIC_ANNOTATION_FOR_TESTS))); IPC::IpcSecurityTestUtil::PwnMessageReceived( rfh->GetProcess()->GetChannel(), ResourceHostMsg_RequestResource(rfh->GetRoutingID(), - kRequestIdNotPreviouslyUsed, request)); + kRequestIdNotPreviouslyUsed, request, + net::MutableNetworkTrafficAnnotationTag( + TRAFFIC_ANNOTATION_FOR_TESTS))); process_killed.Wait(); } @@ -456,7 +461,9 @@ web_rfh->GetProcess()->GetChannel(), ResourceHostMsg_RequestResource(web_rfh->GetRoutingID(), kRequestIdNotPreviouslyUsed, - chrome_origin_msg)); + chrome_origin_msg, + net::MutableNetworkTrafficAnnotationTag( + TRAFFIC_ANNOTATION_FOR_TESTS))); web_process_killed.Wait(); } @@ -476,7 +483,9 @@ web_rfh->GetProcess()->GetChannel(), ResourceHostMsg_RequestResource(web_rfh->GetRoutingID(), kRequestIdNotPreviouslyUsed, - embedder_isolated_origin_msg)); + embedder_isolated_origin_msg, + net::MutableNetworkTrafficAnnotationTag( + TRAFFIC_ANNOTATION_FOR_TESTS))); web_process_killed.Wait(); } @@ -490,7 +499,9 @@ web_rfh->GetProcess()->GetChannel(), ResourceHostMsg_RequestResource(web_rfh->GetRoutingID(), kRequestIdNotPreviouslyUsed, - invalid_origin_msg)); + invalid_origin_msg, + net::MutableNetworkTrafficAnnotationTag( + TRAFFIC_ANNOTATION_FOR_TESTS))); web_process_killed.Wait(); } @@ -504,7 +515,9 @@ web_rfh->GetProcess()->GetChannel(), ResourceHostMsg_RequestResource(web_rfh->GetRoutingID(), kRequestIdNotPreviouslyUsed, - invalid_scheme_origin_msg)); + invalid_scheme_origin_msg, + net::MutableNetworkTrafficAnnotationTag( + TRAFFIC_ANNOTATION_FOR_TESTS))); web_process_killed.Wait(); } }
diff --git a/content/browser/service_worker/embedded_worker_instance.cc b/content/browser/service_worker/embedded_worker_instance.cc index f8df38c9..d64ee26 100644 --- a/content/browser/service_worker/embedded_worker_instance.cc +++ b/content/browser/service_worker/embedded_worker_instance.cc
@@ -238,8 +238,8 @@ DISALLOW_COPY_AND_ASSIGN(DevToolsProxy); }; -// A handle for a worker process managed by ServiceWorkerProcessManager on the -// UI thread. +// A handle for a renderer process managed by ServiceWorkerProcessManager on the +// UI thread. Lives on the IO thread. class EmbeddedWorkerInstance::WorkerProcessHandle { public: WorkerProcessHandle(const base::WeakPtr<ServiceWorkerContextCore>& context, @@ -250,12 +250,19 @@ embedded_worker_id_(embedded_worker_id), process_id_(process_id), is_new_process_(is_new_process) { + DCHECK_CURRENTLY_ON(BrowserThread::IO); DCHECK_NE(ChildProcessHost::kInvalidUniqueID, process_id_); } ~WorkerProcessHandle() { - if (context_) - context_->process_manager()->ReleaseWorkerProcess(embedded_worker_id_); + DCHECK_CURRENTLY_ON(BrowserThread::IO); + if (!context_) + return; + BrowserThread::PostTask( + BrowserThread::UI, FROM_HERE, + base::BindOnce(&ServiceWorkerProcessManager::ReleaseWorkerProcess, + context_->process_manager()->AsWeakPtr(), + embedded_worker_id_)); } int process_id() const { return process_id_; } @@ -290,6 +297,7 @@ is_installed_(false), started_during_browser_startup_(false), weak_factory_(this) { + DCHECK_CURRENTLY_ON(BrowserThread::IO); TRACE_EVENT_NESTABLE_ASYNC_BEGIN1("ServiceWorker", "EmbeddedWorkerInstance::Start", instance_, "Script", script_url.spec()); @@ -309,8 +317,11 @@ break; case ProcessAllocationState::ALLOCATING: // Abort half-baked process allocation on the UI thread. - instance_->context_->process_manager()->ReleaseWorkerProcess( - instance_->embedded_worker_id()); + BrowserThread::PostTask( + BrowserThread::UI, FROM_HERE, + base::BindOnce(&ServiceWorkerProcessManager::ReleaseWorkerProcess, + instance_->context_->process_manager()->AsWeakPtr(), + instance_->embedded_worker_id())); break; case ProcessAllocationState::ALLOCATED: // Otherwise, the process will be released by EmbeddedWorkerInstance. @@ -461,6 +472,7 @@ } EmbeddedWorkerInstance::~EmbeddedWorkerInstance() { + DCHECK_CURRENTLY_ON(BrowserThread::IO); DCHECK(status_ == EmbeddedWorkerStatus::STOPPING || status_ == EmbeddedWorkerStatus::STOPPED) << static_cast<int>(status_); @@ -584,7 +596,9 @@ instance_host_binding_(this), devtools_attached_(false), network_accessed_for_script_(false), - weak_factory_(this) {} + weak_factory_(this) { + DCHECK_CURRENTLY_ON(BrowserThread::IO); +} void EmbeddedWorkerInstance::OnProcessAllocated( std::unique_ptr<WorkerProcessHandle> handle,
diff --git a/content/browser/service_worker/embedded_worker_instance.h b/content/browser/service_worker/embedded_worker_instance.h index b99d435..f70c3fc4 100644 --- a/content/browser/service_worker/embedded_worker_instance.h +++ b/content/browser/service_worker/embedded_worker_instance.h
@@ -47,6 +47,8 @@ // This gives an interface to control one EmbeddedWorker instance, which // may be 'in-waiting' or running in one of the child processes added by // AddProcessReference(). +// +// Owned by ServiceWorkerVersion. Lives on the IO thread. class CONTENT_EXPORT EmbeddedWorkerInstance : NON_EXPORTED_BASE(public mojom::EmbeddedWorkerInstanceHost) { public:
diff --git a/content/browser/service_worker/service_worker_controllee_request_handler.cc b/content/browser/service_worker/service_worker_controllee_request_handler.cc index 61a3c55..6c679e73 100644 --- a/content/browser/service_worker/service_worker_controllee_request_handler.cc +++ b/content/browser/service_worker/service_worker_controllee_request_handler.cc
@@ -9,6 +9,7 @@ #include <string> #include "base/trace_event/trace_event.h" +#include "components/offline_pages/features/features.h" #include "content/browser/service_worker/service_worker_context_core.h" #include "content/browser/service_worker/service_worker_metrics.h" #include "content/browser/service_worker/service_worker_provider_host.h" @@ -30,6 +31,10 @@ #include "net/url_request/url_request.h" #include "ui/base/page_transition_types.h" +#if BUILDFLAG(ENABLE_OFFLINE_PAGES) +#include "components/offline_pages/core/request_header/offline_page_header.h" +#endif // BUILDFLAG(ENABLE_OFFLINE_PAGES) + namespace content { namespace { @@ -50,6 +55,26 @@ return false; } +#if BUILDFLAG(ENABLE_OFFLINE_PAGES) +// A web page, regardless of whether the service worker is used or not, could +// be downloaded with the offline snapshot captured. The user can then open +// the downloaded page which is identified by the presence of a specific +// offline header in the network request. In this case, we want to fall back +// in order for the subsequent offline page interceptor to bring up the +// offline snapshot of the page. +bool ShouldFallbackToLoadOfflinePage( + const net::HttpRequestHeaders& extra_request_headers) { + std::string offline_header_value; + if (!extra_request_headers.GetHeader(offline_pages::kOfflinePageHeader, + &offline_header_value)) { + return false; + } + offline_pages::OfflinePageHeader offline_header(offline_header_value); + return offline_header.reason == + offline_pages::OfflinePageHeader::Reason::DOWNLOAD; +} +#endif // BUILDFLAG(ENABLE_OFFLINE_PAGES) + } // namespace ServiceWorkerControlleeRequestHandler::ServiceWorkerControlleeRequestHandler( @@ -124,6 +149,13 @@ return NULL; } +#if BUILDFLAG(ENABLE_OFFLINE_PAGES) + // Fall back for the subsequent offline page interceptor to load the offline + // snapshot of the page if required. + if (ShouldFallbackToLoadOfflinePage(request->extra_request_headers())) + return nullptr; +#endif // BUILDFLAG(ENABLE_OFFLINE_PAGES) + // It's for original request (A) or redirect case (B-a or B-b). std::unique_ptr<ServiceWorkerURLRequestJob> job( new ServiceWorkerURLRequestJob( @@ -176,6 +208,17 @@ // never see use_network_ gets true. DCHECK(!use_network_); +#if BUILDFLAG(ENABLE_OFFLINE_PAGES) + // Fall back for the subsequent offline page interceptor to load the offline + // snapshot of the page if required. + net::HttpRequestHeaders extra_request_headers; + extra_request_headers.AddHeadersFromString(resource_request.headers); + if (ShouldFallbackToLoadOfflinePage(extra_request_headers)) { + std::move(callback).Run(StartLoaderCallback()); + return; + } +#endif // BUILDFLAG(ENABLE_OFFLINE_PAGES) + url_job_ = base::MakeUnique<ServiceWorkerURLJobWrapper>( base::MakeUnique<ServiceWorkerURLLoaderJob>( std::move(callback), this, resource_request, blob_storage_context_));
diff --git a/content/browser/service_worker/service_worker_controllee_request_handler_unittest.cc b/content/browser/service_worker/service_worker_controllee_request_handler_unittest.cc index fd10726..5c6f391 100644 --- a/content/browser/service_worker/service_worker_controllee_request_handler_unittest.cc +++ b/content/browser/service_worker/service_worker_controllee_request_handler_unittest.cc
@@ -11,6 +11,7 @@ #include "base/files/scoped_temp_dir.h" #include "base/logging.h" #include "base/run_loop.h" +#include "components/offline_pages/features/features.h" #include "content/browser/browser_thread_impl.h" #include "content/browser/service_worker/embedded_worker_test_helper.h" #include "content/browser/service_worker/service_worker_context_core.h" @@ -78,6 +79,8 @@ void ResetHandler() { handler_.reset(nullptr); } + net::URLRequest* request() const { return request_.get(); } + private: ServiceWorkerControlleeRequestHandlerTest* test_; std::unique_ptr<net::URLRequest> request_; @@ -378,4 +381,50 @@ EXPECT_FALSE(sub_cors_job->ShouldForwardToServiceWorker()); } +#if BUILDFLAG(ENABLE_OFFLINE_PAGES) +TEST_F(ServiceWorkerControlleeRequestHandlerTest, FallbackWithOfflineHeader) { + version_->set_fetch_handler_existence( + ServiceWorkerVersion::FetchHandlerExistence::EXISTS); + version_->SetStatus(ServiceWorkerVersion::ACTIVATED); + registration_->SetActiveVersion(version_); + context()->storage()->StoreRegistration( + registration_.get(), version_.get(), + base::Bind(&ServiceWorkerUtils::NoOpStatusCallback)); + base::RunLoop().RunUntilIdle(); + version_ = NULL; + registration_ = NULL; + + ServiceWorkerRequestTestResources test_resources( + this, GURL("https://host/scope/doc"), RESOURCE_TYPE_MAIN_FRAME); + // Sets an offline header to indicate force loading offline page. + test_resources.request()->SetExtraRequestHeaderByName( + "X-Chrome-offline", "reason=download", true); + ServiceWorkerURLRequestJob* sw_job = test_resources.MaybeCreateJob(); + + EXPECT_FALSE(sw_job); +} + +TEST_F(ServiceWorkerControlleeRequestHandlerTest, FallbackWithNoOfflineHeader) { + version_->set_fetch_handler_existence( + ServiceWorkerVersion::FetchHandlerExistence::EXISTS); + version_->SetStatus(ServiceWorkerVersion::ACTIVATED); + registration_->SetActiveVersion(version_); + context()->storage()->StoreRegistration( + registration_.get(), version_.get(), + base::Bind(&ServiceWorkerUtils::NoOpStatusCallback)); + base::RunLoop().RunUntilIdle(); + version_ = NULL; + registration_ = NULL; + + ServiceWorkerRequestTestResources test_resources( + this, GURL("https://host/scope/doc"), RESOURCE_TYPE_MAIN_FRAME); + // Empty offline header value should not cause fallback. + test_resources.request()->SetExtraRequestHeaderByName("X-Chrome-offline", "", + true); + ServiceWorkerURLRequestJob* sw_job = test_resources.MaybeCreateJob(); + + EXPECT_TRUE(sw_job); +} +#endif // BUILDFLAG(ENABLE_OFFLINE_PAGE + } // namespace content
diff --git a/content/browser/service_worker/service_worker_process_manager.cc b/content/browser/service_worker/service_worker_process_manager.cc index 4cf0da9..48d2547 100644 --- a/content/browser/service_worker/service_worker_process_manager.cc +++ b/content/browser/service_worker/service_worker_process_manager.cc
@@ -237,16 +237,7 @@ } void ServiceWorkerProcessManager::ReleaseWorkerProcess(int embedded_worker_id) { - if (!BrowserThread::CurrentlyOn(BrowserThread::UI)) { - BrowserThread::PostTask( - BrowserThread::UI, - FROM_HERE, - base::Bind(&ServiceWorkerProcessManager::ReleaseWorkerProcess, - weak_this_, - embedded_worker_id)); - return; - } - + DCHECK_CURRENTLY_ON(BrowserThread::UI); if (process_id_for_test_ != ChildProcessHost::kInvalidUniqueID) { // Unittests don't increment or decrement the worker refcount of a // RenderProcessHost. @@ -267,7 +258,7 @@ if (info == instance_info_.end()) return; - RenderProcessHost* rph = NULL; + RenderProcessHost* rph = nullptr; if (info->second.site_instance.get()) { rph = info->second.site_instance->GetProcess(); DCHECK_EQ(info->second.process_id, rph->GetID())
diff --git a/content/browser/service_worker/service_worker_process_manager.h b/content/browser/service_worker/service_worker_process_manager.h index 606164f..6c86d491 100644 --- a/content/browser/service_worker/service_worker_process_manager.h +++ b/content/browser/service_worker/service_worker_process_manager.h
@@ -60,9 +60,11 @@ // Returns a reference to a running process suitable for starting the service // worker described by |emdedded_worker_id|, |pattern|, and |script_url|. // - // AllocateWorkerProcess() tries to return an existing process. If one is not - // available, or |can_use_existing_process| is false, it will create a new - // one. + // AllocateWorkerProcess() tries to return a process that already exists in + // this ServiceWorkerProcessManager's map of processes, populated via + // AddProcessReferenceToPattern(). If one is not found, or + // |can_use_existing_process| is false, it will instead use SiteInstance to + // get a process, possibly creating a new one. // // If SERVICE_WORKER_OK is returned, |out_info| contains information about the // process. @@ -79,6 +81,8 @@ // Drops a reference to a process that was running a Service Worker, and its // SiteInstance. This must match a call to AllocateWorkerProcess. + // + // Called on the UI thread. void ReleaseWorkerProcess(int embedded_worker_id); // Sets a single process ID that will be used for all embedded workers. This
diff --git a/content/browser/site_per_process_browsertest.cc b/content/browser/site_per_process_browsertest.cc index 24a2536..ef3341d9b 100644 --- a/content/browser/site_per_process_browsertest.cc +++ b/content/browser/site_per_process_browsertest.cc
@@ -111,8 +111,11 @@ #include "base/android/jni_android.h" #include "base/android/jni_string.h" #include "base/android/scoped_java_ref.h" +#include "base/json/json_reader.h" #include "content/browser/android/ime_adapter_android.h" +#include "content/browser/renderer_host/input/touch_selection_controller_client_manager_android.h" #include "content/browser/renderer_host/render_widget_host_view_android.h" +#include "ui/gfx/geometry/point_f.h" #endif using ::testing::SizeIs; @@ -10487,4 +10490,306 @@ ->GetProcess()); } +#if defined(OS_ANDROID) +// Tests for Android TouchSelectionEditing. +class TouchSelectionControllerClientAndroidSiteIsolationTest + : public SitePerProcessBrowserTest { + public: + TouchSelectionControllerClientAndroidSiteIsolationTest() {} + + void SetUpCommandLine(base::CommandLine* command_line) override { + IsolateAllSitesForTesting(command_line); + } + + RenderWidgetHostViewAndroid* GetRenderWidgetHostViewAndroid() { + return static_cast<RenderWidgetHostViewAndroid*>( + shell()->web_contents()->GetRenderWidgetHostView()); + } + + void SelectWithLongPress(gfx::Point point) { + // Get main frame view for event insertion. + RenderWidgetHostViewAndroid* main_view = GetRenderWidgetHostViewAndroid(); + + SendTouch(main_view, ui::MotionEvent::ACTION_DOWN, point); + // action_timeout() is far longer than needed for a LongPress, so we use + // a custom timeout here. + DelayBy(base::TimeDelta::FromMilliseconds(2000)); + SendTouch(main_view, ui::MotionEvent::ACTION_UP, point); + } + + void SimpleTap(gfx::Point point) { + // Get main frame view for event insertion. + RenderWidgetHostViewAndroid* main_view = GetRenderWidgetHostViewAndroid(); + + SendTouch(main_view, ui::MotionEvent::ACTION_DOWN, point); + // tiny_timeout() is way shorter than a reasonable user-created tap gesture, + // so we use a custom timeout here. + DelayBy(base::TimeDelta::FromMilliseconds(300)); + SendTouch(main_view, ui::MotionEvent::ACTION_UP, point); + } + + protected: + void DelayBy(base::TimeDelta delta) { + base::RunLoop run_loop; + base::ThreadTaskRunnerHandle::Get()->PostDelayedTask( + FROM_HERE, run_loop.QuitClosure(), delta); + run_loop.Run(); + } + + private: + void SendTouch(RenderWidgetHostViewAndroid* view, + ui::MotionEvent::Action action, + gfx::Point point) { + DCHECK(action >= ui::MotionEvent::ACTION_DOWN && + action << ui::MotionEvent::ACTION_CANCEL); + ui::MotionEventGeneric touch( + action, ui::EventTimeForNow(), + ui::PointerProperties(point.x(), point.y(), 10)); + view->OnTouchEvent(touch); + } +}; + +class FrameStableObserver { + public: + FrameStableObserver(RenderWidgetHostViewBase* view, base::TimeDelta delta) + : view_(view), delta_(delta) {} + virtual ~FrameStableObserver() {} + + void WaitUntilStable() { + uint32_t current_frame_number = view_->RendererFrameNumber(); + uint32_t previous_frame_number; + + do { + base::RunLoop run_loop; + base::ThreadTaskRunnerHandle::Get()->PostDelayedTask( + FROM_HERE, run_loop.QuitClosure(), delta_); + run_loop.Run(); + previous_frame_number = current_frame_number; + current_frame_number = view_->RendererFrameNumber(); + } while (current_frame_number != previous_frame_number); + } + + private: + RenderWidgetHostViewBase* view_; + base::TimeDelta delta_; + + DISALLOW_COPY_AND_ASSIGN(FrameStableObserver); +}; + +class TouchSelectionControllerClientTestWrapper + : public ui::TouchSelectionControllerClient { + public: + explicit TouchSelectionControllerClientTestWrapper( + ui::TouchSelectionControllerClient* client) + : expected_event_(ui::SELECTION_HANDLES_SHOWN), client_(client) {} + + ~TouchSelectionControllerClientTestWrapper() override {} + + void InitWaitForSelectionEvent(ui::SelectionEventType expected_event) { + DCHECK(!run_loop_); + expected_event_ = expected_event; + run_loop_.reset(new base::RunLoop()); + } + + void Wait() { + DCHECK(run_loop_); + run_loop_->Run(); + run_loop_.reset(); + } + + private: + // TouchSelectionControllerClient: + void OnSelectionEvent(ui::SelectionEventType event) override { + client_->OnSelectionEvent(event); + if (run_loop_ && event == expected_event_) + run_loop_->Quit(); + } + + bool SupportsAnimation() const override { + return client_->SupportsAnimation(); + } + + void SetNeedsAnimate() override { client_->SetNeedsAnimate(); } + + void MoveCaret(const gfx::PointF& position) override { + client_->MoveCaret(position); + } + + void MoveRangeSelectionExtent(const gfx::PointF& extent) override { + client_->MoveRangeSelectionExtent(extent); + } + + void SelectBetweenCoordinates(const gfx::PointF& base, + const gfx::PointF& extent) override { + client_->SelectBetweenCoordinates(base, extent); + } + + std::unique_ptr<ui::TouchHandleDrawable> CreateDrawable() override { + return client_->CreateDrawable(); + } + + ui::SelectionEventType expected_event_; + std::unique_ptr<base::RunLoop> run_loop_; + // Not owned. + ui::TouchSelectionControllerClient* client_; + + DISALLOW_COPY_AND_ASSIGN(TouchSelectionControllerClientTestWrapper); +}; + +namespace { + +bool ConvertJSONToPoint(const std::string& str, gfx::PointF* point) { + std::unique_ptr<base::Value> value = base::JSONReader::Read(str); + if (!value) + return false; + base::DictionaryValue* root; + if (!value->GetAsDictionary(&root)) + return false; + double x, y; + if (!root->GetDouble("x", &x)) + return false; + if (!root->GetDouble("y", &y)) + return false; + point->set_x(x); + point->set_y(y); + return true; +} + +} // namespace + +IN_PROC_BROWSER_TEST_F(TouchSelectionControllerClientAndroidSiteIsolationTest, + BasicSelectionIsolatedIframe) { + GURL test_url(embedded_test_server()->GetURL( + "a.com", "/cross_site_iframe_factory.html?a(a)")); + EXPECT_TRUE(NavigateToURL(shell(), test_url)); + FrameTreeNode* root = static_cast<WebContentsImpl*>(shell()->web_contents()) + ->GetFrameTree() + ->root(); + EXPECT_EQ( + " Site A\n" + " +--Site A\n" + "Where A = http://a.com/", + FrameTreeVisualizer().DepictFrameTree(root)); + TestNavigationObserver observer(shell()->web_contents()); + EXPECT_EQ(1u, root->child_count()); + FrameTreeNode* child = root->child_at(0); + + RenderWidgetHostViewAndroid* parent_view = + static_cast<RenderWidgetHostViewAndroid*>( + root->current_frame_host()->GetRenderWidgetHost()->GetView()); + TouchSelectionControllerClientTestWrapper* selection_controller_client = + new TouchSelectionControllerClientTestWrapper( + parent_view->GetSelectionControllerClientManagerForTesting()); + parent_view->SetSelectionControllerClientForTesting( + base::WrapUnique(selection_controller_client)); + + // We need to load the desired subframe and then wait until it's stable, i.e. + // generates no new compositor frames for some reasonable time period: a stray + // frame between touch selection's pre-handling of GestureLongPress and the + // expected frame containing the selected region can confuse the + // TouchSelectionController, causing it to fail to show selection handles. + // Note this is an issue with the TouchSelectionController in general, and + // not a property of this test. + GURL child_url( + embedded_test_server()->GetURL("b.com", "/touch_selection.html")); + NavigateFrameToURL(child, child_url); + EXPECT_EQ( + " Site A ------------ proxies for B\n" + " +--Site B ------- proxies for A\n" + "Where A = http://a.com/\n" + " B = http://b.com/", + FrameTreeVisualizer().DepictFrameTree(root)); + // The child will change with the cross-site navigation. It shouldn't change + // after this. + child = root->child_at(0); + WaitForChildFrameSurfaceReady(child->current_frame_host()); + + RenderWidgetHostViewChildFrame* child_view = + static_cast<RenderWidgetHostViewChildFrame*>( + child->current_frame_host()->GetRenderWidgetHost()->GetView()); + + EXPECT_EQ(child_url, observer.last_navigation_url()); + EXPECT_TRUE(observer.last_navigation_succeeded()); + FrameStableObserver child_frame_stable_observer(child_view, + TestTimeouts::tiny_timeout()); + child_frame_stable_observer.WaitUntilStable(); + + EXPECT_EQ(ui::TouchSelectionController::INACTIVE, + parent_view->touch_selection_controller()->active_status()); + // Find the location of some text to select. + auto* manager = static_cast<TouchSelectionControllerClientManagerAndroid*>( + parent_view->GetTouchSelectionControllerClientManager()); + float page_scale_factor = manager->page_scale_factor(); + gfx::PointF point_f; + std::string str; + EXPECT_TRUE(ExecuteScriptAndExtractString(child->current_frame_host(), + "get_point_inside_text()", &str)); + ConvertJSONToPoint(str, &point_f); + gfx::Point origin = child_view->GetViewOriginInRoot(); + gfx::Vector2dF origin_vec(origin.x(), origin.y()); + point_f += origin_vec; + point_f.Scale(page_scale_factor); + + // Initiate selection with a sequence of events that go through the targeting + // system. + selection_controller_client->InitWaitForSelectionEvent( + ui::SELECTION_HANDLES_SHOWN); + + SelectWithLongPress(gfx::Point(point_f.x(), point_f.y())); + + selection_controller_client->Wait(); + + // Check that selection is active and the quick menu is showing. + EXPECT_EQ(ui::TouchSelectionController::SELECTION_ACTIVE, + parent_view->touch_selection_controller()->active_status()); + + // Tap inside/outside the iframe and make sure the selection handles go away. + selection_controller_client->InitWaitForSelectionEvent( + ui::SELECTION_HANDLES_CLEARED); + // Since Android tests may run with page_scale_factor < 1, use an offset a + // bigger than +/-1 for doing the inside/outside taps to cancel the selection + // handles. + gfx::PointF point_inside_iframe = gfx::PointF(+5.f, +5.f) + origin_vec; + point_inside_iframe.Scale(page_scale_factor); + SimpleTap(gfx::Point(point_inside_iframe.x(), point_inside_iframe.y())); + selection_controller_client->Wait(); + + EXPECT_EQ(ui::TouchSelectionController::INACTIVE, + parent_view->touch_selection_controller()->active_status()); + + // Let's wait for the previous events to clear the round-trip to the renders + // and back. + DelayBy(base::TimeDelta::FromMilliseconds(2000)); + + // Initiate selection with a sequence of events that go through the targeting + // system. Repeat of above but this time we'l cancel the selection by + // tapping outside of the OOPIF. + selection_controller_client->InitWaitForSelectionEvent( + ui::SELECTION_HANDLES_SHOWN); + + SelectWithLongPress(gfx::Point(point_f.x(), point_f.y())); + + selection_controller_client->Wait(); + + // Check that selection is active and the quick menu is showing. + EXPECT_EQ(ui::TouchSelectionController::SELECTION_ACTIVE, + parent_view->touch_selection_controller()->active_status()); + + // Tap inside/outside the iframe and make sure the selection handles go away. + selection_controller_client->InitWaitForSelectionEvent( + ui::SELECTION_HANDLES_CLEARED); + // Since Android tests may run with page_scale_factor < 1, use an offset a + // bigger than +/-1 for doing the inside/outside taps to cancel the selection + // handles. + gfx::PointF point_outside_iframe = gfx::PointF(-5.f, -5.f) + origin_vec; + point_outside_iframe.Scale(page_scale_factor); + SimpleTap(gfx::Point(point_outside_iframe.x(), point_outside_iframe.y())); + selection_controller_client->Wait(); + + EXPECT_EQ(ui::TouchSelectionController::INACTIVE, + parent_view->touch_selection_controller()->active_status()); +} + +#endif // defined(OS_ANDROID) + } // namespace content
diff --git a/content/browser/storage_partition_impl.cc b/content/browser/storage_partition_impl.cc index 4ff9f579..c50b6ef 100644 --- a/content/browser/storage_partition_impl.cc +++ b/content/browser/storage_partition_impl.cc
@@ -5,6 +5,7 @@ #include "content/browser/storage_partition_impl.h" #include <stddef.h> +#include <stdint.h> #include <set> #include <vector> @@ -64,7 +65,7 @@ return cookie.IsHostCookie() && cookie.IsDomainMatch(host); } -void OnClearedCookies(const base::Closure& callback, int num_deleted) { +void OnClearedCookies(const base::Closure& callback, uint32_t num_deleted) { // The final callback needs to happen from UI thread. if (!BrowserThread::CurrentlyOn(BrowserThread::UI)) { BrowserThread::PostTask(
diff --git a/content/browser/webrtc/webrtc_capture_from_element_browsertest.cc b/content/browser/webrtc/webrtc_capture_from_element_browsertest.cc index f9da9d08..008ee47f 100644 --- a/content/browser/webrtc/webrtc_capture_from_element_browsertest.cc +++ b/content/browser/webrtc/webrtc_capture_from_element_browsertest.cc
@@ -4,6 +4,7 @@ #include "base/command_line.h" #include "base/strings/stringprintf.h" +#include "build/build_config.h" #include "content/browser/webrtc/webrtc_content_browsertest_base.h" #include "content/public/common/content_switches.h" #include "media/base/media_switches.h" @@ -101,8 +102,15 @@ MakeTypicalCall("testCanvasCapture(drawWebGL);", kCanvasCaptureTestHtmlFile); } +#if defined(OS_LINUX) +#define MAYBE_VerifyCanvasCaptureOffscreenCanvasCommitFrames \ + DISABLED_VerifyCanvasCaptureOffscreenCanvasCommitFrames +#else +#define MAYBE_VerifyCanvasCaptureOffscreenCanvasCommitFrames \ + VerifyCanvasCaptureOffscreenCanvasCommitFrames +#endif IN_PROC_BROWSER_TEST_F(WebRtcCaptureFromElementBrowserTest, - VerifyCanvasCaptureOffscreenCanvasCommitFrames) { + MAYBE_VerifyCanvasCaptureOffscreenCanvasCommitFrames) { MakeTypicalCall("testCanvasCapture(drawOffscreenCanvasCommit);", kCanvasCaptureTestHtmlFile); }
diff --git a/content/browser/webrtc/webrtc_eventlog_host_unittest.cc b/content/browser/webrtc/webrtc_eventlog_host_unittest.cc index a9659cb8..776c80d 100644 --- a/content/browser/webrtc/webrtc_eventlog_host_unittest.cc +++ b/content/browser/webrtc/webrtc_eventlog_host_unittest.cc
@@ -189,7 +189,7 @@ // maximum allowed number of IPC messages and log files will be opened, but we // expect the number of stop IPC messages to be equal to the actual number of // PeerConnections. -TEST_F(WebRtcEventlogHostTest, ExceedMaxPeerConnectionsTest) { +TEST_F(WebRtcEventlogHostTest, DISABLED_ExceedMaxPeerConnectionsTest) { #if defined(OS_ANDROID) const int kMaxNumberLogFiles = 3; #else
diff --git a/content/child/resource_dispatcher.cc b/content/child/resource_dispatcher.cc index 4d724c1..a0b9c47 100644 --- a/content/child/resource_dispatcher.cc +++ b/content/child/resource_dispatcher.cc
@@ -662,6 +662,30 @@ return request_id; } + net::NetworkTrafficAnnotationTag traffic_annotation = + net::DefineNetworkTrafficAnnotation("blink_resource_loader", R"( + semantics { + sender: "Blink Resource Loader" + description: + "Blink initiated request, which includes all resources for " + "normal page loads, chrome URLs, resources for installed " + "extensions, as well as downloads." + trigger: + "Navigating to a URL or downloading a file. A webpage, " + "ServiceWorker, chrome:// page, or extension may also initiate " + "requests in the background." + data: "Anything the initiator wants to send." + destination: OTHER + } + policy { + cookies_allowed: true + cookies_store: "user" + setting: "These requests cannot be disabled in settings." + policy_exception_justification: + "Not implemented. Without these requests, Chrome will be unable " + "to load any webpage." + })"); + if (ipc_type == blink::WebURLRequest::LoadingIPCType::kMojo) { scoped_refptr<base::SingleThreadTaskRunner> task_runner = loading_task_runner ? loading_task_runner : thread_task_runner_; @@ -671,12 +695,13 @@ ThrottlingURLLoader::CreateLoaderAndStart( url_loader_factory, std::move(throttles), routing_id, request_id, mojom::kURLLoadOptionNone, *request, client.get(), - NO_TRAFFIC_ANNOTATION_YET, std::move(task_runner)); + traffic_annotation, std::move(task_runner)); pending_requests_[request_id]->url_loader = std::move(url_loader); pending_requests_[request_id]->url_loader_client = std::move(client); } else { - message_sender_->Send( - new ResourceHostMsg_RequestResource(routing_id, request_id, *request)); + message_sender_->Send(new ResourceHostMsg_RequestResource( + routing_id, request_id, *request, + net::MutableNetworkTrafficAnnotationTag(traffic_annotation))); } return request_id;
diff --git a/content/child/runtime_features.cc b/content/child/runtime_features.cc index d80a199..8affb3fe 100644 --- a/content/child/runtime_features.cc +++ b/content/child/runtime_features.cc
@@ -9,6 +9,7 @@ #include "base/command_line.h" #include "base/feature_list.h" #include "base/metrics/field_trial.h" +#include "base/metrics/field_trial_params.h" #include "base/strings/string_split.h" #include "base/strings/string_util.h" #include "build/build_config.h" @@ -390,6 +391,10 @@ WebRuntimeFeatures::EnableModuleScripts( base::FeatureList::IsEnabled(features::kModuleScripts)); + WebRuntimeFeatures::EnableClientPlaceholdersForServerLoFi( + base::GetFieldTrialParamValue("PreviewsClientLoFi", + "replace_server_placeholders") == "true"); + // Enable explicitly enabled features, and then disable explicitly disabled // ones. if (command_line.HasSwitch(switches::kEnableBlinkFeatures)) {
diff --git a/content/common/resource_messages.h b/content/common/resource_messages.h index 0fe7c8438..885adb0 100644 --- a/content/common/resource_messages.h +++ b/content/common/resource_messages.h
@@ -27,6 +27,7 @@ #include "net/cert/signed_certificate_timestamp_and_status.h" #include "net/http/http_response_info.h" #include "net/ssl/ssl_info.h" +#include "net/traffic_annotation/network_traffic_annotation.h" #include "net/url_request/redirect_info.h" #include "third_party/WebKit/public/platform/WebMixedContentContextType.h" @@ -236,6 +237,10 @@ IPC_STRUCT_TRAITS_MEMBER(referred_token_binding_host) IPC_STRUCT_TRAITS_END() +IPC_STRUCT_TRAITS_BEGIN(net::MutableNetworkTrafficAnnotationTag) + IPC_STRUCT_TRAITS_MEMBER(unique_id_hash_code) +IPC_STRUCT_TRAITS_END() + IPC_STRUCT_TRAITS_BEGIN(net::SignedCertificateTimestampAndStatus) IPC_STRUCT_TRAITS_MEMBER(sct) IPC_STRUCT_TRAITS_MEMBER(status) @@ -369,10 +374,12 @@ // Resource messages sent from the renderer to the browser. // Makes a resource request via the browser. -IPC_MESSAGE_CONTROL3(ResourceHostMsg_RequestResource, - int /* routing_id */, - int /* request_id */, - content::ResourceRequest) +IPC_MESSAGE_CONTROL4( + ResourceHostMsg_RequestResource, + int /* routing_id */, + int /* request_id */, + content::ResourceRequest, + net::MutableNetworkTrafficAnnotationTag /* network_traffic_annotation */) // Cancels a resource request with the ID given as the parameter. IPC_MESSAGE_CONTROL1(ResourceHostMsg_CancelRequest,
diff --git a/content/common/sandbox_init_mac.cc b/content/common/sandbox_init_mac.cc index f73e85db..314bfbb 100644 --- a/content/common/sandbox_init_mac.cc +++ b/content/common/sandbox_init_mac.cc
@@ -4,6 +4,7 @@ #include "content/common/sandbox_init_mac.h" +#include "base/callback.h" #include "base/command_line.h" #include "base/files/file_path.h" #include "base/logging.h" @@ -14,14 +15,28 @@ namespace content { -bool InitializeSandbox(int sandbox_type, const base::FilePath& allowed_dir) { +namespace { + +bool InitializeSandbox(int sandbox_type, + const base::FilePath& allowed_dir, + base::OnceClosure hook) { // Warm up APIs before turning on the sandbox. Sandbox::SandboxWarmup(sandbox_type); + // Execute the post warmup callback. + if (!hook.is_null()) + std::move(hook).Run(); + // Actually sandbox the process. return Sandbox::EnableSandbox(sandbox_type, allowed_dir); } +} // namespace + +bool InitializeSandbox(int sandbox_type, const base::FilePath& allowed_dir) { + return InitializeSandbox(sandbox_type, allowed_dir, base::OnceClosure()); +} + // Fill in |sandbox_type| and |allowed_dir| based on the command line, returns // false if the current process type doesn't need to be sandboxed or if the // sandbox was disabled from the command line. @@ -72,12 +87,16 @@ return true; } -bool InitializeSandbox() { +bool InitializeSandboxWithPostWarmupHook(base::OnceClosure hook) { int sandbox_type = 0; base::FilePath allowed_dir; if (!GetSandboxTypeFromCommandLine(&sandbox_type, &allowed_dir)) return true; - return InitializeSandbox(sandbox_type, allowed_dir); + return InitializeSandbox(sandbox_type, allowed_dir, std::move(hook)); +} + +bool InitializeSandbox() { + return InitializeSandboxWithPostWarmupHook(base::OnceClosure()); } } // namespace content
diff --git a/content/common/sandbox_init_mac.h b/content/common/sandbox_init_mac.h index 8f860efd..375b3d99 100644 --- a/content/common/sandbox_init_mac.h +++ b/content/common/sandbox_init_mac.h
@@ -5,6 +5,8 @@ #ifndef CONTENT_COMMON_SANDBOX_INIT_MAC_H_ #define CONTENT_COMMON_SANDBOX_INIT_MAC_H_ +#include "base/callback_forward.h" + namespace content { // Initialize the sandbox for renderer, gpu, utility, worker, and plugin @@ -15,6 +17,10 @@ // returned. bool InitializeSandbox(); +// Initializes the sandbox, as described above, but executes the callback after +// warmup and before initialization. +bool InitializeSandboxWithPostWarmupHook(base::OnceClosure hook); + } // namespace content #endif // CONTENT_COMMON_SANDBOX_INIT_MAC_H_
diff --git a/content/common/sandbox_mac.mm b/content/common/sandbox_mac.mm index 49886fde..cfe004f 100644 --- a/content/common/sandbox_mac.mm +++ b/content/common/sandbox_mac.mm
@@ -41,12 +41,6 @@ #include "ui/base/layout.h" #include "ui/gl/init/gl_factory.h" -extern "C" { -void CGSSetDenyWindowServerConnections(bool); -void CGSShutdownServerConnections(); -OSStatus SetApplicationIsDaemon(Boolean isDaemon); -}; - namespace content { namespace { @@ -175,21 +169,6 @@ NSColor* color = [NSColor controlTextColor]; [color colorUsingColorSpaceName:NSCalibratedRGBColorSpace]; } - - if (sandbox_type == SANDBOX_TYPE_RENDERER) { - // Now disconnect from WindowServer, after all objects have been warmed up. - // Shutting down the connection requires connecting to WindowServer, - // so do this before actually engaging the sandbox. This may cause two log - // messages to be printed to the system logger on certain OS versions. - CGSSetDenyWindowServerConnections(true); - CGSShutdownServerConnections(); - - // Allow the process to continue without a LaunchServices ASN. The - // INIT_Process function in HIServices will abort if it cannot connect to - // launchservicesd to get an ASN. By setting this flag, HIServices skips - // that. - SetApplicationIsDaemon(true); - } } // Load the appropriate template for the given sandbox type.
diff --git a/content/common/view_messages.h b/content/common/view_messages.h index d52258a..8ca428f 100644 --- a/content/common/view_messages.h +++ b/content/common/view_messages.h
@@ -38,7 +38,6 @@ #include "media/base/audio_parameters.h" #include "media/base/channel_layout.h" #include "media/base/ipc/media_param_traits.h" -#include "media/base/media_log_event.h" #include "media/capture/ipc/capture_param_traits.h" #include "net/base/network_change_notifier.h" #include "ppapi/features/features.h" @@ -109,8 +108,6 @@ content::TAP_MULTIPLE_TARGETS_STRATEGY_MAX) IPC_ENUM_TRAITS_MAX_VALUE(content::ThreeDAPIType, content::THREE_D_API_TYPE_LAST) -IPC_ENUM_TRAITS_MAX_VALUE(media::MediaLogEvent::Type, - media::MediaLogEvent::TYPE_LAST) IPC_ENUM_TRAITS_MAX_VALUE(ui::TextInputMode, ui::TEXT_INPUT_MODE_MAX) IPC_ENUM_TRAITS_MAX_VALUE(ui::TextInputType, ui::TEXT_INPUT_TYPE_MAX) @@ -258,13 +255,6 @@ IPC_STRUCT_TRAITS_MEMBER(default_font_size) IPC_STRUCT_TRAITS_END() -IPC_STRUCT_TRAITS_BEGIN(media::MediaLogEvent) - IPC_STRUCT_TRAITS_MEMBER(id) - IPC_STRUCT_TRAITS_MEMBER(type) - IPC_STRUCT_TRAITS_MEMBER(params) - IPC_STRUCT_TRAITS_MEMBER(time) -IPC_STRUCT_TRAITS_END() - IPC_STRUCT_TRAITS_BEGIN(content::TextInputState) IPC_STRUCT_TRAITS_MEMBER(type) IPC_STRUCT_TRAITS_MEMBER(mode)
diff --git a/content/public/android/BUILD.gn b/content/public/android/BUILD.gn index e9a3dfe..53ceaab2 100644 --- a/content/public/android/BUILD.gn +++ b/content/public/android/BUILD.gn
@@ -114,6 +114,7 @@ "java/src/org/chromium/content/browser/BrowserStartupController.java", "java/src/org/chromium/content/browser/ChildConnectionAllocator.java", "java/src/org/chromium/content/browser/ChildProcessConnection.java", + "java/src/org/chromium/content/browser/ChildProcessLauncher.java", "java/src/org/chromium/content/browser/ChildProcessLauncherHelper.java", "java/src/org/chromium/content/browser/ContentChildProcessConstants.java", "java/src/org/chromium/content/browser/ContentClassFactory.java", @@ -373,6 +374,9 @@ android_library("content_javatests") { testonly = true + + srcjar_deps = [ "//content/shell/android:content_javatests_aidl" ] + deps = [ ":content_java", "//base:base_java", @@ -396,6 +400,7 @@ "//net/android:net_java_test_support", "//third_party/android_support_test_runner:rules_java", "//third_party/android_support_test_runner:runner_java", + "//third_party/jsr-305:jsr_305_javalib", "//third_party/junit", "//ui/android:ui_java", "//ui/gfx/geometry/mojo:mojo_java", @@ -405,6 +410,7 @@ "javatests/src/org/chromium/content/browser/BrowserStartupControllerTest.java", "javatests/src/org/chromium/content/browser/ChildProcessLauncherIntegrationTest.java", "javatests/src/org/chromium/content/browser/ChildProcessLauncherTest.java", + "javatests/src/org/chromium/content/browser/ChildProcessLauncherHelperTest.java", "javatests/src/org/chromium/content/browser/ClipboardTest.java", "javatests/src/org/chromium/content/browser/ContentCommandLineTest.java", "javatests/src/org/chromium/content/browser/ContentViewCoreSelectionTest.java",
diff --git a/content/public/android/java/src/org/chromium/content/browser/ChildConnectionAllocator.java b/content/public/android/java/src/org/chromium/content/browser/ChildConnectionAllocator.java index 8d1e260..c1972fc 100644 --- a/content/public/android/java/src/org/chromium/content/browser/ChildConnectionAllocator.java +++ b/content/public/android/java/src/org/chromium/content/browser/ChildConnectionAllocator.java
@@ -27,14 +27,14 @@ private static final String TAG = "ChildConnAllocator"; /** Listener that clients can use to get notified when connections get allocated/freed. */ - public interface Listener { + public abstract static class Listener { /** Called when a connection has been allocated, before it gets bound. */ - void onConnectionAllocated( - ChildConnectionAllocator allocator, ChildProcessConnection connection); + public void onConnectionAllocated( + ChildConnectionAllocator allocator, ChildProcessConnection connection) {} /** Called when a connection has been freed. */ - void onConnectionFreed( - ChildConnectionAllocator allocator, ChildProcessConnection connection); + public void onConnectionFreed( + ChildConnectionAllocator allocator, ChildProcessConnection connection) {} } /** Factory interface. Used by tests to specialize created connections. */ @@ -103,8 +103,7 @@ // Check that the service exists. try { - // PackageManager#getServiceInfo() throws an exception if the service does not - // exist. + // PackageManager#getServiceInfo() throws an exception if the service does not exist. packageManager.getServiceInfo( new ComponentName(packageName, serviceClassName + "0"), 0); } catch (PackageManager.NameNotFoundException e) {
diff --git a/content/public/android/java/src/org/chromium/content/browser/ChildProcessLauncher.java b/content/public/android/java/src/org/chromium/content/browser/ChildProcessLauncher.java new file mode 100644 index 0000000..4fc7085 --- /dev/null +++ b/content/public/android/java/src/org/chromium/content/browser/ChildProcessLauncher.java
@@ -0,0 +1,298 @@ +// Copyright 2017 The Chromium Authors. All rights reserved. +// Use of this source code is governed by a BSD-style license that can be +// found in the LICENSE file. + +package org.chromium.content.browser; + +import android.os.Bundle; +import android.os.Handler; +import android.os.IBinder; +import android.os.Looper; + +import org.chromium.base.ContextUtils; +import org.chromium.base.Log; +import org.chromium.base.TraceEvent; +import org.chromium.base.annotations.SuppressFBWarnings; +import org.chromium.base.process_launcher.ChildProcessConstants; +import org.chromium.base.process_launcher.FileDescriptorInfo; + +import java.io.IOException; + +/** + * This class is used to start a child process by connecting to a ChildProcessService. + */ +public class ChildProcessLauncher { + private static final String TAG = "ChildProcLauncher"; + + /** Delegate that client should use to customize the process launching. */ + public interface Delegate { + /** + * Called before a connection is allocated. + * Note that this is only called if the ChildProcessLauncher is created with + * {@link #createWithConnectionAllocator}. + * @param serviceBundle the bundle passed in the service intent. Clients can add their own + * extras to the bundle. + */ + void onBeforeConnectionAllocated(Bundle serviceBundle); + + /** + * Called before setup is called on the connection. + * @param connectionBundle the bundle passed to the {@link ChildProcessService} in the + * setup call. Clients can add their own extras to the bundle. + */ + void onBeforeConnectionSetup(Bundle connectionBundle); + + /** + * Called when the connection was successfully established, meaning the setup call on the + * service was successful. + * @param connection the connection over which the setup call was made. + */ + void onConnectionEstablished(ChildProcessConnection connection); + + /** + * Called when a connection has been disconnected. Only invoked if onConnectionEstablished + * was called, meaning the connection was already established. + * @param connection the connection that got disconnected. + */ + void onConnectionLost(ChildProcessConnection connection); + } + + /** + * Interface used by clients that already have a bound connection ready when instanciating the + * ChildProcessLauncher. + */ + public interface BoundConnectionProvider { + ChildProcessConnection getConnection( + ChildProcessConnection.ServiceCallback serviceCallback); + } + + // Represents an invalid process handle; same as base/process/process.h kNullProcessHandle. + private static final int NULL_PROCESS_HANDLE = 0; + + // The handle for the thread we were created on and on which all methods should be called. + private final Handler mLauncherHandler = new Handler(); + + private final Delegate mDelegate; + + private final String[] mCommandLine; + private final FileDescriptorInfo[] mFilesToBeMapped; + + // The allocator used to create the connection. + private final BoundConnectionProvider mConnectionProvider; + + // The allocator used to create the connection. + private final ChildConnectionAllocator mConnectionAllocator; + + // The IBinder provided to the created service. + private final IBinder mIBinderCallback; + + // The actual service connection. Set once we have connected to the service. + private ChildProcessConnection mConnection; + + /** + * Creates a ChildProcessLauncher using the already bound connection provided. + * Note that onBeforeConnectionAllocated and onConnectionBound will not be invoked on the + * delegate since the connection is already available. + */ + public static ChildProcessLauncher createWithBoundConnectionProvider(Delegate delegate, + String[] commandLine, FileDescriptorInfo[] filesToBeMapped, + BoundConnectionProvider connectionProvider, IBinder binderCallback) { + return new ChildProcessLauncher(delegate, commandLine, filesToBeMapped, connectionProvider, + null /* connectionAllocator */, binderCallback); + } + + /** + * Creates a ChildProcessLauncher that will create a connection using the specified + * ChildConnectionAllocator. + */ + public static ChildProcessLauncher createWithConnectionAllocator(Delegate delegate, + String[] commandLine, FileDescriptorInfo[] filesToBeMapped, + ChildConnectionAllocator connectionAllocator, IBinder binderCallback) { + return new ChildProcessLauncher(delegate, commandLine, filesToBeMapped, + null /* connection */, connectionAllocator, binderCallback); + } + + @SuppressFBWarnings("EI_EXPOSE_REP2") + private ChildProcessLauncher(Delegate delegate, String[] commandLine, + FileDescriptorInfo[] filesToBeMapped, BoundConnectionProvider connectionProvider, + ChildConnectionAllocator connectionAllocator, IBinder binderCallback) { + // Either a bound connection provider or a connection allocator should be provided. + assert (connectionProvider == null) != (connectionAllocator == null); + mCommandLine = commandLine; + mConnectionProvider = connectionProvider; + mConnectionAllocator = connectionAllocator; + mDelegate = delegate; + mFilesToBeMapped = filesToBeMapped; + mIBinderCallback = binderCallback; + } + + /** + * Starts the child process and calls setup on it if {@param setupConnection} is true. + * @param setupConnection whether the setup should be performed on the connection once + * established + * @param queueIfNoFreeConnection whether to queue that request if no service connection is + * available. If the launcher was created with a connection provider, this parameter has no + * effect. + * @return true if the connection was started or was queued. + */ + public boolean start(final boolean setupConnection, final boolean queueIfNoFreeConnection) { + assert isRunningOnLauncherThread(); + try { + TraceEvent.begin("ChildProcessLauncher.start"); + ChildProcessConnection.ServiceCallback serviceCallback = + new ChildProcessConnection.ServiceCallback() { + @Override + public void onChildStarted() {} + + @Override + public void onChildStartFailed() { + assert isRunningOnLauncherThread(); + Log.e(TAG, "ChildProcessConnection.start failed, trying again"); + mLauncherHandler.post(new Runnable() { + @Override + public void run() { + // The child process may already be bound to another client + // (this can happen if multi-process WebView is used in more + // than one process), so try starting the process again. + // This connection that failed to start has not been freed, + // so a new bound connection will be allocated. + mConnection = null; + start(setupConnection, queueIfNoFreeConnection); + } + }); + } + + @Override + public void onChildProcessDied(ChildProcessConnection connection) { + assert LauncherThread.runningOnLauncherThread(); + assert mConnection == connection; + ChildProcessLauncher.this.onChildProcessDied(); + } + }; + if (mConnectionProvider != null) { + mConnection = mConnectionProvider.getConnection(serviceCallback); + assert mConnection != null; + setupConnection(); + } else { + assert mConnectionAllocator != null; + if (!allocateAndSetupConnection( + serviceCallback, setupConnection, queueIfNoFreeConnection) + && !queueIfNoFreeConnection) { + return false; + } + } + return true; + } finally { + TraceEvent.end("ChildProcessLauncher.start"); + } + } + + public ChildProcessConnection getConnection() { + return mConnection; + } + + public ChildConnectionAllocator getConnectionAllocator() { + return mConnectionAllocator; + } + + private boolean allocateAndSetupConnection( + final ChildProcessConnection.ServiceCallback serviceCallback, + final boolean setupConnection, final boolean queueIfNoFreeConnection) { + assert mConnection == null; + Bundle serviceBundle = new Bundle(); + mDelegate.onBeforeConnectionAllocated(serviceBundle); + + mConnection = mConnectionAllocator.allocate( + ContextUtils.getApplicationContext(), serviceBundle, serviceCallback); + if (mConnection == null) { + if (!queueIfNoFreeConnection) { + Log.d(TAG, "Failed to allocate a child connection (no queuing)."); + return false; + } + // No connection is available at this time. Add a listener so when one becomes + // available we can create the service. + mConnectionAllocator.addListener(new ChildConnectionAllocator.Listener() { + @Override + public void onConnectionFreed( + ChildConnectionAllocator allocator, ChildProcessConnection connection) { + assert allocator == mConnectionAllocator; + if (!allocator.isFreeConnectionAvailable()) return; + allocator.removeListener(this); + allocateAndSetupConnection( + serviceCallback, setupConnection, queueIfNoFreeConnection); + } + }); + return false; + } + assert mConnection != null; + + if (setupConnection) { + setupConnection(); + } + return true; + } + + private void setupConnection() { + ChildProcessConnection.ConnectionCallback connectionCallback = + new ChildProcessConnection.ConnectionCallback() { + @Override + public void onConnected(ChildProcessConnection connection) { + assert mConnection == connection; + onServiceConnected(); + } + }; + Bundle connectionBundle = createConnectionBundle(); + mDelegate.onBeforeConnectionSetup(connectionBundle); + mConnection.setupConnection(connectionBundle, getIBinderCallback(), connectionCallback); + } + + private void onServiceConnected() { + assert isRunningOnLauncherThread(); + + Log.d(TAG, "on connect callback, pid=%d", mConnection.getPid()); + + mDelegate.onConnectionEstablished(mConnection); + + // Proactively close the FDs rather than waiting for the GC to do it. + try { + for (FileDescriptorInfo fileInfo : mFilesToBeMapped) { + fileInfo.fd.close(); + } + } catch (IOException ioe) { + Log.w(TAG, "Failed to close FD.", ioe); + } + } + + public int getPid() { + assert isRunningOnLauncherThread(); + return mConnection == null ? NULL_PROCESS_HANDLE : mConnection.getPid(); + } + + public IBinder getIBinderCallback() { + return mIBinderCallback; + } + + private boolean isRunningOnLauncherThread() { + return mLauncherHandler.getLooper() == Looper.myLooper(); + } + + private Bundle createConnectionBundle() { + Bundle bundle = new Bundle(); + bundle.putStringArray(ChildProcessConstants.EXTRA_COMMAND_LINE, mCommandLine); + bundle.putParcelableArray(ChildProcessConstants.EXTRA_FILES, mFilesToBeMapped); + return bundle; + } + + private void onChildProcessDied() { + assert LauncherThread.runningOnLauncherThread(); + if (getPid() != 0) { + mDelegate.onConnectionLost(mConnection); + } + } + + public void stop() { + assert isRunningOnLauncherThread(); + Log.d(TAG, "stopping child connection: pid=%d", mConnection.getPid()); + mConnection.stop(); + } +}
diff --git a/content/public/android/java/src/org/chromium/content/browser/ChildProcessLauncherHelper.java b/content/public/android/java/src/org/chromium/content/browser/ChildProcessLauncherHelper.java index ce2e033..9e4204a 100644 --- a/content/public/android/java/src/org/chromium/content/browser/ChildProcessLauncherHelper.java +++ b/content/public/android/java/src/org/chromium/content/browser/ChildProcessLauncherHelper.java
@@ -15,7 +15,6 @@ import org.chromium.base.CpuFeatures; import org.chromium.base.Log; import org.chromium.base.ThreadUtils; -import org.chromium.base.TraceEvent; import org.chromium.base.VisibleForTesting; import org.chromium.base.annotations.CalledByNative; import org.chromium.base.annotations.JNINamespace; @@ -51,12 +50,6 @@ private static final String PRIVILEGED_SERVICES_NAME_KEY = "org.chromium.content.browser.PRIVILEGED_SERVICES_NAME"; - // Represents an invalid process handle; same as base/process/process.h kNullProcessHandle. - private static final int NULL_PROCESS_HANDLE = 0; - - // Delay between the call to freeConnection and the connection actually beeing freed. - private static final long FREE_CONNECTION_DELAY_MILLIS = 1; - // A warmed-up connection to a sandboxed service. private static SpareChildConnection sSpareSandboxedConnection; @@ -64,6 +57,9 @@ private static final Map<String, ChildConnectionAllocator> sSandboxedChildConnectionAllocatorMap = new HashMap<>(); + // Map from PID to ChildProcessLauncherHelper. + private static final Map<Integer, ChildProcessLauncherHelper> sLauncherByPid = new HashMap<>(); + // Allocator used for non-sandboxed services. private static ChildConnectionAllocator sPrivilegedChildConnectionAllocator; @@ -72,40 +68,75 @@ private static int sSandboxedServicesCountForTesting = -1; private static String sSandboxedServicesNameForTesting; - // Map from PID to ChildService connection. - private static Map<Integer, ChildProcessLauncherHelper> sLauncherByPid = new HashMap<>(); - // Manages OOM bindings used to bind chind services. Lazily initialized by getBindingManager(). private static BindingManager sBindingManager; // Whether the main application is currently brought to the foreground. private static boolean sApplicationInForeground = true; - // The IBinder provided to the created service. - private final IBinder mIBinderCallback; - - // Whether the connection should be setup once connected. Tests can set this to false to - // simulate a connected but not yet setup connection. - private final boolean mDoSetupConnection; + // Whether the connection is managed by the BindingManager. + private final boolean mUseBindingManager; private final ChildProcessCreationParams mCreationParams; - private final String[] mCommandLine; - - private final FileDescriptorInfo[] mFilesToBeMapped; - - // The allocator used to create the connection. - private final ChildConnectionAllocator mConnectionAllocator; - // Whether the created process should be sandboxed. private final boolean mSandboxed; + private final ChildProcessLauncher.Delegate mLauncherDelegate = + new ChildProcessLauncher.Delegate() { + @Override + public void onBeforeConnectionAllocated(Bundle bundle) { + populateServiceBundle(bundle, mCreationParams); + } + + @Override + public void onBeforeConnectionSetup(Bundle connectionBundle) { + // Populate the bundle passed to the service setup call with content specific + // parameters. + connectionBundle.putInt( + ContentChildProcessConstants.EXTRA_CPU_COUNT, CpuFeatures.getCount()); + connectionBundle.putLong( + ContentChildProcessConstants.EXTRA_CPU_FEATURES, CpuFeatures.getMask()); + connectionBundle.putBundle(Linker.EXTRA_LINKER_SHARED_RELROS, + Linker.getInstance().getSharedRelros()); + } + + @Override + public void onConnectionEstablished(ChildProcessConnection connection) { + int pid = connection.getPid(); + assert pid > 0; + + sLauncherByPid.put(pid, ChildProcessLauncherHelper.this); + + if (mUseBindingManager) { + getBindingManager().addNewConnection(pid, connection); + } + + // If the connection fails and pid == 0, the Java-side cleanup was already + // handled by DeathCallback. We still have to call back to native for cleanup + // there. + if (mNativeChildProcessLauncherHelper != 0) { + nativeOnChildProcessStarted( + mNativeChildProcessLauncherHelper, connection.getPid()); + } + mNativeChildProcessLauncherHelper = 0; + } + + @Override + public void onConnectionLost(ChildProcessConnection connection) { + assert connection.getPid() > 0; + sLauncherByPid.remove(connection.getPid()); + if (mUseBindingManager) { + getBindingManager().removeConnection(connection.getPid()); + } + } + }; + + private final ChildProcessLauncher mLauncher; + // Note native pointer is only guaranteed live until nativeOnChildProcessStarted. private long mNativeChildProcessLauncherHelper; - // The actual service connection. Set once we have connected to the service. - private ChildProcessConnection mConnection; - @CalledByNative private static FileDescriptorInfo makeFdInfo( int id, int fd, boolean autoClose, long offset, long size) { @@ -152,11 +183,11 @@ ? new GpuProcessCallback() : null; - ChildProcessLauncherHelper process_launcher = - new ChildProcessLauncherHelper(nativePointer, creationParams, commandLine, - filesToBeMapped, sandboxed, binderCallback, true /* doSetupConnection */); - process_launcher.start(); - return process_launcher; + ChildProcessLauncherHelper processLauncher = new ChildProcessLauncherHelper(nativePointer, + creationParams, commandLine, filesToBeMapped, sandboxed, binderCallback); + processLauncher.mLauncher.start( + true /* doSetupConnection */, true /* queueIfNoFreeConnection */); + return processLauncher; } /** @@ -169,23 +200,23 @@ LauncherThread.post(new Runnable() { @Override public void run() { - if (sSpareSandboxedConnection != null && !sSpareSandboxedConnection.isEmpty()) { - return; - } - - ChildProcessCreationParams creationParams = ChildProcessCreationParams.getDefault(); - boolean bindToCallerCheck = - creationParams == null ? false : creationParams.getBindToCallerCheck(); - Bundle serviceBundle = - ChildProcessLauncherHelper.createServiceBundle(bindToCallerCheck); - ChildConnectionAllocator allocator = - getConnectionAllocator(context, creationParams, true /* sandboxed */); - sSpareSandboxedConnection = - new SpareChildConnection(context, allocator, serviceBundle); + warmUpOnLauncherThread(context); } }); } + private static void warmUpOnLauncherThread(Context context) { + if (sSpareSandboxedConnection != null && !sSpareSandboxedConnection.isEmpty()) { + return; + } + + ChildProcessCreationParams creationParams = ChildProcessCreationParams.getDefault(); + Bundle serviceBundle = populateServiceBundle(new Bundle(), creationParams); + ChildConnectionAllocator allocator = + getConnectionAllocator(context, creationParams, true /* sandboxed */); + sSpareSandboxedConnection = new SpareChildConnection(context, allocator, serviceBundle); + } + public static String getPackageNameFromCreationParams( Context context, ChildProcessCreationParams params, boolean sandboxed) { return (sandboxed && params != null) ? params.getPackageNameForSandboxedService() @@ -314,6 +345,7 @@ sSandboxedServiceFactoryForTesting); } sSandboxedChildConnectionAllocatorMap.put(packageName, connectionAllocator); + final ChildConnectionAllocator finalConnectionAllocator = connectionAllocator; // Tracks connections removal so the allocator can be freed when no longer used. connectionAllocator.addListener(new ChildConnectionAllocator.Listener() { @@ -321,6 +353,7 @@ public void onConnectionAllocated( ChildConnectionAllocator allocator, ChildProcessConnection connection) { assert connection != null; + assert allocator == finalConnectionAllocator; if (!allocator.isFreeConnectionAvailable()) { // Proactively releases all the moderate bindings once all the sandboxed // services are allocated, which will be very likely to have some of them @@ -349,195 +382,61 @@ private ChildProcessLauncherHelper(long nativePointer, ChildProcessCreationParams creationParams, String[] commandLine, - FileDescriptorInfo[] filesToBeMapped, boolean sandboxed, IBinder binderCallback, - boolean doSetupConnection) { + FileDescriptorInfo[] filesToBeMapped, boolean sandboxed, IBinder binderCallback) { assert LauncherThread.runningOnLauncherThread(); - mCreationParams = creationParams; - mCommandLine = commandLine; - mFilesToBeMapped = filesToBeMapped; mNativeChildProcessLauncherHelper = nativePointer; - mIBinderCallback = binderCallback; - mDoSetupConnection = doSetupConnection; + mCreationParams = creationParams; + mUseBindingManager = sandboxed; mSandboxed = sandboxed; - mConnectionAllocator = getConnectionAllocator( + final ChildConnectionAllocator connectionAllocator = getConnectionAllocator( ContextUtils.getApplicationContext(), mCreationParams, sandboxed); - - initLinker(); - } - - private void start() { - assert LauncherThread.runningOnLauncherThread(); - assert mConnection == null; - try { - TraceEvent.begin("ChildProcessLauncher.start"); - - ChildProcessConnection.ServiceCallback serviceCallback = - new ChildProcessConnection.ServiceCallback() { + if (sSpareSandboxedConnection != null && !sSpareSandboxedConnection.isEmpty() + && sSpareSandboxedConnection.isForAllocator(connectionAllocator)) { + // Use the warmed-up connection. + ChildProcessLauncher.BoundConnectionProvider connectionProvider = + new ChildProcessLauncher.BoundConnectionProvider() { @Override - public void onChildStarted() {} - - @Override - public void onChildStartFailed() { - assert LauncherThread.runningOnLauncherThread(); - Log.e(TAG, "ChildProcessConnection.start failed, trying again"); - LauncherThread.post(new Runnable() { - @Override - public void run() { - // The child process may already be bound to another client - // (this can happen if multi-process WebView is used in more - // than one process), so try starting the process again. - // This connection that failed to start has not been freed, - // so a new bound connection will be allocated. - mConnection = null; - start(); - } - }); - } - - @Override - public void onChildProcessDied(ChildProcessConnection connection) { - assert LauncherThread.runningOnLauncherThread(); - assert mConnection == connection; - ChildProcessLauncherHelper.this.onChildProcessDied(); + public ChildProcessConnection getConnection( + ChildProcessConnection.ServiceCallback serviceCallback) { + return sSpareSandboxedConnection.getConnection( + connectionAllocator, serviceCallback); } }; - - // Try to use the spare connection if there's one. - if (sSpareSandboxedConnection != null) { - mConnection = sSpareSandboxedConnection.getConnection( - mConnectionAllocator, serviceCallback); - if (mConnection != null) { - Log.d(TAG, "Using warmed-up connection for service %s.", - mConnection.getServiceName()); - // Clear the spare connection now that it's been used. - sSpareSandboxedConnection = null; - } - } - - allocateAndSetupConnection(serviceCallback); - } finally { - TraceEvent.end("ChildProcessLauncher.start"); - } - } - - // Allocates a new connection and calls setUp on it. - // If there are no available connections, it will retry when one becomes available. - private boolean allocateAndSetupConnection( - final ChildProcessConnection.ServiceCallback serviceCallback) { - if (mConnection == null) { - final Context context = ContextUtils.getApplicationContext(); - boolean bindToCallerCheck = - mCreationParams == null ? false : mCreationParams.getBindToCallerCheck(); - Bundle serviceBundle = createServiceBundle(bindToCallerCheck); - onBeforeConnectionAllocated(serviceBundle); - - boolean useBindingManager = mSandboxed; - mConnection = mConnectionAllocator.allocate(context, serviceBundle, serviceCallback); - if (mConnection == null) { - // No connection is available at this time. Add a listener so when one becomes - // available we can create the service. - mConnectionAllocator.addListener(new ChildConnectionAllocator.Listener() { - @Override - public void onConnectionAllocated(ChildConnectionAllocator allocator, - ChildProcessConnection connection) {} - - @Override - public void onConnectionFreed( - ChildConnectionAllocator allocator, ChildProcessConnection connection) { - assert allocator == mConnectionAllocator; - if (!allocator.isFreeConnectionAvailable()) return; - allocator.removeListener(this); - boolean success = allocateAndSetupConnection(serviceCallback); - assert success; - } - }); - return false; - } - } - - assert mConnection != null; - Bundle connectionBundle = createConnectionBundle(); - onConnectionBound(mConnection, mConnectionAllocator, connectionBundle); - - if (mDoSetupConnection) { - setupConnection(connectionBundle); - } - return true; - } - - private void setupConnection(Bundle connectionBundle) { - ChildProcessConnection.ConnectionCallback connectionCallback = - new ChildProcessConnection.ConnectionCallback() { - @Override - public void onConnected(ChildProcessConnection connection) { - assert mConnection == connection; - onChildProcessStarted(); - } - }; - mConnection.setupConnection(connectionBundle, getIBinderCallback(), connectionCallback); - } - - private void onChildProcessStarted() { - assert LauncherThread.runningOnLauncherThread(); - - int pid = mConnection.getPid(); - Log.d(TAG, "on connect callback, pid=%d", pid); - - onConnectionEstablished(mConnection); - - sLauncherByPid.put(pid, this); - - // Proactively close the FDs rather than waiting for the GC to do it. - try { - for (FileDescriptorInfo fileInfo : mFilesToBeMapped) { - fileInfo.fd.close(); - } - } catch (IOException ioe) { - Log.w(TAG, "Failed to close FD.", ioe); - } - - // If the connection fails and pid == 0, the Java-side cleanup was already handled by - // ServiceCallback.onChildStopped. We still have to call back to native for cleanup there. - if (mNativeChildProcessLauncherHelper != 0) { - nativeOnChildProcessStarted(mNativeChildProcessLauncherHelper, getPid()); - } - mNativeChildProcessLauncherHelper = 0; - } - - private void onChildProcessDied() { - assert LauncherThread.runningOnLauncherThread(); - if (getPid() != 0) { - onConnectionLost(mConnection, getPid()); - sLauncherByPid.remove(getPid()); + mLauncher = ChildProcessLauncher.createWithBoundConnectionProvider(mLauncherDelegate, + commandLine, filesToBeMapped, connectionProvider, binderCallback); + } else { + mLauncher = ChildProcessLauncher.createWithConnectionAllocator(mLauncherDelegate, + commandLine, filesToBeMapped, connectionAllocator, binderCallback); } } public int getPid() { assert LauncherThread.runningOnLauncherThread(); - return mConnection == null ? NULL_PROCESS_HANDLE : mConnection.getPid(); + return mLauncher.getPid(); } // Called on client (UI or IO) thread. @CalledByNative private boolean isOomProtected() { - // mConnection is set on a different thread but does not change once it's been set. So it is - // safe to test whether it's null from a different thread. - if (mConnection == null) { + ChildProcessConnection connection = mLauncher.getConnection(); + // Here we are accessing the connection from a thread other than the launcher thread, but it + // does not change once it's been set. So it is safe to test whether it's null here and + // access it afterwards. + if (connection == null) { return false; } // We consider the process to be child protected if it has a strong or moderate binding and // the app is in the foreground. - return sApplicationInForeground && !mConnection.isWaivedBoundOnlyOrWasWhenDied(); + return sApplicationInForeground && !connection.isWaivedBoundOnlyOrWasWhenDied(); } @CalledByNative private void setInForeground(int pid, boolean foreground, boolean boostForPendingViews) { assert LauncherThread.runningOnLauncherThread(); - assert mConnection != null; - assert getPid() == pid; + assert mLauncher.getPid() == pid; getBindingManager().setPriority(pid, foreground, boostForPendingViews); } @@ -545,10 +444,11 @@ static void stop(int pid) { assert LauncherThread.runningOnLauncherThread(); Log.d(TAG, "stopping child connection: pid=%d", pid); - ChildProcessLauncherHelper launcher = sLauncherByPid.get(pid); - // Launcher can be null for single process. + ChildProcessLauncherHelper launcher = getByPid(pid); + // launcher can be null for single process. if (launcher != null) { - launcher.mConnection.stop(); + // Can happen for single process. + launcher.mLauncher.stop(); } } @@ -579,8 +479,7 @@ private static boolean sLinkerInitialized; private static long sLinkerLoadAddress; - @VisibleForTesting - static void initLinker() { + private static void initLinker() { assert LauncherThread.runningOnLauncherThread(); if (sLinkerInitialized) return; if (Linker.isUsed()) { @@ -594,8 +493,9 @@ private static ChromiumLinkerParams getLinkerParamsForNewConnection() { assert LauncherThread.runningOnLauncherThread(); - assert sLinkerInitialized; + initLinker(); + assert sLinkerInitialized; if (sLinkerLoadAddress == 0) return null; // Always wait for the shared RELROs in service processes. @@ -610,70 +510,18 @@ } } - /** - * Creates the common bundle to be passed to child processes through the service binding intent. - * If the service gets recreated by the framework the intent will be reused, so these parameters - * should be common to all processes of that type. - * - * @param commandLine Command line params to be passed to the service. - * @param linkerParams Linker params to start the service. - */ - private static Bundle createServiceBundle(boolean bindToCallerCheck) { - initLinker(); - Bundle bundle = new Bundle(); + private static Bundle populateServiceBundle( + Bundle bundle, ChildProcessCreationParams creationParams) { + boolean bindToCallerCheck = + creationParams == null ? false : creationParams.getBindToCallerCheck(); bundle.putBoolean(ChildProcessConstants.EXTRA_BIND_TO_CALLER, bindToCallerCheck); bundle.putParcelable(ContentChildProcessConstants.EXTRA_LINKER_PARAMS, getLinkerParamsForNewConnection()); return bundle; } - public Bundle createConnectionBundle() { - Bundle bundle = new Bundle(); - bundle.putStringArray(ChildProcessConstants.EXTRA_COMMAND_LINE, mCommandLine); - bundle.putParcelableArray(ChildProcessConstants.EXTRA_FILES, mFilesToBeMapped); - return bundle; - } - - // Below are methods that will eventually be moved to a content delegate class. - - private void onBeforeConnectionAllocated(Bundle commonParameters) { - // TODO(jcivelli): move createServiceBundle in there. - } - - // Called once a connection has been allocated. - private void onConnectionBound(ChildProcessConnection connection, - ChildConnectionAllocator connectionAllocator, Bundle connectionBundle) { - if (mSandboxed && !connectionAllocator.isFreeConnectionAvailable()) { - // Proactively releases all the moderate bindings once all the sandboxed services are - // allocated, which will be very likely to have some of them killed by OOM killer. - getBindingManager().releaseAllModerateBindings(); - } - - // Popuplate the bundle passed to the service setup call with content specific parameters. - connectionBundle.putInt( - ContentChildProcessConstants.EXTRA_CPU_COUNT, CpuFeatures.getCount()); - connectionBundle.putLong( - ContentChildProcessConstants.EXTRA_CPU_FEATURES, CpuFeatures.getMask()); - connectionBundle.putBundle( - Linker.EXTRA_LINKER_SHARED_RELROS, Linker.getInstance().getSharedRelros()); - } - - private void onConnectionEstablished(ChildProcessConnection connection) { - if (mSandboxed) { - getBindingManager().addNewConnection(connection.getPid(), connection); - } - } - - // Called when a connection has been disconnected. Only invoked if onConnectionEstablished was - // called, meaning the connection was already established. - private void onConnectionLost(ChildProcessConnection connection, int pid) { - if (mSandboxed) { - getBindingManager().removeConnection(pid); - } - } - - private IBinder getIBinderCallback() { - return mIBinderCallback; + public static ChildProcessLauncherHelper getByPid(int pid) { + return sLauncherByPid.get(pid); } // Testing only related methods. @@ -682,18 +530,12 @@ ChildProcessCreationParams creationParams, String[] commandLine, FileDescriptorInfo[] filesToBeMapped, boolean sandboxed, IBinder binderCallback, boolean doSetupConnection) { - ChildProcessLauncherHelper launcherHelper = - new ChildProcessLauncherHelper(0L, creationParams, commandLine, filesToBeMapped, - sandboxed, binderCallback, doSetupConnection); - launcherHelper.start(); + ChildProcessLauncherHelper launcherHelper = new ChildProcessLauncherHelper( + 0L, creationParams, commandLine, filesToBeMapped, sandboxed, binderCallback); + launcherHelper.mLauncher.start(doSetupConnection, true /* queueIfNoFreeConnection */); return launcherHelper; } - @VisibleForTesting - public static ChildProcessLauncherHelper getLauncherForPid(int pid) { - return sLauncherByPid.get(pid); - } - /** @return the count of services set-up and working. */ @VisibleForTesting static int getConnectedServicesCountForTesting() { @@ -720,18 +562,13 @@ } @VisibleForTesting - ChildProcessConnection getConnection() { - return mConnection; - } - - @VisibleForTesting public ChildProcessConnection getChildProcessConnection() { - return mConnection; + return mLauncher.getConnection(); } @VisibleForTesting public ChildConnectionAllocator getChildConnectionAllocatorForTesting() { - return mConnectionAllocator; + return mLauncher.getConnectionAllocator(); } @VisibleForTesting @@ -743,9 +580,8 @@ public static boolean crashProcessForTesting(int pid) { if (sLauncherByPid.get(pid) == null) return false; - ChildProcessConnection connection = sLauncherByPid.get(pid).mConnection; + ChildProcessConnection connection = sLauncherByPid.get(pid).mLauncher.getConnection(); if (connection == null) return false; - try { connection.crashServiceForTesting(); return true;
diff --git a/content/public/android/java/src/org/chromium/content/browser/SpareChildConnection.java b/content/public/android/java/src/org/chromium/content/browser/SpareChildConnection.java index dec2322a..6538cc7 100644 --- a/content/public/android/java/src/org/chromium/content/browser/SpareChildConnection.java +++ b/content/public/android/java/src/org/chromium/content/browser/SpareChildConnection.java
@@ -84,8 +84,7 @@ public ChildProcessConnection getConnection(ChildConnectionAllocator allocator, @NonNull final ChildProcessConnection.ServiceCallback serviceCallback) { assert LauncherThread.runningOnLauncherThread(); - if (mConnection == null || allocator != mConnectionAllocator - || mConnectionServiceCallback != null) { + if (isEmpty() || !isForAllocator(allocator) || mConnectionServiceCallback != null) { return null; } @@ -117,6 +116,11 @@ return mConnection == null || mConnectionServiceCallback != null; } + /** Returns true if this spare connection uses {@param allocator}. */ + public boolean isForAllocator(ChildConnectionAllocator allocator) { + return mConnectionAllocator == allocator; + } + private void clearConnection() { assert LauncherThread.runningOnLauncherThread(); mConnection = null;
diff --git a/content/public/android/javatests/src/org/chromium/content/browser/ChildProcessLauncherHelperTest.java b/content/public/android/javatests/src/org/chromium/content/browser/ChildProcessLauncherHelperTest.java new file mode 100644 index 0000000..3e87a5f --- /dev/null +++ b/content/public/android/javatests/src/org/chromium/content/browser/ChildProcessLauncherHelperTest.java
@@ -0,0 +1,563 @@ +// Copyright 2014 The Chromium Authors. All rights reserved. +// Use of this source code is governed by a BSD-style license that can be +// found in the LICENSE file. + +package org.chromium.content.browser; + +import android.content.ComponentName; +import android.content.Context; +import android.content.Intent; +import android.content.ServiceConnection; +import android.os.Handler; +import android.os.IBinder; +import android.os.Looper; +import android.os.Message; +import android.os.Messenger; +import android.os.RemoteException; +import android.support.test.InstrumentationRegistry; +import android.support.test.filters.MediumTest; + +import org.junit.Assert; +import org.junit.Before; +import org.junit.Test; +import org.junit.runner.RunWith; + +import org.chromium.base.BaseSwitches; +import org.chromium.base.ThreadUtils; +import org.chromium.base.library_loader.LibraryLoader; +import org.chromium.base.library_loader.LibraryProcessType; +import org.chromium.base.process_launcher.ChildProcessCreationParams; +import org.chromium.base.process_launcher.FileDescriptorInfo; +import org.chromium.base.test.util.Feature; +import org.chromium.content.browser.test.ChildProcessAllocatorSettings; +import org.chromium.content.browser.test.ContentJUnit4ClassRunner; +import org.chromium.content.browser.test.util.Criteria; +import org.chromium.content.browser.test.util.CriteriaHelper; +import org.chromium.content_shell_apk.ChildProcessLauncherTestHelperService; +import org.chromium.content_shell_apk.ChildProcessLauncherTestUtils; + +import java.util.concurrent.Callable; + +/** + * Instrumentation tests for ChildProcessLauncher. + */ +@RunWith(ContentJUnit4ClassRunner.class) +public class ChildProcessLauncherHelperTest { + // Pseudo command line arguments to instruct the child process to wait until being killed. + // Allowing the process to continue would lead to a crash when attempting to initialize IPC + // channels that are not being set up in this test. + private static final String[] sProcessWaitArguments = { + "_", "--" + BaseSwitches.RENDERER_WAIT_FOR_JAVA_DEBUGGER}; + private static final String EXTERNAL_APK_PACKAGE_NAME = "org.chromium.external.apk"; + private static final String DEFAULT_SANDBOXED_PROCESS_SERVICE = + "org.chromium.content.app.SandboxedProcessService"; + + private static final int DONT_BLOCK = 0; + private static final int BLOCK_UNTIL_CONNECTED = 1; + private static final int BLOCK_UNTIL_SETUP = 2; + + @Before + public void setUp() throws Exception { + LibraryLoader.get(LibraryProcessType.PROCESS_CHILD).ensureInitialized(); + } + + /** + * Tests that external APKs and regular use different ChildConnectionAllocators. + */ + @Test + @MediumTest + @Feature({"ProcessManagement"}) + @ChildProcessAllocatorSettings( + sandboxedServiceCount = 4, sandboxedServiceName = DEFAULT_SANDBOXED_PROCESS_SERVICE) + public void testAllocatorForPackage() { + Context appContext = InstrumentationRegistry.getInstrumentation().getTargetContext(); + + ChildConnectionAllocator connectionAllocator = getChildConnectionAllocator( + appContext, appContext.getPackageName(), true /* sandboxed */); + ChildConnectionAllocator externalConnectionAllocator = getChildConnectionAllocator( + appContext, EXTERNAL_APK_PACKAGE_NAME, true /* sandboxed */); + Assert.assertNotEquals(connectionAllocator, externalConnectionAllocator); + } + + /** + * Tests binding to the same sandboxed service process from multiple processes in the + * same package. This uses the ChildProcessLauncherTestHelperService declared in + * ContentShell.apk as a separate android:process to bind the first (slot 0) service. The + * instrumentation test then tries to bind the same slot, which fails, so the + * ChildProcessLauncher retries on a new connection. + */ + @Test + @MediumTest + @Feature({"ProcessManagement"}) + public void testBindServiceFromMultipleProcesses() throws RemoteException { + final Context context = InstrumentationRegistry.getInstrumentation().getTargetContext(); + + // Start the Helper service. + class HelperConnection implements ServiceConnection { + Messenger mMessenger = null; + + @Override + public void onServiceConnected(ComponentName name, IBinder service) { + mMessenger = new Messenger(service); + } + + @Override + public void onServiceDisconnected(ComponentName name) {} + } + final HelperConnection serviceConnection = new HelperConnection(); + + Intent intent = new Intent(); + intent.setComponent(new ComponentName(context.getPackageName(), + context.getPackageName() + ".ChildProcessLauncherTestHelperService")); + Assert.assertTrue(context.bindService(intent, serviceConnection, Context.BIND_AUTO_CREATE)); + + // Wait for the Helper service to connect. + CriteriaHelper.pollInstrumentationThread( + new Criteria("Failed to get helper service Messenger") { + @Override + public boolean isSatisfied() { + return serviceConnection.mMessenger != null; + } + }); + + Assert.assertNotNull(serviceConnection.mMessenger); + + class ReplyHandler implements Handler.Callback { + Message mMessage; + + @Override + public boolean handleMessage(Message msg) { + // Copy the message so its contents outlive this Binder transaction. + mMessage = Message.obtain(); + mMessage.copyFrom(msg); + return true; + } + } + final ReplyHandler replyHandler = new ReplyHandler(); + + // Send a message to the Helper and wait for the reply. This will cause the slot 0 + // sandboxed service connection to be bound by a different PID (i.e., not this process). + Message msg = Message.obtain(null, ChildProcessLauncherTestHelperService.MSG_BIND_SERVICE); + msg.replyTo = new Messenger(new Handler(Looper.getMainLooper(), replyHandler)); + serviceConnection.mMessenger.send(msg); + + CriteriaHelper.pollInstrumentationThread( + new Criteria("Failed waiting for helper service reply") { + @Override + public boolean isSatisfied() { + return replyHandler.mMessage != null; + } + }); + + // Verify that the Helper was able to launch the sandboxed service. + Assert.assertNotNull(replyHandler.mMessage); + Assert.assertEquals(ChildProcessLauncherTestHelperService.MSG_BIND_SERVICE_REPLY, + replyHandler.mMessage.what); + Assert.assertEquals( + "Connection slot from helper service is not 0", 0, replyHandler.mMessage.arg2); + + final int helperConnectionPid = replyHandler.mMessage.arg1; + Assert.assertTrue(helperConnectionPid > 0); + + // Launch a service from this process. Since slot 0 is already bound by the Helper, it + // will fail to start and the ChildProcessLauncher will retry and use the slot 1. + ChildProcessCreationParams creationParams = new ChildProcessCreationParams( + context.getPackageName(), false /* isExternalService */, + LibraryProcessType.PROCESS_CHILD, true /* bindToCallerCheck */); + ChildProcessLauncherHelper launcher = startSandboxedChildProcessWithCreationParams( + creationParams, BLOCK_UNTIL_SETUP, true /* doSetupConnection */); + + final ChildProcessConnection retryConnection = + ChildProcessLauncherTestUtils.getConnection(launcher); + Assert.assertEquals( + 1, ChildProcessLauncherTestUtils.getConnectionServiceNumber(retryConnection)); + + ChildConnectionAllocator connectionAllocator = + launcher.getChildConnectionAllocatorForTesting(); + + // Check that only two connections are created. + for (int i = 0; i < connectionAllocator.getNumberOfServices(); ++i) { + ChildProcessConnection sandboxedConn = + connectionAllocator.getChildProcessConnectionAtSlotForTesting(i); + if (i <= 1) { + Assert.assertNotNull(sandboxedConn); + Assert.assertNotNull( + ChildProcessLauncherTestUtils.getConnectionService(sandboxedConn)); + } else { + Assert.assertNull(sandboxedConn); + } + } + + Assert.assertEquals( + connectionAllocator.getChildProcessConnectionAtSlotForTesting(1), retryConnection); + + ChildProcessConnection failedConnection = + connectionAllocator.getChildProcessConnectionAtSlotForTesting(0); + Assert.assertEquals(0, ChildProcessLauncherTestUtils.getConnectionPid(failedConnection)); + Assert.assertFalse(ChildProcessLauncherTestUtils.getConnectionService(failedConnection) + .bindToCaller()); + + CriteriaHelper.pollInstrumentationThread( + new Criteria("Failed waiting retry connection to get pid") { + @Override + public boolean isSatisfied() { + return ChildProcessLauncherTestUtils.getConnectionPid(retryConnection) > 0; + } + }); + Assert.assertTrue(ChildProcessLauncherTestUtils.getConnectionPid(retryConnection) + != helperConnectionPid); + Assert.assertTrue( + ChildProcessLauncherTestUtils.getConnectionService(retryConnection).bindToCaller()); + } + + private static void warmUpOnUiThreadBlocking(final Context context) { + ThreadUtils.runOnUiThreadBlocking(new Runnable() { + @Override + public void run() { + ChildProcessLauncherHelper.warmUp(context); + } + }); + ChildProcessConnection connection = getWarmUpConnection(); + Assert.assertNotNull(connection); + blockUntilConnected(connection); + } + + private void testWarmUpWithCreationParams(ChildProcessCreationParams creationParams) { + if (creationParams != null) { + ChildProcessCreationParams.registerDefault(creationParams); + } + + Context context = InstrumentationRegistry.getInstrumentation().getTargetContext(); + warmUpOnUiThreadBlocking(context); + + Assert.assertEquals(1, getConnectedSandboxedServicesCount()); + + ChildProcessLauncherHelper launcherHelper = startSandboxedChildProcessWithCreationParams( + creationParams, BLOCK_UNTIL_SETUP, true /* doSetupConnection */); + + // The warm-up connection was used, so no new process should have been created. + Assert.assertEquals(1, getConnectedSandboxedServicesCount()); + + int pid = getPid(launcherHelper); + Assert.assertNotEquals(0, pid); + + stopProcess(launcherHelper); + + waitForConnectedSandboxedServicesCount(0); + } + + @Test + @MediumTest + @Feature({"ProcessManagement"}) + public void testWarmUp() { + // Use the default creation parameters. + testWarmUpWithCreationParams(null /* creationParams */); + } + + @Test + @MediumTest + @Feature({"ProcessManagement"}) + public void testWarmUpWithBindToCaller() { + Context context = InstrumentationRegistry.getInstrumentation().getTargetContext(); + ChildProcessCreationParams creationParams = new ChildProcessCreationParams( + context.getPackageName(), false /* isExternalService */, + LibraryProcessType.PROCESS_CHILD, true /* bindToCallerCheck */); + testWarmUpWithCreationParams(creationParams); + } + + // Tests that the warm-up connection is freed from its allocator if it crashes. + @Test + @MediumTest + @Feature({"ProcessManagement"}) + public void testWarmUpProcessCrashBeforeUse() throws RemoteException { + Assert.assertEquals(0, getConnectedSandboxedServicesCount()); + + Context context = InstrumentationRegistry.getInstrumentation().getTargetContext(); + warmUpOnUiThreadBlocking(context); + + Assert.assertEquals(1, getConnectedSandboxedServicesCount()); + + // Crash the warm-up connection before it gets used. + ChildProcessConnection connection = getWarmUpConnection(); + Assert.assertNotNull(connection); + connection.crashServiceForTesting(); + + // It should get cleaned-up. + waitForConnectedSandboxedServicesCount(0); + + // And subsequent process launches should work. + ChildProcessLauncherHelper launcher = startSandboxedChildProcess( + null /* packageName */, BLOCK_UNTIL_SETUP, true /* doSetupConnection */); + Assert.assertEquals(1, getConnectedSandboxedServicesCount()); + Assert.assertNotNull(ChildProcessLauncherTestUtils.getConnection(launcher)); + } + + // Tests that the warm-up connection is freed from its allocator if it crashes after being used. + @Test + @MediumTest + @Feature({"ProcessManagement"}) + public void testWarmUpProcessCrashAfterUse() throws RemoteException { + Context context = InstrumentationRegistry.getInstrumentation().getTargetContext(); + warmUpOnUiThreadBlocking(context); + + Assert.assertEquals(1, getConnectedSandboxedServicesCount()); + + ChildProcessLauncherHelper launcherHelper = startSandboxedChildProcessWithCreationParams( + null /* creationParams */, BLOCK_UNTIL_SETUP, true /* doSetupConnection */); + + // The warm-up connection was used, so no new process should have been created. + Assert.assertEquals(1, getConnectedSandboxedServicesCount()); + + int pid = getPid(launcherHelper); + Assert.assertNotEquals(0, pid); + + ChildProcessConnection connection = retrieveConnection(launcherHelper); + connection.crashServiceForTesting(); + + waitForConnectedSandboxedServicesCount(0); + } + + @Test + @MediumTest + @Feature({"ProcessManagement"}) + public void testSandboxedAllocatorFreed() { + final String packageName = + InstrumentationRegistry.getInstrumentation().getTargetContext().getPackageName(); + + ChildProcessLauncherHelper launcher = startSandboxedChildProcess( + null /* packageName */, BLOCK_UNTIL_SETUP, true /* doSetupConnection */); + + Assert.assertTrue(hasSandboxedConnectionAllocatorForPackage(packageName)); + + stopProcess(launcher); + + // Poll until allocator is removed. Need to poll here because actually freeing a connection + // from allocator is a posted task, rather than a direct call from stop. + CriteriaHelper.pollInstrumentationThread( + new Criteria("The connection allocator was not removed.") { + @Override + public boolean isSatisfied() { + return !hasSandboxedConnectionAllocatorForPackage(packageName); + } + }); + } + + @Test + @MediumTest + @Feature({"ProcessManagement"}) + @ChildProcessAllocatorSettings(sandboxedServiceCount = 4) + public void testCustomCreationParamDoesNotReuseWarmupConnection() { + // Since warmUp only uses default params. + final Context context = InstrumentationRegistry.getInstrumentation().getTargetContext(); + ChildProcessCreationParams defaultCreationParams = + getDefaultChildProcessCreationParams(context.getPackageName()); + ChildProcessCreationParams.registerDefault(defaultCreationParams); + ChildProcessCreationParams otherCreationParams = getDefaultChildProcessCreationParams( + InstrumentationRegistry.getInstrumentation().getContext().getPackageName()); + + warmUpOnUiThreadBlocking(context); + Assert.assertEquals(1, getConnectedSandboxedServicesCount()); + + // First create a connnection with different creation params than the default, it should not + // use the warmup connection (note that it won't bind since we are using the wrong package, + // but we need to use a different package to differentiate them, and we can only have 1 + // valid package per app). + startSandboxedChildProcessWithCreationParams( + otherCreationParams, DONT_BLOCK, false /* doSetupConnection */); + Assert.assertNotNull(getWarmUpConnection()); + + // Then start a process with the default creation params, the warmup-connection should be + // used. + startSandboxedChildProcessWithCreationParams( + defaultCreationParams, BLOCK_UNTIL_SETUP, true /* doSetupConnection */); + Assert.assertNull(getWarmUpConnection()); + } + + @Test + @MediumTest + @Feature({"ProcessManagement"}) + public void testLauncherCleanup() throws RemoteException { + ChildProcessLauncherHelper launcher = startSandboxedChildProcess( + null /* packageName */, BLOCK_UNTIL_SETUP, true /* doSetupConnection */); + int pid = getPid(launcher); + Assert.assertNotEquals(0, pid); + + // Stop the process explicitly, the launcher should get cleared. + stopProcess(launcher); + waitForConnectedSandboxedServicesCount(0); + + launcher = startSandboxedChildProcess( + null /* packageName */, BLOCK_UNTIL_SETUP, true /* doSetupConnection */); + pid = getPid(launcher); + Assert.assertNotEquals(0, pid); + + // This time crash the connection, the launcher should also get cleared. + ChildProcessConnection connection = retrieveConnection(launcher); + connection.crashServiceForTesting(); + waitForConnectedSandboxedServicesCount(0); + } + + private static ChildProcessLauncherHelper startSandboxedChildProcess( + final String packageName, int blockingPolicy, final boolean doSetupConnection) { + ChildProcessCreationParams creationParams = + packageName == null ? null : getDefaultChildProcessCreationParams(packageName); + return startSandboxedChildProcessWithCreationParams( + creationParams, blockingPolicy, doSetupConnection); + } + + private static ChildProcessLauncherHelper startSandboxedChildProcessWithCreationParams( + final ChildProcessCreationParams creationParams, int blockingPolicy, + final boolean doSetupConnection) { + assert doSetupConnection || blockingPolicy != BLOCK_UNTIL_SETUP; + ChildProcessLauncherHelper launcher = + ChildProcessLauncherTestUtils.runOnLauncherAndGetResult( + new Callable<ChildProcessLauncherHelper>() { + @Override + public ChildProcessLauncherHelper call() { + return ChildProcessLauncherHelper.createAndStartForTesting( + creationParams, sProcessWaitArguments, + new FileDescriptorInfo[0], true /* sandboxed */, + null /* binderCallback */, doSetupConnection); + } + }); + if (blockingPolicy != DONT_BLOCK) { + assert blockingPolicy == BLOCK_UNTIL_CONNECTED || blockingPolicy == BLOCK_UNTIL_SETUP; + blockUntilConnected(launcher); + if (blockingPolicy == BLOCK_UNTIL_SETUP) { + blockUntilSetup(launcher); + } + } + return launcher; + } + + private static void blockUntilConnected(final ChildProcessLauncherHelper launcher) { + CriteriaHelper.pollInstrumentationThread( + new Criteria("The connection wasn't established.") { + @Override + public boolean isSatisfied() { + return launcher.getChildProcessConnection() != null + && launcher.getChildProcessConnection().isConnected(); + } + }); + } + + private static void blockUntilConnected(final ChildProcessConnection connection) { + CriteriaHelper.pollInstrumentationThread( + new Criteria("The connection wasn't established.") { + @Override + public boolean isSatisfied() { + return connection.isConnected(); + } + }); + } + + private static void blockUntilSetup(final ChildProcessLauncherHelper launcher) { + CriteriaHelper.pollInstrumentationThread( + new Criteria("The connection wasn't established.") { + @Override + public boolean isSatisfied() { + return getPid(launcher) != 0; + } + }); + } + + private static ChildConnectionAllocator getChildConnectionAllocator( + final Context context, final String packageName, final boolean sandboxed) { + return ChildProcessLauncherTestUtils.runOnLauncherAndGetResult( + new Callable<ChildConnectionAllocator>() { + @Override + public ChildConnectionAllocator call() { + return ChildProcessLauncherHelper.getConnectionAllocator(context, + getDefaultChildProcessCreationParams(packageName), sandboxed); + } + }); + } + + // Returns the number of sandboxed connection currently connected, + private static int getConnectedSandboxedServicesCount() { + return getConnectedSandboxedServicesCountForPackage(null /* packageName */); + } + + // Returns the number of sandboxed connection matching the specificed package name that are + // connected, + private static int getConnectedSandboxedServicesCountForPackage(final String packageName) { + return ChildProcessLauncherTestUtils.runOnLauncherAndGetResult(new Callable<Integer>() { + @Override + public Integer call() { + return ChildProcessLauncherHelper.getConnectedSandboxedServicesCountForTesting( + packageName); + } + }); + } + + // Blocks until the number of sandboxed connections reaches targetCount. + private static void waitForConnectedSandboxedServicesCount(int targetCount) { + CriteriaHelper.pollInstrumentationThread( + Criteria.equals(targetCount, new Callable<Integer>() { + @Override + public Integer call() { + return getConnectedSandboxedServicesCountForPackage(null /* packageName */); + } + })); + } + + private static ChildProcessCreationParams getDefaultChildProcessCreationParams( + String packageName) { + return packageName == null + ? null + : new ChildProcessCreationParams(packageName, false /* isExternalService */, + LibraryProcessType.PROCESS_CHILD, false /* bindToCallerCheck */); + } + + private static boolean hasSandboxedConnectionAllocatorForPackage(final String packageName) { + return ChildProcessLauncherTestUtils.runOnLauncherAndGetResult(new Callable<Boolean>() { + @Override + public Boolean call() { + return ChildProcessLauncherHelper.hasSandboxedConnectionAllocatorForPackage( + packageName); + } + }); + } + + private static ChildProcessConnection retrieveConnection( + final ChildProcessLauncherHelper launcherHelper) { + CriteriaHelper.pollInstrumentationThread( + new Criteria("Failed waiting for child process to connect") { + @Override + public boolean isSatisfied() { + return ChildProcessLauncherTestUtils.getConnection(launcherHelper) != null; + } + }); + + return ChildProcessLauncherTestUtils.getConnection(launcherHelper); + } + + private static void stopProcess(ChildProcessLauncherHelper launcherHelper) { + final ChildProcessConnection connection = retrieveConnection(launcherHelper); + ChildProcessLauncherTestUtils.runOnLauncherThreadBlocking(new Runnable() { + @Override + public void run() { + ChildProcessLauncherHelper.stop(connection.getPid()); + } + }); + } + + private static int getPid(final ChildProcessLauncherHelper launcherHelper) { + return ChildProcessLauncherTestUtils.runOnLauncherAndGetResult(new Callable<Integer>() { + @Override + public Integer call() { + return launcherHelper.getPid(); + } + }); + } + + private static ChildProcessConnection getWarmUpConnection() { + return ChildProcessLauncherTestUtils.runOnLauncherAndGetResult( + new Callable<ChildProcessConnection>() { + @Override + public ChildProcessConnection call() { + return ChildProcessLauncherHelper.getWarmUpConnectionForTesting(); + } + }); + } +}
diff --git a/content/public/android/javatests/src/org/chromium/content/browser/ChildProcessLauncherTest.java b/content/public/android/javatests/src/org/chromium/content/browser/ChildProcessLauncherTest.java index 3a36065f..5ff7ab2 100644 --- a/content/public/android/javatests/src/org/chromium/content/browser/ChildProcessLauncherTest.java +++ b/content/public/android/javatests/src/org/chromium/content/browser/ChildProcessLauncherTest.java
@@ -1,4 +1,4 @@ -// Copyright 2014 The Chromium Authors. All rights reserved. +// Copyright 2017 The Chromium Authors. All rights reserved. // Use of this source code is governed by a BSD-style license that can be // found in the LICENSE file. @@ -6,15 +6,11 @@ import android.content.ComponentName; import android.content.Context; -import android.content.Intent; -import android.content.ServiceConnection; -import android.os.Handler; +import android.os.Bundle; import android.os.IBinder; -import android.os.Looper; -import android.os.Message; -import android.os.Messenger; import android.os.RemoteException; import android.support.test.InstrumentationRegistry; +import android.support.test.filters.LargeTest; import android.support.test.filters.MediumTest; import org.junit.Assert; @@ -22,49 +18,381 @@ import org.junit.Test; import org.junit.runner.RunWith; -import org.chromium.base.BaseSwitches; -import org.chromium.base.ThreadUtils; -import org.chromium.base.library_loader.LibraryLoader; -import org.chromium.base.library_loader.LibraryProcessType; -import org.chromium.base.process_launcher.ChildProcessCreationParams; import org.chromium.base.process_launcher.FileDescriptorInfo; +import org.chromium.base.test.util.CallbackHelper; import org.chromium.base.test.util.Feature; -import org.chromium.content.browser.test.ChildProcessAllocatorSettings; import org.chromium.content.browser.test.ContentJUnit4ClassRunner; import org.chromium.content.browser.test.util.Criteria; import org.chromium.content.browser.test.util.CriteriaHelper; -import org.chromium.content_shell_apk.ChildProcessLauncherTestHelperService; import org.chromium.content_shell_apk.ChildProcessLauncherTestUtils; +import org.chromium.content_shell_apk.IChildProcessTest; import java.util.concurrent.Callable; +import java.util.concurrent.TimeoutException; +import java.util.concurrent.atomic.AtomicReference; /** * Instrumentation tests for ChildProcessLauncher. */ @RunWith(ContentJUnit4ClassRunner.class) public class ChildProcessLauncherTest { - // Pseudo command line arguments to instruct the child process to wait until being killed. - // Allowing the process to continue would lead to a crash when attempting to initialize IPC - // channels that are not being set up in this test. - private static final String[] sProcessWaitArguments = { - "_", "--" + BaseSwitches.RENDERER_WAIT_FOR_JAVA_DEBUGGER }; - private static final String EXTERNAL_APK_PACKAGE_NAME = "org.chromium.external.apk"; - private static final String DEFAULT_SANDBOXED_PROCESS_SERVICE = - "org.chromium.content.app.SandboxedProcessService"; + private static final long CONDITION_WAIT_TIMEOUT_MS = 5000; - private static final int DONT_BLOCK = 0; - private static final int BLOCK_UNTIL_CONNECTED = 1; - private static final int BLOCK_UNTIL_SETUP = 2; + private static final String SERVICE_PACKAGE_NAME = "org.chromium.content_shell_apk"; + private static final String SERVICE_NAME_META_DATA_KEY = + "org.chromium.content.browser.TEST_SERVICES_NAME"; + private static final String SERVICE_COUNT_META_DATA_KEY = + "org.chromium.content.browser.NUM_TEST_SERVICES"; + private static final String SERVICE0_FULL_NAME = + "org.chromium.content_shell_apk.TestChildProcessService0"; + + private static final String EXTRA_SERVICE_PARAM = "org.chromium.content.browser.SERVICE_EXTRA"; + private static final String EXTRA_SERVICE_PARAM_VALUE = "SERVICE_EXTRA"; + + private static final String EXTRA_CONNECTION_PARAM = + "org.chromium.content.browser.CONNECTION_EXTRA"; + private static final String EXTRA_CONNECTION_PARAM_VALUE = "CONNECTION_EXTRA"; + + private static final int CONNECTION_BLOCK_UNTIL_CONNECTED = 1; + private static final int CONNECTION_BLOCK_UNTIL_SETUP = 2; + + /** + * A factory used to create a ChildProcessLauncher with a bound connection or with a connection + * connection allocator so that the test code can be reused for both scenarios. + */ + private abstract static class ChildProcessLauncherFactory { + private final boolean mConnectionProvided; + + public ChildProcessLauncherFactory(boolean connectionProvided) { + mConnectionProvided = connectionProvided; + } + + public abstract ChildProcessLauncher createChildProcessLauncher( + ChildProcessLauncher.Delegate delegate, String[] commandLine, + FileDescriptorInfo[] filesToBeMapped, IBinder binderCallback); + + public boolean isConnectionProvided() { + return mConnectionProvided; + } + } + + private static final ChildProcessLauncher.Delegate EMPTY_LAUNCHER_DELEGATE = + new ChildProcessLauncher.Delegate() { + @Override + public void onBeforeConnectionAllocated(Bundle serviceBundle) {} + + @Override + public void onBeforeConnectionSetup(Bundle connectionBundle) {} + + @Override + public void onConnectionEstablished(ChildProcessConnection connection) {} + + @Override + public void onConnectionLost(ChildProcessConnection connection) {} + }; + + private ChildConnectionAllocator mConnectionAllocator; @Before public void setUp() throws Exception { - LibraryLoader.get(LibraryProcessType.PROCESS_CHILD).ensureInitialized(); + mConnectionAllocator = ChildProcessLauncherTestUtils.runOnLauncherAndGetResult( + new Callable<ChildConnectionAllocator>() { + @Override + public ChildConnectionAllocator call() { + Context context = + InstrumentationRegistry.getInstrumentation().getTargetContext(); + return ChildConnectionAllocator.create(context, null /* creationParams */, + SERVICE_PACKAGE_NAME, SERVICE_NAME_META_DATA_KEY, + SERVICE_COUNT_META_DATA_KEY, false /* bindAsExternalService */, + false /* useStrongBinding */); + } + }); + } + + private static class IChildProcessBinder extends IChildProcessTest.Stub { + private final CallbackHelper mOnConnectionSetupHelper = new CallbackHelper(); + private final CallbackHelper mOnLoadNativeHelper = new CallbackHelper(); + private final CallbackHelper mOnBeforeMainHelper = new CallbackHelper(); + private final CallbackHelper mOnRunMainHelper = new CallbackHelper(); + private final CallbackHelper mOnDestroyHelper = new CallbackHelper(); + + // Can be accessed after mOnConnectionSetupCalled is signaled. + private boolean mServiceCreated; + private Bundle mServiceBundle; + private Bundle mConnectionBundle; + + // Can be accessed after mOnLoadNativeCalled is signaled. + private boolean mNativeLibraryLoaded; + + // Can be accessed after mOnBeforeMainCalled is signaled. + private String[] mCommandLine; + + @Override + public void onConnectionSetup( + boolean serviceCreatedCalled, Bundle serviceBundle, Bundle connectionBundle) { + mServiceCreated = serviceCreatedCalled; + mServiceBundle = serviceBundle; + mConnectionBundle = connectionBundle; + Assert.assertEquals(0, mOnConnectionSetupHelper.getCallCount()); + mOnConnectionSetupHelper.notifyCalled(); + } + + @Override + public void onLoadNativeLibrary(boolean loadedSuccessfully) { + mNativeLibraryLoaded = loadedSuccessfully; + Assert.assertEquals(0, mOnLoadNativeHelper.getCallCount()); + mOnLoadNativeHelper.notifyCalled(); + } + + @Override + public void onBeforeMain(String[] commandLine) { + mCommandLine = commandLine; + Assert.assertEquals(0, mOnBeforeMainHelper.getCallCount()); + mOnBeforeMainHelper.notifyCalled(); + } + + @Override + public void onRunMain() { + Assert.assertEquals(0, mOnRunMainHelper.getCallCount()); + mOnRunMainHelper.notifyCalled(); + } + + @Override + public void onDestroy() { + Assert.assertEquals(0, mOnDestroyHelper.getCallCount()); + mOnDestroyHelper.notifyCalled(); + } + + public void waitForOnConnectionSetupCalled() throws InterruptedException, TimeoutException { + mOnConnectionSetupHelper.waitForCallback(0 /* currentCallCount */); + } + + public void waitForOnNativeLibraryCalled() throws InterruptedException, TimeoutException { + mOnLoadNativeHelper.waitForCallback(0 /* currentCallCount */); + } + + public void waitOnBeforeMainCalled() throws InterruptedException, TimeoutException { + mOnBeforeMainHelper.waitForCallback(0 /* currentCallCount */); + } + + public void waitOnRunMainCalled() throws InterruptedException, TimeoutException { + mOnRunMainHelper.waitForCallback(0 /* currentCallCount */); + } + + public void waitOnDestroyCalled() throws InterruptedException, TimeoutException { + mOnDestroyHelper.waitForCallback(0 /* currentCallCount */); + } + }; + + /** + * Creates a child process with the ChildProcessLauncher created with {@param launcherFactory} + * and tests that the all callbacks on the client and in the service are called appropriately. + * The service echos back the delegate calls through the IBinder callback so that the test can + * validate them. + */ + private void testProcessLauncher(final ChildProcessLauncherFactory launcherFactory) + throws InterruptedException, TimeoutException { + // ConditionVariables used to check the ChildProcessLauncher.Delegate methods get called. + final CallbackHelper onBeforeConnectionAllocatedHelper = new CallbackHelper(); + final CallbackHelper onBeforeConnectionSetupHelper = new CallbackHelper(); + final CallbackHelper onConnectionEstablishedHelper = new CallbackHelper(); + final CallbackHelper onConnectionLostHelper = new CallbackHelper(); + + final ChildProcessLauncher.Delegate delegate = new ChildProcessLauncher.Delegate() { + @Override + public void onBeforeConnectionAllocated(Bundle serviceBundle) { + // Should only be called when the ChildProcessLauncher creates the connection. + Assert.assertFalse(launcherFactory.isConnectionProvided()); + Assert.assertEquals(0, onBeforeConnectionAllocatedHelper.getCallCount()); + serviceBundle.putString(EXTRA_SERVICE_PARAM, EXTRA_SERVICE_PARAM_VALUE); + onBeforeConnectionAllocatedHelper.notifyCalled(); + } + + @Override + public void onBeforeConnectionSetup(Bundle connectionBundle) { + connectionBundle.putString(EXTRA_CONNECTION_PARAM, EXTRA_CONNECTION_PARAM_VALUE); + Assert.assertEquals(0, onBeforeConnectionSetupHelper.getCallCount()); + onBeforeConnectionSetupHelper.notifyCalled(); + } + + @Override + public void onConnectionEstablished(ChildProcessConnection connection) { + Assert.assertEquals(0, onConnectionEstablishedHelper.getCallCount()); + onConnectionEstablishedHelper.notifyCalled(); + } + + @Override + public void onConnectionLost(ChildProcessConnection connection) { + Assert.assertEquals(0, onConnectionLostHelper.getCallCount()); + onConnectionLostHelper.notifyCalled(); + } + }; + + final String[] commandLine = new String[] {"--test-param1", "--test-param2"}; + final FileDescriptorInfo[] filesToBeMapped = new FileDescriptorInfo[0]; + + final IChildProcessBinder childProcessBinder = new IChildProcessBinder(); + + final ChildProcessLauncher processLauncher = + ChildProcessLauncherTestUtils.runOnLauncherAndGetResult( + new Callable<ChildProcessLauncher>() { + @Override + public ChildProcessLauncher call() { + ChildProcessLauncher processLauncher = + launcherFactory.createChildProcessLauncher(delegate, + commandLine, filesToBeMapped, childProcessBinder); + processLauncher.start(true /* setupConnection */, + false /*queueIfNoFreeConnection */); + return processLauncher; + } + }); + + Assert.assertNotNull(processLauncher); + + if (!launcherFactory.isConnectionProvided()) { + onBeforeConnectionAllocatedHelper.waitForCallback(0 /* currentCallback */); + } + + onBeforeConnectionSetupHelper.waitForCallback(0 /* currentCallback */); + + // Wait for the service to notify its onConnectionSetup was called. + childProcessBinder.waitForOnConnectionSetupCalled(); + Assert.assertTrue(childProcessBinder.mServiceCreated); + Assert.assertNotNull(childProcessBinder.mServiceBundle); + Assert.assertNotNull(childProcessBinder.mConnectionBundle); + if (!launcherFactory.isConnectionProvided()) { + Assert.assertEquals(EXTRA_SERVICE_PARAM_VALUE, + childProcessBinder.mServiceBundle.getString(EXTRA_SERVICE_PARAM)); + } + Assert.assertEquals(EXTRA_CONNECTION_PARAM_VALUE, + childProcessBinder.mConnectionBundle.getString(EXTRA_CONNECTION_PARAM)); + + // Wait for the client onConnectionEstablished call. + onConnectionEstablishedHelper.waitForCallback(0 /* currentCallback */); + + // Wait for the service to notify its library got loaded. + childProcessBinder.waitForOnNativeLibraryCalled(); + Assert.assertTrue(childProcessBinder.mNativeLibraryLoaded); + + // Wait for the service to notify its onBeforeMain was called. + childProcessBinder.waitOnBeforeMainCalled(); + Assert.assertArrayEquals(commandLine, childProcessBinder.mCommandLine); + + // Wait for the service to notify its onRunMain was called. + childProcessBinder.waitOnRunMainCalled(); + + // Stop the launcher. ChildProcessLauncherTestUtils.runOnLauncherThreadBlocking(new Runnable() { @Override public void run() { - ChildProcessLauncherHelper.initLinker(); + processLauncher.stop(); } }); + // Wait for service to notify its onDestroy was called. + childProcessBinder.waitOnDestroyCalled(); + // The client should also get a notification that the connection was lost. + onConnectionLostHelper.waitForCallback(0 /* currentCallback */); + } + + @Test + @LargeTest + @Feature({"ProcessManagement"}) + public void testLaunchServiceCreatedWithConnectionAllocator() throws Exception { + final ChildProcessLauncherFactory childProcessLauncherFactory = + new ChildProcessLauncherFactory(false /* providesConnection */) { + @Override + public ChildProcessLauncher createChildProcessLauncher( + ChildProcessLauncher.Delegate delegate, String[] commandLine, + FileDescriptorInfo[] filesToBeMapped, IBinder binderCallback) { + return ChildProcessLauncher.createWithConnectionAllocator(delegate, + commandLine, filesToBeMapped, mConnectionAllocator, binderCallback); + } + }; + + testProcessLauncher(childProcessLauncherFactory); + } + + @Test + @LargeTest + @Feature({"ProcessManagement"}) + public void testLaunchServiceCreatedWithBoundConnection() throws Exception { + // Wraps the serviceCallback provided by the ChildProcessLauncher so that the + // ChildProcessConnection can forward to them appropriately. + final AtomicReference<ChildProcessConnection.ServiceCallback> serviceCallbackWrapper = + new AtomicReference<>(); + + final ChildProcessConnection boundConnection = + ChildProcessLauncherTestUtils.runOnLauncherAndGetResult(new Callable< + ChildProcessConnection>() { + @Override + public ChildProcessConnection call() { + Context context = + InstrumentationRegistry.getInstrumentation().getTargetContext(); + ComponentName serviceName = + new ComponentName(SERVICE_PACKAGE_NAME, SERVICE0_FULL_NAME); + ChildProcessConnection connection = new ChildProcessConnection(context, + serviceName, false /* bindAsExternalService */, + new Bundle() /* serviceBundle */, null /* creationParams */); + connection.start(false /* useStrongBinding */, + new ChildProcessConnection.ServiceCallback() { + @Override + public void onChildStarted() { + if (serviceCallbackWrapper.get() != null) { + serviceCallbackWrapper.get().onChildStarted(); + } + } + + @Override + public void onChildStartFailed() { + if (serviceCallbackWrapper.get() != null) { + serviceCallbackWrapper.get().onChildStartFailed(); + } + } + + @Override + public void onChildProcessDied( + ChildProcessConnection connection) { + if (serviceCallbackWrapper.get() != null) { + serviceCallbackWrapper.get().onChildProcessDied( + connection); + } + } + }); + return connection; + } + }); + + Assert.assertNotNull(boundConnection); + + CriteriaHelper.pollInstrumentationThread(new Criteria("Connection failed to connect") { + @Override + public boolean isSatisfied() { + return boundConnection.isConnected(); + } + }); + + final ChildProcessLauncher.BoundConnectionProvider connectionProvider = + new ChildProcessLauncher.BoundConnectionProvider() { + @Override + public ChildProcessConnection getConnection( + ChildProcessConnection.ServiceCallback serviceCallback) { + serviceCallbackWrapper.set(serviceCallback); + return boundConnection; + } + }; + + final ChildProcessLauncherFactory childProcessLauncherFactory = + new ChildProcessLauncherFactory(true /* providesConnection */) { + @Override + public ChildProcessLauncher createChildProcessLauncher( + ChildProcessLauncher.Delegate delegate, String[] commandLine, + FileDescriptorInfo[] filesToBeMapped, IBinder binderCallback) { + return ChildProcessLauncher.createWithBoundConnectionProvider(delegate, + commandLine, filesToBeMapped, connectionProvider, binderCallback); + } + }; + + testProcessLauncher(childProcessLauncherFactory); } /** @@ -73,19 +401,32 @@ @Test @MediumTest @Feature({"ProcessManagement"}) - @ChildProcessAllocatorSettings(sandboxedServiceCount = 4) public void testServiceFailedToBind() { - Assert.assertEquals(0, getConnectedSandboxedServicesCount()); + final ChildConnectionAllocator badConnectionAllocator = + ChildProcessLauncherTestUtils.runOnLauncherAndGetResult( + new Callable<ChildConnectionAllocator>() { + @Override + public ChildConnectionAllocator call() { + return ChildConnectionAllocator.createForTest( + null /* creationParams */, "org.chromium.wrong_package", + "WrongService", 2 /* serviceCount */, + false /* bindAsExternalService */, + false /* useStrongBinding */); + } + }); + Assert.assertFalse(badConnectionAllocator.anyConnectionAllocated()); // Try to allocate a connection to service class in incorrect package. We can do that by // using the instrumentation context (getContext()) instead of the app context // (getTargetContext()). - Context context = InstrumentationRegistry.getInstrumentation().getContext(); - startSandboxedChildProcess( - context.getPackageName(), DONT_BLOCK, true /* doSetupConnection */); + ChildProcessLauncher processLauncher = createChildProcessLauncher(badConnectionAllocator, + true /* setupConnection */, false /* queueIfNoFreeConnection */); - // Verify that the connection is not considered as allocated. - waitForConnectedSandboxedServicesCount(0); + Assert.assertNotNull(processLauncher); + + // Verify that the connection is not considered as allocated (or only briefly, as the + // freeing is delayed). + waitForConnectionAllocatorState(badConnectionAllocator, true /* isEmpty */); } /** @@ -95,617 +436,166 @@ @MediumTest @Feature({"ProcessManagement"}) public void testServiceCrashedBeforeSetup() throws RemoteException { - Assert.assertEquals(0, getConnectedSandboxedServicesCount()); + Assert.assertFalse(mConnectionAllocator.anyConnectionAllocated()); // Start and connect to a new service. - ChildProcessLauncherHelper launcher = startSandboxedChildProcess( - null /* packageName */, BLOCK_UNTIL_CONNECTED, false /* doSetupConnection */); + ChildProcessLauncher processLauncher = createChildProcessLauncher(mConnectionAllocator, + false /* setupConnection */, false /* queueIfNoFreeConnection */); // Verify that the service is bound but not yet set up. - Assert.assertEquals(1, getConnectedSandboxedServicesCount()); - ChildProcessConnection connection = retrieveConnection(launcher); + Assert.assertTrue(mConnectionAllocator.anyConnectionAllocated()); + ChildProcessConnection connection = processLauncher.getConnection(); Assert.assertNotNull(connection); - Assert.assertTrue(connection.isConnected()); - Assert.assertEquals(0, ChildProcessLauncherTestUtils.getConnectionPid(connection)); + waitForConnectionState(connection, CONNECTION_BLOCK_UNTIL_CONNECTED); + Assert.assertEquals(0, getConnectionPid(connection)); // Crash the service. connection.crashServiceForTesting(); // Verify that the connection gets cleaned-up. - waitForConnectedSandboxedServicesCount(0); + waitForConnectionAllocatorState(mConnectionAllocator, true /* isEmpty */); } - /** - * Tests cleanup for a connection that terminates after setup. - */ @Test @MediumTest @Feature({"ProcessManagement"}) public void testServiceCrashedAfterSetup() throws RemoteException { - Assert.assertEquals(0, getConnectedSandboxedServicesCount()); + Assert.assertFalse(mConnectionAllocator.anyConnectionAllocated()); // Start and connect to a new service. - ChildProcessLauncherHelper launcher = startSandboxedChildProcess( - null /* packageName */, BLOCK_UNTIL_SETUP, true /* doSetupConnection */); - Assert.assertEquals(1, getConnectedSandboxedServicesCount()); + ChildProcessLauncher processLauncher = createChildProcessLauncher(mConnectionAllocator, + true /* setupConnection */, false /* queueIfNoFreeConnection */); - int pid = getPid(launcher); - Assert.assertNotEquals(0, pid); + Assert.assertTrue(mConnectionAllocator.anyConnectionAllocated()); + ChildProcessConnection connection = processLauncher.getConnection(); + Assert.assertNotNull(connection); + waitForConnectionState(connection, CONNECTION_BLOCK_UNTIL_SETUP); + // We are passed set-up, the connection should have received its PID. + Assert.assertNotEquals(0, getConnectionPid(connection)); // Crash the service. - ChildProcessConnection connection = retrieveConnection(launcher); connection.crashServiceForTesting(); // Verify that the connection gets cleaned-up. - waitForConnectedSandboxedServicesCount(0); + waitForConnectionAllocatorState(mConnectionAllocator, true /* isEmpty */); // Verify that the connection pid remains set after termination. - Assert.assertTrue(ChildProcessLauncherTestUtils.getConnectionPid(connection) != 0); - // And that the launcher is cleared. - Assert.assertNull(ChildProcessLauncherHelper.getLauncherForPid(pid)); + Assert.assertNotEquals(0, getConnectionPid(connection)); } - /** - * Tests that connection requests get queued when no slot is availabe and created once a slot - * frees up . - */ @Test @MediumTest @Feature({"ProcessManagement"}) - @ChildProcessAllocatorSettings(sandboxedServiceCount = 1) public void testPendingSpawnQueue() throws RemoteException { - Assert.assertEquals(0, getConnectedSandboxedServicesCount()); + Assert.assertFalse(mConnectionAllocator.anyConnectionAllocated()); - ChildProcessLauncherHelper launcher1 = startSandboxedChildProcess( - null /* packageName */, BLOCK_UNTIL_SETUP, true /* doSetupConnection */); - Assert.assertEquals(1, getConnectedSandboxedServicesCount()); - Assert.assertNotNull(ChildProcessLauncherTestUtils.getConnection(launcher1)); - - ChildProcessLauncherHelper launcher2 = startSandboxedChildProcess( - null /* packageName */, DONT_BLOCK, true /* doSetupConnection */); - Assert.assertEquals(1, getConnectedSandboxedServicesCount()); - Assert.assertNull(ChildProcessLauncherTestUtils.getConnection(launcher2)); - - final ChildProcessConnection connection1 = - ChildProcessLauncherTestUtils.getConnection(launcher1); - connection1.crashServiceForTesting(); - - // The previous service crashing should have freed a connection that should be used for the - // pending process. - blockUntilConnected(launcher2); - } - - /** - * Tests that external APKs and regular use different ChildConnectionAllocators. - */ - @Test - @MediumTest - @Feature({"ProcessManagement"}) - @ChildProcessAllocatorSettings( - sandboxedServiceCount = 4, sandboxedServiceName = DEFAULT_SANDBOXED_PROCESS_SERVICE) - public void testAllocatorForPackage() { - Context appContext = InstrumentationRegistry.getInstrumentation().getTargetContext(); - - ChildConnectionAllocator connectionAllocator = getChildConnectionAllocator( - appContext, appContext.getPackageName(), true /* sandboxed */); - ChildConnectionAllocator externalConnectionAllocator = getChildConnectionAllocator( - appContext, EXTERNAL_APK_PACKAGE_NAME, true /* sandboxed */); - Assert.assertNotEquals(connectionAllocator, externalConnectionAllocator); - } - - /** - * Tests binding to the same sandboxed service process from multiple processes in the - * same package. This uses the ChildProcessLauncherTestHelperService declared in - * ContentShell.apk as a separate android:process to bind the first (slot 0) service. The - * instrumentation test then tries to bind the same slot, which fails, so the - * ChildProcessLauncher retries on a new connection. - */ - @Test - @MediumTest - @Feature({"ProcessManagement"}) - public void testBindServiceFromMultipleProcesses() throws RemoteException { - final Context context = InstrumentationRegistry.getInstrumentation().getTargetContext(); - - // Start the Helper service. - class HelperConnection implements ServiceConnection { - Messenger mMessenger = null; - - @Override - public void onServiceConnected(ComponentName name, IBinder service) { - mMessenger = new Messenger(service); - } - - @Override - public void onServiceDisconnected(ComponentName name) {} + // Launch 4 processes. Since we have only 2 services, the 3rd and 4th should get queued. + ChildProcessLauncher[] launchers = new ChildProcessLauncher[4]; + ChildProcessConnection[] connections = new ChildProcessConnection[4]; + for (int i = 0; i < 4; i++) { + launchers[i] = createChildProcessLauncher(mConnectionAllocator, + true /* setupConnection */, true /* queueIfNoFreeConnection */); + Assert.assertNotNull(launchers[i]); + connections[i] = launchers[i].getConnection(); } - final HelperConnection serviceConnection = new HelperConnection(); + Assert.assertNotNull(connections[0]); + Assert.assertNotNull(connections[1]); + Assert.assertNull(connections[2]); + Assert.assertNull(connections[3]); - Intent intent = new Intent(); - intent.setComponent(new ComponentName(context.getPackageName(), - context.getPackageName() + ".ChildProcessLauncherTestHelperService")); - Assert.assertTrue(context.bindService(intent, serviceConnection, Context.BIND_AUTO_CREATE)); + // Test creating a launcher with queueIfNoFreeConnection false with no connection available. + Assert.assertNull(createChildProcessLauncher(mConnectionAllocator, + true /* setupConnection */, false /* queueIfNoFreeConnection */)); - // Wait for the Helper service to connect. - CriteriaHelper.pollInstrumentationThread( - new Criteria("Failed to get helper service Messenger") { - @Override - public boolean isSatisfied() { - return serviceConnection.mMessenger != null; - } - }); + // Stop one connection, that should free-up a connection and the first queued launcher + // should use it. + stopLauncher(launchers[0]); + waitUntilLauncherSetup(launchers[2]); - Assert.assertNotNull(serviceConnection.mMessenger); + // Last launcher is still queued. + Assert.assertNull(launchers[3].getConnection()); - class ReplyHandler implements Handler.Callback { - Message mMessage; - - @Override - public boolean handleMessage(Message msg) { - // Copy the message so its contents outlive this Binder transaction. - mMessage = Message.obtain(); - mMessage.copyFrom(msg); - return true; - } - } - final ReplyHandler replyHandler = new ReplyHandler(); - - // Send a message to the Helper and wait for the reply. This will cause the slot 0 - // sandboxed service connection to be bound by a different PID (i.e., not this process). - Message msg = Message.obtain(null, ChildProcessLauncherTestHelperService.MSG_BIND_SERVICE); - msg.replyTo = new Messenger(new Handler(Looper.getMainLooper(), replyHandler)); - serviceConnection.mMessenger.send(msg); - - CriteriaHelper.pollInstrumentationThread( - new Criteria("Failed waiting for helper service reply") { - @Override - public boolean isSatisfied() { - return replyHandler.mMessage != null; - } - }); - - // Verify that the Helper was able to launch the sandboxed service. - Assert.assertNotNull(replyHandler.mMessage); - Assert.assertEquals(ChildProcessLauncherTestHelperService.MSG_BIND_SERVICE_REPLY, - replyHandler.mMessage.what); - Assert.assertEquals( - "Connection slot from helper service is not 0", 0, replyHandler.mMessage.arg2); - - final int helperConnectionPid = replyHandler.mMessage.arg1; - Assert.assertTrue(helperConnectionPid > 0); - - // Launch a service from this process. Since slot 0 is already bound by the Helper, it - // will fail to start and the ChildProcessLauncher will retry and use the slot 1. - ChildProcessCreationParams creationParams = new ChildProcessCreationParams( - context.getPackageName(), false /* isExternalService */, - LibraryProcessType.PROCESS_CHILD, true /* bindToCallerCheck */); - ChildProcessLauncherHelper launcher = startSandboxedChildProcessWithCreationParams( - creationParams, BLOCK_UNTIL_SETUP, true /* doSetupConnection */); - - final ChildProcessConnection retryConnection = - ChildProcessLauncherTestUtils.getConnection(launcher); - Assert.assertEquals( - 1, ChildProcessLauncherTestUtils.getConnectionServiceNumber(retryConnection)); - - ChildConnectionAllocator connectionAllocator = - launcher.getChildConnectionAllocatorForTesting(); - - // Check that only two connections are created. - for (int i = 0; i < connectionAllocator.getNumberOfServices(); ++i) { - ChildProcessConnection sandboxedConn = - connectionAllocator.getChildProcessConnectionAtSlotForTesting(i); - if (i <= 1) { - Assert.assertNotNull(sandboxedConn); - Assert.assertNotNull( - ChildProcessLauncherTestUtils.getConnectionService(sandboxedConn)); - } else { - Assert.assertNull(sandboxedConn); - } - } - - Assert.assertEquals( - connectionAllocator.getChildProcessConnectionAtSlotForTesting(1), retryConnection); - - ChildProcessConnection failedConnection = - connectionAllocator.getChildProcessConnectionAtSlotForTesting(0); - Assert.assertEquals(0, ChildProcessLauncherTestUtils.getConnectionPid(failedConnection)); - Assert.assertFalse(ChildProcessLauncherTestUtils.getConnectionService(failedConnection) - .bindToCaller()); - - CriteriaHelper.pollInstrumentationThread( - new Criteria("Failed waiting retry connection to get pid") { - @Override - public boolean isSatisfied() { - return ChildProcessLauncherTestUtils.getConnectionPid(retryConnection) > 0; - } - }); - Assert.assertTrue(ChildProcessLauncherTestUtils.getConnectionPid(retryConnection) - != helperConnectionPid); - Assert.assertTrue( - ChildProcessLauncherTestUtils.getConnectionService(retryConnection).bindToCaller()); + // Crash another launcher. It should free-up another connection that the queued-up launcher + // should use. + connections[1].crashServiceForTesting(); + waitUntilLauncherSetup(launchers[3]); } - private static void warmUpOnUiThreadBlocking(final Context context) { - ThreadUtils.runOnUiThreadBlocking(new Runnable() { - @Override - public void run() { - ChildProcessLauncherHelper.warmUp(context); - } - }); - ChildProcessConnection connection = getWarmUpConnection(); - Assert.assertNotNull(connection); - blockUntilConnected(connection); - } - - private void testWarmUpWithCreationParams(ChildProcessCreationParams creationParams) { - if (creationParams != null) { - ChildProcessCreationParams.registerDefault(creationParams); - } - - Context context = InstrumentationRegistry.getInstrumentation().getTargetContext(); - warmUpOnUiThreadBlocking(context); - - Assert.assertEquals(1, getConnectedSandboxedServicesCount()); - - ChildProcessLauncherHelper launcherHelper = startSandboxedChildProcessWithCreationParams( - creationParams, BLOCK_UNTIL_SETUP, true /* doSetupConnection */); - - // The warm-up connection was used, so no new process should have been created. - Assert.assertEquals(1, getConnectedSandboxedServicesCount()); - - int pid = getPid(launcherHelper); - Assert.assertNotEquals(0, pid); - - stopProcess(launcherHelper); - - waitForConnectedSandboxedServicesCount(0); - Assert.assertNull(ChildProcessLauncherHelper.getLauncherForPid(pid)); - } - - @Test - @MediumTest - @Feature({"ProcessManagement"}) - public void testWarmUp() { - // Use the default creation parameters. - testWarmUpWithCreationParams(null /* creationParams */); - } - - @Test - @MediumTest - @Feature({"ProcessManagement"}) - public void testWarmUpWithBindToCaller() { - Context context = InstrumentationRegistry.getInstrumentation().getTargetContext(); - ChildProcessCreationParams creationParams = new ChildProcessCreationParams( - context.getPackageName(), false /* isExternalService */, - LibraryProcessType.PROCESS_CHILD, true /* bindToCallerCheck */); - testWarmUpWithCreationParams(creationParams); - } - - // Tests that the warm-up connection is freed from its allocator if it crashes. - @Test - @MediumTest - @Feature({"ProcessManagement"}) - public void testWarmUpProcessCrashBeforeUse() throws RemoteException { - Assert.assertEquals(0, getConnectedSandboxedServicesCount()); - - Context context = InstrumentationRegistry.getInstrumentation().getTargetContext(); - warmUpOnUiThreadBlocking(context); - - Assert.assertEquals(1, getConnectedSandboxedServicesCount()); - - // Crash the warm-up connection before it gets used. - ChildProcessConnection connection = getWarmUpConnection(); - Assert.assertNotNull(connection); - connection.crashServiceForTesting(); - - // It should get cleaned-up. - waitForConnectedSandboxedServicesCount(0); - - // And subsequent process launches should work. - ChildProcessLauncherHelper launcher = startSandboxedChildProcess( - null /* packageName */, BLOCK_UNTIL_SETUP, true /* doSetupConnection */); - Assert.assertEquals(1, getConnectedSandboxedServicesCount()); - Assert.assertNotNull(ChildProcessLauncherTestUtils.getConnection(launcher)); - } - - // Tests that the warm-up connection is freed from its allocator if it crashes after being used. - @Test - @MediumTest - @Feature({"ProcessManagement"}) - public void testWarmUpProcessCrashAfterUse() throws RemoteException { - Context context = InstrumentationRegistry.getInstrumentation().getTargetContext(); - warmUpOnUiThreadBlocking(context); - - Assert.assertEquals(1, getConnectedSandboxedServicesCount()); - - ChildProcessLauncherHelper launcherHelper = startSandboxedChildProcessWithCreationParams( - null /* creationParams */, BLOCK_UNTIL_SETUP, true /* doSetupConnection */); - - // The warm-up connection was used, so no new process should have been created. - Assert.assertEquals(1, getConnectedSandboxedServicesCount()); - - int pid = getPid(launcherHelper); - Assert.assertNotEquals(0, pid); - - ChildProcessConnection connection = retrieveConnection(launcherHelper); - connection.crashServiceForTesting(); - - waitForConnectedSandboxedServicesCount(0); - Assert.assertNull(ChildProcessLauncherHelper.getLauncherForPid(pid)); - } - - @Test - @MediumTest - @Feature({"ProcessManagement"}) - public void testSandboxedAllocatorFreed() { - final String packageName = - InstrumentationRegistry.getInstrumentation().getTargetContext().getPackageName(); - - ChildProcessLauncherHelper launcher = startSandboxedChildProcess( - null /* packageName */, BLOCK_UNTIL_SETUP, true /* doSetupConnection */); - - Assert.assertTrue(hasSandboxedConnectionAllocatorForPackage(packageName)); - - stopProcess(launcher); - - // Poll until allocator is removed. Need to poll here because actually freeing a connection - // from allocator is a posted task, rather than a direct call from stop. - CriteriaHelper.pollInstrumentationThread( - new Criteria("The connection allocator was not removed.") { - @Override - public boolean isSatisfied() { - return !hasSandboxedConnectionAllocatorForPackage(packageName); - } - }); - } - - @Test - @MediumTest - @Feature({"ProcessManagement"}) - @ChildProcessAllocatorSettings(sandboxedServiceCount = 4) - public void testCustomCreationParamDoesNotReuseWarmupConnection() { - // Since warmUp only uses default params. - final Context context = InstrumentationRegistry.getInstrumentation().getTargetContext(); - ChildProcessCreationParams defaultCreationParams = - getDefaultChildProcessCreationParams(context.getPackageName()); - ChildProcessCreationParams.registerDefault(defaultCreationParams); - ChildProcessCreationParams otherCreationParams = getDefaultChildProcessCreationParams( - InstrumentationRegistry.getInstrumentation().getContext().getPackageName()); - - warmUpOnUiThreadBlocking(context); - Assert.assertEquals(1, getConnectedSandboxedServicesCount()); - - // First create a connnection with different creation params than the default, it should not - // use the warmup connection (note that it won't bind since we are using the wrong package, - // but we need to use a different package to differentiate them, and we can only have 1 - // valid package per app). - startSandboxedChildProcessWithCreationParams( - otherCreationParams, DONT_BLOCK, false /* doSetupConnection */); - Assert.assertNotNull(getWarmUpConnection()); - - // Then start a process with the default creation params, the warmup-connection should be - // used. - startSandboxedChildProcessWithCreationParams( - defaultCreationParams, BLOCK_UNTIL_SETUP, true /* doSetupConnection */); - Assert.assertNull(getWarmUpConnection()); - } - - @Test - @MediumTest - @Feature({"ProcessManagement"}) - public void testUseStrongBindingConnection() { - // Since warmUp only uses default params. - Context context = InstrumentationRegistry.getInstrumentation().getTargetContext(); - ChildProcessCreationParams creationParams = new ChildProcessCreationParams( - context.getPackageName(), false /* isExternalService */, - LibraryProcessType.PROCESS_CHILD, true /* bindToCallerCheck */); - - for (final boolean sandboxed : new boolean[] {true, false}) { - ChildProcessLauncherHelper launcher = ChildProcessLauncherTestUtils.startForTesting( - sandboxed, sProcessWaitArguments, new FileDescriptorInfo[0], creationParams, - true /* doSetupConnection */); - final ChildProcessConnection connection = - ChildProcessLauncherTestUtils.getConnection(launcher); - Assert.assertNotNull(connection); - ChildProcessLauncherTestUtils.runOnLauncherThreadBlocking(new Runnable() { - @Override - public void run() { - // Only non sandboxed connections should use strong bindings. - Assert.assertNotEquals(sandboxed, connection.isStrongBindingBound()); - } - }); - } - } - - @Test - @MediumTest - @Feature({"ProcessManagement"}) - public void testLauncherCleanup() throws RemoteException { - ChildProcessLauncherHelper launcher = startSandboxedChildProcess( - null /* packageName */, BLOCK_UNTIL_SETUP, true /* doSetupConnection */); - int pid = getPid(launcher); - Assert.assertNotEquals(0, pid); - Assert.assertNotNull(ChildProcessLauncherHelper.getLauncherForPid(pid)); - - // Stop the process explicitly, the launcher should get cleared. - stopProcess(launcher); - waitForConnectedSandboxedServicesCount(0); - Assert.assertNull(ChildProcessLauncherHelper.getLauncherForPid(pid)); - - launcher = startSandboxedChildProcess( - null /* packageName */, BLOCK_UNTIL_SETUP, true /* doSetupConnection */); - pid = getPid(launcher); - Assert.assertNotEquals(0, pid); - Assert.assertNotNull(ChildProcessLauncherHelper.getLauncherForPid(pid)); - - // This time crash the connection, the launcher should also get cleared. - ChildProcessConnection connection = retrieveConnection(launcher); - connection.crashServiceForTesting(); - waitForConnectedSandboxedServicesCount(0); - Assert.assertNull(ChildProcessLauncherHelper.getLauncherForPid(pid)); - } - - private static ChildProcessLauncherHelper startSandboxedChildProcess( - final String packageName, int blockingPolicy, final boolean doSetupConnection) { - ChildProcessCreationParams creationParams = - packageName == null ? null : getDefaultChildProcessCreationParams(packageName); - return startSandboxedChildProcessWithCreationParams( - creationParams, blockingPolicy, doSetupConnection); - } - - private static ChildProcessLauncherHelper startSandboxedChildProcessWithCreationParams( - final ChildProcessCreationParams creationParams, int blockingPolicy, - final boolean doSetupConnection) { - assert doSetupConnection || blockingPolicy != BLOCK_UNTIL_SETUP; - ChildProcessLauncherHelper launcher = - ChildProcessLauncherTestUtils.runOnLauncherAndGetResult( - new Callable<ChildProcessLauncherHelper>() { - @Override - public ChildProcessLauncherHelper call() { - return ChildProcessLauncherHelper.createAndStartForTesting( - creationParams, sProcessWaitArguments, - new FileDescriptorInfo[0], true /* sandboxed */, - null /* binderCallback */, doSetupConnection); - } - }); - if (blockingPolicy != DONT_BLOCK) { - assert blockingPolicy == BLOCK_UNTIL_CONNECTED || blockingPolicy == BLOCK_UNTIL_SETUP; - blockUntilConnected(launcher); - if (blockingPolicy == BLOCK_UNTIL_SETUP) { - blockUntilSetup(launcher); - } - } - return launcher; - } - - private static void blockUntilConnected(final ChildProcessLauncherHelper launcher) { - CriteriaHelper.pollInstrumentationThread( - new Criteria("The connection wasn't established.") { - @Override - public boolean isSatisfied() { - return launcher.getConnection() != null - && launcher.getConnection().isConnected(); - } - }); - } - - private static void blockUntilConnected(final ChildProcessConnection connection) { - CriteriaHelper.pollInstrumentationThread( - new Criteria("The connection wasn't established.") { - @Override - public boolean isSatisfied() { - return connection.isConnected(); - } - }); - } - - private static void blockUntilSetup(final ChildProcessLauncherHelper launcher) { - CriteriaHelper.pollInstrumentationThread( - new Criteria("The connection wasn't established.") { - @Override - public boolean isSatisfied() { - return getPid(launcher) != 0; - } - }); - } - - private static ChildConnectionAllocator getChildConnectionAllocator( - final Context context, final String packageName, final boolean sandboxed) { + private static ChildProcessLauncher createChildProcessLauncher( + final ChildConnectionAllocator connectionAllocator, final boolean setupConnection, + final boolean queueIfNoFreeConnection) { return ChildProcessLauncherTestUtils.runOnLauncherAndGetResult( - new Callable<ChildConnectionAllocator>() { + new Callable<ChildProcessLauncher>() { @Override - public ChildConnectionAllocator call() { - return ChildProcessLauncherHelper.getConnectionAllocator(context, - getDefaultChildProcessCreationParams(packageName), sandboxed); + public ChildProcessLauncher call() { + ChildProcessLauncher processLauncher = + ChildProcessLauncher.createWithConnectionAllocator( + EMPTY_LAUNCHER_DELEGATE, new String[0], + new FileDescriptorInfo[0], connectionAllocator, + null /* binderCallback */); + if (!processLauncher.start(setupConnection, queueIfNoFreeConnection)) { + return null; + } + return processLauncher; } }); } - // Returns the number of sandboxed connection currently connected, - private static int getConnectedSandboxedServicesCount() { - return getConnectedSandboxedServicesCountForPackage(null /* packageName */); - } - - // Returns the number of sandboxed connection matching the specificed package name that are - // connected, - private static int getConnectedSandboxedServicesCountForPackage(final String packageName) { - return ChildProcessLauncherTestUtils.runOnLauncherAndGetResult( - new Callable<Integer>() { - @Override - public Integer call() { - return ChildProcessLauncherHelper - .getConnectedSandboxedServicesCountForTesting(packageName); - } - }); - } - - // Blocks until the number of sandboxed connections reaches targetCount. - private static void waitForConnectedSandboxedServicesCount(int targetCount) { + private static void waitForConnectionAllocatorState( + final ChildConnectionAllocator connectionAllocator, final boolean emptyState) { CriteriaHelper.pollInstrumentationThread( - Criteria.equals(targetCount, new Callable<Integer>() { - @Override - public Integer call() { - return getConnectedSandboxedServicesCountForPackage(null /* packageName */); - } - })); - } - - private static ChildProcessCreationParams getDefaultChildProcessCreationParams( - String packageName) { - return packageName == null - ? null - : new ChildProcessCreationParams(packageName, false /* isExternalService */, - LibraryProcessType.PROCESS_CHILD, false /* bindToCallerCheck */); - } - - private static boolean hasSandboxedConnectionAllocatorForPackage(final String packageName) { - return ChildProcessLauncherTestUtils.runOnLauncherAndGetResult(new Callable<Boolean>() { - @Override - public Boolean call() { - return ChildProcessLauncherHelper.hasSandboxedConnectionAllocatorForPackage( - packageName); - } - }); - } - - private static ChildProcessConnection retrieveConnection( - final ChildProcessLauncherHelper launcherHelper) { - CriteriaHelper.pollInstrumentationThread( - new Criteria("Failed waiting for child process to connect") { + new Criteria("Failed to wait for connection allocator.") { @Override public boolean isSatisfied() { - return ChildProcessLauncherTestUtils.getConnection(launcherHelper) != null; + return emptyState ? !connectionAllocator.anyConnectionAllocated() + : connectionAllocator.anyConnectionAllocated(); } }); - - return ChildProcessLauncherTestUtils.getConnection(launcherHelper); } - private static void stopProcess(ChildProcessLauncherHelper launcherHelper) { - final ChildProcessConnection connection = retrieveConnection(launcherHelper); - ChildProcessLauncherTestUtils.runOnLauncherThreadBlocking(new Runnable() { - @Override - public void run() { - ChildProcessLauncherHelper.stop(connection.getPid()); - } - }); + private static void waitForConnectionState( + final ChildProcessConnection connection, final int connectionState) { + assert connectionState == CONNECTION_BLOCK_UNTIL_CONNECTED + || connectionState == CONNECTION_BLOCK_UNTIL_SETUP; + CriteriaHelper.pollInstrumentationThread( + new Criteria("Failed wait for connection to connect.") { + @Override + public boolean isSatisfied() { + if (connectionState == CONNECTION_BLOCK_UNTIL_CONNECTED) { + return connection.isConnected(); + } + assert connectionState == CONNECTION_BLOCK_UNTIL_SETUP; + return getConnectionPid(connection) != 0; + } + }); } - private static int getPid(final ChildProcessLauncherHelper launcherHelper) { + private static void waitUntilLauncherSetup(final ChildProcessLauncher launcher) { + CriteriaHelper.pollInstrumentationThread( + new Criteria("Failed wait for launcher to connect.") { + @Override + public boolean isSatisfied() { + return launcher.getConnection() != null; + } + }); + waitForConnectionState(launcher.getConnection(), CONNECTION_BLOCK_UNTIL_SETUP); + } + + private static int getConnectionPid(final ChildProcessConnection connection) { return ChildProcessLauncherTestUtils.runOnLauncherAndGetResult(new Callable<Integer>() { @Override public Integer call() { - return launcherHelper.getPid(); + return connection.getPid(); } }); } - private static ChildProcessConnection getWarmUpConnection() { - return ChildProcessLauncherTestUtils.runOnLauncherAndGetResult( - new Callable<ChildProcessConnection>() { - @Override - public ChildProcessConnection call() { - return ChildProcessLauncherHelper.getWarmUpConnectionForTesting(); - } - }); + private static void stopLauncher(final ChildProcessLauncher launcher) { + ChildProcessLauncherTestUtils.runOnLauncherThreadBlocking(new Runnable() { + @Override + public void run() { + launcher.stop(); + } + }); } }
diff --git a/content/public/browser/BUILD.gn b/content/public/browser/BUILD.gn index d29dd4f6..df45385 100644 --- a/content/public/browser/BUILD.gn +++ b/content/public/browser/BUILD.gn
@@ -87,6 +87,8 @@ "content_browser_client.h", "context_factory.h", "cookie_store_factory.h", + "desktop_capture.cc", + "desktop_capture.h", "desktop_media_id.cc", "desktop_media_id.h", "devtools_agent_host.h", @@ -326,6 +328,7 @@ "//ui/events", "//ui/gl", "//ui/surface", + "//third_party/webrtc/modules/desktop_capture", ] allow_circular_includes_from = [
diff --git a/content/public/browser/DEPS b/content/public/browser/DEPS index f6f0e3bb..b1bf25da 100644 --- a/content/public/browser/DEPS +++ b/content/public/browser/DEPS
@@ -13,4 +13,10 @@ # file will be moved elsewhere. See http://crbug.com/598073. "!content/browser/loader/resource_dispatcher_host_impl.h", ], + + "desktop_capture\.h": [ + # desktop_capture.h creates a DesktopCaptureOptions to share between + # content/browser and chrome/browser. + "+third_party/webrtc/modules/desktop_capture/desktop_capture_options.h", + ], }
diff --git a/content/public/browser/desktop_capture.cc b/content/public/browser/desktop_capture.cc new file mode 100644 index 0000000..139ea14a --- /dev/null +++ b/content/public/browser/desktop_capture.cc
@@ -0,0 +1,30 @@ +// Copyright 2017 The Chromium Authors. All rights reserved. +// Use of this source code is governed by a BSD-style license that can be +// found in the LICENSE file. + +#include "content/public/browser/desktop_capture.h" + +#include "base/feature_list.h" +#include "build/build_config.h" + +namespace content { + +webrtc::DesktopCaptureOptions CreateDesktopCaptureOptions() { + auto options = webrtc::DesktopCaptureOptions::CreateDefault(); + // Leave desktop effects enabled during WebRTC captures. + options.set_disable_effects(false); +#if defined(OS_WIN) + static constexpr base::Feature kDirectXCapturer{ + "DirectXCapturer", + base::FEATURE_ENABLED_BY_DEFAULT}; + if (base::FeatureList::IsEnabled(kDirectXCapturer)) { + options.set_allow_directx_capturer(true); + options.set_allow_use_magnification_api(false); + } else { + options.set_allow_use_magnification_api(true); + } +#endif // defined(OS_WIN) + return options; +} + +} // namespace content
diff --git a/content/public/browser/desktop_capture.h b/content/public/browser/desktop_capture.h new file mode 100644 index 0000000..1b44477 --- /dev/null +++ b/content/public/browser/desktop_capture.h
@@ -0,0 +1,18 @@ +// Copyright 2017 The Chromium Authors. All rights reserved. +// Use of this source code is governed by a BSD-style license that can be +// found in the LICENSE file. + +#ifndef CONTENT_PUBLIC_BROWSER_DESKTOP_CAPTURE_H_ +#define CONTENT_PUBLIC_BROWSER_DESKTOP_CAPTURE_H_ + +#include "content/common/content_export.h" +#include "third_party/webrtc/modules/desktop_capture/desktop_capture_options.h" + +namespace content { + +// Creates a DesktopCaptureOptions with required settings. +CONTENT_EXPORT webrtc::DesktopCaptureOptions CreateDesktopCaptureOptions(); + +} // namespace content + +#endif // CONTENT_PUBLIC_BROWSER_DESKTOP_CAPTURE_H_
diff --git a/content/public/browser/provision_fetcher_impl.cc b/content/public/browser/provision_fetcher_impl.cc index 1663f3e..ddfcc14 100644 --- a/content/public/browser/provision_fetcher_impl.cc +++ b/content/public/browser/provision_fetcher_impl.cc
@@ -32,19 +32,19 @@ void ProvisionFetcherImpl::Retrieve(const std::string& default_url, const std::string& request_data, - const RetrieveCallback& callback) { + RetrieveCallback callback) { DVLOG(1) << __FUNCTION__ << ": " << default_url; provision_fetcher_->Retrieve( default_url, request_data, base::Bind(&ProvisionFetcherImpl::OnResponse, weak_factory_.GetWeakPtr(), - callback)); + base::Passed(&callback))); } -void ProvisionFetcherImpl::OnResponse(const RetrieveCallback& callback, +void ProvisionFetcherImpl::OnResponse(RetrieveCallback callback, bool success, const std::string& response) { DVLOG(1) << __FUNCTION__ << ": " << success; - callback.Run(success, response); + std::move(callback).Run(success, response); } } // namespace content
diff --git a/content/public/browser/provision_fetcher_impl.h b/content/public/browser/provision_fetcher_impl.h index b3d63023..a37d9ee 100644 --- a/content/public/browser/provision_fetcher_impl.h +++ b/content/public/browser/provision_fetcher_impl.h
@@ -40,11 +40,11 @@ // media::mojom::ProvisionFetcher implementation. void Retrieve(const std::string& default_url, const std::string& request_data, - const RetrieveCallback& callback) final; + RetrieveCallback callback) final; private: // Callback for media::ProvisionFetcher::Retrieve(). - void OnResponse(const RetrieveCallback& callback, + void OnResponse(RetrieveCallback callback, bool success, const std::string& response);
diff --git a/content/public/renderer/render_frame_observer.h b/content/public/renderer/render_frame_observer.h index 8bb72a3..48b932e 100644 --- a/content/public/renderer/render_frame_observer.h +++ b/content/public/renderer/render_frame_observer.h
@@ -24,6 +24,7 @@ class WebNode; class WebString; struct WebURLError; +class WebWorkerFetchContext; } namespace content { @@ -127,6 +128,9 @@ // Called when draggable regions change. virtual void DraggableRegionsChanged() {} + // Called when a worker fetch context will be created. + virtual void WillCreateWorkerFetchContext(blink::WebWorkerFetchContext*) {} + // IPC::Listener implementation. bool OnMessageReceived(const IPC::Message& message) override;
diff --git a/content/public/test/web_contents_tester.h b/content/public/test/web_contents_tester.h index 9918445..f3f802f 100644 --- a/content/public/test/web_contents_tester.h +++ b/content/public/test/web_contents_tester.h
@@ -151,6 +151,9 @@ int http_status_code, const std::vector<SkBitmap>& bitmaps, const std::vector<gfx::Size>& original_bitmap_sizes) = 0; + + // Sets the return value of GetLastCommittedUrl() of TestWebContents. + virtual void SetLastCommittedURL(const GURL& url) = 0; }; } // namespace content
diff --git a/content/renderer/browser_plugin/browser_plugin.cc b/content/renderer/browser_plugin/browser_plugin.cc index 301ea0e..a532eff 100644 --- a/content/renderer/browser_plugin/browser_plugin.cc +++ b/content/renderer/browser_plugin/browser_plugin.cc
@@ -589,7 +589,7 @@ std::vector<blink::WebCompositionUnderline> std_underlines; for (size_t i = 0; i < underlines.size(); ++i) { - std_underlines.push_back(std_underlines[i]); + std_underlines.push_back(underlines[i]); } gfx::Range replacement_range = replacementRange.IsNull()
diff --git a/content/renderer/gpu/render_widget_compositor.cc b/content/renderer/gpu/render_widget_compositor.cc index 46049eac..29447582 100644 --- a/content/renderer/gpu/render_widget_compositor.cc +++ b/content/renderer/gpu/render_widget_compositor.cc
@@ -474,7 +474,7 @@ // and are disabled for Android WebView as it doesn't support the format. if (!cmd.HasSwitch(switches::kDisableRGBA4444Textures) && base::SysInfo::AmountOfPhysicalMemoryMB() <= 512) - settings.preferred_tile_format = cc::RGBA_4444; + settings.preferred_tile_format = viz::RGBA_4444; } else { // On other devices we have increased memory excessively to avoid // raster-on-demand already, so now we reserve 50% _only_ to avoid @@ -522,11 +522,11 @@ if (cmd.HasSwitch(switches::kEnableRGBA4444Textures) && !cmd.HasSwitch(switches::kDisableRGBA4444Textures)) { - settings.preferred_tile_format = cc::RGBA_4444; + settings.preferred_tile_format = viz::RGBA_4444; } if (cmd.HasSwitch(cc::switches::kEnableTileCompression)) { - settings.preferred_tile_format = cc::ETC1; + settings.preferred_tile_format = viz::ETC1; } settings.max_staging_buffer_usage_in_bytes = 32 * 1024 * 1024; // 32MB
diff --git a/content/renderer/media/audio_renderer_sink_cache_impl.cc b/content/renderer/media/audio_renderer_sink_cache_impl.cc index 7cbfe8b..157fd88460 100644 --- a/content/renderer/media/audio_renderer_sink_cache_impl.cc +++ b/content/renderer/media/audio_renderer_sink_cache_impl.cc
@@ -173,8 +173,9 @@ void AudioRendererSinkCacheImpl::DeleteLaterIfUnused( const media::AudioRendererSink* sink_ptr) { task_runner_->PostDelayedTask( - FROM_HERE, base::Bind(&AudioRendererSinkCacheImpl::DeleteSink, weak_this_, - sink_ptr, false /*do not delete if used*/), + FROM_HERE, + base::Bind(&AudioRendererSinkCacheImpl::DeleteSink, weak_this_, + base::RetainedRef(sink_ptr), false /*do not delete if used*/), delete_timeout_); }
diff --git a/content/renderer/media/gpu/rtc_video_encoder.cc b/content/renderer/media/gpu/rtc_video_encoder.cc index 2185d7e..dc153db4 100644 --- a/content/renderer/media/gpu/rtc_video_encoder.cc +++ b/content/renderer/media/gpu/rtc_video_encoder.cc
@@ -100,6 +100,16 @@ return true; } +void RecordInitEncodeUMA(int32_t init_retval, + media::VideoCodecProfile profile) { + UMA_HISTOGRAM_BOOLEAN("Media.RTCVideoEncoderInitEncodeSuccess", + init_retval == WEBRTC_VIDEO_CODEC_OK); + if (init_retval != WEBRTC_VIDEO_CODEC_OK) + return; + UMA_HISTOGRAM_ENUMERATION("Media.RTCVideoEncoderProfile", profile, + media::VIDEO_CODEC_PROFILE_MAX + 1); +} + } // namespace // This private class of RTCVideoEncoder does the actual work of communicating @@ -154,7 +164,7 @@ // Return the status of Impl. One of WEBRTC_VIDEO_CODEC_XXX value. int32_t GetStatus() const; - webrtc::VideoCodecType video_codec_type() { return video_codec_type_; } + webrtc::VideoCodecType video_codec_type() const { return video_codec_type_; } // media::VideoEncodeAccelerator::Client implementation. void RequireBitstreamBuffers(unsigned int input_count, @@ -309,7 +319,7 @@ media::VideoCodecProfile profile, base::WaitableEvent* async_waiter, int32_t* async_retval) { - DVLOG(3) << "Impl::CreateAndInitializeVEA()"; + DVLOG(3) << __func__; DCHECK(thread_checker_.CalledOnValidThread()); SetStatus(WEBRTC_VIDEO_CODEC_UNINITIALIZED); @@ -340,7 +350,7 @@ bool force_keyframe, base::WaitableEvent* async_waiter, int32_t* async_retval) { - DVLOG(3) << "Impl::Enqueue()"; + DVLOG(3) << __func__; DCHECK(thread_checker_.CalledOnValidThread()); DCHECK(!input_next_frame_); @@ -383,8 +393,7 @@ void RTCVideoEncoder::Impl::UseOutputBitstreamBufferId( int32_t bitstream_buffer_id) { - DVLOG(3) << "Impl::UseOutputBitstreamBufferIndex(): " - "bitstream_buffer_id=" << bitstream_buffer_id; + DVLOG(3) << __func__ << " bitstream_buffer_id=" << bitstream_buffer_id; DCHECK(thread_checker_.CalledOnValidThread()); if (video_encoder_) { video_encoder_->UseOutputBitstreamBuffer(media::BitstreamBuffer( @@ -398,8 +407,7 @@ void RTCVideoEncoder::Impl::RequestEncodingParametersChange( uint32_t bitrate, uint32_t framerate) { - DVLOG(3) << "Impl::RequestEncodingParametersChange(): bitrate=" << bitrate - << ", framerate=" << framerate; + DVLOG(3) << __func__ << " bitrate=" << bitrate << ", framerate=" << framerate; DCHECK(thread_checker_.CalledOnValidThread()); // Check for overflow converting bitrate (kilobits/sec) to bits/sec. @@ -411,7 +419,7 @@ } void RTCVideoEncoder::Impl::Destroy(base::WaitableEvent* async_waiter) { - DVLOG(3) << "Impl::Destroy()"; + DVLOG(3) << __func__; DCHECK(thread_checker_.CalledOnValidThread()); RecordTimestampMatchUMA(); if (video_encoder_) { @@ -440,7 +448,7 @@ unsigned int input_count, const gfx::Size& input_coded_size, size_t output_buffer_size) { - DVLOG(3) << "Impl::RequireBitstreamBuffers(): input_count=" << input_count + DVLOG(3) << __func__ << " input_count=" << input_count << ", input_coded_size=" << input_coded_size.ToString() << ", output_buffer_size=" << output_buffer_size; DCHECK(thread_checker_.CalledOnValidThread()); @@ -489,9 +497,8 @@ size_t payload_size, bool key_frame, base::TimeDelta timestamp) { - DVLOG(3) << "Impl::BitstreamBufferReady(): bitstream_buffer_id=" - << bitstream_buffer_id << ", payload_size=" << payload_size - << ", key_frame=" << key_frame + DVLOG(3) << __func__ << " bitstream_buffer_id=" << bitstream_buffer_id + << ", payload_size=" << payload_size << ", key_frame=" << key_frame << ", timestamp ms=" << timestamp.InMilliseconds(); DCHECK(thread_checker_.CalledOnValidThread()); @@ -726,7 +733,7 @@ int32_t* async_retval, webrtc::EncodedImageCallback* callback) { DCHECK(thread_checker_.CalledOnValidThread()); - DVLOG(3) << "RegisterEncodeCompleteCallback()"; + DVLOG(3) << __func__; RegisterAsyncWaiter(async_waiter, async_retval); int32_t retval = GetStatus(); if (retval == WEBRTC_VIDEO_CODEC_OK) @@ -739,8 +746,7 @@ int32_t bitstream_buffer_id, uint16_t picture_id) { DCHECK(thread_checker_.CalledOnValidThread()); - DVLOG(3) << "ReturnEncodedImage(): " - << "bitstream_buffer_id=" << bitstream_buffer_id + DVLOG(3) << __func__ << " bitstream_buffer_id=" << bitstream_buffer_id << ", picture_id=" << picture_id; if (!encoded_image_callback_) @@ -797,11 +803,11 @@ : video_codec_type_(type), gpu_factories_(gpu_factories), gpu_task_runner_(gpu_factories->GetTaskRunner()) { - DVLOG(1) << "RTCVideoEncoder(): codec type=" << type; + DVLOG(1) << __func__ << " codec type=" << type; } RTCVideoEncoder::~RTCVideoEncoder() { - DVLOG(3) << "~RTCVideoEncoder"; + DVLOG(3) << __func__; Release(); DCHECK(!impl_.get()); } @@ -809,14 +815,12 @@ int32_t RTCVideoEncoder::InitEncode(const webrtc::VideoCodec* codec_settings, int32_t number_of_cores, size_t max_payload_size) { - DVLOG(1) << "InitEncode(): codecType=" << codec_settings->codecType + DVLOG(1) << __func__ << " codecType=" << codec_settings->codecType << ", width=" << codec_settings->width << ", height=" << codec_settings->height << ", startBitrate=" << codec_settings->startBitrate; - if (impl_) { - DVLOG(1) << "Release because of reinitialization"; + if (impl_) Release(); - } impl_ = new Impl(gpu_factories_, video_codec_type_); const media::VideoCodecProfile profile = WebRTCVideoCodecToVideoCodecProfile( @@ -846,7 +850,7 @@ const webrtc::VideoFrame& input_image, const webrtc::CodecSpecificInfo* codec_specific_info, const std::vector<webrtc::FrameType>* frame_types) { - DVLOG(3) << "Encode()"; + DVLOG(3) << __func__; if (!impl_.get()) { DVLOG(3) << "Encoder is not initialized"; return WEBRTC_VIDEO_CODEC_UNINITIALIZED; @@ -875,7 +879,7 @@ int32_t RTCVideoEncoder::RegisterEncodeCompleteCallback( webrtc::EncodedImageCallback* callback) { - DVLOG(3) << "RegisterEncodeCompleteCallback()"; + DVLOG(3) << __func__; if (!impl_.get()) { DVLOG(3) << "Encoder is not initialized"; return WEBRTC_VIDEO_CODEC_UNINITIALIZED; @@ -894,7 +898,7 @@ } int32_t RTCVideoEncoder::Release() { - DVLOG(3) << "Release()"; + DVLOG(3) << __func__; if (!impl_.get()) return WEBRTC_VIDEO_CODEC_OK; @@ -911,14 +915,13 @@ int32_t RTCVideoEncoder::SetChannelParameters(uint32_t packet_loss, int64_t rtt) { - DVLOG(3) << "SetChannelParameters(): packet_loss=" << packet_loss - << ", rtt=" << rtt; + DVLOG(3) << __func__ << " packet_loss=" << packet_loss << ", rtt=" << rtt; // Ignored. return WEBRTC_VIDEO_CODEC_OK; } int32_t RTCVideoEncoder::SetRates(uint32_t new_bit_rate, uint32_t frame_rate) { - DVLOG(3) << "SetRates(): new_bit_rate=" << new_bit_rate + DVLOG(3) << __func__ << " new_bit_rate=" << new_bit_rate << ", frame_rate=" << frame_rate; if (!impl_.get()) { DVLOG(3) << "Encoder is not initialized"; @@ -927,7 +930,7 @@ const int32_t retval = impl_->GetStatus(); if (retval != WEBRTC_VIDEO_CODEC_OK) { - DVLOG(3) << "SetRates(): returning " << retval; + DVLOG(3) << __func__ << " returning " << retval; return retval; } @@ -944,15 +947,4 @@ return true; } -void RTCVideoEncoder::RecordInitEncodeUMA( - int32_t init_retval, media::VideoCodecProfile profile) { - UMA_HISTOGRAM_BOOLEAN("Media.RTCVideoEncoderInitEncodeSuccess", - init_retval == WEBRTC_VIDEO_CODEC_OK); - if (init_retval == WEBRTC_VIDEO_CODEC_OK) { - UMA_HISTOGRAM_ENUMERATION("Media.RTCVideoEncoderProfile", - profile, - media::VIDEO_CODEC_PROFILE_MAX + 1); - } -} - } // namespace content
diff --git a/content/renderer/media/gpu/rtc_video_encoder.h b/content/renderer/media/gpu/rtc_video_encoder.h index bef4f21c..390dc7b 100644 --- a/content/renderer/media/gpu/rtc_video_encoder.h +++ b/content/renderer/media/gpu/rtc_video_encoder.h
@@ -65,9 +65,6 @@ class Impl; friend class RTCVideoEncoder::Impl; - void RecordInitEncodeUMA(int32_t init_retval, - media::VideoCodecProfile profile); - // The video codec type, as reported to WebRTC. const webrtc::VideoCodecType video_codec_type_;
diff --git a/content/renderer/media/mojo_audio_output_ipc_unittest.cc b/content/renderer/media/mojo_audio_output_ipc_unittest.cc index a88c8da..bfb02beb 100644 --- a/content/renderer/media/mojo_audio_output_ipc_unittest.cc +++ b/content/renderer/media/mojo_audio_output_ipc_unittest.cc
@@ -139,7 +139,7 @@ void Acquire(media::mojom::AudioOutputStreamRequest stream_request, const media::AudioParameters& params, - const AcquireCallback& callback) override { + AcquireCallback callback) override { EXPECT_EQ(binding_, base::nullopt); EXPECT_NE(stream_, nullptr); binding_.emplace(stream_, std::move(stream_request));
diff --git a/content/renderer/mojo/blink_interface_provider_impl.cc b/content/renderer/mojo/blink_interface_provider_impl.cc index 251de34..95cb7bf 100644 --- a/content/renderer/mojo/blink_interface_provider_impl.cc +++ b/content/renderer/mojo/blink_interface_provider_impl.cc
@@ -23,14 +23,6 @@ weak_ptr_ = weak_ptr_factory_.GetWeakPtr(); } -BlinkInterfaceProviderImpl::BlinkInterfaceProviderImpl( - base::WeakPtr<service_manager::InterfaceProvider> remote_interfaces) - : remote_interfaces_(remote_interfaces), - main_thread_task_runner_(base::ThreadTaskRunnerHandle::Get()), - weak_ptr_factory_(this) { - weak_ptr_ = weak_ptr_factory_.GetWeakPtr(); -} - BlinkInterfaceProviderImpl::~BlinkInterfaceProviderImpl() = default; void BlinkInterfaceProviderImpl::GetInterface( @@ -49,14 +41,10 @@ return; } - if (connector_) { - connector_->BindInterface( - service_manager::Identity(mojom::kBrowserServiceName, - service_manager::mojom::kInheritUserID), - name, std::move(handle)); - } else { - remote_interfaces_->GetInterface(name, std::move(handle)); - } + connector_->BindInterface( + service_manager::Identity(mojom::kBrowserServiceName, + service_manager::mojom::kInheritUserID), + name, std::move(handle)); } } // namespace content
diff --git a/content/renderer/mojo/blink_interface_provider_impl.h b/content/renderer/mojo/blink_interface_provider_impl.h index c14509504..a7c320da 100644 --- a/content/renderer/mojo/blink_interface_provider_impl.h +++ b/content/renderer/mojo/blink_interface_provider_impl.h
@@ -17,7 +17,6 @@ namespace service_manager { class Connector; -class InterfaceProvider; } namespace content { @@ -28,8 +27,6 @@ public: explicit BlinkInterfaceProviderImpl( base::WeakPtr<service_manager::Connector> connector); - explicit BlinkInterfaceProviderImpl( - base::WeakPtr<service_manager::InterfaceProvider> remote_interfaces); ~BlinkInterfaceProviderImpl(); // blink::InterfaceProvider override. @@ -41,7 +38,6 @@ mojo::ScopedMessagePipeHandle handle); const base::WeakPtr<service_manager::Connector> connector_; - const base::WeakPtr<service_manager::InterfaceProvider> remote_interfaces_; scoped_refptr<base::SingleThreadTaskRunner> main_thread_task_runner_;
diff --git a/content/renderer/render_frame_impl.cc b/content/renderer/render_frame_impl.cc index 9255fbd..d0dc5c7c 100644 --- a/content/renderer/render_frame_impl.cc +++ b/content/renderer/render_frame_impl.cc
@@ -994,7 +994,6 @@ render_frame->InitializeBlameContext(nullptr); WebLocalFrame* web_frame = WebLocalFrame::CreateMainFrame( render_view->webview(), render_frame, - render_frame->blink_interface_provider_.get(), render_frame->blink_interface_registry_.get(), opener, // This conversion is a little sad, as this often comes from a // WebString... @@ -1045,7 +1044,6 @@ web_frame = parent_web_frame->CreateLocalChild( replicated_state.scope, WebString::FromUTF8(replicated_state.name), replicated_state.sandbox_flags, render_frame, - render_frame->blink_interface_provider_.get(), render_frame->blink_interface_registry_.get(), previous_sibling_web_frame, FeaturePolicyHeaderToWeb(replicated_state.container_policy), @@ -1071,9 +1069,8 @@ render_frame->proxy_routing_id_ = proxy_routing_id; proxy->set_provisional_frame_routing_id(routing_id); web_frame = blink::WebLocalFrame::CreateProvisional( - render_frame, render_frame->blink_interface_provider_.get(), - render_frame->blink_interface_registry_.get(), proxy->web_frame(), - replicated_state.sandbox_flags, + render_frame, render_frame->blink_interface_registry_.get(), + proxy->web_frame(), replicated_state.sandbox_flags, FeaturePolicyHeaderToWeb(replicated_state.container_policy)); } CHECK(parent_routing_id != MSG_ROUTING_NONE || !web_frame->Parent()); @@ -1209,8 +1206,6 @@ pending_remote_interface_provider_request_ = MakeRequest(&remote_interfaces); remote_interfaces_.reset(new service_manager::InterfaceProvider); remote_interfaces_->Bind(std::move(remote_interfaces)); - blink_interface_provider_.reset(new BlinkInterfaceProviderImpl( - remote_interfaces_->GetWeakPtr())); blink_interface_registry_.reset( new BlinkInterfaceRegistryImpl(interface_registry_->GetWeakPtr())); @@ -2965,6 +2960,8 @@ worker_fetch_context->set_is_controlled_by_service_worker( provider->IsControlledByServiceWorker()); } + for (auto& observer : observers_) + observer.WillCreateWorkerFetchContext(worker_fetch_context.get()); return std::move(worker_fetch_context); } @@ -3109,7 +3106,6 @@ child_render_frame->InitializeBlameContext(this); blink::WebLocalFrame* web_frame = parent->CreateLocalChild( scope, child_render_frame, - child_render_frame->blink_interface_provider_.get(), child_render_frame->blink_interface_registry_.get()); child_render_frame->in_frame_tree_ = true;
diff --git a/content/renderer/render_frame_impl.h b/content/renderer/render_frame_impl.h index 6db17694..351489a5 100644 --- a/content/renderer/render_frame_impl.h +++ b/content/renderer/render_frame_impl.h
@@ -48,7 +48,6 @@ #include "content/public/renderer/render_frame.h" #include "content/renderer/frame_blame_context.h" #include "content/renderer/media/media_factory.h" -#include "content/renderer/mojo/blink_interface_provider_impl.h" #include "content/renderer/renderer_webcookiejar_impl.h" #include "ipc/ipc_message.h" #include "ipc/ipc_platform_file.h" @@ -1276,7 +1275,6 @@ std::unique_ptr<service_manager::BinderRegistry> interface_registry_; std::unique_ptr<service_manager::InterfaceProvider> remote_interfaces_; - std::unique_ptr<BlinkInterfaceProviderImpl> blink_interface_provider_; std::unique_ptr<BlinkInterfaceRegistryImpl> blink_interface_registry_; service_manager::mojom::InterfaceProviderRequest pending_remote_interface_provider_request_;
diff --git a/content/renderer/renderer_main_platform_delegate_mac.mm b/content/renderer/renderer_main_platform_delegate_mac.mm index c890040b..c4d1da8d 100644 --- a/content/renderer/renderer_main_platform_delegate_mac.mm +++ b/content/renderer/renderer_main_platform_delegate_mac.mm
@@ -9,6 +9,7 @@ #include <objc/runtime.h> #include <stdint.h> +#include "base/bind.h" #include "base/command_line.h" #include "base/logging.h" #include "base/mac/mac_util.h" @@ -18,11 +19,34 @@ #include "content/common/sandbox_init_mac.h" #include "content/common/sandbox_mac.h" #include "content/public/common/content_switches.h" +#include "sandbox/mac/seatbelt.h" + +extern "C" { +void CGSSetDenyWindowServerConnections(bool); +void CGSShutdownServerConnections(); +OSStatus SetApplicationIsDaemon(Boolean isDaemon); +}; namespace content { namespace { +// This disconnects from the window server, and then indicates that Chrome +// should continue execution without access to launchservicesd. +void DisconnectWindowServer() { + // Now disconnect from WindowServer, after all objects have been warmed up. + // Shutting down the connection requires connecting to WindowServer, + // so do this before actually engaging the sandbox. This may cause two log + // messages to be printed to the system logger on certain OS versions. + CGSSetDenyWindowServerConnections(true); + CGSShutdownServerConnections(); + // Allow the process to continue without a LaunchServices ASN. The + // INIT_Process function in HIServices will abort if it cannot connect to + // launchservicesd to get an ASN. By setting this flag, HIServices skips + // that. + SetApplicationIsDaemon(true); +} + // You are about to read a pretty disgusting hack. In a static initializer, // CoreFoundation decides to connect with cfprefsd(8) using Mach IPC. There is // no public way to close this Mach port after-the-fact, nor a way to stop it @@ -128,8 +152,15 @@ } bool RendererMainPlatformDelegate::EnableSandbox() { - // Enable the sandbox. - bool sandbox_initialized = InitializeSandbox(); + bool sandbox_initialized = sandbox::Seatbelt::IsSandboxed(); + + // If the sandbox is already engaged, just disconnect from the window server. + if (sandbox_initialized) { + DisconnectWindowServer(); + } else { + sandbox_initialized = InitializeSandboxWithPostWarmupHook( + base::BindOnce(&DisconnectWindowServer)); + } // The sandbox is now engaged. Make sure that the renderer has not connected // itself to Cocoa.
diff --git a/content/renderer/renderer_v2.sb b/content/renderer/renderer_v2.sb index 341bbf3..4e10b34 100644 --- a/content/renderer/renderer_v2.sb +++ b/content/renderer/renderer_v2.sb
@@ -119,6 +119,7 @@ (global-name "com.apple.distributed_notifications@Uv3") (global-name "com.apple.fonts") (global-name "com.apple.logd") + (global-name "com.apple.lsd.mapdb") (global-name "com.apple.system.logger") (global-name "com.apple.system.notification_center") (global-name "com.apple.system.opendirectoryd.libinfo")
diff --git a/content/renderer/scheduler/resource_dispatch_throttler_unittest.cc b/content/renderer/scheduler/resource_dispatch_throttler_unittest.cc index 6a85000..e5a0d661 100644 --- a/content/renderer/scheduler/resource_dispatch_throttler_unittest.cc +++ b/content/renderer/scheduler/resource_dispatch_throttler_unittest.cc
@@ -14,6 +14,7 @@ #include "base/memory/ptr_util.h" #include "content/common/resource_messages.h" #include "content/public/common/resource_request.h" +#include "net/traffic_annotation/network_traffic_annotation_test_helper.h" #include "testing/gtest/include/gtest/gtest.h" #include "third_party/WebKit/public/platform/scheduler/test/fake_renderer_scheduler.h" @@ -135,7 +136,8 @@ ResourceRequest request; request.download_to_file = true; return throttler_->Send(new ResourceHostMsg_RequestResource( - kRoutingId, ++last_request_id_, request)); + kRoutingId, ++last_request_id_, request, + net::MutableNetworkTrafficAnnotationTag(TRAFFIC_ANNOTATION_FOR_TESTS))); } bool RequestResourceSync() {
diff --git a/content/renderer/service_worker/worker_fetch_context_impl.cc b/content/renderer/service_worker/worker_fetch_context_impl.cc index 96721068..c608bf78 100644 --- a/content/renderer/service_worker/worker_fetch_context_impl.cc +++ b/content/renderer/service_worker/worker_fetch_context_impl.cc
@@ -91,6 +91,19 @@ url)); } +void WorkerFetchContextImpl::SetSubresourceFilterBuilder( + std::unique_ptr<blink::WebDocumentSubresourceFilter::Builder> + subresource_filter_builder) { + subresource_filter_builder_ = std::move(subresource_filter_builder); +} + +std::unique_ptr<blink::WebDocumentSubresourceFilter> +WorkerFetchContextImpl::TakeSubresourceFilter() { + if (!subresource_filter_builder_) + return nullptr; + return std::move(subresource_filter_builder_)->Build(); +} + void WorkerFetchContextImpl::set_service_worker_provider_id(int id) { service_worker_provider_id_ = id; }
diff --git a/content/renderer/service_worker/worker_fetch_context_impl.h b/content/renderer/service_worker/worker_fetch_context_impl.h index f89ce10b..200f2fe 100644 --- a/content/renderer/service_worker/worker_fetch_context_impl.h +++ b/content/renderer/service_worker/worker_fetch_context_impl.h
@@ -54,6 +54,10 @@ const blink::WebURL& url) override; void SetApplicationCacheHostID(int id) override; int ApplicationCacheHostID() const override; + void SetSubresourceFilterBuilder( + std::unique_ptr<blink::WebDocumentSubresourceFilter::Builder>) override; + std::unique_ptr<blink::WebDocumentSubresourceFilter> TakeSubresourceFilter() + override; // mojom::ServiceWorkerWorkerClient implementation: void SetControllerServiceWorker(int64_t controller_version_id) override; @@ -88,6 +92,8 @@ int controller_version_id_ = kInvalidServiceWorkerVersionId; scoped_refptr<ThreadSafeSender> thread_safe_sender_; + std::unique_ptr<blink::WebDocumentSubresourceFilter::Builder> + subresource_filter_builder_; bool is_data_saver_enabled_ = false; int parent_frame_id_ = MSG_ROUTING_NONE; GURL first_party_for_cookies_;
diff --git a/content/shell/android/BUILD.gn b/content/shell/android/BUILD.gn index b6fd7b6..96af4c2 100644 --- a/content/shell/android/BUILD.gn +++ b/content/shell/android/BUILD.gn
@@ -99,6 +99,9 @@ android_library("content_shell_apk_java") { testonly = true + + srcjar_deps = [ ":content_javatests_aidl" ] + deps = [ ":content_shell_apk_resources", ":content_shell_java", @@ -107,6 +110,7 @@ "//content/public/android:content_java", "//media/capture/video/android:capture_java", "//net/android:net_java", + "//third_party/jsr-305:jsr_305_javalib", "//ui/android:ui_java", ] @@ -118,6 +122,16 @@ "shell_apk/src/org/chromium/content_shell_apk/ChildProcessLauncherTestUtils.java", "shell_apk/src/org/chromium/content_shell_apk/ContentShellActivity.java", "shell_apk/src/org/chromium/content_shell_apk/ContentShellApplication.java", + "shell_apk/src/org/chromium/content_shell_apk/TestChildProcessService.java", + "shell_apk/src/org/chromium/content_shell_apk/TestChildProcessService0.java", + "shell_apk/src/org/chromium/content_shell_apk/TestChildProcessService1.java", + ] +} + +android_aidl("content_javatests_aidl") { + import_include = [ "shell_apk/src" ] + sources = [ + "shell_apk/src/org/chromium/content_shell_apk/IChildProcessTest.aidl", ] }
diff --git a/content/shell/android/shell_apk/AndroidManifest.xml.jinja2 b/content/shell/android/shell_apk/AndroidManifest.xml.jinja2 index ea6845e..9862508b 100644 --- a/content/shell/android/shell_apk/AndroidManifest.xml.jinja2 +++ b/content/shell/android/shell_apk/AndroidManifest.xml.jinja2
@@ -67,5 +67,20 @@ <service android:name="org.chromium.content_shell_apk.ChildProcessLauncherTestHelperService" android:process=":ChildProcessLauncherHelper" /> + + <!-- The following entries are for ChildProcessLauncherTest. They should eventually be moved + to base. --> + {% set num_test_services = 2 %} + <meta-data android:name="org.chromium.content.browser.NUM_TEST_SERVICES" + android:value="{{ num_test_services }}"/> + <meta-data android:name="org.chromium.content.browser.TEST_SERVICES_NAME" + android:value="org.chromium.content_shell_apk.TestChildProcessService"/> + {% for i in range(num_test_services) %} + <service android:name="org.chromium.content_shell_apk.TestChildProcessService{{ i }}" + android:process=":test_child_service_process{{ i }}" + android:isolatedProcess="true" + android:exported="false" /> + {% endfor %} + </application> </manifest>
diff --git a/content/shell/android/shell_apk/src/org/chromium/content_shell_apk/IChildProcessTest.aidl b/content/shell/android/shell_apk/src/org/chromium/content_shell_apk/IChildProcessTest.aidl new file mode 100644 index 0000000..b413d556 --- /dev/null +++ b/content/shell/android/shell_apk/src/org/chromium/content_shell_apk/IChildProcessTest.aidl
@@ -0,0 +1,25 @@ +// Copyright 2017 The Chromium Authors. All rights reserved. +// Use of this source code is governed by a BSD-style license that can be +// found in the LICENSE file. + +package org.chromium.content_shell_apk; + +import android.os.Bundle; + +/** + * Interface provided to the TestChildProcessService. Used to echo back the calls made on the + * ChildProcessServiceDelegate to the test process. + */ +interface IChildProcessTest { + // Called by the service when onConnectionSetup is received. Echos back the parameters received + // so far. + oneway void onConnectionSetup(boolean serviceCreatedCalled, in Bundle serviceBundle, in Bundle connectionBundle); + + oneway void onLoadNativeLibrary(boolean loadedSuccessfully); + + oneway void onBeforeMain(in String[] commandLine); + + oneway void onRunMain(); + + oneway void onDestroy(); +}
diff --git a/content/shell/android/shell_apk/src/org/chromium/content_shell_apk/OWNERS b/content/shell/android/shell_apk/src/org/chromium/content_shell_apk/OWNERS new file mode 100644 index 0000000..8f094e0 --- /dev/null +++ b/content/shell/android/shell_apk/src/org/chromium/content_shell_apk/OWNERS
@@ -0,0 +1,2 @@ +per-file *.aidl=set noparent +per-file *.aidl=file://ipc/SECURITY_OWNERS
diff --git a/content/shell/android/shell_apk/src/org/chromium/content_shell_apk/TestChildProcessService.java b/content/shell/android/shell_apk/src/org/chromium/content_shell_apk/TestChildProcessService.java new file mode 100644 index 0000000..6cc7189 --- /dev/null +++ b/content/shell/android/shell_apk/src/org/chromium/content_shell_apk/TestChildProcessService.java
@@ -0,0 +1,153 @@ +// Copyright 2017 The Chromium Authors. All rights reserved. +// Use of this source code is governed by a BSD-style license that can be +// found in the LICENSE file. + +package org.chromium.content_shell_apk; + +import android.content.Context; +import android.content.Intent; +import android.os.Bundle; +import android.os.IBinder; +import android.os.Looper; +import android.os.RemoteException; +import android.util.SparseArray; + +import org.chromium.base.CommandLine; +import org.chromium.base.Log; +import org.chromium.base.library_loader.LibraryLoader; +import org.chromium.base.library_loader.LibraryProcessType; +import org.chromium.base.library_loader.ProcessInitException; +import org.chromium.base.process_launcher.ChildProcessService; +import org.chromium.base.process_launcher.ChildProcessServiceDelegate; + +import javax.annotation.concurrent.GuardedBy; + +/** + * Child service started by ChildProcessLauncherTest. + */ +public class TestChildProcessService extends ChildProcessService { + private static final String TAG = "TestProcessService"; + + private static final long MAIN_BLOCKING_DURATION_MS = 5000; + + private static class TestChildProcessServiceDelegate implements ChildProcessServiceDelegate { + private final Object mConnectionSetupLock = new Object(); + @GuardedBy("mConnectionSetupLock") + private boolean mConnectionSetup; + + private boolean mServiceCreated; + private Bundle mServiceBundle; + private String[] mCommandLine; + private IChildProcessTest mIChildProcessTest; + + @Override + public void onServiceCreated() { + mServiceCreated = true; + } + + @Override + public void onServiceBound(Intent intent) { + mServiceBundle = intent.getExtras(); + } + + @Override + public void onConnectionSetup(Bundle connectionBundle, IBinder callback) { + if (callback != null) { + mIChildProcessTest = IChildProcessTest.Stub.asInterface(callback); + } + if (mIChildProcessTest != null) { + try { + mIChildProcessTest.onConnectionSetup( + mServiceCreated, mServiceBundle, connectionBundle); + } catch (RemoteException re) { + Log.e(TAG, "Failed to call IChildProcessTest.onConnectionSetup.", re); + } + } + synchronized (mConnectionSetupLock) { + mConnectionSetup = true; + mConnectionSetupLock.notifyAll(); + } + } + + @Override + public void onDestroy() { + if (mIChildProcessTest == null) return; + try { + mIChildProcessTest.onDestroy(); + } catch (RemoteException re) { + Log.e(TAG, "Failed to call IChildProcessTest.onDestroy.", re); + } + } + + @Override + public boolean loadNativeLibrary(Context hostContext) { + // Store the command line before loading the library to avoid an assert in CommandLine. + mCommandLine = CommandLine.getJavaSwitchesOrNull(); + + LibraryLoader libraryLoader = null; + boolean isLoaded = false; + try { + libraryLoader = LibraryLoader.get(LibraryProcessType.PROCESS_CHILD); + libraryLoader.loadNow(); + libraryLoader.ensureInitialized(); + isLoaded = true; + } catch (ProcessInitException e) { + Log.e(TAG, "Failed to load native library.", e); + } + + // Loading the library happen on the main thread and onConnectionSetup is called from + // the client. Wait for onConnectionSetup so mIChildProcessTest is set. + synchronized (mConnectionSetupLock) { + while (!mConnectionSetup) { + try { + mConnectionSetupLock.wait(); + } catch (InterruptedException e) { + // Ignore. + } + } + } + + if (mIChildProcessTest != null) { + try { + mIChildProcessTest.onLoadNativeLibrary(isLoaded); + } catch (RemoteException re) { + Log.e(TAG, "Failed to call IChildProcessTest.onLoadNativeLibrary.", re); + } + } + return true; + } + + @Override + public SparseArray<String> getFileDescriptorsIdsToKeys() { + return null; + } + + @Override + public void onBeforeMain() { + if (mIChildProcessTest == null) return; + try { + mIChildProcessTest.onBeforeMain(mCommandLine); + } catch (RemoteException re) { + Log.e(TAG, "Failed to call IChildProcessTest.onBeforeMain.", re); + } + } + + @Override + public void runMain() { + if (mIChildProcessTest != null) { + try { + mIChildProcessTest.onRunMain(); + } catch (RemoteException re) { + Log.e(TAG, "Failed to call IChildProcessTest.onRunMain.", re); + } + } + // Run a message loop to keep the service from exiting. + Looper.prepare(); + Looper.loop(); + } + }; + + public TestChildProcessService() { + super(new TestChildProcessServiceDelegate()); + } +}
diff --git a/content/shell/android/shell_apk/src/org/chromium/content_shell_apk/TestChildProcessService0.java b/content/shell/android/shell_apk/src/org/chromium/content_shell_apk/TestChildProcessService0.java new file mode 100644 index 0000000..90fb3336 --- /dev/null +++ b/content/shell/android/shell_apk/src/org/chromium/content_shell_apk/TestChildProcessService0.java
@@ -0,0 +1,8 @@ +// Copyright 2017 The Chromium Authors. All rights reserved. +// Use of this source code is governed by a BSD-style license that can be +// found in the LICENSE file. + +package org.chromium.content_shell_apk; + +/** One of the TestChildProcessService defined in the AndroidManifest.xml. */ +public class TestChildProcessService0 extends TestChildProcessService {}
diff --git a/content/shell/android/shell_apk/src/org/chromium/content_shell_apk/TestChildProcessService1.java b/content/shell/android/shell_apk/src/org/chromium/content_shell_apk/TestChildProcessService1.java new file mode 100644 index 0000000..e7429bac --- /dev/null +++ b/content/shell/android/shell_apk/src/org/chromium/content_shell_apk/TestChildProcessService1.java
@@ -0,0 +1,8 @@ +// Copyright 2017 The Chromium Authors. All rights reserved. +// Use of this source code is governed by a BSD-style license that can be +// found in the LICENSE file. + +package org.chromium.content_shell_apk; + +/** One of the TestChildProcessService defined in the AndroidManifest.xml. */ +public class TestChildProcessService1 extends TestChildProcessService {}
diff --git a/content/test/BUILD.gn b/content/test/BUILD.gn index c3234aac..f55394f 100644 --- a/content/test/BUILD.gn +++ b/content/test/BUILD.gn
@@ -1504,6 +1504,7 @@ "//cc/surfaces", "//components/leveldb/public/cpp", "//components/metrics/proto", + "//components/offline_pages/features:features", "//components/rappor:test_support", "//components/ukm:test_support", "//components/viz/common",
diff --git a/content/test/test_web_contents.cc b/content/test/test_web_contents.cc index 7369046..f495cd8 100644 --- a/content/test/test_web_contents.cc +++ b/content/test/test_web_contents.cc
@@ -100,6 +100,13 @@ return g_next_image_download_id; } +const GURL& TestWebContents::GetLastCommittedURL() const { + if (last_committed_url_.is_valid()) { + return last_committed_url_; + } + return WebContentsImpl::GetLastCommittedURL(); +} + void TestWebContents::TestDidNavigate(RenderFrameHost* render_frame_host, int nav_entry_id, bool did_create_new_entry, @@ -208,6 +215,10 @@ return true; } +void TestWebContents::SetLastCommittedURL(const GURL& url) { + last_committed_url_ = url; +} + bool TestWebContents::CrossProcessNavigationPending() { if (IsBrowserSideNavigationEnabled()) { return GetRenderManager()->speculative_render_frame_host_ != nullptr;
diff --git a/content/test/test_web_contents.h b/content/test/test_web_contents.h index f075d52a..c8ca044 100644 --- a/content/test/test_web_contents.h +++ b/content/test/test_web_contents.h
@@ -55,6 +55,7 @@ uint32_t max_bitmap_size, bool bypass_cache, const ImageDownloadCallback& callback) override; + const GURL& GetLastCommittedURL() const override; // WebContentsTester implementation. void CommitPendingNavigation() override; @@ -90,6 +91,7 @@ int http_status_code, const std::vector<SkBitmap>& bitmaps, const std::vector<gfx::Size>& original_bitmap_sizes) override; + void SetLastCommittedURL(const GURL& url) override; // True if a cross-site navigation is pending. bool CrossProcessNavigationPending(); @@ -187,6 +189,7 @@ // Map keyed by image URL. Values are <id, callback> pairs. std::map<GURL, std::list<std::pair<int, ImageDownloadCallback>>> pending_image_downloads_; + GURL last_committed_url_; }; } // namespace content
diff --git a/docs/fuchsia_build_instructions.md b/docs/fuchsia_build_instructions.md index 16197d4..1d9eb5a3 100644 --- a/docs/fuchsia_build_instructions.md +++ b/docs/fuchsia_build_instructions.md
@@ -90,7 +90,7 @@ configurations. To create a build directory, run: ```shell -$ gn gen out/fuch --args="is_debug=false dcheck_always_on=true is_component_build=false target_os=\"fuchsia\"" +$ gn gen out/fuchsia --args="is_debug=false dcheck_always_on=true is_component_build=false target_os=\"fuchsia\"" ``` `use_goma=true` is fine to use also if you're a Googler. @@ -101,7 +101,7 @@ example: ```shell -$ ninja -C out/fuch base_unittests +$ ninja -C out/fuchsia base_unittests ``` ## Run @@ -122,6 +122,6 @@ A useful alias (for "Build And Run Filtered") is: ```shell -alias barf='ninja -C out/fuch base_unittests -j1000 && out/fuch/bin/run_base_unittests --test-launcher-filter-file=../../testing/buildbot/filters/fuchsia.base_unittests.filter' +alias barf='ninja -C out/fuchsia base_unittests -j1000 && out/fuch/bin/run_base_unittests --test-launcher-filter-file=../../testing/buildbot/filters/fuchsia.base_unittests.filter' ``` to build and run only the tests that are not excluded/known-failing on the bot.
diff --git a/extensions/browser/api/bluetooth_low_energy/bluetooth_low_energy_api.cc b/extensions/browser/api/bluetooth_low_energy/bluetooth_low_energy_api.cc index 45933bc4..69fb27f 100644 --- a/extensions/browser/api/bluetooth_low_energy/bluetooth_low_energy_api.cc +++ b/extensions/browser/api/bluetooth_low_energy/bluetooth_low_energy_api.cc
@@ -354,39 +354,6 @@ namespace api { -BluetoothLowEnergyExtensionFunctionDeprecated:: - BluetoothLowEnergyExtensionFunctionDeprecated() {} - -BluetoothLowEnergyExtensionFunctionDeprecated:: - ~BluetoothLowEnergyExtensionFunctionDeprecated() {} - -bool BluetoothLowEnergyExtensionFunctionDeprecated::RunAsync() { - DCHECK_CURRENTLY_ON(BrowserThread::UI); - - if (!BluetoothManifestData::CheckLowEnergyPermitted(extension())) { - error_ = kErrorPermissionDenied; - return false; - } - - BluetoothLowEnergyEventRouter* event_router = - GetEventRouter(browser_context()); - if (!event_router->IsBluetoothSupported()) { - SetError(kErrorPlatformNotSupported); - return false; - } - - // It is safe to pass |this| here as ExtensionFunction is refcounted. - if (!event_router->InitializeAdapterAndInvokeCallback(base::Bind( - &DoWorkCallback<bool>, - base::Bind(&BluetoothLowEnergyExtensionFunctionDeprecated::DoWork, - this)))) { - SetError(kErrorAdapterNotInitialized); - return false; - } - - return true; -} - BluetoothLowEnergyExtensionFunction::BluetoothLowEnergyExtensionFunction() : event_router_(nullptr) {} @@ -395,6 +362,8 @@ ExtensionFunction::ResponseAction BluetoothLowEnergyExtensionFunction::Run() { DCHECK_CURRENTLY_ON(BrowserThread::UI); + EXTENSION_FUNCTION_VALIDATE(ParseParams()); + if (!BluetoothManifestData::CheckLowEnergyPermitted(extension())) return RespondNow(Error(kErrorPermissionDenied)); @@ -414,6 +383,8 @@ } void BluetoothLowEnergyExtensionFunction::PreDoWork() { + DCHECK_CURRENTLY_ON(BrowserThread::UI); + // The adapter must be initialized at this point, but return an error instead // of asserting. if (!event_router_->HasAdapter()) { @@ -423,15 +394,11 @@ DoWork(); } -template <typename Params> -BLEPeripheralExtensionFunction<Params>::BLEPeripheralExtensionFunction() {} +BLEPeripheralExtensionFunction::BLEPeripheralExtensionFunction() {} -template <typename Params> -BLEPeripheralExtensionFunction<Params>::~BLEPeripheralExtensionFunction() {} +BLEPeripheralExtensionFunction::~BLEPeripheralExtensionFunction() {} -template <typename Params> -ExtensionFunction::ResponseAction -BLEPeripheralExtensionFunction<Params>::Run() { +ExtensionFunction::ResponseAction BLEPeripheralExtensionFunction::Run() { DCHECK_CURRENTLY_ON(BrowserThread::UI); // Check permissions in manifest. @@ -443,219 +410,212 @@ return RespondNow(Error(kErrorPermissionDenied)); } -// Causes link error on Windows. API will never be on Windows, so #ifdefing. -#if !defined(OS_WIN) - params_ = Params::Create(*args_); - EXTENSION_FUNCTION_VALIDATE(params_.get() != NULL); -#endif - return BluetoothLowEnergyExtensionFunction::Run(); } -bool BluetoothLowEnergyConnectFunction::DoWork() { - DCHECK_CURRENTLY_ON(BrowserThread::UI); +BluetoothLowEnergyConnectFunction::BluetoothLowEnergyConnectFunction() {} +BluetoothLowEnergyConnectFunction::~BluetoothLowEnergyConnectFunction() {} + +bool BluetoothLowEnergyConnectFunction::ParseParams() { + params_ = apibtle::Connect::Params::Create(*args_); + return params_.get() != nullptr; +} + +void BluetoothLowEnergyConnectFunction::DoWork() { BluetoothLowEnergyEventRouter* event_router = GetEventRouter(browser_context()); // The adapter must be initialized at this point, but return an error instead // of asserting. if (!event_router->HasAdapter()) { - SetError(kErrorAdapterNotInitialized); - SendResponse(false); - return false; + Respond(Error(kErrorAdapterNotInitialized)); + return; } - std::unique_ptr<apibtle::Connect::Params> params( - apibtle::Connect::Params::Create(*args_)); - EXTENSION_FUNCTION_VALIDATE(params.get() != NULL); - bool persistent = false; // Not persistent by default. - apibtle::ConnectProperties* properties = params->properties.get(); + apibtle::ConnectProperties* properties = params_->properties.get(); if (properties) persistent = properties->persistent; event_router->Connect( - persistent, extension(), params->device_address, + persistent, extension(), params_->device_address, base::Bind(&BluetoothLowEnergyConnectFunction::SuccessCallback, this), base::Bind(&BluetoothLowEnergyConnectFunction::ErrorCallback, this)); - - return true; } void BluetoothLowEnergyConnectFunction::SuccessCallback() { - SendResponse(true); + Respond(NoArguments()); } void BluetoothLowEnergyConnectFunction::ErrorCallback( BluetoothLowEnergyEventRouter::Status status) { - SetError(StatusToString(status)); - SendResponse(false); + Respond(Error(StatusToString(status))); } -bool BluetoothLowEnergyDisconnectFunction::DoWork() { - DCHECK_CURRENTLY_ON(BrowserThread::UI); +BluetoothLowEnergyDisconnectFunction::BluetoothLowEnergyDisconnectFunction() {} +BluetoothLowEnergyDisconnectFunction::~BluetoothLowEnergyDisconnectFunction() {} + +bool BluetoothLowEnergyDisconnectFunction::ParseParams() { + params_ = apibtle::Disconnect::Params::Create(*args_); + return params_.get() != nullptr; +} + +void BluetoothLowEnergyDisconnectFunction::DoWork() { BluetoothLowEnergyEventRouter* event_router = GetEventRouter(browser_context()); // The adapter must be initialized at this point, but return an error instead // of asserting. if (!event_router->HasAdapter()) { - SetError(kErrorAdapterNotInitialized); - SendResponse(false); - return false; + Respond(Error(kErrorAdapterNotInitialized)); + return; } - std::unique_ptr<apibtle::Disconnect::Params> params( - apibtle::Disconnect::Params::Create(*args_)); - EXTENSION_FUNCTION_VALIDATE(params.get() != NULL); - event_router->Disconnect( - extension(), params->device_address, + extension(), params_->device_address, base::Bind(&BluetoothLowEnergyDisconnectFunction::SuccessCallback, this), base::Bind(&BluetoothLowEnergyDisconnectFunction::ErrorCallback, this)); - - return true; } void BluetoothLowEnergyDisconnectFunction::SuccessCallback() { - SendResponse(true); + Respond(NoArguments()); } void BluetoothLowEnergyDisconnectFunction::ErrorCallback( BluetoothLowEnergyEventRouter::Status status) { - SetError(StatusToString(status)); - SendResponse(false); + Respond(Error(StatusToString(status))); } -bool BluetoothLowEnergyGetServiceFunction::DoWork() { - DCHECK_CURRENTLY_ON(BrowserThread::UI); +BluetoothLowEnergyGetServiceFunction::BluetoothLowEnergyGetServiceFunction() {} +BluetoothLowEnergyGetServiceFunction::~BluetoothLowEnergyGetServiceFunction() {} + +bool BluetoothLowEnergyGetServiceFunction::ParseParams() { + params_ = apibtle::GetService::Params::Create(*args_); + return params_.get() != nullptr; +} + +void BluetoothLowEnergyGetServiceFunction::DoWork() { BluetoothLowEnergyEventRouter* event_router = GetEventRouter(browser_context()); // The adapter must be initialized at this point, but return an error instead // of asserting. if (!event_router->HasAdapter()) { - SetError(kErrorAdapterNotInitialized); - SendResponse(false); - return false; + Respond(Error(kErrorAdapterNotInitialized)); + return; } - std::unique_ptr<apibtle::GetService::Params> params( - apibtle::GetService::Params::Create(*args_)); - EXTENSION_FUNCTION_VALIDATE(params.get() != NULL); - apibtle::Service service; BluetoothLowEnergyEventRouter::Status status = - event_router->GetService(params->service_id, &service); + event_router->GetService(params_->service_id, &service); if (status != BluetoothLowEnergyEventRouter::kStatusSuccess) { - SetError(StatusToString(status)); - SendResponse(false); - return false; + Respond(Error(StatusToString(status))); + return; } - results_ = apibtle::GetService::Results::Create(service); - SendResponse(true); - - return true; + Respond(ArgumentList(apibtle::GetService::Results::Create(service))); } -bool BluetoothLowEnergyGetServicesFunction::DoWork() { - DCHECK_CURRENTLY_ON(BrowserThread::UI); +BluetoothLowEnergyGetServicesFunction::BluetoothLowEnergyGetServicesFunction() { +} +BluetoothLowEnergyGetServicesFunction:: + ~BluetoothLowEnergyGetServicesFunction() {} + +bool BluetoothLowEnergyGetServicesFunction::ParseParams() { + params_ = apibtle::GetServices::Params::Create(*args_); + return params_.get() != nullptr; +} + +void BluetoothLowEnergyGetServicesFunction::DoWork() { BluetoothLowEnergyEventRouter* event_router = GetEventRouter(browser_context()); // The adapter must be initialized at this point, but return an error instead // of asserting. if (!event_router->HasAdapter()) { - SetError(kErrorAdapterNotInitialized); - SendResponse(false); - return false; + Respond(Error(kErrorAdapterNotInitialized)); + return; } - std::unique_ptr<apibtle::GetServices::Params> params( - apibtle::GetServices::Params::Create(*args_)); - EXTENSION_FUNCTION_VALIDATE(params.get() != NULL); - BluetoothLowEnergyEventRouter::ServiceList service_list; - if (!event_router->GetServices(params->device_address, &service_list)) { - SetError(kErrorNotFound); - SendResponse(false); - return false; + if (!event_router->GetServices(params_->device_address, &service_list)) { + Respond(Error(kErrorNotFound)); + return; } - results_ = apibtle::GetServices::Results::Create(service_list); - SendResponse(true); - - return true; + Respond(ArgumentList(apibtle::GetServices::Results::Create(service_list))); } -bool BluetoothLowEnergyGetCharacteristicFunction::DoWork() { - DCHECK_CURRENTLY_ON(BrowserThread::UI); +BluetoothLowEnergyGetCharacteristicFunction:: + BluetoothLowEnergyGetCharacteristicFunction() {} +BluetoothLowEnergyGetCharacteristicFunction:: + ~BluetoothLowEnergyGetCharacteristicFunction() {} + +bool BluetoothLowEnergyGetCharacteristicFunction::ParseParams() { + params_ = apibtle::GetCharacteristic::Params::Create(*args_); + return params_.get() != nullptr; +} + +void BluetoothLowEnergyGetCharacteristicFunction::DoWork() { BluetoothLowEnergyEventRouter* event_router = GetEventRouter(browser_context()); // The adapter must be initialized at this point, but return an error instead // of asserting. if (!event_router->HasAdapter()) { - SetError(kErrorAdapterNotInitialized); - SendResponse(false); - return false; + Respond(Error(kErrorAdapterNotInitialized)); + return; } - std::unique_ptr<apibtle::GetCharacteristic::Params> params( - apibtle::GetCharacteristic::Params::Create(*args_)); - EXTENSION_FUNCTION_VALIDATE(params.get() != NULL); - apibtle::Characteristic characteristic; BluetoothLowEnergyEventRouter::Status status = - event_router->GetCharacteristic(extension(), params->characteristic_id, + event_router->GetCharacteristic(extension(), params_->characteristic_id, &characteristic); if (status != BluetoothLowEnergyEventRouter::kStatusSuccess) { - SetError(StatusToString(status)); - SendResponse(false); - return false; + Respond(Error(StatusToString(status))); + return; } // Manually construct the result instead of using // apibtle::GetCharacteristic::Result::Create as it doesn't convert lists of // enums correctly. - SetResult(apibtle::CharacteristicToValue(&characteristic)); - SendResponse(true); - - return true; + Respond(OneArgument(apibtle::CharacteristicToValue(&characteristic))); } -bool BluetoothLowEnergyGetCharacteristicsFunction::DoWork() { - DCHECK_CURRENTLY_ON(BrowserThread::UI); +BluetoothLowEnergyGetCharacteristicsFunction:: + BluetoothLowEnergyGetCharacteristicsFunction() {} +BluetoothLowEnergyGetCharacteristicsFunction:: + ~BluetoothLowEnergyGetCharacteristicsFunction() {} + +bool BluetoothLowEnergyGetCharacteristicsFunction::ParseParams() { + params_ = apibtle::GetCharacteristics::Params::Create(*args_); + return params_.get() != nullptr; +} + +void BluetoothLowEnergyGetCharacteristicsFunction::DoWork() { BluetoothLowEnergyEventRouter* event_router = GetEventRouter(browser_context()); // The adapter must be initialized at this point, but return an error instead // of asserting. if (!event_router->HasAdapter()) { - SetError(kErrorAdapterNotInitialized); - SendResponse(false); - return false; + Respond(Error(kErrorAdapterNotInitialized)); + return; } - std::unique_ptr<apibtle::GetCharacteristics::Params> params( - apibtle::GetCharacteristics::Params::Create(*args_)); - EXTENSION_FUNCTION_VALIDATE(params.get() != NULL); - BluetoothLowEnergyEventRouter::CharacteristicList characteristic_list; BluetoothLowEnergyEventRouter::Status status = - event_router->GetCharacteristics(extension(), params->service_id, + event_router->GetCharacteristics(extension(), params_->service_id, &characteristic_list); if (status != BluetoothLowEnergyEventRouter::kStatusSuccess) { - SetError(StatusToString(status)); - SendResponse(false); - return false; + Respond(Error(StatusToString(status))); + return; } // Manually construct the result instead of using @@ -665,106 +625,107 @@ for (apibtle::Characteristic& characteristic : characteristic_list) result->Append(apibtle::CharacteristicToValue(&characteristic)); - SetResult(std::move(result)); - SendResponse(true); - - return true; + Respond(OneArgument(std::move(result))); } -bool BluetoothLowEnergyGetIncludedServicesFunction::DoWork() { - DCHECK_CURRENTLY_ON(BrowserThread::UI); +BluetoothLowEnergyGetIncludedServicesFunction:: + BluetoothLowEnergyGetIncludedServicesFunction() {} +BluetoothLowEnergyGetIncludedServicesFunction:: + ~BluetoothLowEnergyGetIncludedServicesFunction() {} + +bool BluetoothLowEnergyGetIncludedServicesFunction::ParseParams() { + params_ = apibtle::GetIncludedServices::Params::Create(*args_); + return params_.get() != nullptr; +} + +void BluetoothLowEnergyGetIncludedServicesFunction::DoWork() { BluetoothLowEnergyEventRouter* event_router = GetEventRouter(browser_context()); // The adapter must be initialized at this point, but return an error instead // of asserting. if (!event_router->HasAdapter()) { - SetError(kErrorAdapterNotInitialized); - SendResponse(false); - return false; + Respond(Error(kErrorAdapterNotInitialized)); + return; } - std::unique_ptr<apibtle::GetIncludedServices::Params> params( - apibtle::GetIncludedServices::Params::Create(*args_)); - EXTENSION_FUNCTION_VALIDATE(params.get() != NULL); - BluetoothLowEnergyEventRouter::ServiceList service_list; BluetoothLowEnergyEventRouter::Status status = - event_router->GetIncludedServices(params->service_id, &service_list); + event_router->GetIncludedServices(params_->service_id, &service_list); if (status != BluetoothLowEnergyEventRouter::kStatusSuccess) { - SetError(StatusToString(status)); - SendResponse(false); - return false; + Respond(Error(StatusToString(status))); + return; } - results_ = apibtle::GetIncludedServices::Results::Create(service_list); - SendResponse(true); - - return true; + Respond(ArgumentList( + apibtle::GetIncludedServices::Results::Create(service_list))); } -bool BluetoothLowEnergyGetDescriptorFunction::DoWork() { - DCHECK_CURRENTLY_ON(BrowserThread::UI); +BluetoothLowEnergyGetDescriptorFunction:: + BluetoothLowEnergyGetDescriptorFunction() {} +BluetoothLowEnergyGetDescriptorFunction:: + ~BluetoothLowEnergyGetDescriptorFunction() {} + +bool BluetoothLowEnergyGetDescriptorFunction::ParseParams() { + params_ = apibtle::GetDescriptor::Params::Create(*args_); + return params_.get() != nullptr; +} + +void BluetoothLowEnergyGetDescriptorFunction::DoWork() { BluetoothLowEnergyEventRouter* event_router = GetEventRouter(browser_context()); // The adapter must be initialized at this point, but return an error instead // of asserting. if (!event_router->HasAdapter()) { - SetError(kErrorAdapterNotInitialized); - SendResponse(false); - return false; + Respond(Error(kErrorAdapterNotInitialized)); + return; } - std::unique_ptr<apibtle::GetDescriptor::Params> params( - apibtle::GetDescriptor::Params::Create(*args_)); - EXTENSION_FUNCTION_VALIDATE(params.get() != NULL); - apibtle::Descriptor descriptor; BluetoothLowEnergyEventRouter::Status status = event_router->GetDescriptor( - extension(), params->descriptor_id, &descriptor); + extension(), params_->descriptor_id, &descriptor); if (status != BluetoothLowEnergyEventRouter::kStatusSuccess) { - SetError(StatusToString(status)); - SendResponse(false); - return false; + Respond(Error(StatusToString(status))); + return; } // Manually construct the result instead of using // apibtle::GetDescriptor::Result::Create as it doesn't convert lists of enums // correctly. - SetResult(apibtle::DescriptorToValue(&descriptor)); - SendResponse(true); - - return true; + Respond(OneArgument(apibtle::DescriptorToValue(&descriptor))); } -bool BluetoothLowEnergyGetDescriptorsFunction::DoWork() { - DCHECK_CURRENTLY_ON(BrowserThread::UI); +BluetoothLowEnergyGetDescriptorsFunction:: + BluetoothLowEnergyGetDescriptorsFunction() {} +BluetoothLowEnergyGetDescriptorsFunction:: + ~BluetoothLowEnergyGetDescriptorsFunction() {} + +bool BluetoothLowEnergyGetDescriptorsFunction::ParseParams() { + params_ = apibtle::GetDescriptors::Params::Create(*args_); + return params_.get() != nullptr; +} + +void BluetoothLowEnergyGetDescriptorsFunction::DoWork() { BluetoothLowEnergyEventRouter* event_router = GetEventRouter(browser_context()); // The adapter must be initialized at this point, but return an error instead // of asserting. if (!event_router->HasAdapter()) { - SetError(kErrorAdapterNotInitialized); - SendResponse(false); - return false; + Respond(Error(kErrorAdapterNotInitialized)); + return; } - std::unique_ptr<apibtle::GetDescriptors::Params> params( - apibtle::GetDescriptors::Params::Create(*args_)); - EXTENSION_FUNCTION_VALIDATE(params.get() != NULL); - BluetoothLowEnergyEventRouter::DescriptorList descriptor_list; BluetoothLowEnergyEventRouter::Status status = event_router->GetDescriptors( - extension(), params->characteristic_id, &descriptor_list); + extension(), params_->characteristic_id, &descriptor_list); if (status != BluetoothLowEnergyEventRouter::kStatusSuccess) { - SetError(StatusToString(status)); - SendResponse(false); - return false; + Respond(Error(StatusToString(status))); + return; } // Manually construct the result instead of using @@ -774,31 +735,32 @@ for (apibtle::Descriptor& descriptor : descriptor_list) result->Append(apibtle::DescriptorToValue(&descriptor)); - SetResult(std::move(result)); - SendResponse(true); - - return true; + Respond(OneArgument(std::move(result))); } -bool BluetoothLowEnergyReadCharacteristicValueFunction::DoWork() { - DCHECK_CURRENTLY_ON(BrowserThread::UI); +BluetoothLowEnergyReadCharacteristicValueFunction:: + BluetoothLowEnergyReadCharacteristicValueFunction() {} +BluetoothLowEnergyReadCharacteristicValueFunction:: + ~BluetoothLowEnergyReadCharacteristicValueFunction() {} + +bool BluetoothLowEnergyReadCharacteristicValueFunction::ParseParams() { + params_ = apibtle::ReadCharacteristicValue::Params::Create(*args_); + return params_.get() != nullptr; +} + +void BluetoothLowEnergyReadCharacteristicValueFunction::DoWork() { BluetoothLowEnergyEventRouter* event_router = GetEventRouter(browser_context()); // The adapter must be initialized at this point, but return an error instead // of asserting. if (!event_router->HasAdapter()) { - SetError(kErrorAdapterNotInitialized); - SendResponse(false); - return false; + Respond(Error(kErrorAdapterNotInitialized)); + return; } - std::unique_ptr<apibtle::ReadCharacteristicValue::Params> params( - apibtle::ReadCharacteristicValue::Params::Create(*args_)); - EXTENSION_FUNCTION_VALIDATE(params.get() != NULL); - - instance_id_ = params->characteristic_id; + instance_id_ = params_->characteristic_id; event_router->ReadCharacteristicValue( extension(), instance_id_, base::Bind( @@ -807,8 +769,6 @@ base::Bind( &BluetoothLowEnergyReadCharacteristicValueFunction::ErrorCallback, this)); - - return true; } void BluetoothLowEnergyReadCharacteristicValueFunction::SuccessCallback() { @@ -819,172 +779,175 @@ GetEventRouter(browser_context()) ->GetCharacteristic(extension(), instance_id_, &characteristic); if (status != BluetoothLowEnergyEventRouter::kStatusSuccess) { - SetError(StatusToString(status)); - SendResponse(false); + Respond(Error(StatusToString(status))); return; } // Manually construct the result instead of using // apibtle::GetCharacteristic::Result::Create as it doesn't convert lists of // enums correctly. - SetResult(apibtle::CharacteristicToValue(&characteristic)); - SendResponse(true); + Respond(OneArgument(apibtle::CharacteristicToValue(&characteristic))); } void BluetoothLowEnergyReadCharacteristicValueFunction::ErrorCallback( BluetoothLowEnergyEventRouter::Status status) { - SetError(StatusToString(status)); - SendResponse(false); + Respond(Error(StatusToString(status))); } -bool BluetoothLowEnergyWriteCharacteristicValueFunction::DoWork() { - DCHECK_CURRENTLY_ON(BrowserThread::UI); +BluetoothLowEnergyWriteCharacteristicValueFunction:: + BluetoothLowEnergyWriteCharacteristicValueFunction() {} +BluetoothLowEnergyWriteCharacteristicValueFunction:: + ~BluetoothLowEnergyWriteCharacteristicValueFunction() {} + +bool BluetoothLowEnergyWriteCharacteristicValueFunction::ParseParams() { + params_ = apibtle::WriteCharacteristicValue::Params::Create(*args_); + return params_.get() != nullptr; +} + +void BluetoothLowEnergyWriteCharacteristicValueFunction::DoWork() { BluetoothLowEnergyEventRouter* event_router = GetEventRouter(browser_context()); // The adapter must be initialized at this point, but return an error instead // of asserting. if (!event_router->HasAdapter()) { - SetError(kErrorAdapterNotInitialized); - SendResponse(false); - return false; + Respond(Error(kErrorAdapterNotInitialized)); + return; } - std::unique_ptr<apibtle::WriteCharacteristicValue::Params> params( - apibtle::WriteCharacteristicValue::Params::Create(*args_)); - EXTENSION_FUNCTION_VALIDATE(params.get() != NULL); - - std::vector<uint8_t> value(params->value.begin(), params->value.end()); + std::vector<uint8_t> value(params_->value.begin(), params_->value.end()); event_router->WriteCharacteristicValue( - extension(), params->characteristic_id, value, + extension(), params_->characteristic_id, value, base::Bind( &BluetoothLowEnergyWriteCharacteristicValueFunction::SuccessCallback, this), base::Bind( &BluetoothLowEnergyWriteCharacteristicValueFunction::ErrorCallback, this)); - - return true; } void BluetoothLowEnergyWriteCharacteristicValueFunction::SuccessCallback() { - results_ = apibtle::WriteCharacteristicValue::Results::Create(); - SendResponse(true); + Respond(ArgumentList(apibtle::WriteCharacteristicValue::Results::Create())); } void BluetoothLowEnergyWriteCharacteristicValueFunction::ErrorCallback( BluetoothLowEnergyEventRouter::Status status) { - SetError(StatusToString(status)); - SendResponse(false); + Respond(Error(StatusToString(status))); } -bool BluetoothLowEnergyStartCharacteristicNotificationsFunction::DoWork() { - DCHECK_CURRENTLY_ON(BrowserThread::UI); +BluetoothLowEnergyStartCharacteristicNotificationsFunction:: + BluetoothLowEnergyStartCharacteristicNotificationsFunction() {} +BluetoothLowEnergyStartCharacteristicNotificationsFunction:: + ~BluetoothLowEnergyStartCharacteristicNotificationsFunction() {} + +bool BluetoothLowEnergyStartCharacteristicNotificationsFunction::ParseParams() { + params_ = apibtle::StartCharacteristicNotifications::Params::Create(*args_); + return params_.get() != nullptr; +} + +void BluetoothLowEnergyStartCharacteristicNotificationsFunction::DoWork() { BluetoothLowEnergyEventRouter* event_router = GetEventRouter(browser_context()); // The adapter must be initialized at this point, but return an error instead // of asserting. if (!event_router->HasAdapter()) { - SetError(kErrorAdapterNotInitialized); - SendResponse(false); - return false; + Respond(Error(kErrorAdapterNotInitialized)); + return; } - std::unique_ptr<apibtle::StartCharacteristicNotifications::Params> params( - apibtle::StartCharacteristicNotifications::Params::Create(*args_)); - EXTENSION_FUNCTION_VALIDATE(params.get() != NULL); - bool persistent = false; // Not persistent by default. - apibtle::NotificationProperties* properties = params->properties.get(); + apibtle::NotificationProperties* properties = params_->properties.get(); if (properties) persistent = properties->persistent; event_router->StartCharacteristicNotifications( - persistent, extension(), params->characteristic_id, + persistent, extension(), params_->characteristic_id, base::Bind(&BluetoothLowEnergyStartCharacteristicNotificationsFunction:: SuccessCallback, this), base::Bind(&BluetoothLowEnergyStartCharacteristicNotificationsFunction:: ErrorCallback, this)); - - return true; } void BluetoothLowEnergyStartCharacteristicNotificationsFunction:: SuccessCallback() { - SendResponse(true); + Respond(NoArguments()); } void BluetoothLowEnergyStartCharacteristicNotificationsFunction::ErrorCallback( BluetoothLowEnergyEventRouter::Status status) { - SetError(StatusToString(status)); - SendResponse(false); + Respond(Error(StatusToString(status))); } -bool BluetoothLowEnergyStopCharacteristicNotificationsFunction::DoWork() { - DCHECK_CURRENTLY_ON(BrowserThread::UI); +BluetoothLowEnergyStopCharacteristicNotificationsFunction:: + BluetoothLowEnergyStopCharacteristicNotificationsFunction() {} +BluetoothLowEnergyStopCharacteristicNotificationsFunction:: + ~BluetoothLowEnergyStopCharacteristicNotificationsFunction() {} + +bool BluetoothLowEnergyStopCharacteristicNotificationsFunction::ParseParams() { + params_ = apibtle::StopCharacteristicNotifications::Params::Create(*args_); + return params_.get() != nullptr; +} + +void BluetoothLowEnergyStopCharacteristicNotificationsFunction::DoWork() { BluetoothLowEnergyEventRouter* event_router = GetEventRouter(browser_context()); // The adapter must be initialized at this point, but return an error instead // of asserting. if (!event_router->HasAdapter()) { - SetError(kErrorAdapterNotInitialized); - SendResponse(false); - return false; + Respond(Error(kErrorAdapterNotInitialized)); + return; } - std::unique_ptr<apibtle::StopCharacteristicNotifications::Params> params( - apibtle::StopCharacteristicNotifications::Params::Create(*args_)); - EXTENSION_FUNCTION_VALIDATE(params.get() != NULL); - event_router->StopCharacteristicNotifications( - extension(), params->characteristic_id, + extension(), params_->characteristic_id, base::Bind(&BluetoothLowEnergyStopCharacteristicNotificationsFunction:: SuccessCallback, this), base::Bind(&BluetoothLowEnergyStopCharacteristicNotificationsFunction:: ErrorCallback, this)); - - return true; } void BluetoothLowEnergyStopCharacteristicNotificationsFunction:: SuccessCallback() { - SendResponse(true); + Respond(NoArguments()); } void BluetoothLowEnergyStopCharacteristicNotificationsFunction::ErrorCallback( BluetoothLowEnergyEventRouter::Status status) { - SetError(StatusToString(status)); - SendResponse(false); + Respond(Error(StatusToString(status))); } -bool BluetoothLowEnergyReadDescriptorValueFunction::DoWork() { - DCHECK_CURRENTLY_ON(BrowserThread::UI); +BluetoothLowEnergyReadDescriptorValueFunction:: + BluetoothLowEnergyReadDescriptorValueFunction() {} +BluetoothLowEnergyReadDescriptorValueFunction:: + ~BluetoothLowEnergyReadDescriptorValueFunction() {} + +bool BluetoothLowEnergyReadDescriptorValueFunction::ParseParams() { + params_ = apibtle::ReadDescriptorValue::Params::Create(*args_); + return params_.get() != nullptr; +} + +void BluetoothLowEnergyReadDescriptorValueFunction::DoWork() { BluetoothLowEnergyEventRouter* event_router = GetEventRouter(browser_context()); // The adapter must be initialized at this point, but return an error instead // of asserting. if (!event_router->HasAdapter()) { - SetError(kErrorAdapterNotInitialized); - SendResponse(false); - return false; + Respond(Error(kErrorAdapterNotInitialized)); + return; } - std::unique_ptr<apibtle::ReadDescriptorValue::Params> params( - apibtle::ReadDescriptorValue::Params::Create(*args_)); - EXTENSION_FUNCTION_VALIDATE(params.get() != NULL); - - instance_id_ = params->descriptor_id; + instance_id_ = params_->descriptor_id; event_router->ReadDescriptorValue( extension(), instance_id_, base::Bind( @@ -992,8 +955,6 @@ this), base::Bind(&BluetoothLowEnergyReadDescriptorValueFunction::ErrorCallback, this)); - - return true; } void BluetoothLowEnergyReadDescriptorValueFunction::SuccessCallback() { @@ -1004,63 +965,60 @@ GetEventRouter(browser_context()) ->GetDescriptor(extension(), instance_id_, &descriptor); if (status != BluetoothLowEnergyEventRouter::kStatusSuccess) { - SetError(StatusToString(status)); - SendResponse(false); + Respond(Error(StatusToString(status))); return; } // Manually construct the result instead of using // apibtle::GetDescriptor::Results::Create as it doesn't convert lists of // enums correctly. - SetResult(apibtle::DescriptorToValue(&descriptor)); - SendResponse(true); + Respond(OneArgument(apibtle::DescriptorToValue(&descriptor))); } void BluetoothLowEnergyReadDescriptorValueFunction::ErrorCallback( BluetoothLowEnergyEventRouter::Status status) { - SetError(StatusToString(status)); - SendResponse(false); + Respond(Error(StatusToString(status))); } -bool BluetoothLowEnergyWriteDescriptorValueFunction::DoWork() { - DCHECK_CURRENTLY_ON(BrowserThread::UI); +BluetoothLowEnergyWriteDescriptorValueFunction:: + BluetoothLowEnergyWriteDescriptorValueFunction() {} +BluetoothLowEnergyWriteDescriptorValueFunction:: + ~BluetoothLowEnergyWriteDescriptorValueFunction() {} + +bool BluetoothLowEnergyWriteDescriptorValueFunction::ParseParams() { + params_ = apibtle::WriteDescriptorValue::Params::Create(*args_); + return params_.get() != nullptr; +} + +void BluetoothLowEnergyWriteDescriptorValueFunction::DoWork() { BluetoothLowEnergyEventRouter* event_router = GetEventRouter(browser_context()); // The adapter must be initialized at this point, but return an error instead // of asserting. if (!event_router->HasAdapter()) { - SetError(kErrorAdapterNotInitialized); - SendResponse(false); - return false; + Respond(Error(kErrorAdapterNotInitialized)); + return; } - std::unique_ptr<apibtle::WriteDescriptorValue::Params> params( - apibtle::WriteDescriptorValue::Params::Create(*args_)); - EXTENSION_FUNCTION_VALIDATE(params.get() != NULL); - - std::vector<uint8_t> value(params->value.begin(), params->value.end()); + std::vector<uint8_t> value(params_->value.begin(), params_->value.end()); event_router->WriteDescriptorValue( - extension(), params->descriptor_id, value, + extension(), params_->descriptor_id, value, base::Bind( &BluetoothLowEnergyWriteDescriptorValueFunction::SuccessCallback, this), base::Bind(&BluetoothLowEnergyWriteDescriptorValueFunction::ErrorCallback, this)); - - return true; } void BluetoothLowEnergyWriteDescriptorValueFunction::SuccessCallback() { - results_ = apibtle::WriteDescriptorValue::Results::Create(); - SendResponse(true); + Respond(ArgumentList(apibtle::WriteDescriptorValue::Results::Create())); } void BluetoothLowEnergyWriteDescriptorValueFunction::ErrorCallback( BluetoothLowEnergyEventRouter::Status status) { - SetError(StatusToString(status)); - SendResponse(false); + Respond(Error(StatusToString(status))); } BluetoothLowEnergyAdvertisementFunction:: @@ -1094,25 +1052,11 @@ return advertisements_manager_->GetResourceIds(extension_id()); } -bool BluetoothLowEnergyAdvertisementFunction::RunAsync() { +ExtensionFunction::ResponseAction +BluetoothLowEnergyAdvertisementFunction::Run() { Initialize(); - // Check permission in the manifest. - if (!BluetoothManifestData::CheckPeripheralPermitted(extension())) { - SetError(kErrorPermissionDenied); - return false; - } - - // For advertisement API to be available the app has to be either auto - // launched in Kiosk Mode or the enable-ble-advertisement-in-apps - // should be set. - if (!(IsAutoLaunchedKioskApp(extension()->id()) || - IsPeripheralFlagEnabled())) { - SetError(kErrorPermissionDenied); - return false; - } - - return BluetoothLowEnergyExtensionFunctionDeprecated::RunAsync(); + return BLEPeripheralExtensionFunction::Run(); } void BluetoothLowEnergyAdvertisementFunction::Initialize() { @@ -1122,27 +1066,31 @@ // RegisterAdvertisement: -bool BluetoothLowEnergyRegisterAdvertisementFunction::DoWork() { - DCHECK_CURRENTLY_ON(BrowserThread::UI); +BluetoothLowEnergyRegisterAdvertisementFunction:: + BluetoothLowEnergyRegisterAdvertisementFunction() {} +BluetoothLowEnergyRegisterAdvertisementFunction:: + ~BluetoothLowEnergyRegisterAdvertisementFunction() {} + +bool BluetoothLowEnergyRegisterAdvertisementFunction::ParseParams() { + params_ = apibtle::RegisterAdvertisement::Params::Create(*args_); + return params_.get() != nullptr; +} + +void BluetoothLowEnergyRegisterAdvertisementFunction::DoWork() { BluetoothLowEnergyEventRouter* event_router = GetEventRouter(browser_context()); // The adapter must be initialized at this point, but return an error instead // of asserting. if (!event_router->HasAdapter()) { - SetError(kErrorAdapterNotInitialized); - SendResponse(false); - return false; + Respond(Error(kErrorAdapterNotInitialized)); + return; } - std::unique_ptr<apibtle::RegisterAdvertisement::Params> params( - apibtle::RegisterAdvertisement::Params::Create(*args_)); - EXTENSION_FUNCTION_VALIDATE(params.get() != NULL); - std::unique_ptr<device::BluetoothAdvertisement::Data> advertisement_data( new device::BluetoothAdvertisement::Data( - params->advertisement.type == + params_->advertisement.type == apibtle::AdvertisementType::ADVERTISEMENT_TYPE_BROADCAST ? device::BluetoothAdvertisement::AdvertisementType:: ADVERTISEMENT_TYPE_BROADCAST @@ -1150,16 +1098,16 @@ ADVERTISEMENT_TYPE_PERIPHERAL)); advertisement_data->set_service_uuids( - std::move(params->advertisement.service_uuids)); + std::move(params_->advertisement.service_uuids)); advertisement_data->set_solicit_uuids( - std::move(params->advertisement.solicit_uuids)); - if (params->advertisement.manufacturer_data) { + std::move(params_->advertisement.solicit_uuids)); + if (params_->advertisement.manufacturer_data) { advertisement_data->set_manufacturer_data( - CreateManufacturerData(params->advertisement.manufacturer_data.get())); + CreateManufacturerData(params_->advertisement.manufacturer_data.get())); } - if (params->advertisement.service_data) { + if (params_->advertisement.service_data) { advertisement_data->set_service_data( - CreateServiceData(params->advertisement.service_data.get())); + CreateServiceData(params_->advertisement.service_data.get())); } event_router->adapter()->RegisterAdvertisement( @@ -1170,15 +1118,13 @@ base::Bind( &BluetoothLowEnergyRegisterAdvertisementFunction::ErrorCallback, this)); - - return true; } void BluetoothLowEnergyRegisterAdvertisementFunction::SuccessCallback( scoped_refptr<device::BluetoothAdvertisement> advertisement) { - results_ = apibtle::RegisterAdvertisement::Results::Create(AddAdvertisement( - new BluetoothApiAdvertisement(extension_id(), advertisement))); - SendResponse(true); + Respond(ArgumentList( + apibtle::RegisterAdvertisement::Results::Create(AddAdvertisement( + new BluetoothApiAdvertisement(extension_id(), advertisement))))); } void BluetoothLowEnergyRegisterAdvertisementFunction::ErrorCallback( @@ -1186,57 +1132,60 @@ switch (status) { case device::BluetoothAdvertisement::ErrorCode:: ERROR_ADVERTISEMENT_ALREADY_EXISTS: - SetError(kStatusAdvertisementAlreadyExists); + Respond(Error(kStatusAdvertisementAlreadyExists)); break; case device::BluetoothAdvertisement::ErrorCode:: ERROR_ADVERTISEMENT_INVALID_LENGTH: - SetError(kErrorInvalidAdvertisementLength); + Respond(Error(kErrorInvalidAdvertisementLength)); break; default: - SetError(kErrorOperationFailed); + Respond(Error(kErrorOperationFailed)); } - SendResponse(false); } // UnregisterAdvertisement: -bool BluetoothLowEnergyUnregisterAdvertisementFunction::DoWork() { - DCHECK_CURRENTLY_ON(BrowserThread::UI); +BluetoothLowEnergyUnregisterAdvertisementFunction:: + BluetoothLowEnergyUnregisterAdvertisementFunction() {} +BluetoothLowEnergyUnregisterAdvertisementFunction:: + ~BluetoothLowEnergyUnregisterAdvertisementFunction() {} + +bool BluetoothLowEnergyUnregisterAdvertisementFunction::ParseParams() { + params_ = apibtle::UnregisterAdvertisement::Params::Create(*args_); + return params_.get() != nullptr; +} + +void BluetoothLowEnergyUnregisterAdvertisementFunction::DoWork() { BluetoothLowEnergyEventRouter* event_router = GetEventRouter(browser_context()); // If we don't have an initialized adapter, unregistering is a no-op. - if (!event_router->HasAdapter()) - return true; - - std::unique_ptr<apibtle::UnregisterAdvertisement::Params> params( - apibtle::UnregisterAdvertisement::Params::Create(*args_)); - EXTENSION_FUNCTION_VALIDATE(params.get() != NULL); + if (!event_router->HasAdapter()) { + Respond(NoArguments()); + return; + } BluetoothApiAdvertisement* advertisement = - GetAdvertisement(params->advertisement_id); + GetAdvertisement(params_->advertisement_id); if (!advertisement) { - error_ = kStatusAdvertisementDoesNotExist; - SendResponse(false); - return false; + Respond(Error(kStatusAdvertisementDoesNotExist)); + return; } advertisement->advertisement()->Unregister( base::Bind( &BluetoothLowEnergyUnregisterAdvertisementFunction::SuccessCallback, - this, params->advertisement_id), + this, params_->advertisement_id), base::Bind( &BluetoothLowEnergyUnregisterAdvertisementFunction::ErrorCallback, - this, params->advertisement_id)); - - return true; + this, params_->advertisement_id)); } void BluetoothLowEnergyUnregisterAdvertisementFunction::SuccessCallback( int advertisement_id) { RemoveAdvertisement(advertisement_id); - SendResponse(true); + Respond(NoArguments()); } void BluetoothLowEnergyUnregisterAdvertisementFunction::ErrorCallback( @@ -1246,33 +1195,40 @@ switch (status) { case device::BluetoothAdvertisement::ErrorCode:: ERROR_ADVERTISEMENT_DOES_NOT_EXIST: - SetError(kStatusAdvertisementDoesNotExist); + Respond(Error(kStatusAdvertisementDoesNotExist)); break; default: - SetError(kErrorOperationFailed); + Respond(Error(kErrorOperationFailed)); } - SendResponse(false); } // ResetAdvertising: -bool BluetoothLowEnergyResetAdvertisingFunction::DoWork() { -#if defined(OS_CHROMEOS) || defined(OS_LINUX) - DCHECK_CURRENTLY_ON(BrowserThread::UI); +BluetoothLowEnergyResetAdvertisingFunction:: + BluetoothLowEnergyResetAdvertisingFunction() {} +BluetoothLowEnergyResetAdvertisingFunction:: + ~BluetoothLowEnergyResetAdvertisingFunction() {} + +bool BluetoothLowEnergyResetAdvertisingFunction::ParseParams() { + return true; +} + +void BluetoothLowEnergyResetAdvertisingFunction::DoWork() { +#if defined(OS_CHROMEOS) || defined(OS_LINUX) BluetoothLowEnergyEventRouter* event_router = GetEventRouter(browser_context()); // If the adapter is not initialized, there is nothing to reset. if (!event_router->HasAdapter()) { - SendResponse(true); - return true; + Respond(NoArguments()); + return; } const base::hash_set<int>* advertisement_ids = GetAdvertisementIds(); if (!advertisement_ids || advertisement_ids->empty()) { - SendResponse(true); - return true; + Respond(NoArguments()); + return; } // Copy the hash set, as RemoveAdvertisement can change advertisement_ids @@ -1288,24 +1244,29 @@ base::Bind(&BluetoothLowEnergyResetAdvertisingFunction::ErrorCallback, this)); #endif - - return true; } void BluetoothLowEnergyResetAdvertisingFunction::SuccessCallback() { - SendResponse(true); + Respond(NoArguments()); } void BluetoothLowEnergyResetAdvertisingFunction::ErrorCallback( device::BluetoothAdvertisement::ErrorCode status) { - error_ = kErrorOperationFailed; - SendResponse(false); + Respond(Error(kErrorOperationFailed)); } // SetAdvertisingInterval: -template class BLEPeripheralExtensionFunction< - apibtle::SetAdvertisingInterval::Params>; +BluetoothLowEnergySetAdvertisingIntervalFunction:: + BluetoothLowEnergySetAdvertisingIntervalFunction() {} + +BluetoothLowEnergySetAdvertisingIntervalFunction:: + ~BluetoothLowEnergySetAdvertisingIntervalFunction() {} + +bool BluetoothLowEnergySetAdvertisingIntervalFunction::ParseParams() { + params_ = apibtle::SetAdvertisingInterval::Params::Create(*args_); + return params_.get() != nullptr; +} void BluetoothLowEnergySetAdvertisingIntervalFunction::DoWork() { #if defined(OS_CHROMEOS) || defined(OS_LINUX) @@ -1343,10 +1304,23 @@ // createService: -template class BLEPeripheralExtensionFunction<apibtle::CreateService::Params>; +BluetoothLowEnergyCreateServiceFunction:: + BluetoothLowEnergyCreateServiceFunction() {} + +BluetoothLowEnergyCreateServiceFunction:: + ~BluetoothLowEnergyCreateServiceFunction() {} + +bool BluetoothLowEnergyCreateServiceFunction::ParseParams() { +// Causes link error on Windows. API will never be on Windows, so #ifdefing. +#if !defined(OS_WIN) + params_ = apibtle::CreateService::Params::Create(*args_); + return params_.get() != nullptr; +#else + return true; +#endif +} void BluetoothLowEnergyCreateServiceFunction::DoWork() { - DCHECK_CURRENTLY_ON(BrowserThread::UI); // Causes link error on Windows. API will never be on Windows, so #ifdefing. // TODO: Ideally this should be handled by our feature system, so that this // code doesn't even compile on OSes it isn't being used on, but currently this @@ -1368,8 +1342,16 @@ // createCharacteristic: -template class BLEPeripheralExtensionFunction< - apibtle::CreateCharacteristic::Params>; +BluetoothLowEnergyCreateCharacteristicFunction:: + BluetoothLowEnergyCreateCharacteristicFunction() {} + +BluetoothLowEnergyCreateCharacteristicFunction:: + ~BluetoothLowEnergyCreateCharacteristicFunction() {} + +bool BluetoothLowEnergyCreateCharacteristicFunction::ParseParams() { + params_ = apibtle::CreateCharacteristic::Params::Create(*args_); + return params_.get() != nullptr; +} void BluetoothLowEnergyCreateCharacteristicFunction::DoWork() { device::BluetoothLocalGattService* service = @@ -1396,8 +1378,16 @@ // createDescriptor: -template class BLEPeripheralExtensionFunction< - apibtle::CreateDescriptor::Params>; +BluetoothLowEnergyCreateDescriptorFunction:: + BluetoothLowEnergyCreateDescriptorFunction() {} + +BluetoothLowEnergyCreateDescriptorFunction:: + ~BluetoothLowEnergyCreateDescriptorFunction() {} + +bool BluetoothLowEnergyCreateDescriptorFunction::ParseParams() { + params_ = apibtle::CreateDescriptor::Params::Create(*args_); + return params_.get() != nullptr; +} void BluetoothLowEnergyCreateDescriptorFunction::DoWork() { device::BluetoothLocalGattCharacteristic* characteristic = @@ -1419,7 +1409,16 @@ // registerService: -template class BLEPeripheralExtensionFunction<apibtle::RegisterService::Params>; +BluetoothLowEnergyRegisterServiceFunction:: + BluetoothLowEnergyRegisterServiceFunction() {} + +BluetoothLowEnergyRegisterServiceFunction:: + ~BluetoothLowEnergyRegisterServiceFunction() {} + +bool BluetoothLowEnergyRegisterServiceFunction::ParseParams() { + params_ = apibtle::RegisterService::Params::Create(*args_); + return params_.get() != nullptr; +} void BluetoothLowEnergyRegisterServiceFunction::DoWork() { event_router_->RegisterGattService( @@ -1441,8 +1440,16 @@ // unregisterService: -template class BLEPeripheralExtensionFunction< - apibtle::UnregisterService::Params>; +BluetoothLowEnergyUnregisterServiceFunction:: + BluetoothLowEnergyUnregisterServiceFunction() {} + +BluetoothLowEnergyUnregisterServiceFunction:: + ~BluetoothLowEnergyUnregisterServiceFunction() {} + +bool BluetoothLowEnergyUnregisterServiceFunction::ParseParams() { + params_ = apibtle::UnregisterService::Params::Create(*args_); + return params_.get() != nullptr; +} void BluetoothLowEnergyUnregisterServiceFunction::DoWork() { event_router_->UnregisterGattService( @@ -1464,8 +1471,16 @@ // notifyCharacteristicValueChanged: -template class BLEPeripheralExtensionFunction< - apibtle::NotifyCharacteristicValueChanged::Params>; +BluetoothLowEnergyNotifyCharacteristicValueChangedFunction:: + BluetoothLowEnergyNotifyCharacteristicValueChangedFunction() {} + +BluetoothLowEnergyNotifyCharacteristicValueChangedFunction:: + ~BluetoothLowEnergyNotifyCharacteristicValueChangedFunction() {} + +bool BluetoothLowEnergyNotifyCharacteristicValueChangedFunction::ParseParams() { + params_ = apibtle::NotifyCharacteristicValueChanged::Params::Create(*args_); + return params_.get() != nullptr; +} void BluetoothLowEnergyNotifyCharacteristicValueChangedFunction::DoWork() { device::BluetoothLocalGattCharacteristic* characteristic = @@ -1505,7 +1520,16 @@ // removeService: -template class BLEPeripheralExtensionFunction<apibtle::RemoveService::Params>; +BluetoothLowEnergyRemoveServiceFunction:: + BluetoothLowEnergyRemoveServiceFunction() {} + +BluetoothLowEnergyRemoveServiceFunction:: + ~BluetoothLowEnergyRemoveServiceFunction() {} + +bool BluetoothLowEnergyRemoveServiceFunction::ParseParams() { + params_ = apibtle::RemoveService::Params::Create(*args_); + return params_.get() != nullptr; +} void BluetoothLowEnergyRemoveServiceFunction::DoWork() { device::BluetoothLocalGattService* service = @@ -1521,8 +1545,16 @@ // sendRequestResponse: -template class BLEPeripheralExtensionFunction< - apibtle::SendRequestResponse::Params>; +BluetoothLowEnergySendRequestResponseFunction:: + BluetoothLowEnergySendRequestResponseFunction() {} + +BluetoothLowEnergySendRequestResponseFunction:: + ~BluetoothLowEnergySendRequestResponseFunction() {} + +bool BluetoothLowEnergySendRequestResponseFunction::ParseParams() { + params_ = apibtle::SendRequestResponse::Params::Create(*args_); + return params_.get() != nullptr; +} void BluetoothLowEnergySendRequestResponseFunction::DoWork() { std::vector<uint8_t> uint8_vector;
diff --git a/extensions/browser/api/bluetooth_low_energy/bluetooth_low_energy_api.h b/extensions/browser/api/bluetooth_low_energy/bluetooth_low_energy_api.h index 26c3303d..69d72ca 100644 --- a/extensions/browser/api/bluetooth_low_energy/bluetooth_low_energy_api.h +++ b/extensions/browser/api/bluetooth_low_energy/bluetooth_low_energy_api.h
@@ -89,34 +89,6 @@ // Base class for bluetoothLowEnergy API functions. This class handles some of // the common logic involved in all API functions, such as checking for // platform support and returning the correct error. -// -// DEPRECATED: This inherits from AsyncExtensionFunction, which we're trying to -// get rid of for various reasons. Please inherit from the -// BluetoothLowEnergyExtensionFunction class instead. -class BluetoothLowEnergyExtensionFunctionDeprecated - : public AsyncExtensionFunction { - public: - BluetoothLowEnergyExtensionFunctionDeprecated(); - - protected: - ~BluetoothLowEnergyExtensionFunctionDeprecated() override; - - // AsyncExtensionFunction override. - bool RunAsync() override; - - // Implemented by individual bluetoothLowEnergy extension functions to perform - // the body of the function. This invoked asynchonously after RunAsync after - // the BluetoothLowEnergyEventRouter has obtained a handle on the - // BluetoothAdapter. - virtual bool DoWork() = 0; - - private: - DISALLOW_COPY_AND_ASSIGN(BluetoothLowEnergyExtensionFunctionDeprecated); -}; - -// Replacement for BluetoothLowEnergyExtensionFunctionDeprecated. Has the same -// functionality except that instead of the SendResponse/return combo, we'll -// return our response with Respond(). class BluetoothLowEnergyExtensionFunction : public UIThreadExtensionFunction { public: BluetoothLowEnergyExtensionFunction(); @@ -133,6 +105,12 @@ // BluetoothAdapter. virtual void DoWork() = 0; + // Subclasses to implement this method to set and validate its type-specific + // params. This method should return true if the params is valid and + // false otherwise. This method is called before DoWork() to allow early exit + // in the case of invalid params. + virtual bool ParseParams() = 0; + BluetoothLowEnergyEventRouter* event_router_; private: @@ -146,7 +124,6 @@ // handles some of the common logic involved in all API peripheral mode // functions, such as checking for peripheral permissions and returning the // correct error. -template <typename Params> class BLEPeripheralExtensionFunction : public BluetoothLowEnergyExtensionFunction { public: @@ -158,28 +135,26 @@ // ExtensionFunction override. ResponseAction Run() override; -// Causes link error on Windows. API will never be on Windows, so #ifdefing. -#if !defined(OS_WIN) - std::unique_ptr<Params> params_; -#else - Params* params_; -#endif - private: DISALLOW_COPY_AND_ASSIGN(BLEPeripheralExtensionFunction); }; class BluetoothLowEnergyConnectFunction - : public BluetoothLowEnergyExtensionFunctionDeprecated { + : public BluetoothLowEnergyExtensionFunction { public: DECLARE_EXTENSION_FUNCTION("bluetoothLowEnergy.connect", BLUETOOTHLOWENERGY_CONNECT); - protected: - ~BluetoothLowEnergyConnectFunction() override {} + BluetoothLowEnergyConnectFunction(); - // BluetoothLowEnergyExtensionFunctionDeprecated override. - bool DoWork() override; + protected: + ~BluetoothLowEnergyConnectFunction() override; + + // BluetoothLowEnergyExtensionFunction override. + void DoWork() override; + bool ParseParams() override; + + std::unique_ptr<bluetooth_low_energy::Connect::Params> params_; private: // Success and error callbacks, called by @@ -189,16 +164,21 @@ }; class BluetoothLowEnergyDisconnectFunction - : public BluetoothLowEnergyExtensionFunctionDeprecated { + : public BluetoothLowEnergyExtensionFunction { public: DECLARE_EXTENSION_FUNCTION("bluetoothLowEnergy.disconnect", BLUETOOTHLOWENERGY_DISCONNECT); - protected: - ~BluetoothLowEnergyDisconnectFunction() override {} + BluetoothLowEnergyDisconnectFunction(); - // BluetoothLowEnergyExtensionFunctionDeprecated override. - bool DoWork() override; + protected: + ~BluetoothLowEnergyDisconnectFunction() override; + + // BluetoothLowEnergyExtensionFunction override. + void DoWork() override; + bool ParseParams() override; + + std::unique_ptr<bluetooth_low_energy::Disconnect::Params> params_; private: // Success and error callbacks, called by @@ -208,107 +188,148 @@ }; class BluetoothLowEnergyGetServiceFunction - : public BluetoothLowEnergyExtensionFunctionDeprecated { + : public BluetoothLowEnergyExtensionFunction { public: DECLARE_EXTENSION_FUNCTION("bluetoothLowEnergy.getService", BLUETOOTHLOWENERGY_GETSERVICE); - protected: - ~BluetoothLowEnergyGetServiceFunction() override {} + BluetoothLowEnergyGetServiceFunction(); - // BluetoothLowEnergyExtensionFunctionDeprecated override. - bool DoWork() override; + protected: + ~BluetoothLowEnergyGetServiceFunction() override; + + // BluetoothLowEnergyExtensionFunction override. + void DoWork() override; + bool ParseParams() override; + + std::unique_ptr<bluetooth_low_energy::GetService::Params> params_; }; class BluetoothLowEnergyGetServicesFunction - : public BluetoothLowEnergyExtensionFunctionDeprecated { + : public BluetoothLowEnergyExtensionFunction { public: DECLARE_EXTENSION_FUNCTION("bluetoothLowEnergy.getServices", BLUETOOTHLOWENERGY_GETSERVICES); - protected: - ~BluetoothLowEnergyGetServicesFunction() override {} + BluetoothLowEnergyGetServicesFunction(); - // BluetoothLowEnergyExtensionFunctionDeprecated override. - bool DoWork() override; + protected: + ~BluetoothLowEnergyGetServicesFunction() override; + + // BluetoothLowEnergyExtensionFunction override. + void DoWork() override; + bool ParseParams() override; + + std::unique_ptr<bluetooth_low_energy::GetServices::Params> params_; }; class BluetoothLowEnergyGetCharacteristicFunction - : public BluetoothLowEnergyExtensionFunctionDeprecated { + : public BluetoothLowEnergyExtensionFunction { public: DECLARE_EXTENSION_FUNCTION("bluetoothLowEnergy.getCharacteristic", BLUETOOTHLOWENERGY_GETCHARACTERISTIC); - protected: - ~BluetoothLowEnergyGetCharacteristicFunction() override {} + BluetoothLowEnergyGetCharacteristicFunction(); - // BluetoothLowEnergyExtensionFunctionDeprecated override. - bool DoWork() override; + protected: + ~BluetoothLowEnergyGetCharacteristicFunction() override; + + // BluetoothLowEnergyExtensionFunction override. + void DoWork() override; + bool ParseParams() override; + + std::unique_ptr<bluetooth_low_energy::GetCharacteristic::Params> params_; }; class BluetoothLowEnergyGetCharacteristicsFunction - : public BluetoothLowEnergyExtensionFunctionDeprecated { + : public BluetoothLowEnergyExtensionFunction { public: DECLARE_EXTENSION_FUNCTION("bluetoothLowEnergy.getCharacteristics", BLUETOOTHLOWENERGY_GETCHARACTERISTICS); - protected: - ~BluetoothLowEnergyGetCharacteristicsFunction() override {} + BluetoothLowEnergyGetCharacteristicsFunction(); - // BluetoothLowEnergyExtensionFunctionDeprecated override. - bool DoWork() override; + protected: + ~BluetoothLowEnergyGetCharacteristicsFunction() override; + + // BluetoothLowEnergyExtensionFunction override. + void DoWork() override; + bool ParseParams() override; + + std::unique_ptr<bluetooth_low_energy::GetCharacteristics::Params> params_; }; class BluetoothLowEnergyGetIncludedServicesFunction - : public BluetoothLowEnergyExtensionFunctionDeprecated { + : public BluetoothLowEnergyExtensionFunction { public: DECLARE_EXTENSION_FUNCTION("bluetoothLowEnergy.getIncludedServices", BLUETOOTHLOWENERGY_GETINCLUDEDSERVICES); - protected: - ~BluetoothLowEnergyGetIncludedServicesFunction() override {} + BluetoothLowEnergyGetIncludedServicesFunction(); - // BluetoothLowEnergyExtensionFunctionDeprecated override. - bool DoWork() override; + protected: + ~BluetoothLowEnergyGetIncludedServicesFunction() override; + + // BluetoothLowEnergyExtensionFunction override. + void DoWork() override; + bool ParseParams() override; + + std::unique_ptr<bluetooth_low_energy::GetIncludedServices::Params> params_; }; class BluetoothLowEnergyGetDescriptorFunction - : public BluetoothLowEnergyExtensionFunctionDeprecated { + : public BluetoothLowEnergyExtensionFunction { public: DECLARE_EXTENSION_FUNCTION("bluetoothLowEnergy.getDescriptor", BLUETOOTHLOWENERGY_GETDESCRIPTOR); - protected: - ~BluetoothLowEnergyGetDescriptorFunction() override {} + BluetoothLowEnergyGetDescriptorFunction(); - // BluetoothLowEnergyExtensionFunctionDeprecated override. - bool DoWork() override; + protected: + ~BluetoothLowEnergyGetDescriptorFunction() override; + + // BluetoothLowEnergyExtensionFunction override. + void DoWork() override; + bool ParseParams() override; + + std::unique_ptr<bluetooth_low_energy::GetDescriptor::Params> params_; }; class BluetoothLowEnergyGetDescriptorsFunction - : public BluetoothLowEnergyExtensionFunctionDeprecated { + : public BluetoothLowEnergyExtensionFunction { public: DECLARE_EXTENSION_FUNCTION("bluetoothLowEnergy.getDescriptors", BLUETOOTHLOWENERGY_GETDESCRIPTORS); - protected: - ~BluetoothLowEnergyGetDescriptorsFunction() override {} + BluetoothLowEnergyGetDescriptorsFunction(); - // BluetoothLowEnergyExtensionFunctionDeprecated override. - bool DoWork() override; + protected: + ~BluetoothLowEnergyGetDescriptorsFunction() override; + + // BluetoothLowEnergyExtensionFunction override. + void DoWork() override; + bool ParseParams() override; + + std::unique_ptr<bluetooth_low_energy::GetDescriptors::Params> params_; }; class BluetoothLowEnergyReadCharacteristicValueFunction - : public BluetoothLowEnergyExtensionFunctionDeprecated { + : public BluetoothLowEnergyExtensionFunction { public: DECLARE_EXTENSION_FUNCTION("bluetoothLowEnergy.readCharacteristicValue", BLUETOOTHLOWENERGY_READCHARACTERISTICVALUE); - protected: - ~BluetoothLowEnergyReadCharacteristicValueFunction() override {} + BluetoothLowEnergyReadCharacteristicValueFunction(); - // BluetoothLowEnergyExtensionFunctionDeprecated override. - bool DoWork() override; + protected: + ~BluetoothLowEnergyReadCharacteristicValueFunction() override; + + // BluetoothLowEnergyExtensionFunction override. + void DoWork() override; + bool ParseParams() override; + + std::unique_ptr<bluetooth_low_energy::ReadCharacteristicValue::Params> + params_; private: // Success and error callbacks, called by @@ -321,16 +342,22 @@ }; class BluetoothLowEnergyWriteCharacteristicValueFunction - : public BluetoothLowEnergyExtensionFunctionDeprecated { + : public BluetoothLowEnergyExtensionFunction { public: DECLARE_EXTENSION_FUNCTION("bluetoothLowEnergy.writeCharacteristicValue", BLUETOOTHLOWENERGY_WRITECHARACTERISTICVALUE); - protected: - ~BluetoothLowEnergyWriteCharacteristicValueFunction() override {} + BluetoothLowEnergyWriteCharacteristicValueFunction(); - // BluetoothLowEnergyExtensionFunctionDeprecated override. - bool DoWork() override; + protected: + ~BluetoothLowEnergyWriteCharacteristicValueFunction() override; + + // BluetoothLowEnergyExtensionFunction override. + void DoWork() override; + bool ParseParams() override; + + std::unique_ptr<bluetooth_low_energy::WriteCharacteristicValue::Params> + params_; private: // Success and error callbacks, called by @@ -343,17 +370,24 @@ }; class BluetoothLowEnergyStartCharacteristicNotificationsFunction - : public BluetoothLowEnergyExtensionFunctionDeprecated { + : public BluetoothLowEnergyExtensionFunction { public: DECLARE_EXTENSION_FUNCTION( "bluetoothLowEnergy.startCharacteristicNotifications", BLUETOOTHLOWENERGY_STARTCHARACTERISTICNOTIFICATIONS); - protected: - ~BluetoothLowEnergyStartCharacteristicNotificationsFunction() override {} + BluetoothLowEnergyStartCharacteristicNotificationsFunction(); - // BluetoothLowEnergyExtensionFunctionDeprecated override. - bool DoWork() override; + protected: + ~BluetoothLowEnergyStartCharacteristicNotificationsFunction() override; + + // BluetoothLowEnergyExtensionFunction override. + void DoWork() override; + bool ParseParams() override; + + std::unique_ptr< + bluetooth_low_energy::StartCharacteristicNotifications::Params> + params_; private: // Success and error callbacks, called by @@ -363,17 +397,23 @@ }; class BluetoothLowEnergyStopCharacteristicNotificationsFunction - : public BluetoothLowEnergyExtensionFunctionDeprecated { + : public BluetoothLowEnergyExtensionFunction { public: DECLARE_EXTENSION_FUNCTION( "bluetoothLowEnergy.stopCharacteristicNotifications", BLUETOOTHLOWENERGY_STOPCHARACTERISTICNOTIFICATIONS); - protected: - ~BluetoothLowEnergyStopCharacteristicNotificationsFunction() override {} + BluetoothLowEnergyStopCharacteristicNotificationsFunction(); - // BluetoothLowEnergyExtensionFunctionDeprecated override. - bool DoWork() override; + protected: + ~BluetoothLowEnergyStopCharacteristicNotificationsFunction() override; + + // BluetoothLowEnergyExtensionFunction override. + void DoWork() override; + bool ParseParams() override; + + std::unique_ptr<bluetooth_low_energy::StopCharacteristicNotifications::Params> + params_; private: // Success and error callbacks, called by @@ -383,16 +423,21 @@ }; class BluetoothLowEnergyReadDescriptorValueFunction - : public BluetoothLowEnergyExtensionFunctionDeprecated { + : public BluetoothLowEnergyExtensionFunction { public: DECLARE_EXTENSION_FUNCTION("bluetoothLowEnergy.readDescriptorValue", BLUETOOTHLOWENERGY_READDESCRIPTORVALUE); - protected: - ~BluetoothLowEnergyReadDescriptorValueFunction() override {} + BluetoothLowEnergyReadDescriptorValueFunction(); - // BluetoothLowEnergyExtensionFunctionDeprecated override. - bool DoWork() override; + protected: + ~BluetoothLowEnergyReadDescriptorValueFunction() override; + + // BluetoothLowEnergyExtensionFunction override. + void DoWork() override; + bool ParseParams() override; + + std::unique_ptr<bluetooth_low_energy::ReadDescriptorValue::Params> params_; private: // Success and error callbacks, called by @@ -405,16 +450,21 @@ }; class BluetoothLowEnergyWriteDescriptorValueFunction - : public BluetoothLowEnergyExtensionFunctionDeprecated { + : public BluetoothLowEnergyExtensionFunction { public: DECLARE_EXTENSION_FUNCTION("bluetoothLowEnergy.writeDescriptorValue", BLUETOOTHLOWENERGY_WRITEDESCRIPTORVALUE); - protected: - ~BluetoothLowEnergyWriteDescriptorValueFunction() override {} + BluetoothLowEnergyWriteDescriptorValueFunction(); - // BluetoothLowEnergyExtensionFunctionDeprecated override. - bool DoWork() override; + protected: + ~BluetoothLowEnergyWriteDescriptorValueFunction() override; + + // BluetoothLowEnergyExtensionFunction override. + void DoWork() override; + bool ParseParams() override; + + std::unique_ptr<bluetooth_low_energy::WriteDescriptorValue::Params> params_; private: // Success and error callbacks, called by @@ -427,7 +477,7 @@ }; class BluetoothLowEnergyAdvertisementFunction - : public BluetoothLowEnergyExtensionFunctionDeprecated { + : public BLEPeripheralExtensionFunction { public: BluetoothLowEnergyAdvertisementFunction(); @@ -441,7 +491,7 @@ const base::hash_set<int>* GetAdvertisementIds(); // ExtensionFunction override. - bool RunAsync() override; + ResponseAction Run() override; private: void Initialize(); @@ -457,11 +507,16 @@ DECLARE_EXTENSION_FUNCTION("bluetoothLowEnergy.registerAdvertisement", BLUETOOTHLOWENERGY_REGISTERADVERTISEMENT); - protected: - ~BluetoothLowEnergyRegisterAdvertisementFunction() override {} + BluetoothLowEnergyRegisterAdvertisementFunction(); - // BluetoothLowEnergyExtensionFunctionDeprecated override. - bool DoWork() override; + protected: + ~BluetoothLowEnergyRegisterAdvertisementFunction() override; + + // BluetoothLowEnergyExtensionFunction override. + void DoWork() override; + bool ParseParams() override; + + std::unique_ptr<bluetooth_low_energy::RegisterAdvertisement::Params> params_; private: void SuccessCallback(scoped_refptr<device::BluetoothAdvertisement>); @@ -474,11 +529,17 @@ DECLARE_EXTENSION_FUNCTION("bluetoothLowEnergy.unregisterAdvertisement", BLUETOOTHLOWENERGY_UNREGISTERADVERTISEMENT); - protected: - ~BluetoothLowEnergyUnregisterAdvertisementFunction() override {} + BluetoothLowEnergyUnregisterAdvertisementFunction(); - // BluetoothLowEnergyExtensionFunctionDeprecated override. - bool DoWork() override; + protected: + ~BluetoothLowEnergyUnregisterAdvertisementFunction() override; + + // BluetoothLowEnergyExtensionFunction override. + void DoWork() override; + bool ParseParams() override; + + std::unique_ptr<bluetooth_low_energy::UnregisterAdvertisement::Params> + params_; private: void SuccessCallback(int advertisement_id); @@ -492,11 +553,14 @@ DECLARE_EXTENSION_FUNCTION("bluetoothLowEnergy.resetAdvertising", BLUETOOTHLOWENERGY_RESETADVERTISING); - protected: - ~BluetoothLowEnergyResetAdvertisingFunction() override {} + BluetoothLowEnergyResetAdvertisingFunction(); - // BluetoothLowEnergyExtensionFunctionDeprecated override. - bool DoWork() override; + protected: + ~BluetoothLowEnergyResetAdvertisingFunction() override; + + // BluetoothLowEnergyExtensionFunction override. + void DoWork() override; + bool ParseParams() override; private: void SuccessCallback(); @@ -504,18 +568,21 @@ }; class BluetoothLowEnergySetAdvertisingIntervalFunction - : public BLEPeripheralExtensionFunction< - extensions::api::bluetooth_low_energy::SetAdvertisingInterval:: - Params> { + : public BLEPeripheralExtensionFunction { public: DECLARE_EXTENSION_FUNCTION("bluetoothLowEnergy.setAdvertisingInterval", BLUETOOTHLOWENERGY_SETADVERTISINGINTERVAL); - protected: - ~BluetoothLowEnergySetAdvertisingIntervalFunction() override {} + BluetoothLowEnergySetAdvertisingIntervalFunction(); - // BluetoothLowEnergyExtensionFunctionDeprecated override. + protected: + ~BluetoothLowEnergySetAdvertisingIntervalFunction() override; + + // BluetoothLowEnergyExtensionFunction override. void DoWork() override; + bool ParseParams() override; + + std::unique_ptr<bluetooth_low_energy::SetAdvertisingInterval::Params> params_; private: void SuccessCallback(); @@ -523,75 +590,99 @@ }; class BluetoothLowEnergyCreateServiceFunction - : public BLEPeripheralExtensionFunction< - extensions::api::bluetooth_low_energy::CreateService::Params> { + : public BLEPeripheralExtensionFunction { public: DECLARE_EXTENSION_FUNCTION("bluetoothLowEnergy.createService", BLUETOOTHLOWENERGY_CREATESERVICE); + BluetoothLowEnergyCreateServiceFunction(); + protected: - ~BluetoothLowEnergyCreateServiceFunction() override {} + ~BluetoothLowEnergyCreateServiceFunction() override; // BluetoothLowEnergyPeripheralExtensionFunction override. void DoWork() override; + bool ParseParams() override; + + // Causes link error on Windows. API will never be on Windows, so #ifdefing. +#if !defined(OS_WIN) + std::unique_ptr<bluetooth_low_energy::CreateService::Params> params_; +#endif }; class BluetoothLowEnergyCreateCharacteristicFunction - : public BLEPeripheralExtensionFunction< - extensions::api::bluetooth_low_energy::CreateCharacteristic::Params> { + : public BLEPeripheralExtensionFunction { public: DECLARE_EXTENSION_FUNCTION("bluetoothLowEnergy.createCharacteristic", BLUETOOTHLOWENERGY_CREATECHARACTERISTIC); + BluetoothLowEnergyCreateCharacteristicFunction(); + protected: - ~BluetoothLowEnergyCreateCharacteristicFunction() override {} + ~BluetoothLowEnergyCreateCharacteristicFunction() override; // BluetoothLowEnergyPeripheralExtensionFunction override. void DoWork() override; + bool ParseParams() override; + + std::unique_ptr<bluetooth_low_energy::CreateCharacteristic::Params> params_; }; class BluetoothLowEnergyNotifyCharacteristicValueChangedFunction - : public BLEPeripheralExtensionFunction< - extensions::api::bluetooth_low_energy:: - NotifyCharacteristicValueChanged::Params> { + : public BLEPeripheralExtensionFunction { public: DECLARE_EXTENSION_FUNCTION( "bluetoothLowEnergy.notifyCharacteristicValueChanged", BLUETOOTHLOWENERGY_NOTIFYCHARACTERISTICVALUECHANGED); + BluetoothLowEnergyNotifyCharacteristicValueChangedFunction(); + protected: - ~BluetoothLowEnergyNotifyCharacteristicValueChangedFunction() override {} + ~BluetoothLowEnergyNotifyCharacteristicValueChangedFunction() override; // BluetoothLowEnergyPeripheralExtensionFunction override. void DoWork() override; + bool ParseParams() override; + + std::unique_ptr< + bluetooth_low_energy::NotifyCharacteristicValueChanged::Params> + params_; }; class BluetoothLowEnergyCreateDescriptorFunction - : public BLEPeripheralExtensionFunction< - extensions::api::bluetooth_low_energy::CreateDescriptor::Params> { + : public BLEPeripheralExtensionFunction { public: DECLARE_EXTENSION_FUNCTION("bluetoothLowEnergy.createDescriptor", BLUETOOTHLOWENERGY_CREATEDESCRIPTOR); + BluetoothLowEnergyCreateDescriptorFunction(); + protected: - ~BluetoothLowEnergyCreateDescriptorFunction() override {} + ~BluetoothLowEnergyCreateDescriptorFunction() override; // BluetoothLowEnergyPeripheralExtensionFunction override. void DoWork() override; + bool ParseParams() override; + + std::unique_ptr<bluetooth_low_energy::CreateDescriptor::Params> params_; }; class BluetoothLowEnergyRegisterServiceFunction - : public BLEPeripheralExtensionFunction< - extensions::api::bluetooth_low_energy::RegisterService::Params> { + : public BLEPeripheralExtensionFunction { public: DECLARE_EXTENSION_FUNCTION("bluetoothLowEnergy.registerService", BLUETOOTHLOWENERGY_REGISTERSERVICE); + BluetoothLowEnergyRegisterServiceFunction(); + protected: - ~BluetoothLowEnergyRegisterServiceFunction() override {} + ~BluetoothLowEnergyRegisterServiceFunction() override; // BluetoothLowEnergyPeripheralExtensionFunction override. void DoWork() override; + bool ParseParams() override; + + std::unique_ptr<bluetooth_low_energy::RegisterService::Params> params_; private: void SuccessCallback(); @@ -599,17 +690,21 @@ }; class BluetoothLowEnergyUnregisterServiceFunction - : public BLEPeripheralExtensionFunction< - extensions::api::bluetooth_low_energy::UnregisterService::Params> { + : public BLEPeripheralExtensionFunction { public: DECLARE_EXTENSION_FUNCTION("bluetoothLowEnergy.unregisterService", BLUETOOTHLOWENERGY_UNREGISTERSERVICE); + BluetoothLowEnergyUnregisterServiceFunction(); + protected: - ~BluetoothLowEnergyUnregisterServiceFunction() override {} + ~BluetoothLowEnergyUnregisterServiceFunction() override; // BluetoothLowEnergyPeripheralExtensionFunction override. void DoWork() override; + bool ParseParams() override; + + std::unique_ptr<bluetooth_low_energy::UnregisterService::Params> params_; private: // Success and error callbacks, called by @@ -619,31 +714,39 @@ }; class BluetoothLowEnergyRemoveServiceFunction - : public BLEPeripheralExtensionFunction< - extensions::api::bluetooth_low_energy::RemoveService::Params> { + : public BLEPeripheralExtensionFunction { public: DECLARE_EXTENSION_FUNCTION("bluetoothLowEnergy.removeService", BLUETOOTHLOWENERGY_REMOVESERVICE); + BluetoothLowEnergyRemoveServiceFunction(); + protected: - ~BluetoothLowEnergyRemoveServiceFunction() override {} + ~BluetoothLowEnergyRemoveServiceFunction() override; // BluetoothLowEnergyPeripheralExtensionFunction override. void DoWork() override; + bool ParseParams() override; + + std::unique_ptr<bluetooth_low_energy::RemoveService::Params> params_; }; class BluetoothLowEnergySendRequestResponseFunction - : public BLEPeripheralExtensionFunction< - extensions::api::bluetooth_low_energy::SendRequestResponse::Params> { + : public BLEPeripheralExtensionFunction { public: DECLARE_EXTENSION_FUNCTION("bluetoothLowEnergy.sendRequestResponse", BLUETOOTHLOWENERGY_SENDREQUESTRESPONSE); + BluetoothLowEnergySendRequestResponseFunction(); + protected: - ~BluetoothLowEnergySendRequestResponseFunction() override {} + ~BluetoothLowEnergySendRequestResponseFunction() override; // BluetoothLowEnergyPeripheralExtensionFunction override. void DoWork() override; + bool ParseParams() override; + + std::unique_ptr<bluetooth_low_energy::SendRequestResponse::Params> params_; }; } // namespace api
diff --git a/extensions/renderer/dispatcher.cc b/extensions/renderer/dispatcher.cc index 7dfb51c..67d8bea 100644 --- a/extensions/renderer/dispatcher.cc +++ b/extensions/renderer/dispatcher.cc
@@ -727,7 +727,6 @@ {"guestViewEvents", IDR_GUEST_VIEW_EVENTS_JS}, {"imageUtil", IDR_IMAGE_UTIL_JS}, {"json_schema", IDR_JSON_SCHEMA_JS}, - {"lastError", IDR_LAST_ERROR_JS}, {"messaging", IDR_MESSAGING_JS}, {"messaging_utils", IDR_MESSAGING_UTILS_JS}, {kSchemaUtils, IDR_SCHEMA_UTILS_JS}, @@ -801,6 +800,7 @@ if (!FeatureSwitch::native_crx_bindings()->IsEnabled()) { resources.emplace_back("binding", IDR_BINDING_JS); resources.emplace_back(kEventBindings, IDR_EVENT_BINDINGS_JS); + resources.emplace_back("lastError", IDR_LAST_ERROR_JS); resources.emplace_back("sendRequest", IDR_SEND_REQUEST_JS); // Custom types sources.
diff --git a/extensions/renderer/resources/file_entry_binding_util.js b/extensions/renderer/resources/file_entry_binding_util.js index 6ae219c..cdef7222 100644 --- a/extensions/renderer/resources/file_entry_binding_util.js +++ b/extensions/renderer/resources/file_entry_binding_util.js
@@ -4,12 +4,20 @@ var fileSystemNatives = requireNative('file_system_natives'); var GetIsolatedFileSystem = fileSystemNatives.GetIsolatedFileSystem; -var lastError = require('lastError'); var GetModuleSystem = requireNative('v8_context').GetModuleSystem; // TODO(sammc): Don't require extension. See http://crbug.com/235689. var GetExtensionViews = requireNative('runtime').GetExtensionViews; var safeCallbackApply = require('uncaught_exception_handler').safeCallbackApply; +var jsLastError = bindingUtil ? undefined : require('lastError'); +function runCallbackWithLastError(name, message, stack, callback) { + if (bindingUtil) + bindingUtil.runCallbackWithLastError(message, callback); + else + jsLastError.run(name, message, stack, callback); +} + + var WINDOW = {}; try { WINDOW = window; @@ -51,7 +59,7 @@ var getEntryError = function(fileError) { if (!hasError) { hasError = true; - lastError.run( + runCallbackWithLastError( apiName + '.' + functionName, 'Error getting fileEntry, code: ' + fileError.code, request.stack, @@ -103,10 +111,9 @@ } catch (e) { if (!hasError) { hasError = true; - lastError.run(apiName + '.' + functionName, - 'Error getting fileEntry: ' + e.stack, - request.stack, - callback); + runCallbackWithLastError(apiName + '.' + functionName, + 'Error getting fileEntry: ' + e.stack, + request.stack, callback); } } }); @@ -150,16 +157,15 @@ try { fs.root.getDirectory(baseName, {}, callback, function(fileError) { - lastError.run('runtime.' + functionName, - 'Error getting Entry, code: ' + fileError.code, - request.stack, - callback); + runCallbackWithLastError( + 'runtime.' + functionName, + 'Error getting Entry, code: ' + fileError.code, + request.stack, callback); }); } catch (e) { - lastError.run('runtime.' + functionName, - 'Error: ' + e.stack, - request.stack, - callback); + runCallbackWithLastError('runtime.' + functionName, + 'Error: ' + e.stack, + request.stack, callback); } } }
diff --git a/extensions/renderer/resources/messaging.js b/extensions/renderer/resources/messaging.js index f44d753d..d0ca6c8 100644 --- a/extensions/renderer/resources/messaging.js +++ b/extensions/renderer/resources/messaging.js
@@ -7,7 +7,6 @@ // TODO(kalman): factor requiring chrome out of here. var chrome = requireNative('chrome').GetChrome(); - var lastError = require('lastError'); var logActivity = requireNative('activityLogger'); var logging = requireNative('logging'); var messagingNatives = requireNative('messaging_natives'); @@ -46,6 +45,28 @@ privates(event).impl.destroy_(); } + var jsLastError = bindingUtil ? undefined : require('lastError'); + function setLastError(name, error) { + if (bindingUtil) + bindingUtil.setLastError(error); + else + jsLastError.set(name, error, null, chrome); + } + + function clearLastError() { + if (bindingUtil) + bindingUtil.clearLastError(); + else + jsLastError.clear(chrome); + } + + function hasLastError() { + if (bindingUtil) + return bindingUtil.hasLastError(); + else + return jsLastError.hasError(chrome); + } + // Map of port IDs to port object. var ports = {__proto__: null}; @@ -152,7 +173,7 @@ if (sourceUrl) errorMsg += ' for URL ' + sourceUrl; errorMsg += ').'; - lastError.set(eventName, errorMsg, null, chrome); + setLastError(eventName, errorMsg); } // Helper function for dispatchOnConnect @@ -348,12 +369,12 @@ if (port) { delete ports[portId]; if (errorMessage) - lastError.set('Port', errorMessage, null, chrome); + setLastError('Port', errorMessage); try { port.onDisconnect.dispatch(port); } finally { privates(port).impl.destroy_(); - lastError.clear(chrome); + clearLastError(); } } }; @@ -406,17 +427,16 @@ if (!responseCallback) return; - if (lastError.hasError(chrome)) { + if (hasLastError()) { sendResponseAndClearCallback(); } else { - lastError.set( + setLastError( port.name, - 'The message port closed before a response was received.', null, - chrome); + 'The message port closed before a response was received.'); try { sendResponseAndClearCallback(); } finally { - lastError.clear(chrome); + clearLastError(); } } }
diff --git a/extensions/shell/installer/linux/BUILD.gn b/extensions/shell/installer/linux/BUILD.gn index d537e713..08f8bfa 100644 --- a/extensions/shell/installer/linux/BUILD.gn +++ b/extensions/shell/installer/linux/BUILD.gn
@@ -128,6 +128,14 @@ "//ppapi/native_client:irt", ] } + + # TODO(thomasanderson): Move this variable into a .gni file + # somewhere. It is currently copied from + # buildtools/third_party/libc++/BUILD.gn. + libcpp_is_static = !is_component_build && !using_sanitizer + if (!libcpp_is_static && use_custom_libcxx) { + public_deps += [ "//buildtools/third_party/libc++:libc++" ] + } } # Creates .deb installer package.
diff --git a/google_apis/gcm/monitoring/fake_gcm_stats_recorder.cc b/google_apis/gcm/monitoring/fake_gcm_stats_recorder.cc index 5b138d2fa..62ca46e 100644 --- a/google_apis/gcm/monitoring/fake_gcm_stats_recorder.cc +++ b/google_apis/gcm/monitoring/fake_gcm_stats_recorder.cc
@@ -56,6 +56,12 @@ int64_t delay_msec, int retries_left) {} +void FakeGCMStatsRecorder::RecordDataMessageReceived( + const std::string& app_id, + const std::string& from, + int message_byte_size, + ReceivedMessageType message_type) {} + void FakeGCMStatsRecorder::RecordUnregistrationSent( const std::string& app_id, const std::string& source) { } @@ -72,14 +78,6 @@ int64_t delay_msec, int retries_left) {} -void FakeGCMStatsRecorder::RecordDataMessageReceived( - const std::string& app_id, - const std::string& from, - int message_byte_size, - bool to_registered_app, - ReceivedMessageType message_type) { -} - void FakeGCMStatsRecorder::RecordDataSentToWire( const std::string& app_id, const std::string& receiver_id,
diff --git a/google_apis/gcm/monitoring/fake_gcm_stats_recorder.h b/google_apis/gcm/monitoring/fake_gcm_stats_recorder.h index 8e10231..a998a02c 100644 --- a/google_apis/gcm/monitoring/fake_gcm_stats_recorder.h +++ b/google_apis/gcm/monitoring/fake_gcm_stats_recorder.h
@@ -52,7 +52,6 @@ void RecordDataMessageReceived(const std::string& app_id, const std::string& from, int message_byte_size, - bool to_registered_app, ReceivedMessageType message_type) override; void RecordDataSentToWire(const std::string& app_id, const std::string& receiver_id,
diff --git a/google_apis/gcm/monitoring/gcm_stats_recorder.h b/google_apis/gcm/monitoring/gcm_stats_recorder.h index 7cd45eb..dff4a47 100644 --- a/google_apis/gcm/monitoring/gcm_stats_recorder.h +++ b/google_apis/gcm/monitoring/gcm_stats_recorder.h
@@ -109,14 +109,12 @@ int64_t delay_msec, int retries_left) = 0; - // Records that a data message has been received. If this message is not - // sent to a registered app, to_registered_app should be false. If it - // indicates that one or more messages were dropped on the server, - // message_type should be DELETED_MESSAGES. + // Records that a data message has been received. If it indicates that one or + // more messages were dropped on the server, message_type should be + // DELETED_MESSAGES. virtual void RecordDataMessageReceived(const std::string& app_id, const std::string& from, int message_byte_size, - bool to_registered_app, ReceivedMessageType message_type) = 0; // Records that an outgoing data message was sent over the wire.
diff --git a/gpu/BUILD.gn b/gpu/BUILD.gn index 3fa2b3e..86b3d704 100644 --- a/gpu/BUILD.gn +++ b/gpu/BUILD.gn
@@ -157,6 +157,7 @@ "command_buffer/tests/gl_map_buffer_range_unittest.cc", "command_buffer/tests/gl_native_gmb_backbuffer_unittest.cc", "command_buffer/tests/gl_object_bindings_unittest.cc", + "command_buffer/tests/gl_oob_attrib_unittest.cc", "command_buffer/tests/gl_pointcoord_unittest.cc", "command_buffer/tests/gl_program_unittest.cc", "command_buffer/tests/gl_query_unittest.cc",
diff --git a/gpu/command_buffer/service/program_manager.cc b/gpu/command_buffer/service/program_manager.cc index 9fb9cc8..c1ffc0a 100644 --- a/gpu/command_buffer/service/program_manager.cc +++ b/gpu/command_buffer/service/program_manager.cc
@@ -225,6 +225,26 @@ return total.ValueOrDefault(std::numeric_limits<GLsizeiptr>::max()); } +size_t LocationCountForAttribType(GLenum type) { + switch (type) { + case GL_FLOAT_MAT2: + case GL_FLOAT_MAT2x3: + case GL_FLOAT_MAT2x4: + return 2; + case GL_FLOAT_MAT3x2: + case GL_FLOAT_MAT3: + case GL_FLOAT_MAT3x4: + return 3; + break; + case GL_FLOAT_MAT4x2: + case GL_FLOAT_MAT4x3: + case GL_FLOAT_MAT4: + return 4; + default: + return 1; + } +} + } // anonymous namespace. Program::UniformInfo::UniformInfo() @@ -457,16 +477,21 @@ void Program::UpdateVertexInputBaseTypes() { ClearVertexInputMasks(); - DCHECK_LE(attrib_infos_.size(), manager_->max_vertex_attribs()); for (size_t ii = 0; ii < attrib_infos_.size(); ++ii) { const VertexAttrib& input = attrib_infos_[ii]; if (ProgramManager::HasBuiltInPrefix(input.name)) { continue; } - int shift_bits = (input.location % 16) * 2; - vertex_input_active_mask_[ii / 16] |= 0x3 << shift_bits; - vertex_input_base_type_mask_[ii / 16] |= - InputOutputTypeToBaseType(true, input.type) << shift_bits; + + DCHECK_LE(input.location + input.location_count, + manager_->max_vertex_attribs()); + for (size_t location = input.location; + location < input.location + input.location_count; ++location) { + int shift_bits = (location % 16) * 2; + vertex_input_active_mask_[location / 16] |= 0x3 << shift_bits; + vertex_input_base_type_mask_[location / 16] |= + InputOutputTypeToBaseType(true, input.type) << shift_bits; + } } } @@ -706,7 +731,7 @@ uniforms_cleared_ = false; GLint num_attribs = 0; GLint max_len = 0; - GLint max_location = -1; + size_t num_locations = 0; glGetProgramiv(service_id_, GL_ACTIVE_ATTRIBUTES, &num_attribs); glGetProgramiv(service_id_, GL_ACTIVE_ATTRIBUTE_MAX_LENGTH, &max_len); // TODO(gman): Should we check for error? @@ -721,26 +746,25 @@ DCHECK(length == 0 || name_buffer[length] == '\0'); std::string original_name; GetVertexAttribData(name_buffer.get(), &original_name, &type); + size_t location_count = size * LocationCountForAttribType(type); // TODO(gman): Should we check for error? GLint location = glGetAttribLocation(service_id_, name_buffer.get()); - if (location > max_location) { - max_location = location; - } - attrib_infos_.push_back(VertexAttrib(1, type, original_name, location)); + num_locations = std::max(num_locations, location + location_count); + attrib_infos_.push_back( + VertexAttrib(1, type, original_name, location, location_count)); max_attrib_name_length_ = std::max( max_attrib_name_length_, static_cast<GLsizei>(original_name.size())); } // Create attrib location to index map. - attrib_location_to_index_map_.resize(max_location + 1); - for (GLint ii = 0; ii <= max_location; ++ii) { - attrib_location_to_index_map_[ii] = -1; - } + attrib_location_to_index_map_.resize(num_locations, -1); for (size_t ii = 0; ii < attrib_infos_.size(); ++ii) { const VertexAttrib& info = attrib_infos_[ii]; - if (info.location >= 0 && info.location <= max_location) { - attrib_location_to_index_map_[info.location] = ii; - } + if (info.location < 0) + continue; + DCHECK_LE(info.location + info.location_count, num_locations); + for (size_t j = 0; j < info.location_count; ++j) + attrib_location_to_index_map_[info.location + j] = ii; } if (manager_->gpu_preferences_.enable_gpu_service_logging_gpu) { @@ -1864,20 +1888,7 @@ } } if (attrib) { - size_t num_of_locations = 1; - switch (attrib->type) { - case GL_FLOAT_MAT2: - num_of_locations = 2; - break; - case GL_FLOAT_MAT3: - num_of_locations = 3; - break; - case GL_FLOAT_MAT4: - num_of_locations = 4; - break; - default: - break; - } + size_t num_of_locations = LocationCountForAttribType(attrib->type); for (size_t ii = 0; ii < num_of_locations; ++ii) { GLint loc = key_value.second + ii; auto result = location_binding_used.insert(loc);
diff --git a/gpu/command_buffer/service/program_manager.h b/gpu/command_buffer/service/program_manager.h index 74bb256..a3b8e64 100644 --- a/gpu/command_buffer/service/program_manager.h +++ b/gpu/command_buffer/service/program_manager.h
@@ -133,16 +133,20 @@ std::vector<GLuint> texture_units; }; struct VertexAttrib { - VertexAttrib(GLsizei _size, GLenum _type, const std::string& _name, - GLint _location) - : size(_size), - type(_type), - location(_location), - name(_name) { - } + VertexAttrib(GLsizei size, + GLenum type, + const std::string& name, + GLint location, + size_t location_count) + : size(size), + type(type), + location(location), + location_count(location_count), + name(name) {} GLsizei size; GLenum type; GLint location; + size_t location_count; std::string name; }; struct UniformBlockSizeInfo {
diff --git a/gpu/command_buffer/service/program_manager_unittest.cc b/gpu/command_buffer/service/program_manager_unittest.cc index 154bf9d..e0269249 100644 --- a/gpu/command_buffer/service/program_manager_unittest.cc +++ b/gpu/command_buffer/service/program_manager_unittest.cc
@@ -187,19 +187,24 @@ static const char* kAttrib1Name; static const char* kAttrib2Name; static const char* kAttrib3Name; + static const char* kAttrib4Name; static const GLint kAttrib1Size = 1; static const GLint kAttrib2Size = 1; static const GLint kAttrib3Size = 1; + static const GLint kAttrib4Size = 1; static const GLenum kAttrib1Precision = GL_MEDIUM_FLOAT; static const GLenum kAttrib2Precision = GL_HIGH_FLOAT; - static const GLenum kAttrib3Precision = GL_LOW_FLOAT; + static const GLenum kAttrib3Precision = GL_LOW_INT; + static const GLenum kAttrib4Precision = GL_HIGH_FLOAT; static const bool kAttribStaticUse = true; static const GLint kAttrib1Location = 0; static const GLint kAttrib2Location = 1; static const GLint kAttrib3Location = 2; + static const GLint kAttrib4Location = 3; static const GLenum kAttrib1Type = GL_FLOAT_VEC4; static const GLenum kAttrib2Type = GL_FLOAT_VEC2; - static const GLenum kAttrib3Type = GL_FLOAT_VEC3; + static const GLenum kAttrib3Type = GL_INT_VEC3; + static const GLenum kAttrib4Type = GL_FLOAT_MAT3x2; static const GLint kInvalidAttribLocation = 30; static const GLint kBadAttribIndex = kNumVertexAttribs; @@ -459,9 +464,18 @@ ProgramManagerWithShaderTest::AttribInfo ProgramManagerWithShaderTest::kAttribs[] = { - { kAttrib1Name, kAttrib1Size, kAttrib1Type, kAttrib1Location, }, - { kAttrib2Name, kAttrib2Size, kAttrib2Type, kAttrib2Location, }, - { kAttrib3Name, kAttrib3Size, kAttrib3Type, kAttrib3Location, }, + { + kAttrib1Name, kAttrib1Size, kAttrib1Type, kAttrib1Location, + }, + { + kAttrib2Name, kAttrib2Size, kAttrib2Type, kAttrib2Location, + }, + { + kAttrib3Name, kAttrib3Size, kAttrib3Type, kAttrib3Location, + }, + { + kAttrib4Name, kAttrib4Size, kAttrib4Type, kAttrib4Location, + }, }; // GCC requires these declarations, but MSVC requires they not be present @@ -476,12 +490,15 @@ const GLint ProgramManagerWithShaderTest::kAttrib1Size; const GLint ProgramManagerWithShaderTest::kAttrib2Size; const GLint ProgramManagerWithShaderTest::kAttrib3Size; +const GLint ProgramManagerWithShaderTest::kAttrib4Size; const GLint ProgramManagerWithShaderTest::kAttrib1Location; const GLint ProgramManagerWithShaderTest::kAttrib2Location; const GLint ProgramManagerWithShaderTest::kAttrib3Location; +const GLint ProgramManagerWithShaderTest::kAttrib4Location; const GLenum ProgramManagerWithShaderTest::kAttrib1Type; const GLenum ProgramManagerWithShaderTest::kAttrib2Type; const GLenum ProgramManagerWithShaderTest::kAttrib3Type; +const GLenum ProgramManagerWithShaderTest::kAttrib4Type; const GLint ProgramManagerWithShaderTest::kInvalidAttribLocation; const GLint ProgramManagerWithShaderTest::kBadAttribIndex; const GLint ProgramManagerWithShaderTest::kUniform1Size; @@ -540,6 +557,7 @@ const char* ProgramManagerWithShaderTest::kAttrib1Name = "attrib1"; const char* ProgramManagerWithShaderTest::kAttrib2Name = "attrib2"; const char* ProgramManagerWithShaderTest::kAttrib3Name = "attrib3"; +const char* ProgramManagerWithShaderTest::kAttrib4Name = "attrib4"; const char* ProgramManagerWithShaderTest::kUniform1Name = "uniform1"; const char* ProgramManagerWithShaderTest::kUniform2Name = "uniform2"; const char* ProgramManagerWithShaderTest::kUniform2NameWithArrayIndex = @@ -580,6 +598,31 @@ EXPECT_TRUE(program->GetAttribInfo(kInvalidIndex) == NULL); } +TEST_F(ProgramManagerWithShaderTest, GetAttribInfoByLocation) { + const GLint kInvalidLocation = 1000; + const Program* program = SetupDefaultProgram(); + ASSERT_TRUE(program != NULL); + + // attrib2 is a vec2, takes 1 location + const Program::VertexAttrib* expected_info = program->GetAttribInfo(1); + EXPECT_EQ(1u, expected_info->location_count); + const Program::VertexAttrib* info = + program->GetAttribInfoByLocation(kAttrib2Location); + EXPECT_EQ(expected_info, info); + + // attrib4 is a mat3x2, takes 3 locations (1 per column) + expected_info = program->GetAttribInfo(3); + EXPECT_EQ(3u, expected_info->location_count); + info = program->GetAttribInfoByLocation(kAttrib4Location); + EXPECT_EQ(expected_info, info); + info = program->GetAttribInfoByLocation(kAttrib4Location + 1); + EXPECT_EQ(expected_info, info); + info = program->GetAttribInfoByLocation(kAttrib4Location + 2); + EXPECT_EQ(expected_info, info); + + EXPECT_TRUE(program->GetAttribInfoByLocation(kInvalidLocation) == NULL); +} + TEST_F(ProgramManagerWithShaderTest, GetAttribLocation) { const char* kInvalidName = "foo"; const Program* program = SetupDefaultProgram(); @@ -588,6 +631,27 @@ EXPECT_EQ(-1, program->GetAttribLocation(kInvalidName)); } +TEST_F(ProgramManagerWithShaderTest, VertexArrayMasks) { + const Program* program = SetupDefaultProgram(); + ASSERT_TRUE(program != NULL); + + std::vector<uint32_t> active_mask = program->vertex_input_active_mask(); + ASSERT_EQ(1u, active_mask.size()); + uint32_t expected = 0x3 << 0 | // attrib1 + 0x3 << 2 | // attrib2 + 0x3 << 4 | // attrib3 + (0x3 * 0b010101) << 6; // attrib4 + EXPECT_EQ(expected, active_mask[0]); + + std::vector<uint32_t> base_type_mask = program->vertex_input_base_type_mask(); + ASSERT_EQ(1u, base_type_mask.size()); + expected = SHADER_VARIABLE_FLOAT << 0 | // attrib1 + SHADER_VARIABLE_FLOAT << 2 | // attrib2 + SHADER_VARIABLE_INT << 4 | // attrib3 + (SHADER_VARIABLE_FLOAT * 0b010101) << 6; // attrib4 + EXPECT_EQ(expected, base_type_mask[0]); +} + TEST_F(ProgramManagerWithShaderTest, GetUniformInfo) { const GLint kInvalidIndex = 1000; const Program* program = SetupDefaultProgram(); @@ -770,7 +834,7 @@ program->Link(NULL, Program::kCountOnlyStaticallyUsed, this); GLint value = 0; program->GetProgramiv(GL_ACTIVE_ATTRIBUTES, &value); - EXPECT_EQ(3, value); + EXPECT_EQ(4, value); // Check that we didn't skip the "gl_" uniform. program->GetProgramiv(GL_ACTIVE_UNIFORMS, &value); EXPECT_EQ(3, value);
diff --git a/gpu/command_buffer/tests/gl_oob_attrib_unittest.cc b/gpu/command_buffer/tests/gl_oob_attrib_unittest.cc new file mode 100644 index 0000000..d4c050f5 --- /dev/null +++ b/gpu/command_buffer/tests/gl_oob_attrib_unittest.cc
@@ -0,0 +1,86 @@ +// Copyright 2017 The Chromium Authors. All rights reserved. +// Use of this source code is governed by a BSD-style license that can be +// found in the LICENSE file. + +#include <GLES2/gl2.h> +#include <GLES2/gl2ext.h> +#include <stdint.h> + +#include "gpu/command_buffer/tests/gl_manager.h" +#include "gpu/command_buffer/tests/gl_test_utils.h" +#include "testing/gtest/include/gtest/gtest.h" + +namespace gpu { + +namespace { + +class GLOOBAttribTest : public testing::Test { + protected: + void SetUp() override { gl_.Initialize(GLManager::Options()); } + void TearDown() override { gl_.Destroy(); } + GLManager gl_; +}; + +// Tests that enabling a vertex array for a location that matches any column of +// a matrix attribute correctly triggers out-of-bounds checks. +TEST_F(GLOOBAttribTest, DrawUsingOOBMatrixAttrib) { + const char kVertexShader[] = + "attribute mat3 attrib;\n" + "varying vec4 color;\n" + "void main () {\n" + " color = vec4(1.0,\n" + " attrib[0][0] + attrib[0][1] + attrib[0][2] +\n" + " attrib[1][0] + attrib[1][1] + attrib[1][2] +\n" + " attrib[2][0] + attrib[2][1] + attrib[2][2],\n" + " 1.0,\n" + " 1.0);\n" + "}\n"; + const char kFragmentShader[] = + "precision mediump float;\n" + "varying vec4 color;\n" + "void main() {\n" + " gl_FragColor = color;\n" + "}\n"; + + GLuint program = GLTestHelper::LoadProgram(kVertexShader, kFragmentShader); + DCHECK(program); + glUseProgram(program); + GLuint vbo; + glGenBuffers(1, &vbo); + glBindBuffer(GL_ARRAY_BUFFER, vbo); + glBufferData(GL_ARRAY_BUFFER, 16, nullptr, GL_STATIC_DRAW); + GLint location = glGetAttribLocation(program, "attrib"); + EXPECT_GE(0, location); + + // All attribs disabled - no error. + glDrawArrays(GL_TRIANGLES, 0, 1000); + GLenum expected = GL_NO_ERROR; + EXPECT_EQ(expected, glGetError()); + + for (int i = 0; i < 3; ++i) { + // Enable any of the valid locations for the attribute, should raise an + // error if trying to access attributes out-of-bounds. + glVertexAttribPointer(location + i, 4, GL_UNSIGNED_BYTE, false, 0, nullptr); + glEnableVertexAttribArray(location + i); + glDrawArrays(GL_TRIANGLES, 0, 1000); + expected = GL_INVALID_OPERATION; + EXPECT_EQ(expected, glGetError()); + + // But in-bounds should pass. + glDrawArrays(GL_TRIANGLES, 0, 3); + expected = GL_NO_ERROR; + EXPECT_EQ(expected, glGetError()); + glDisableVertexAttribArray(location + i); + } + + // Enable an unused location, should not trigger out-of-bounds checks. + glVertexAttribPointer(location + 3, 4, GL_UNSIGNED_BYTE, false, 0, nullptr); + glEnableVertexAttribArray(location + 3); + glDrawArrays(GL_TRIANGLES, 0, 1000); + expected = GL_NO_ERROR; + EXPECT_EQ(expected, glGetError()); +} + +} // anonymous namespace + +} // namespace gpu
diff --git a/headless/OWNERS b/headless/OWNERS index f8f1df65..e96cb2c 100644 --- a/headless/OWNERS +++ b/headless/OWNERS
@@ -2,6 +2,10 @@ alexclarke@chromium.org altimin@chromium.org eseckler@chromium.org +dvallet@chromium.org +irisu@chromium.org +jzfeng@chromium.org +rvera@chromium.org # TEAM: headless-dev@chromium.org # COMPONENT: Internals>Headless
diff --git a/ios/chrome/browser/browsing_data/browsing_data_removal_controller.mm b/ios/chrome/browser/browsing_data/browsing_data_removal_controller.mm index 115c6ff..ba09317 100644 --- a/ios/chrome/browser/browsing_data/browsing_data_removal_controller.mm +++ b/ios/chrome/browser/browsing_data/browsing_data_removal_controller.mm
@@ -6,6 +6,8 @@ #import <WebKit/WebKit.h> +#include <stdint.h> + #include <memory> #include "base/bind.h" @@ -39,7 +41,7 @@ namespace { // Empty callback used by DeleteAllCreatedBetweenAsync below. -void DoNothing(int n) {} +void DoNothing(uint32_t n) {} } @interface BrowsingDataRemovalController ()
diff --git a/ios/chrome/browser/browsing_data/ios_chrome_browsing_data_remover.h b/ios/chrome/browser/browsing_data/ios_chrome_browsing_data_remover.h index 643c1db..979d8bf08 100644 --- a/ios/chrome/browser/browsing_data/ios_chrome_browsing_data_remover.h +++ b/ios/chrome/browser/browsing_data/ios_chrome_browsing_data_remover.h
@@ -5,6 +5,8 @@ #ifndef IOS_CHROME_BROWSER_BROWSING_DATA_IOS_CHROME_BROWSING_DATA_REMOVER_H_ #define IOS_CHROME_BROWSER_BROWSING_DATA_IOS_CHROME_BROWSING_DATA_REMOVER_H_ +#include <stdint.h> + #include <memory> #include <set> @@ -189,7 +191,7 @@ void OnClearedPasswords(); // Callback for when Cookies has been deleted. Invokes NotifyAndDeleteIfDone. - void OnClearedCookies(int num_deleted); + void OnClearedCookies(uint32_t num_deleted); // Invoked on the IO thread to delete cookies. void ClearCookiesOnIOThread(
diff --git a/ios/chrome/browser/browsing_data/ios_chrome_browsing_data_remover.mm b/ios/chrome/browser/browsing_data/ios_chrome_browsing_data_remover.mm index a9f0d06..19ae87a 100644 --- a/ios/chrome/browser/browsing_data/ios_chrome_browsing_data_remover.mm +++ b/ios/chrome/browser/browsing_data/ios_chrome_browsing_data_remover.mm
@@ -447,7 +447,7 @@ NotifyAndDeleteIfDone(); } -void IOSChromeBrowsingDataRemover::OnClearedCookies(int num_deleted) { +void IOSChromeBrowsingDataRemover::OnClearedCookies(uint32_t num_deleted) { if (!WebThread::CurrentlyOn(WebThread::UI)) { WebThread::PostTask( WebThread::UI, FROM_HERE,
diff --git a/ios/chrome/browser/chrome_url_constants.cc b/ios/chrome/browser/chrome_url_constants.cc index b23d0ff..e4268bd 100644 --- a/ios/chrome/browser/chrome_url_constants.cc +++ b/ios/chrome/browser/chrome_url_constants.cc
@@ -20,8 +20,6 @@ const char kChromeUINTPTilesInternalsURL[] = "chrome://ntp-tiles-internals/"; const char kChromeUIOfflineURL[] = "chrome://offline/"; const char kChromeUIPhysicalWebURL[] = "chrome://physical-web/"; -const char kChromeUIPopularSitesInternalsURL[] = - "chrome://popular-sites-internals/"; const char kChromeUISettingsURL[] = "chrome://settings/"; const char kChromeUITermsURL[] = "chrome://terms/"; const char kChromeUIVersionURL[] = "chrome://version/"; @@ -44,7 +42,6 @@ const char kChromeUIOfflineHost[] = "offline"; const char kChromeUIOmahaHost[] = "omaha"; const char kChromeUIPhysicalWebHost[] = "physical-web"; -const char kChromeUIPopularSitesInternalsHost[] = "popular-sites-internals"; const char kChromeUIPolicyHost[] = "policy"; const char kChromeUISignInInternalsHost[] = "signin-internals"; const char kChromeUISyncInternalsHost[] = "sync-internals"; @@ -60,8 +57,8 @@ kChromeUIHistogramHost, kChromeUINetExportHost, kChromeUINewTabHost, kChromeUINTPTilesInternalsHost, kChromeUISignInInternalsHost, kChromeUISyncInternalsHost, - kChromeUIPhysicalWebHost, kChromeUIPopularSitesInternalsHost, - kChromeUITermsHost, kChromeUIVersionHost, + kChromeUIPhysicalWebHost, kChromeUITermsHost, + kChromeUIVersionHost, }; const size_t kNumberOfChromeHostURLs = arraysize(kChromeHostURLs);
diff --git a/ios/chrome/browser/google/google_logo_service.mm b/ios/chrome/browser/google/google_logo_service.mm index 1d58dfe..3a93491 100644 --- a/ios/chrome/browser/google/google_logo_service.mm +++ b/ios/chrome/browser/google/google_logo_service.mm
@@ -27,7 +27,6 @@ namespace { -const char kGoogleDoodleURLPath[] = "async/newtab_mobile"; static NSArray* const kDoodleCacheDirectory = @[ @"Chromium", @"Doodle" ]; // Cache directory for doodle. @@ -42,21 +41,6 @@ base::SysNSStringToUTF8([NSString pathWithComponents:path_components])); } -// Returns the URL where the doodle can be downloaded, e.g. -// https://www.google.com/async/newtab_mobile. This depends on the user's -// Google domain. -GURL GetGoogleDoodleURL(ios::ChromeBrowserState* browser_state) { - GURL google_base_url( - ios::UIThreadSearchTermsData(browser_state).GoogleBaseURLValue()); - // SetPathStr() requires its argument to stay in scope as long as - // |replacements| is, so a std::string is needed, instead of a char*. - std::string path = kGoogleDoodleURLPath; - GURL::Replacements replacements; - replacements.SetPathStr(path); - - return google_base_url.ReplaceComponents(replacements); -} - class IOSChromeLogoDelegate : public search_provider_logos::LogoDelegate { public: IOSChromeLogoDelegate() {} @@ -103,11 +87,15 @@ base::MakeUnique<IOSChromeLogoDelegate>()); } + GURL google_base_url( + ios::UIThreadSearchTermsData(browser_state_).GoogleBaseURLValue()); + logo_tracker_->SetServerAPI( - GetGoogleDoodleURL(browser_state_), - base::Bind(&search_provider_logos::GoogleParseLogoResponse), - base::Bind(&search_provider_logos::GoogleAppendQueryparamsToLogoURL, - false /* gray_background */)); + search_provider_logos::GetGoogleDoodleURL(google_base_url), + search_provider_logos::GetGoogleParseLogoResponseCallback( + google_base_url), + search_provider_logos::GetGoogleAppendQueryparamsCallback( + /*gray_background=*/false)); logo_tracker_->GetLogo(observer); }
diff --git a/ios/chrome/browser/net/cookie_util.mm b/ios/chrome/browser/net/cookie_util.mm index 48a2187..2b513cd4 100644 --- a/ios/chrome/browser/net/cookie_util.mm +++ b/ios/chrome/browser/net/cookie_util.mm
@@ -6,6 +6,7 @@ #import <Foundation/Foundation.h> #include <stddef.h> +#include <stdint.h> #include <sys/sysctl.h> #include "base/logging.h" @@ -34,7 +35,7 @@ NSString* const kLastCookieDeletionDate = @"LastCookieDeletionDate"; // Empty callback. -void DoNothing(int n) {} +void DoNothing(uint32_t n) {} // Creates a SQLitePersistentCookieStore running on a background thread. scoped_refptr<net::SQLitePersistentCookieStore> CreatePersistentCookieStore(
diff --git a/ios/chrome/browser/payments/BUILD.gn b/ios/chrome/browser/payments/BUILD.gn index 33bd463..a57b8fa 100644 --- a/ios/chrome/browser/payments/BUILD.gn +++ b/ios/chrome/browser/payments/BUILD.gn
@@ -9,6 +9,8 @@ sources = [ "ios_can_make_payment_query_factory.cc", "ios_can_make_payment_query_factory.h", + "itunes_json_request.cc", + "itunes_json_request.h", "payment_request.h", "payment_request.mm", "payment_request_util.h", @@ -27,7 +29,9 @@ "//ios/chrome/browser/browser_state", "//ios/chrome/browser/signin", "//ios/web", + "//net", "//ui/base", + "//url", ] libs = [ "UIKit.framework" ] }
diff --git a/ios/chrome/browser/payments/itunes_json_request.cc b/ios/chrome/browser/payments/itunes_json_request.cc new file mode 100644 index 0000000..ef7904b --- /dev/null +++ b/ios/chrome/browser/payments/itunes_json_request.cc
@@ -0,0 +1,117 @@ +// Copyright 2017 The Chromium Authors. All rights reserved. +// Use of this source code is governed by a BSD-style license that can be +// found in the LICENSE file. + +#include "ios/chrome/browser/payments/itunes_json_request.h" + +#include <utility> + +#include "base/bind.h" +#include "base/json/json_reader.h" +#include "base/memory/ptr_util.h" +#include "base/values.h" +#include "net/base/load_flags.h" +#include "net/http/http_status_code.h" +#include "net/url_request/url_fetcher.h" +#include "net/url_request/url_request_status.h" +#include "url/gurl.h" + +namespace payment_request_util { + +const char kBadResponse[] = "Bad iTunes Store search response"; +const char kITunesStoreLookupPrefix[] = "https://itunes.apple.com/lookup?"; +const char kITunesStoreSearchPrefix[] = "https://itunes.apple.com/search?"; + +ITunesJsonRequest::ITunesJsonRequest( + const Callback& callback, + net::URLRequestContextGetter* context_getter) + : callback_(callback), + context_getter_(context_getter), + weak_factory_(this) { + DCHECK(!callback_.is_null()); +} + +ITunesJsonRequest::~ITunesJsonRequest() {} + +void ITunesJsonRequest::Start(ITunesStoreRequestType request_type, + const std::string& request_query) { + Stop(); + + std::string complete_query; + switch (request_type) { + case LOOKUP: + complete_query = kITunesStoreLookupPrefix + request_query; + case SEARCH: + complete_query = kITunesStoreSearchPrefix + request_query; + } + + fetcher_ = + net::URLFetcher::Create(GURL(complete_query), net::URLFetcher::GET, this); + fetcher_->SetRequestContext(context_getter_); + fetcher_->SetLoadFlags(net::LOAD_MAYBE_USER_GESTURE | + net::LOAD_DO_NOT_SAVE_COOKIES | + net::LOAD_VERIFY_EV_CERT); + fetcher_->Start(); +} + +void ITunesJsonRequest::Stop() { + fetcher_.reset(); + weak_factory_.InvalidateWeakPtrs(); +} + +void ITunesJsonRequest::ParseJson( + const std::string& json, + const payment_request_util::ITunesJsonRequest::SuccessCallback& + success_callback, + const payment_request_util::ITunesJsonRequest::ErrorCallback& + error_callback) { + DCHECK(!success_callback.is_null()); + DCHECK(!error_callback.is_null()); + + base::JSONReader json_reader; + std::unique_ptr<base::Value> value = json_reader.ReadToValue(json); + if (value) { + success_callback.Run(std::move(value)); + } else { + error_callback.Run(json_reader.GetErrorMessage()); + } +} + +void ITunesJsonRequest::OnJsonParseSuccess( + std::unique_ptr<base::Value> parsed_json) { + if (!parsed_json->IsType(base::Value::Type::DICTIONARY)) { + OnJsonParseError(kBadResponse); + return; + } + + callback_.Run(base::WrapUnique( + static_cast<base::DictionaryValue*>(parsed_json.release()))); +} + +void ITunesJsonRequest::OnJsonParseError(const std::string& error) { + callback_.Run(std::unique_ptr<base::DictionaryValue>()); +} + +void ITunesJsonRequest::OnURLFetchComplete(const net::URLFetcher* source) { + CHECK_EQ(fetcher_.get(), source); + + std::unique_ptr<net::URLFetcher> fetcher(std::move(fetcher_)); + + if (!fetcher->GetStatus().is_success() || + fetcher->GetResponseCode() != net::HTTP_OK) { + OnJsonParseError(kBadResponse); + return; + } + + std::string json_data; + fetcher->GetResponseAsString(&json_data); + + // The parser will call us back via one of the callbacks. + ParseJson(json_data, + base::Bind(&ITunesJsonRequest::OnJsonParseSuccess, + weak_factory_.GetWeakPtr()), + base::Bind(&ITunesJsonRequest::OnJsonParseError, + weak_factory_.GetWeakPtr())); +} + +} // namespace payment_request_util
diff --git a/ios/chrome/browser/payments/itunes_json_request.h b/ios/chrome/browser/payments/itunes_json_request.h new file mode 100644 index 0000000..fbae57f --- /dev/null +++ b/ios/chrome/browser/payments/itunes_json_request.h
@@ -0,0 +1,80 @@ +// Copyright 2017 The Chromium Authors. All rights reserved. +// Use of this source code is governed by a BSD-style license that can be +// found in the LICENSE file. + +#ifndef IOS_CHROME_BROWSER_PAYMENTS_ITUNES_JSON_REQUEST_H_ +#define IOS_CHROME_BROWSER_PAYMENTS_ITUNES_JSON_REQUEST_H_ + +#include <memory> +#include <string> + +#include "base/callback.h" +#include "base/macros.h" +#include "base/memory/weak_ptr.h" +#include "net/url_request/url_fetcher_delegate.h" + +namespace base { +class DictionaryValue; +class Value; +} // namespace base + +namespace net { +class URLFetcher; +class URLRequestContextGetter; +} // namespace net + +namespace payment_request_util { + +// A class that fetches a JSON formatted response from the iTunes Store using +// the iTunes Search API and a basic JSON parser to parse the response as a +// DictionaryValue. +class ITunesJsonRequest : public net::URLFetcherDelegate { + public: + // Callback to pass back the parsed json dictionary returned from iTunes. + // Invoked with NULL if there is an error. + typedef base::Callback<void(std::unique_ptr<base::DictionaryValue>)> Callback; + + ITunesJsonRequest(const Callback& callback, + net::URLRequestContextGetter* context_getter); + ~ITunesJsonRequest() override; + + // Used to express the type of request. Please view the following for info: + // https://affiliate.itunes.apple.com/resources/documentation/itunes-store-web-service-search-api/ + enum ITunesStoreRequestType { + LOOKUP, + SEARCH, + }; + + // Starts to fetch results for the given |request_type| and |request_query|. + void Start(ITunesStoreRequestType request_type, + const std::string& request_query); + void Stop(); + + private: + // Callbacks for JSON parsing. + typedef base::Callback<void(std::unique_ptr<base::Value> result)> + SuccessCallback; + typedef base::Callback<void(const std::string& error)> ErrorCallback; + + void ParseJson(const std::string& raw_json_string, + const SuccessCallback& success_callback, + const ErrorCallback& error_callback); + + void OnJsonParseSuccess(std::unique_ptr<base::Value> parsed_json); + void OnJsonParseError(const std::string& error); + + // net::URLFetcherDelegate overrides: + void OnURLFetchComplete(const net::URLFetcher* source) override; + + Callback callback_; + net::URLRequestContextGetter* context_getter_; + + std::unique_ptr<net::URLFetcher> fetcher_; + base::WeakPtrFactory<ITunesJsonRequest> weak_factory_; + + DISALLOW_COPY_AND_ASSIGN(ITunesJsonRequest); +}; + +} // namespace payment_request_util + +#endif // IOS_CHROME_BROWSER_PAYMENTS_ITUNES_JSON_REQUEST_H_
diff --git a/ios/chrome/browser/ui/bookmarks/BUILD.gn b/ios/chrome/browser/ui/bookmarks/BUILD.gn index 8319da47..08ed9ac 100644 --- a/ios/chrome/browser/ui/bookmarks/BUILD.gn +++ b/ios/chrome/browser/ui/bookmarks/BUILD.gn
@@ -30,6 +30,8 @@ "bookmark_home_primary_view.h", "bookmark_home_tablet_ntp_controller.h", "bookmark_home_tablet_ntp_controller.mm", + "bookmark_home_view_controller.h", + "bookmark_home_view_controller.mm", "bookmark_home_waiting_view.h", "bookmark_home_waiting_view.mm", "bookmark_interaction_controller.h", @@ -147,6 +149,7 @@ testonly = true sources = [ "bookmark_home_handset_view_controller_unittest.mm", + "bookmark_home_view_controller_unittest.mm", "bookmark_ios_unittest.h", "bookmark_ios_unittest.mm", "bookmark_position_cache_unittest.mm",
diff --git a/ios/chrome/browser/ui/bookmarks/bookmark_home_handset_view_controller.h b/ios/chrome/browser/ui/bookmarks/bookmark_home_handset_view_controller.h index 83bd477..2d09e87 100644 --- a/ios/chrome/browser/ui/bookmarks/bookmark_home_handset_view_controller.h +++ b/ios/chrome/browser/ui/bookmarks/bookmark_home_handset_view_controller.h
@@ -5,6 +5,8 @@ #ifndef IOS_CHROME_BROWSER_UI_BOOKMARKS_BOOKMARK_HOME_HANDSET_VIEW_CONTROLLER_H_ #define IOS_CHROME_BROWSER_UI_BOOKMARKS_BOOKMARK_HOME_HANDSET_VIEW_CONTROLLER_H_ +#import "ios/chrome/browser/ui/bookmarks/bookmark_home_view_controller.h" + #import <UIKit/UIKit.h> #include <set> @@ -16,14 +18,9 @@ @protocol UrlLoader; namespace bookmarks { -class BookmarkModel; class BookmarkNode; } // namespace bookmarks -namespace ios { -class ChromeBrowserState; -} // namespace ios - @protocol BookmarkHomeHandsetViewControllerDelegate // The view controller wants to be dismissed. // If |url| != GURL(), then the user has selected |url| for navigation. @@ -33,7 +30,7 @@ @end // Navigate/edit the bookmark hierarchy on a handset. -@interface BookmarkHomeHandsetViewController : UIViewController { +@interface BookmarkHomeHandsetViewController : BookmarkHomeViewController { @protected // The following 2 ivars both represent the set of nodes being edited. // The set is for fast lookup. @@ -43,9 +40,6 @@ std::set<const bookmarks::BookmarkNode*> _editNodes; std::vector<const bookmarks::BookmarkNode*> _editNodesOrdered; } -// Designated initializer. -- (instancetype)initWithLoader:(id<UrlLoader>)loader - browserState:(ios::ChromeBrowserState*)browserState; #pragma mark - Properties Relevant To Presenters @@ -57,9 +51,6 @@ @property(nonatomic, assign, readonly) BOOL editing; // The set of selected index paths for edition. @property(nonatomic, strong, readonly) NSMutableArray* editIndexPaths; -@property(nonatomic, assign, readonly) bookmarks::BookmarkModel* bookmarks; -@property(nonatomic, weak, readonly) id<UrlLoader> loader; -@property(nonatomic, assign, readonly) ios::ChromeBrowserState* browserState; #pragma mark - Relevant Methods // Replaces |_editNodes| and |_editNodesOrdered| with new container objects.
diff --git a/ios/chrome/browser/ui/bookmarks/bookmark_home_handset_view_controller.mm b/ios/chrome/browser/ui/bookmarks/bookmark_home_handset_view_controller.mm index 7a139fb..d642cb6 100644 --- a/ios/chrome/browser/ui/bookmarks/bookmark_home_handset_view_controller.mm +++ b/ios/chrome/browser/ui/bookmarks/bookmark_home_handset_view_controller.mm
@@ -45,10 +45,6 @@ using bookmarks::BookmarkNode; -namespace { -const CGFloat kBookmarkMenuWidth = 264; -} // namespace - @interface BookmarkHomeHandsetViewController ()< BookmarkCollectionViewDelegate, BookmarkEditViewControllerDelegate, @@ -74,26 +70,12 @@ // This views holds the primary content of this view controller. @property(nonatomic, strong) UIView* contentView; -// The possible views that can be shown from the menu. -@property(nonatomic, strong) BookmarkCollectionView* folderView; -// This view is created and used if the model is not fully loaded yet by the -// time this controller starts. -@property(nonatomic, strong) BookmarkHomeWaitingView* waitForModelView; -// The menu with all the folders and special entries. -@property(nonatomic, strong) BookmarkMenuView* menuView; -// At any point in time, there is exactly one collection view whose view is part -// of the view hierarchy. This property determine which collection view is -// visible. Not by accident, this property also reflects the selected menu item -// in the BookmarkMenuView. -@property(nonatomic, strong) BookmarkMenuItem* primaryMenuItem; // When the view is first shown on the screen, this property represents the // cached value of the y of the content offset of the primary view. This // property is set to nil after it is used. @property(nonatomic, strong) NSNumber* cachedContentPosition; -// The navigation bar sits on top of the main content. -@property(nonatomic, strong) BookmarkNavigationBar* navigationBar; // The layout code in this class relies on the assumption that the editingBar // has the same frame as the navigationBar. @property(nonatomic, strong) BookmarkEditingBar* editingBar; @@ -109,25 +91,15 @@ @property(nonatomic, strong) BookmarkFolderEditorViewController* folderEditor; #pragma mark Specific to this class. -// The panel view slides on top of the content to display the menu. -@property(nonatomic, strong) BookmarkPanelView* panelView; - -// Either the menu or the primaryView can scrollToTop. -@property(nonatomic, assign) BOOL scrollingMenuToTop; // The controller managing the display of the promo cell and the promo view // controller. @property(nonatomic, strong) BookmarkPromoController* bookmarkPromoController; #pragma mark View loading and switching -// This method is called if the view needs to be loaded and the model is not -// ready yet. -- (void)loadWaitingView; // This method should be called at most once in the life-cycle of the // class. It should be called at the soonest possible time after the // view has been loaded, and the bookmark model is loaded. - (void)loadBookmarkViews; -// If the view doesn't exist, create it. -- (void)ensureFolderViewExists; // Updates the property 'primaryMenuItem'. // Updates the UI to reflect the new state of 'primaryMenuItem'. - (void)updatePrimaryMenuItem:(BookmarkMenuItem*)menuItem @@ -201,9 +173,6 @@ - (void)navigationBarBack:(id)sender; #pragma mark private methods -// The active collection view that corresponds to primaryMenuItem. -// This must be implemented by subclass. -- (UIView<BookmarkHomePrimaryView>*)primaryView; // Returns the size of the primary view. - (CGRect)frameForPrimaryView; // Updates the UI to reflect the given orientation, with an animation lasting @@ -223,13 +192,8 @@ @implementation BookmarkHomeHandsetViewController @synthesize contentView = _contentView; -@synthesize folderView = _folderView; -@synthesize waitForModelView = _waitForModelView; -@synthesize menuView = _menuView; -@synthesize primaryMenuItem = _primaryMenuItem; @synthesize cachedContentPosition = _cachedContentPosition; -@synthesize navigationBar = _navigationBar; @synthesize editingBar = _editingBar; @synthesize actionSheetCoordinator = _actionSheetCoordinator; @@ -237,26 +201,16 @@ @synthesize folderSelector = _folderSelector; @synthesize folderEditor = _folderEditor; -@synthesize panelView = _panelView; -@synthesize scrollingMenuToTop = _scrollingMenuToTop; @synthesize bookmarkPromoController = _bookmarkPromoController; @synthesize delegate = _delegate; @synthesize editIndexPaths = _editIndexPaths; @synthesize editing = _editing; -@synthesize bookmarks = _bookmarks; -@synthesize loader = _loader; -@synthesize browserState = _browserState; - (instancetype)initWithLoader:(id<UrlLoader>)loader browserState:(ios::ChromeBrowserState*)browserState { - DCHECK(browserState); - self = [super initWithNibName:nil bundle:nil]; + self = [super initWithLoader:loader browserState:browserState]; if (self) { - _browserState = browserState->GetOriginalChromeBrowserState(); - _loader = loader; - - _bookmarks = ios::BookmarkModelFactory::GetForBrowserState(_browserState); _editIndexPaths = [[NSMutableArray alloc] init]; [self resetEditNodes]; @@ -272,19 +226,8 @@ } - (void)dealloc { - _folderView.delegate = nil; - - _menuView.delegate = nil; - _editViewController.delegate = nil; _folderSelector.delegate = nil; - - _panelView.delegate = nil; -} - -- (void)loadView { - CGRect frame = [[UIScreen mainScreen] bounds]; - self.view = [[UIView alloc] initWithFrame:frame]; } - (void)resetEditNodes { @@ -343,9 +286,7 @@ - (void)viewDidLoad { [super viewDidLoad]; - BookmarkNavigationBar* bar = - [[BookmarkNavigationBar alloc] initWithFrame:[self navigationBarFrame]]; - self.navigationBar = bar; + self.navigationBar.frame = [self navigationBarFrame]; [self.navigationBar setEditTarget:self action:@selector(navigationBarWantsEditing:)]; [self.navigationBar setMenuTarget:self @@ -376,27 +317,15 @@ #pragma mark - Methods duplicated from BookmarkHomeTabletNTPController. -- (void)loadWaitingView { - DCHECK(!self.waitForModelView); - DCHECK([self isViewLoaded]); - - // Present a waiting view. - BookmarkHomeWaitingView* waitingView = - [[BookmarkHomeWaitingView alloc] initWithFrame:self.view.bounds]; - self.waitForModelView = waitingView; - [self.view addSubview:self.waitForModelView]; - [self.waitForModelView startWaiting]; -} - - (void)loadBookmarkViews { + [super loadBookmarkViews]; DCHECK(self.bookmarks->loaded()); DCHECK([self isViewLoaded]); - self.panelView = - [[BookmarkPanelView alloc] initWithFrame:[self frameForPrimaryView] - menuViewWidth:kBookmarkMenuWidth]; - self.panelView.autoresizingMask = - UIViewAutoresizingFlexibleWidth | UIViewAutoresizingFlexibleHeight; + self.folderView.delegate = self; + [self.folderView setFrame:[self frameForPrimaryView]]; + + [self.panelView setFrame:[self frameForPrimaryView]]; self.panelView.delegate = self; [self.view insertSubview:self.panelView atIndex:0]; @@ -406,15 +335,8 @@ UIViewAutoresizingFlexibleWidth | UIViewAutoresizingFlexibleHeight; [self.panelView.contentView addSubview:self.contentView]; - // The user can swipe the BookmarkPanelView to show the menuView. - // Therefore, it must be created here. - self.menuView = [[BookmarkMenuView alloc] - initWithBrowserState:self.browserState - frame:self.panelView.menuView.bounds]; self.menuView.delegate = self; [self.panelView.menuView addSubview:self.menuView]; - self.menuView.autoresizingMask = - UIViewAutoresizingFlexibleWidth | UIViewAutoresizingFlexibleHeight; // Load the last primary menu item which the user had active. BookmarkMenuItem* item = nil; @@ -439,55 +361,21 @@ } } -- (void)ensureFolderViewExists { - if (self.folderView) - return; - - BookmarkCollectionView* view = [[BookmarkCollectionView alloc] - initWithBrowserState:self.browserState - frame:[self frameForPrimaryView]]; - self.folderView = view; - self.folderView.delegate = self; - [self.folderView setEditing:self.editing animated:NO]; - self.folderView.autoresizingMask = - UIViewAutoresizingFlexibleHeight | UIViewAutoresizingFlexibleWidth; -} - - (void)updatePrimaryMenuItem:(BookmarkMenuItem*)menuItem animated:(BOOL)animated { - DCHECK(menuItem.type == bookmarks::MenuItemFolder); - if ([self.primaryMenuItem isEqual:menuItem]) - return; + [super updatePrimaryMenuItem:menuItem]; // Disable editing on previous primary view before dismissing it. No need to // animate because this view is immediately removed from hierarchy. if ([[self primaryMenuItem] supportsEditing]) [self.primaryView setEditing:NO animated:NO]; - [[self primaryView] removeFromSuperview]; - self.primaryMenuItem = menuItem; - - [self ensureFolderViewExists]; - [self.folderView resetFolder:self.primaryMenuItem.folder]; - [self.folderView promoStateChangedAnimated:NO]; - UIView* primaryView = [self primaryView]; - [[self primaryView] changeOrientation:GetInterfaceOrientation()]; - [[self primaryView] setScrollsToTop:!self.scrollingMenuToTop]; - [self.contentView insertSubview:primaryView atIndex:0]; primaryView.frame = self.contentView.bounds; [self updateNavigationBarAnimated:animated orientation:GetInterfaceOrientation()]; - - [self.menuView updatePrimaryMenuItem:self.primaryMenuItem]; -} - -- (UIView<BookmarkHomePrimaryView>*)primaryView { - if (self.primaryMenuItem.type == bookmarks::MenuItemFolder) - return self.folderView; - return nil; } #pragma mark - Editing bar methods. @@ -1023,7 +911,7 @@ - (void)showMenuAnimated:(BOOL)animated { [self.menuView setScrollsToTop:YES]; [[self primaryView] setScrollsToTop:NO]; - self.scrollingMenuToTop = YES; + self.scrollToTop = YES; [self.panelView showMenuAnimated:animated]; [self updateNavigationBarAnimated:animated orientation:GetInterfaceOrientation()]; @@ -1032,7 +920,7 @@ - (void)hideMenuAnimated:(BOOL)animated updateNavigationBar:(BOOL)update { [self.menuView setScrollsToTop:NO]; [[self primaryView] setScrollsToTop:YES]; - self.scrollingMenuToTop = NO; + self.scrollToTop = NO; [self.panelView hideMenuAnimated:animated]; if (update) { UIInterfaceOrientation orient = GetInterfaceOrientation(); @@ -1053,11 +941,11 @@ if (showMenu) { [self.menuView setScrollsToTop:YES]; [[self primaryView] setScrollsToTop:NO]; - self.scrollingMenuToTop = YES; + self.scrollToTop = YES; } else { [self.menuView setScrollsToTop:NO]; [[self primaryView] setScrollsToTop:YES]; - self.scrollingMenuToTop = NO; + self.scrollToTop = NO; } if ([self shouldShowEditButtonWithMenuVisibility:showMenu])
diff --git a/ios/chrome/browser/ui/bookmarks/bookmark_home_tablet_ntp_controller.h b/ios/chrome/browser/ui/bookmarks/bookmark_home_tablet_ntp_controller.h index 5ba0323e..615bf17 100644 --- a/ios/chrome/browser/ui/bookmarks/bookmark_home_tablet_ntp_controller.h +++ b/ios/chrome/browser/ui/bookmarks/bookmark_home_tablet_ntp_controller.h
@@ -5,20 +5,15 @@ #ifndef IOS_CHROME_BROWSER_UI_BOOKMARKS_BOOKMARK_HOME_TABLET_NTP_CONTROLLER_H_ #define IOS_CHROME_BROWSER_UI_BOOKMARKS_BOOKMARK_HOME_TABLET_NTP_CONTROLLER_H_ +#import "ios/chrome/browser/ui/bookmarks/bookmark_home_view_controller.h" #import "ios/chrome/browser/ui/ntp/new_tab_page_panel_protocol.h" @protocol UrlLoader; -namespace ios { -class ChromeBrowserState; -} // namespace ios - // Navigate/edit the bookmark hierarchy on tablet, from the New Tab Page (NTP). @interface BookmarkHomeTabletNTPController - : UIViewController<NewTabPagePanelProtocol> -// Designated initializer. -- (instancetype)initWithLoader:(id<UrlLoader>)loader - browserState:(ios::ChromeBrowserState*)browserState; + : BookmarkHomeViewController<NewTabPagePanelProtocol> + @end #endif // IOS_CHROME_BROWSER_UI_BOOKMARKS_BOOKMARK_HOME_TABLET_NTP_CONTROLLER_H_
diff --git a/ios/chrome/browser/ui/bookmarks/bookmark_home_tablet_ntp_controller.mm b/ios/chrome/browser/ui/bookmarks/bookmark_home_tablet_ntp_controller.mm index e2f6e0a..f7d4eba 100644 --- a/ios/chrome/browser/ui/bookmarks/bookmark_home_tablet_ntp_controller.mm +++ b/ios/chrome/browser/ui/bookmarks/bookmark_home_tablet_ntp_controller.mm
@@ -50,30 +50,10 @@ using bookmarks::BookmarkNode; namespace { -// The width of the bookmark menu, displaying the different sections. -const CGFloat kMenuWidth = 264.0; // The margin on top to the navigation bar. const CGFloat kNavigationBarTopMargin = 8.0; } // namespace -// A simple UIView subclass to pass on relayout information to its delegate. -@protocol ContentViewDelegate<NSObject> -- (void)willLayoutSubviews; -@end - -@interface ContentView : UIView -@property(nonatomic, weak) id<ContentViewDelegate> delegate; -@end - -@implementation ContentView -@synthesize delegate = _delegate; - -- (void)layoutSubviews { - [self.delegate willLayoutSubviews]; - [super layoutSubviews]; -} -@end - @interface BookmarkHomeTabletNTPController ()< BookmarkCollectionViewDelegate, BookmarkEditViewControllerDelegate, @@ -81,12 +61,9 @@ BookmarkFolderViewControllerDelegate, BookmarkMenuViewDelegate, BookmarkModelBridgeObserver, - BookmarkPromoControllerDelegate, - ContentViewDelegate> { + BookmarkPromoControllerDelegate> { // Bridge to register for bookmark changes. std::unique_ptr<bookmarks::BookmarkModelBridge> _bridge; - ios::ChromeBrowserState* _browserState; // Weak. - __weak id<UrlLoader> _loader; // The following 2 ivars both represent the set of nodes being edited. // The set is for fast lookup. @@ -97,19 +74,12 @@ std::vector<const BookmarkNode*> _editNodesOrdered; } -@property(nonatomic, strong) BookmarkPanelView* panelView; - #pragma mark - Properties and methods akin to BookmarkHomeHandsetViewController // Whether the view controller is in editing mode. @property(nonatomic, assign) BOOL editing; // The set of edited index paths. @property(nonatomic, strong) NSMutableArray* editIndexPaths; -// The bookmark model used. -@property(nonatomic, assign, readonly) bookmarks::BookmarkModel* bookmarks; -// The user's browser state model used. -@property(nonatomic, assign, readonly) - ios::ChromeBrowserState* browserState; // from superclass. // Replaces |_editNodes| and |_editNodesOrdered| with new container objects. - (void)resetEditNodes; @@ -123,31 +93,12 @@ - (void)setEditing:(BOOL)editing animated:(BOOL)animated; #pragma mark - Properties and methods akin to BookmarkHomeHandsetViewController - -// This views holds the primary content of this controller. -@property(nonatomic, readwrite, strong) ContentView* view; - -// The possible views that can be shown from the menu. -@property(nonatomic, strong) BookmarkCollectionView* folderView; -// This view is created and used if the model is not fully loaded yet by the -// time this controller starts. -@property(nonatomic, strong) BookmarkHomeWaitingView* waitForModelView; - -// The menu with all the folders and special entries. -@property(nonatomic, strong) BookmarkMenuView* menuView; -// At any point in time, there is exactly one collection view whose view is part -// of the view hierarchy. This property determines which collection view is -// visible. Not by accident, this property also reflects the selected menu item -// in the BookmarkMenuView. -@property(nonatomic, strong) BookmarkMenuItem* primaryMenuItem; // When the view is first shown on the screen, this property represents the // cached value of the y of the content offset of the primary view. This // property is set to nil after it is used. @property(nonatomic, strong) NSNumber* cachedContentPosition; // FIXME: INACTIVE -// The navigation bar sits on top of the main content. -@property(nonatomic, strong) BookmarkNavigationBar* navigationBar; // The editing bar present when items are selected. @property(nonatomic, strong) BookmarkEditingBar* editingBar; @@ -167,31 +118,19 @@ #pragma mark Specific to this class. -// Either the menu or the primaryView can scrollToTop. -@property(nonatomic, assign) BOOL scrollToTop; - // Opens the url. - (void)loadURL:(const GURL&)url; #pragma mark View loading, laying out, and switching. -// This method is called if the view needs to be loaded and the model is not -// ready yet. -- (void)loadWaitingView; // This method should be called at most once in the life-cycle of the class. // It should be called at the soonest possible time after the view has been // loaded, and the bookmark model is loaded. - (void)loadBookmarkViews; -// If the view doesn't exist, create it. -- (void)ensureFolderViewExists; // Updates the property 'primaryMenuItem'. // Updates the UI to reflect the new state of 'primaryMenuItem'. - (void)updatePrimaryMenuItem:(BookmarkMenuItem*)menuItem animated:(BOOL)animated; -// The active collection view that corresponds to primaryMenuItem. -- (UIView<BookmarkHomePrimaryView>*)primaryView; // Returns whether the menu should be in a side panel that slides in. - (BOOL)shouldPresentMenuInSlideInPanel; -// Returns the width of the menu. -- (CGFloat)menuWidth; // Returns the leading margin of the primary view. - (CGFloat)primaryViewLeadingMargin; // Moves the menu and primary view to their correct parent views depending on @@ -273,20 +212,10 @@ @implementation BookmarkHomeTabletNTPController -@dynamic view; @synthesize editing = _editing; @synthesize editIndexPaths = _editIndexPaths; -@synthesize bookmarks = _bookmarks; - -@synthesize folderView = _folderView; -@synthesize waitForModelView = _waitForModelView; - -@synthesize menuView = _menuView; -@synthesize primaryMenuItem = _primaryMenuItem; @synthesize cachedContentPosition = _cachedContentPosition; -@synthesize navigationBar = _navigationBar; @synthesize editingBar = _editingBar; -@synthesize panelView = _panelView; @synthesize actionSheetCoordinator = _actionSheetCoordinator; @synthesize editViewController = _editViewController; @@ -294,21 +223,14 @@ @synthesize folderEditor = _folderEditor; @synthesize bookmarkPromoController = _bookmarkPromoController; -@synthesize scrollToTop = _scrollToTop; - // Property declared in NewTabPagePanelProtocol. @synthesize delegate = _delegate; - (id)initWithLoader:(id<UrlLoader>)loader browserState:(ios::ChromeBrowserState*)browserState { - self = [super init]; + self = [super initWithLoader:loader browserState:browserState]; if (self) { - DCHECK(browserState); - _browserState = browserState->GetOriginalChromeBrowserState(); - _loader = loader; - - _bookmarks = ios::BookmarkModelFactory::GetForBrowserState(_browserState); - _bridge.reset(new bookmarks::BookmarkModelBridge(self, _bookmarks)); + _bridge.reset(new bookmarks::BookmarkModelBridge(self, self.bookmarks)); _editIndexPaths = [[NSMutableArray alloc] init]; // It is important to initialize the promo controller with the browser state // passed in, as it could be incognito. @@ -320,23 +242,14 @@ } - (void)dealloc { - self.view.delegate = nil; - - _folderView.delegate = nil; - - _menuView.delegate = nil; - _editViewController.delegate = nil; _folderSelector.delegate = nil; } -- (ios::ChromeBrowserState*)browserState { - return _browserState; -} +#pragma mark - UIViewController method. -#pragma mark - ContentViewDelegate method. - -- (void)willLayoutSubviews { +- (void)viewWillLayoutSubviews { + [super viewWillLayoutSubviews]; if (![self primaryView] && ![self primaryMenuItem] && self.bookmarks->loaded()) { BookmarkMenuItem* item = nil; @@ -428,7 +341,7 @@ new_tab_page_uma::ACTION_OPENED_BOOKMARK); base::RecordAction( base::UserMetricsAction("MobileBookmarkManagerEntryOpened")); - [_loader loadURL:url + [self.loader loadURL:url referrer:web::Referrer() transition:ui::PAGE_TRANSITION_AUTO_BOOKMARK rendererInitiated:NO]; @@ -436,18 +349,6 @@ #pragma mark - Views -- (void)loadWaitingView { - DCHECK(!self.waitForModelView); - DCHECK(self.view); - - // Present a waiting view. - BookmarkHomeWaitingView* waitingView = - [[BookmarkHomeWaitingView alloc] initWithFrame:self.view.bounds]; - self.waitForModelView = waitingView; - [self.view addSubview:self.waitForModelView]; - [self.waitForModelView startWaiting]; -} - - (void)updateMenuViewLayout { LayoutRect menuLayout = LayoutRectMake(0, self.view.bounds.size.width, 0, self.menuWidth, @@ -456,17 +357,11 @@ } - (void)loadBookmarkViews { + [super loadBookmarkViews]; DCHECK(self.bookmarks->loaded()); - // Create the menu. - LayoutRect menuLayout = - LayoutRectMake(0, self.view.bounds.size.width, 0, self.menuWidth, - self.view.bounds.size.height); - self.menuView = [[BookmarkMenuView alloc] - initWithBrowserState:self.browserState - frame:LayoutRectGetRect(menuLayout)]; self.menuView.delegate = self; - self.menuView.autoresizingMask = UIViewAutoresizingFlexibleHeight; + self.folderView.delegate = self; [self moveMenuAndPrimaryViewToAdequateParent]; @@ -495,38 +390,12 @@ } } -- (void)ensureFolderViewExists { - if (self.folderView) - return; - - BookmarkCollectionView* view = - [[BookmarkCollectionView alloc] initWithBrowserState:self.browserState - frame:CGRectZero]; - self.folderView = view; - self.folderView.delegate = self; - [self.folderView setEditing:self.editing animated:NO]; - self.folderView.autoresizingMask = - UIViewAutoresizingFlexibleHeight | UIViewAutoresizingFlexibleWidth; -} - - (void)updatePrimaryMenuItem:(BookmarkMenuItem*)menuItem animated:(BOOL)animated { - DCHECK(menuItem.type == bookmarks::MenuItemFolder); - if ([self.primaryMenuItem isEqual:menuItem]) - return; - if (![self.view superview]) return; - [[self primaryView] removeFromSuperview]; - self.primaryMenuItem = menuItem; - - [self ensureFolderViewExists]; - [self.folderView resetFolder:self.primaryMenuItem.folder]; - [self.folderView promoStateChangedAnimated:NO]; - - [[self primaryView] changeOrientation:GetInterfaceOrientation()]; - [[self primaryView] setScrollsToTop:self.scrollToTop]; + [super updatePrimaryMenuItem:menuItem]; [self moveMenuAndPrimaryViewToAdequateParent]; @@ -536,25 +405,13 @@ self.navigationBar.hidden = NO; [self updateNavigationBarAnimated:animated orientation:GetInterfaceOrientation()]; - - [self.menuView updatePrimaryMenuItem:self.primaryMenuItem]; [self updateEditBarShadow]; } -- (UIView<BookmarkHomePrimaryView>*)primaryView { - if (self.primaryMenuItem.type == bookmarks::MenuItemFolder) - return self.folderView; - return nil; -} - - (BOOL)shouldPresentMenuInSlideInPanel { return IsCompactTablet(); } -- (CGFloat)menuWidth { - return kMenuWidth; -} - - (CGFloat)primaryViewLeadingMargin { if ([self shouldPresentMenuInSlideInPanel]) return 0; @@ -572,12 +429,7 @@ [primaryView removeFromSuperview]; if ([self shouldPresentMenuInSlideInPanel]) { - // Create (if needed), and add the panelView to the view hierarchy. - if (!self.panelView) { - self.panelView = - [[BookmarkPanelView alloc] initWithFrame:CGRectZero - menuViewWidth:[self menuWidth]]; - } + // Add the panelView to the view hierarchy. [self.view addSubview:self.panelView]; CGSize size = self.view.bounds.size; CGFloat navBarHeight = CGRectGetHeight([self navigationBarFrame]); @@ -1159,12 +1011,12 @@ } - (void)wasShown { - [_folderView wasShown]; + [self.folderView wasShown]; } - (void)wasHidden { [self cachePosition]; - [_folderView wasHidden]; + [self.folderView wasHidden]; } - (void)dismissModals { @@ -1184,17 +1036,9 @@ [[self primaryView] setScrollsToTop:self.scrollToTop]; } -- (void)loadView { - self.view = [[ContentView alloc] initWithFrame:CGRectZero]; -} - - (void)viewDidLoad { [super viewDidLoad]; - self.view.delegate = self; self.view.backgroundColor = bookmark_utils_ios::mainBackgroundColor(); - BookmarkNavigationBar* bar = - [[BookmarkNavigationBar alloc] initWithFrame:CGRectZero]; - self.navigationBar = bar; self.navigationBar.autoresizingMask = UIViewAutoresizingFlexibleWidth; [self.navigationBar setEditTarget:self
diff --git a/ios/chrome/browser/ui/bookmarks/bookmark_home_view_controller.h b/ios/chrome/browser/ui/bookmarks/bookmark_home_view_controller.h new file mode 100644 index 0000000..9f29228 --- /dev/null +++ b/ios/chrome/browser/ui/bookmarks/bookmark_home_view_controller.h
@@ -0,0 +1,97 @@ +// Copyright 2017 The Chromium Authors. All rights reserved. +// Use of this source code is governed by a BSD-style license that can be +// found in the LICENSE file. + +#ifndef IOS_CHROME_BROWSER_UI_BOOKMARKS_HOME_VIEW_CONTROLLER_H_ +#define IOS_CHROME_BROWSER_UI_BOOKMARKS_HOME_VIEW_CONTROLLER_H_ + +#import <UIKit/UIKit.h> + +#include <set> +#include <vector> + +@protocol UrlLoader; +@protocol BookmarkHomePrimaryView; + +namespace ios { +class ChromeBrowserState; +} // namespace ios + +namespace bookmarks { +class BookmarkModel; +} // namespace bookmarks + +@class BookmarkCollectionView; +@class BookmarkPanelView; +@class BookmarkMenuView; +@class BookmarkHomeWaitingView; +@class BookmarkNavigationBar; +@class BookmarkMenuItem; + +// Class to navigate the bookmark hierarchy, needs subclassing for tablet / +// handset case. +@interface BookmarkHomeViewController : UIViewController + +- (instancetype)initWithNibName:(NSString*)nibNameOrNil + bundle:(NSBundle*)nibBundleOrNil NS_UNAVAILABLE; +- (instancetype)initWithCoder:(NSCoder*)aDecoder NS_UNAVAILABLE; +- (instancetype)init NS_UNAVAILABLE; +- (instancetype)initWithLoader:(id<UrlLoader>)loader + browserState:(ios::ChromeBrowserState*)browserState + NS_DESIGNATED_INITIALIZER; + +// The bookmark model used. +@property(nonatomic, assign, readonly) bookmarks::BookmarkModel* bookmarks; + +// The user's browser state model used. +@property(nonatomic, assign, readonly) ios::ChromeBrowserState* browserState; + +// The main view showing all the bookmarks. +@property(nonatomic, strong, readonly) BookmarkCollectionView* folderView; + +// Object to load URLs. +@property(nonatomic, weak, readonly) id<UrlLoader> loader; + +// The menu with all the folders. +@property(nonatomic, strong, readonly) BookmarkMenuView* menuView; + +// The navigation bar sits on top of the main content. +@property(nonatomic, strong, readonly) BookmarkNavigationBar* navigationBar; + +// At any point in time, there is exactly one collection view whose view is part +// of the view hierarchy. This property determines what data is visible in the +// collection view. +@property(nonatomic, strong, readonly) BookmarkMenuItem* primaryMenuItem; + +// This view holds a content view, and a menu view. +@property(nonatomic, strong, readonly) BookmarkPanelView* panelView; + +// Either the menu or the primaryView can scrollToTop. +@property(nonatomic, assign) BOOL scrollToTop; + +// This view is created and used if the model is not fully loaded yet by the +// time this controller starts. Property is readwrite, so that subclasses can +// set it to nil, once finished with it. +@property(nonatomic, strong) BookmarkHomeWaitingView* waitForModelView; + +// This method should be called at most once in the life-cycle of the class. +// It should be called at the soonest possible time after the view has been +// loaded, and the bookmark model is loaded. +- (void)loadBookmarkViews; + +// Returns the width of the menu. +- (CGFloat)menuWidth; + +// This method is called if the view needs to be loaded and the model is not +// ready yet. +- (void)loadWaitingView; + +// Updates the property 'primaryMenuItem'. +// Updates the UI to reflect the new state of 'primaryMenuItem'. +- (void)updatePrimaryMenuItem:(BookmarkMenuItem*)menuItem; + +// The active collection view that corresponds to primaryMenuItem. +- (UIView<BookmarkHomePrimaryView>*)primaryView; +@end + +#endif // IOS_CHROME_BROWSER_UI_BOOKMARKS_HOME_VIEW_CONTROLLER_H_
diff --git a/ios/chrome/browser/ui/bookmarks/bookmark_home_view_controller.mm b/ios/chrome/browser/ui/bookmarks/bookmark_home_view_controller.mm new file mode 100644 index 0000000..4ebcdcc --- /dev/null +++ b/ios/chrome/browser/ui/bookmarks/bookmark_home_view_controller.mm
@@ -0,0 +1,153 @@ +// Copyright 2017 The Chromium Authors. All rights reserved. +// Use of this source code is governed by a BSD-style license that can be +// found in the LICENSE file. + +#import "ios/chrome/browser/ui/bookmarks/bookmark_home_view_controller.h" + +#include "components/bookmarks/browser/bookmark_model.h" +#include "ios/chrome/browser/bookmarks/bookmark_model_factory.h" +#include "ios/chrome/browser/browser_state/chrome_browser_state.h" +#import "ios/chrome/browser/ui/bookmarks/bars/bookmark_navigation_bar.h" +#import "ios/chrome/browser/ui/bookmarks/bookmark_collection_view.h" +#import "ios/chrome/browser/ui/bookmarks/bookmark_home_primary_view.h" +#import "ios/chrome/browser/ui/bookmarks/bookmark_home_waiting_view.h" +#import "ios/chrome/browser/ui/bookmarks/bookmark_menu_item.h" +#import "ios/chrome/browser/ui/bookmarks/bookmark_menu_view.h" +#import "ios/chrome/browser/ui/bookmarks/bookmark_panel_view.h" +#import "ios/chrome/browser/ui/rtl_geometry.h" +#import "ios/chrome/browser/ui/ui_util.h" +#import "ios/chrome/browser/ui/uikit_ui_util.h" +#import "ios/chrome/browser/ui/url_loader.h" + +using bookmarks::BookmarkNode; + +namespace { +// The width of the bookmark menu, displaying the different sections. +const CGFloat kMenuWidth = 264; +} + +@interface BookmarkHomeViewController () +// Read / write declaration of read only properties. +@property(nonatomic, assign) bookmarks::BookmarkModel* bookmarks; +@property(nonatomic, assign) ios::ChromeBrowserState* browserState; +@property(nonatomic, strong) BookmarkCollectionView* folderView; +@property(nonatomic, weak) id<UrlLoader> loader; +@property(nonatomic, strong) BookmarkMenuView* menuView; +@property(nonatomic, strong) BookmarkNavigationBar* navigationBar; +@property(nonatomic, strong) BookmarkPanelView* panelView; +@property(nonatomic, strong) BookmarkMenuItem* primaryMenuItem; +@end + +@implementation BookmarkHomeViewController + +@synthesize bookmarks = _bookmarks; +@synthesize browserState = _browserState; +@synthesize folderView = _folderView; +@synthesize loader = _loader; +@synthesize menuView = _menuView; +@synthesize navigationBar = _navigationBar; +@synthesize panelView = _panelView; +@synthesize primaryMenuItem = _primaryMenuItem; +@synthesize waitForModelView = _waitForModelView; +@synthesize scrollToTop = _scrollToTop; + +#if !defined(__has_feature) || !__has_feature(objc_arc) +#error "This file requires ARC support." +#endif + +#pragma mark - Initializer + +- (instancetype)initWithLoader:(id<UrlLoader>)loader + browserState:(ios::ChromeBrowserState*)browserState { + DCHECK(browserState); + self = [super initWithNibName:nil bundle:nil]; + if (self) { + _browserState = browserState->GetOriginalChromeBrowserState(); + _loader = loader; + + _bookmarks = ios::BookmarkModelFactory::GetForBrowserState(browserState); + } + return self; +} + +#pragma mark - UIViewController + +- (void)viewDidLoad { + [super viewDidLoad]; + self.navigationBar = [[BookmarkNavigationBar alloc] initWithFrame:CGRectZero]; +} + +#pragma mark - Public + +- (void)loadBookmarkViews { + LayoutRect menuLayout = + LayoutRectMake(0, self.view.bounds.size.width, 0, self.menuWidth, + self.view.bounds.size.height); + + // Create menu view. + self.menuView = [[BookmarkMenuView alloc] + initWithBrowserState:_browserState + frame:LayoutRectGetRect(menuLayout)]; + self.menuView.autoresizingMask = + UIViewAutoresizingFlexibleWidth | UIViewAutoresizingFlexibleHeight; + + // Create panel view. + self.panelView = [[BookmarkPanelView alloc] initWithFrame:CGRectZero + menuViewWidth:self.menuWidth]; + self.panelView.autoresizingMask = + UIViewAutoresizingFlexibleWidth | UIViewAutoresizingFlexibleHeight; + + // Create folder view. + BookmarkCollectionView* view = + [[BookmarkCollectionView alloc] initWithBrowserState:self.browserState + frame:CGRectZero]; + self.folderView = view; + [self.folderView setEditing:self.editing animated:NO]; + self.folderView.autoresizingMask = + UIViewAutoresizingFlexibleHeight | UIViewAutoresizingFlexibleWidth; +} + +- (void)updatePrimaryMenuItem:(BookmarkMenuItem*)menuItem { + DCHECK(menuItem.type == bookmarks::MenuItemFolder); + if ([self.primaryMenuItem isEqual:menuItem]) + return; + + // TODO(crbug.com/705339): Folder view is the only primary view now, + // hence we don't need to remove primary view anymore. + // Simplify this code that removes primary view and adds it back + // in subclasses, once the addition code moves here. + [[self primaryView] removeFromSuperview]; + self.primaryMenuItem = menuItem; + + [self.folderView resetFolder:self.primaryMenuItem.folder]; + [self.folderView promoStateChangedAnimated:NO]; + + [[self primaryView] changeOrientation:GetInterfaceOrientation()]; + [[self primaryView] setScrollsToTop:!self.scrollToTop]; + + [self.menuView updatePrimaryMenuItem:self.primaryMenuItem]; +} + +- (UIView<BookmarkHomePrimaryView>*)primaryView { + if (self.primaryMenuItem.type == bookmarks::MenuItemFolder) + return self.folderView; + return nil; +} + +- (void)loadWaitingView { + DCHECK(!self.waitForModelView); + DCHECK(self.view); + + // Present a waiting view. + BookmarkHomeWaitingView* waitingView = + [[BookmarkHomeWaitingView alloc] initWithFrame:self.view.bounds]; + self.waitForModelView = waitingView; + [self.view addSubview:self.waitForModelView]; + [self.waitForModelView startWaiting]; +} + +- (CGFloat)menuWidth { + return kMenuWidth; +} + +@end
diff --git a/ios/chrome/browser/ui/bookmarks/bookmark_home_view_controller_unittest.mm b/ios/chrome/browser/ui/bookmarks/bookmark_home_view_controller_unittest.mm new file mode 100644 index 0000000..039f704 --- /dev/null +++ b/ios/chrome/browser/ui/bookmarks/bookmark_home_view_controller_unittest.mm
@@ -0,0 +1,51 @@ +// Copyright 2017 The Chromium Authors. All rights reserved. +// Use of this source code is governed by a BSD-style license that can be +// found in the LICENSE file. + +#import "ios/chrome/browser/ui/bookmarks/bookmark_home_view_controller.h" + +#import "ios/chrome/browser/browser_state/test_chrome_browser_state.h" +#include "ios/chrome/browser/ui/bookmarks/bookmark_ios_unittest.h" + +namespace { + +using BookmarkHomeViewControllerTest = BookmarkIOSUnitTest; + +TEST_F(BookmarkHomeViewControllerTest, LoadBookmarks) { + @autoreleasepool { + BookmarkHomeViewController* controller = [[BookmarkHomeViewController alloc] + initWithLoader:nil + browserState:chrome_browser_state_.get()]; + + EXPECT_EQ(nil, controller.menuView); + EXPECT_EQ(nil, controller.panelView); + EXPECT_EQ(nil, controller.folderView); + + [controller view]; + [controller loadBookmarkViews]; + + EXPECT_NE(nil, controller); + EXPECT_NE(nil, controller.navigationBar); + EXPECT_NE(nil, controller.menuView); + EXPECT_NE(nil, controller.panelView); + EXPECT_NE(nil, controller.folderView); + } +} + +TEST_F(BookmarkHomeViewControllerTest, LoadWaitingView) { + @autoreleasepool { + BookmarkHomeViewController* controller = [[BookmarkHomeViewController alloc] + initWithLoader:nil + browserState:chrome_browser_state_.get()]; + + EXPECT_TRUE(controller.waitForModelView == nil); + + [controller view]; + [controller loadWaitingView]; + + EXPECT_TRUE(controller != nil); + EXPECT_TRUE(controller.waitForModelView != nil); + } +} + +} // namespace
diff --git a/ios/chrome/browser/ui/browser_view_controller.mm b/ios/chrome/browser/ui/browser_view_controller.mm index e2389e0..c39ee90 100644 --- a/ios/chrome/browser/ui/browser_view_controller.mm +++ b/ios/chrome/browser/ui/browser_view_controller.mm
@@ -4044,6 +4044,21 @@ } } +- (void)sharePage { + ShareToData* data = activity_services::ShareToDataForTab([_model currentTab]); + if (data) + [self sharePageWithData:data]; +} + +- (void)bookmarkPage { + [self initializeBookmarkInteractionController]; + [_bookmarkInteractionController + presentBookmarkForTab:[_model currentTab] + currentlyBookmarked:_toolbarModelIOS->IsCurrentTabBookmarkedByUser() + inView:[_toolbarController bookmarkButtonView] + originRect:[_toolbarController bookmarkButtonAnchorRect]]; +} + #pragma mark - Command Handling - (IBAction)chromeExecuteCommand:(id)sender { @@ -4054,14 +4069,6 @@ Tab* currentTab = [_model currentTab]; switch (command) { - case IDC_BOOKMARK_PAGE: - [self initializeBookmarkInteractionController]; - [_bookmarkInteractionController - presentBookmarkForTab:[_model currentTab] - currentlyBookmarked:_toolbarModelIOS->IsCurrentTabBookmarkedByUser() - inView:[_toolbarController bookmarkButtonView] - originRect:[_toolbarController bookmarkButtonAnchorRect]]; - break; case IDC_FIND: [self initFindBarForTab]; break; @@ -4122,9 +4129,6 @@ [self.dispatcher reload]; break; } - case IDC_SHARE_PAGE: - [self sharePage]; - break; case IDC_SHOW_MAIL_COMPOSER: [self showMailComposer:sender]; break; @@ -4248,11 +4252,6 @@ } } -- (void)sharePage { - ShareToData* data = activity_services::ShareToDataForTab([_model currentTab]); - if (data) - [self sharePageWithData:data]; -} - (void)sharePageWithData:(ShareToData*)data { id<ShareProtocol> controller = [_dependencyFactory shareControllerInstance];
diff --git a/ios/chrome/browser/ui/browser_view_controller_unittest.mm b/ios/chrome/browser/ui/browser_view_controller_unittest.mm index 72f2e73..917d8fd 100644 --- a/ios/chrome/browser/ui/browser_view_controller_unittest.mm +++ b/ios/chrome/browser/ui/browser_view_controller_unittest.mm
@@ -33,6 +33,7 @@ #import "ios/chrome/browser/ui/browser_view_controller.h" #import "ios/chrome/browser/ui/browser_view_controller_dependency_factory.h" #import "ios/chrome/browser/ui/browser_view_controller_testing.h" +#import "ios/chrome/browser/ui/commands/browser_commands.h" #import "ios/chrome/browser/ui/commands/generic_chrome_command.h" #include "ios/chrome/browser/ui/commands/ios_command_ids.h" #import "ios/chrome/browser/ui/ntp/new_tab_page_controller.h" @@ -429,7 +430,7 @@ } // Verifies that BVC invokes -shareURL on ShareController with the correct -// parameters in response to the IDC_SHARE_PAGE command. +// parameters in response to the -sharePage command. TEST_F(BrowserViewControllerTest, TestSharePageCommandHandling) { GURL expectedUrl("http://www.testurl.net"); NSString* expectedTitle = @"title"; @@ -472,12 +473,12 @@ shareToDelegate:bvc_ fromRect:[bvc_ testing_shareButtonAnchorRect] inView:[OCMArg any]]; - [bvc_ chromeExecuteCommand:GetCommandWithTag(IDC_SHARE_PAGE)]; + [bvc_.dispatcher sharePage]; EXPECT_OCMOCK_VERIFY(shareControllerMock); } // Verifies that BVC does not invoke -shareURL on ShareController in response -// to the IDC_SHARE_PAGE command if tab is in the process of being closed. +// to the |-sharePage| command if tab is in the process of being closed. TEST_F(BrowserViewControllerTest, TestSharePageWhenClosing) { GURL expectedUrl("http://www.testurl.net"); NSString* expectedTitle = @"title"; @@ -498,7 +499,7 @@ shareToDelegate:bvc_ fromRect:[bvc_ testing_shareButtonAnchorRect] inView:[OCMArg any]]; - [bvc_ chromeExecuteCommand:GetCommandWithTag(IDC_SHARE_PAGE)]; + [bvc_.dispatcher sharePage]; EXPECT_OCMOCK_VERIFY(shareControllerMock); }
diff --git a/ios/chrome/browser/ui/chrome_web_view_factory.mm b/ios/chrome/browser/ui/chrome_web_view_factory.mm index c53d324..cbd7be9 100644 --- a/ios/chrome/browser/ui/chrome_web_view_factory.mm +++ b/ios/chrome/browser/ui/chrome_web_view_factory.mm
@@ -4,6 +4,8 @@ #import "ios/chrome/browser/ui/chrome_web_view_factory.h" +#include <stdint.h> + #include "base/base64.h" #include "base/logging.h" #include "ios/chrome/browser/browser_state/chrome_browser_state.h" @@ -52,7 +54,7 @@ scoped_refptr<web::RequestTrackerImpl> g_request_tracker; // Empty callback used by ClearCookiesOnIOThread below. -void DoNothing(int n) {} +void DoNothing(uint32_t n) {} // Clears the cookies. void ClearCookiesOnIOThread(net::URLRequestContextGetter* context_getter,
diff --git a/ios/chrome/browser/ui/commands/browser_commands.h b/ios/chrome/browser/ui/commands/browser_commands.h index 3c97d78b..07ed08b 100644 --- a/ios/chrome/browser/ui/commands/browser_commands.h +++ b/ios/chrome/browser/ui/commands/browser_commands.h
@@ -24,6 +24,12 @@ // Reloads the current web page - (void)reload; +// Shows the share sheet for the current page. +- (void)sharePage; + +// Bookmarks the current page. +- (void)bookmarkPage; + @end #endif // IOS_CHROME_BROWSER_UI_COMMANDS_BROWSER_COMMANDS_H_
diff --git a/ios/chrome/browser/ui/commands/ios_command_ids.h b/ios/chrome/browser/ui/commands/ios_command_ids.h index ad25284..23e66f2 100644 --- a/ios/chrome/browser/ui/commands/ios_command_ids.h +++ b/ios/chrome/browser/ui/commands/ios_command_ids.h
@@ -16,7 +16,6 @@ #define IDC_RELOAD 33002 #define IDC_NEW_TAB 34014 #define IDC_FULLSCREEN 34030 -#define IDC_BOOKMARK_PAGE 35000 #define IDC_VIEW_SOURCE 35002 #define IDC_PRINT 35003 #define IDC_FIND 37000 @@ -52,7 +51,6 @@ #define IDC_CLEAR_BROWSING_DATA_IOS 40924 #define IDC_SHOW_MAIL_COMPOSER 40926 #define IDC_RESET_ALL_WEBVIEWS 40928 -#define IDC_SHARE_PAGE 40929 #define IDC_BACK_FORWARD_IN_TAB_HISTORY 40930 #define IDC_SHOW_PRIVACY_SETTINGS 40934 #define IDC_HIDE_SETTINGS_AND_SHOW_PRIVACY_SETTINGS 40935
diff --git a/ios/chrome/browser/ui/content_suggestions/content_suggestions_collection_updater.h b/ios/chrome/browser/ui/content_suggestions/content_suggestions_collection_updater.h index 6d9d043..cedd920 100644 --- a/ios/chrome/browser/ui/content_suggestions/content_suggestions_collection_updater.h +++ b/ios/chrome/browser/ui/content_suggestions/content_suggestions_collection_updater.h
@@ -76,7 +76,8 @@ // header containing the fake omnibox and the logo. - (BOOL)isHeaderSection:(NSInteger)section; -// Updates the number of Most Visited tiles shown for the |size|. +// Updates the number of Most Visited tiles shown for the |size| on the model +// only. The collection needs to be updated separately. - (void)updateMostVisitedForSize:(CGSize)size; // Dismisses the |item| from the model. Does not change the UI.
diff --git a/ios/chrome/browser/ui/content_suggestions/content_suggestions_collection_updater.mm b/ios/chrome/browser/ui/content_suggestions/content_suggestions_collection_updater.mm index 8b33943..1f6b8a3 100644 --- a/ios/chrome/browser/ui/content_suggestions/content_suggestions_collection_updater.mm +++ b/ios/chrome/browser/ui/content_suggestions/content_suggestions_collection_updater.mm
@@ -446,24 +446,22 @@ if (currentCount == newCount) return; - // If the animations are enabled, the items are added then the rotation - // animation is triggered, creating a weird sequenced animation. - [UIView setAnimationsEnabled:NO]; if (currentCount > newCount) { for (NSInteger i = newCount; i < currentCount; i++) { - NSIndexPath* itemToRemove = - [NSIndexPath indexPathForItem:newCount inSection:mostVisitedSection]; - [self.collectionViewController dismissEntryAtIndexPath:itemToRemove]; + [self.collectionViewController.collectionViewModel + removeItemWithType:ItemTypeMostVisited + fromSectionWithIdentifier:SectionIdentifierMostVisited + atIndex:newCount]; } } else { - NSMutableArray* itemsToBeAdded = [NSMutableArray array]; for (NSInteger i = currentCount; i < newCount; i++) { - [itemsToBeAdded addObject:mostVisited[i]]; + CSCollectionViewItem* item = mostVisited[i]; + item.type = ItemTypeMostVisited; + [self.collectionViewController.collectionViewModel + addItem:item + toSectionWithIdentifier:SectionIdentifierMostVisited]; } - [self.collectionViewController addSuggestions:itemsToBeAdded - toSectionInfo:mostVisitedSectionInfo]; } - [UIView setAnimationsEnabled:YES]; } - (void)dismissItem:(CSCollectionViewItem*)item {
diff --git a/ios/chrome/browser/ui/content_suggestions/content_suggestions_view_controller.mm b/ios/chrome/browser/ui/content_suggestions/content_suggestions_view_controller.mm index 597a0d6..95ba674 100644 --- a/ios/chrome/browser/ui/content_suggestions/content_suggestions_view_controller.mm +++ b/ios/chrome/browser/ui/content_suggestions/content_suggestions_view_controller.mm
@@ -204,7 +204,7 @@ UIEdgeInsetsMake(0, self.cardStyleMargin, 0, self.cardStyleMargin); } [self.collectionUpdater updateMostVisitedForSize:size]; - [self.collectionView.collectionViewLayout invalidateLayout]; + [self.collectionView reloadData]; } - (void)willTransitionToTraitCollection:(UITraitCollection*)newCollection @@ -212,6 +212,10 @@ (id<UIViewControllerTransitionCoordinator>)coordinator { [super willTransitionToTraitCollection:newCollection withTransitionCoordinator:coordinator]; + // Invalidating the layout after changing the cellStyle/contentInset results + // in the layout not being updated. Do it before to have it taken into + // account. + [self.collectionView.collectionViewLayout invalidateLayout]; if (ShouldCellsBeFullWidth(newCollection)) { self.collectionView.contentInset = UIEdgeInsetsZero; self.styler.cellStyle = MDCCollectionViewCellStyleGrouped; @@ -220,7 +224,6 @@ UIEdgeInsetsMake(0, self.cardStyleMargin, 0, self.cardStyleMargin); self.styler.cellStyle = MDCCollectionViewCellStyleCard; } - [self.collectionView.collectionViewLayout invalidateLayout]; } #pragma mark - UICollectionViewDelegate
diff --git a/ios/chrome/browser/ui/external_url_error_page_egtest.mm b/ios/chrome/browser/ui/external_url_error_page_egtest.mm index 6397978..26f250b 100644 --- a/ios/chrome/browser/ui/external_url_error_page_egtest.mm +++ b/ios/chrome/browser/ui/external_url_error_page_egtest.mm
@@ -24,8 +24,6 @@ using chrome_test_util::OmniboxText; using chrome_test_util::TapWebViewElementWithId; -using chrome_test_util::WebViewNotContainingText; - using web::test::HttpServer; // Tests display of error pages for bad URLs. @@ -49,8 +47,7 @@ assertWithMatcher:grey_notNil()]; const std::string kError = l10n_util::GetStringUTF8(IDS_ERRORPAGES_HEADING_NOT_AVAILABLE); - [[EarlGrey selectElementWithMatcher:WebViewNotContainingText(kError)] - assertWithMatcher:grey_notNil()]; + [ChromeEarlGrey waitForWebViewNotContainingText:kError]; } #pragma mark - tests
diff --git a/ios/chrome/browser/ui/key_commands_provider.mm b/ios/chrome/browser/ui/key_commands_provider.mm index 06d711d4..1a387aa 100644 --- a/ios/chrome/browser/ui/key_commands_provider.mm +++ b/ios/chrome/browser/ui/key_commands_provider.mm
@@ -129,7 +129,7 @@ title:l10n_util::GetNSStringWithFixup( IDS_IOS_KEYBOARD_BOOKMARK_THIS_PAGE) action:^{ - execute(IDC_BOOKMARK_PAGE); + [weakDispatcher bookmarkPage]; }], [UIKeyCommand cr_keyCommandWithInput:@"f" modifierFlags:UIKeyModifierCommand
diff --git a/ios/chrome/browser/ui/settings/save_passwords_collection_view_controller.mm b/ios/chrome/browser/ui/settings/save_passwords_collection_view_controller.mm index d1a678d4..ea70274a 100644 --- a/ios/chrome/browser/ui/settings/save_passwords_collection_view_controller.mm +++ b/ios/chrome/browser/ui/settings/save_passwords_collection_view_controller.mm
@@ -65,18 +65,6 @@ ItemTypeBlacklisted, // This is a repeated item type. }; -// TODO(crbug.com/669538): This function should be removed after original -// version of GetHumanReadableOrigin will be moved to affiliation_utils. -std::string GetHumanReadableOriginCopy( - const autofill::PasswordForm& password_form) { - password_manager::FacetURI facet_uri = - password_manager::FacetURI::FromPotentiallyInvalidSpec( - password_form.signon_realm); - if (facet_uri.IsValidAndroidFacetURI()) - return facet_uri.scheme() + "://" + facet_uri.android_package_name(); - return base::UTF16ToUTF8(url_formatter::FormatUrl(password_form.origin)); -} - } // namespace namespace password_manager { @@ -274,7 +262,7 @@ SavedFormContentItem* passwordItem = [[SavedFormContentItem alloc] initWithType:ItemTypeSavedPassword]; passwordItem.text = - base::SysUTF8ToNSString(GetHumanReadableOriginCopy(*form)); + base::SysUTF8ToNSString(password_manager::GetHumanReadableOrigin(*form)); passwordItem.detailText = base::SysUTF16ToNSString(form->username_value); if (experimental_flags::IsViewCopyPasswordsEnabled()) { passwordItem.accessibilityTraits |= UIAccessibilityTraitButton; @@ -289,7 +277,7 @@ BlacklistedFormContentItem* passwordItem = [[BlacklistedFormContentItem alloc] initWithType:ItemTypeBlacklisted]; passwordItem.text = - base::SysUTF8ToNSString(GetHumanReadableOriginCopy(*form)); + base::SysUTF8ToNSString(password_manager::GetHumanReadableOrigin(*form)); return passwordItem; } @@ -460,8 +448,8 @@ autofill::PasswordForm* form = savedForms_[indexPath.item].get(); NSString* username = base::SysUTF16ToNSString(form->username_value); NSString* password = base::SysUTF16ToNSString(form->password_value); - NSString* origin = - base::SysUTF8ToNSString(GetHumanReadableOriginCopy(*form)); + NSString* origin = base::SysUTF8ToNSString( + password_manager::GetHumanReadableOrigin(*form)); UIViewController* controller = [[PasswordDetailsCollectionViewController alloc] initWithPasswordForm:*form
diff --git a/ios/chrome/browser/ui/toolbar/toolbar_controller.mm b/ios/chrome/browser/ui/toolbar/toolbar_controller.mm index 9b526c8..3921ae95 100644 --- a/ios/chrome/browser/ui/toolbar/toolbar_controller.mm +++ b/ios/chrome/browser/ui/toolbar/toolbar_controller.mm
@@ -16,7 +16,7 @@ #include "base/metrics/user_metrics_action.h" #import "ios/chrome/browser/ui/animation_util.h" #import "ios/chrome/browser/ui/commands/UIKit+ChromeExecuteCommand.h" -#import "ios/chrome/browser/ui/commands/generic_chrome_command.h" +#import "ios/chrome/browser/ui/commands/browser_commands.h" #include "ios/chrome/browser/ui/commands/ios_command_ids.h" #import "ios/chrome/browser/ui/fullscreen_controller.h" #import "ios/chrome/browser/ui/image_util.h" @@ -302,7 +302,6 @@ if (idiom == IPAD_IDIOM) { CGRect shareButtonFrame = LayoutRectGetRect(kShareMenuButtonFrame); shareButton_ = [[UIButton alloc] initWithFrame:shareButtonFrame]; - [shareButton_ setTag:IDC_SHARE_PAGE]; [shareButton_ setAutoresizingMask:UIViewAutoresizingFlexibleLeadingMargin() | UIViewAutoresizingFlexibleBottomMargin]; @@ -311,6 +310,9 @@ forInitialState:UIControlStateNormal hasDisabledImage:YES synchronously:NO]; + [shareButton_ addTarget:self.dispatcher + action:@selector(sharePage) + forControlEvents:UIControlEventTouchUpInside]; SetA11yLabelAndUiAutomationName(shareButton_, IDS_IOS_TOOLS_MENU_SHARE, kToolbarShareButtonIdentifier); [view_ addSubview:shareButton_];
diff --git a/ios/chrome/browser/ui/toolbar/web_toolbar_controller.mm b/ios/chrome/browser/ui/toolbar/web_toolbar_controller.mm index a067d08..3b4039b 100644 --- a/ios/chrome/browser/ui/toolbar/web_toolbar_controller.mm +++ b/ios/chrome/browser/ui/toolbar/web_toolbar_controller.mm
@@ -508,7 +508,6 @@ // Assign tags before calling -setUpButton, since only buttons with tags // have -chromeExecuteCommand added as a target. - [_starButton setTag:IDC_BOOKMARK_PAGE]; [_voiceSearchButton setTag:IDC_VOICE_SEARCH]; [_webToolbar addSubview:_voiceSearchButton]; @@ -544,6 +543,9 @@ [_reloadButton addTarget:self.dispatcher action:@selector(reload) forControlEvents:UIControlEventTouchUpInside]; + [_starButton addTarget:self.dispatcher + action:@selector(bookmarkPage) + forControlEvents:UIControlEventTouchUpInside]; } else { [_forwardButton setAlpha:0.0]; }
diff --git a/ios/chrome/browser/ui/tools_menu/tools_menu_constants.h b/ios/chrome/browser/ui/tools_menu/tools_menu_constants.h index b7904b6..7fada93 100644 --- a/ios/chrome/browser/ui/tools_menu/tools_menu_constants.h +++ b/ios/chrome/browser/ui/tools_menu/tools_menu_constants.h
@@ -43,6 +43,9 @@ // All of these values must be < 0. TOOLS_STOP_ITEM = -1, TOOLS_RELOAD_ITEM = -2, + TOOLS_BOOKMARK_ITEM = -3, + TOOLS_BOOKMARK_EDIT = -4, + TOOLS_SHARE_ITEM = -5, }; #endif // IOS_CHROME_BROWSER_UI_TOOLS_MENU_TOOLS_MENU_CONSTANTS_H_
diff --git a/ios/chrome/browser/ui/tools_menu/tools_menu_view_controller.mm b/ios/chrome/browser/ui/tools_menu/tools_menu_view_controller.mm index 3928cfaa..5806909 100644 --- a/ios/chrome/browser/ui/tools_menu/tools_menu_view_controller.mm +++ b/ios/chrome/browser/ui/tools_menu/tools_menu_view_controller.mm
@@ -194,7 +194,6 @@ - (void)setCanShowShareMenu:(BOOL)enabled { ToolsMenuViewToolsCell* toolsCell = [self toolsCell]; [[toolsCell shareButton] setEnabled:enabled]; - [self setItemEnabled:enabled withTag:IDC_SHARE_PAGE]; } - (UIButton*)toolsButton { @@ -473,6 +472,12 @@ [toolsCell.reloadButton removeTarget:self.dispatcher action:@selector(reload) forControlEvents:UIControlEventTouchUpInside]; + [toolsCell.starButton removeTarget:self.dispatcher + action:@selector(bookmarkPage) + forControlEvents:UIControlEventTouchUpInside]; + [toolsCell.starredButton removeTarget:self.dispatcher + action:@selector(bookmarkPage) + forControlEvents:UIControlEventTouchUpInside]; } #pragma mark - Button event handling @@ -480,20 +485,12 @@ - (void)buttonPressed:(id)sender { int commandId = [sender tag]; DCHECK(commandId); - // The bookmark command workaround is only needed for metrics; remap it - // to the real command for the dispatch. This is very hacky, but it will go - // away soon. See crbug/228521 - DCHECK([sender respondsToSelector:@selector(setTag:)]); - if (commandId == IDC_TEMP_EDIT_BOOKMARK) - [sender setTag:IDC_BOOKMARK_PAGE]; // Do nothing when tapping the tools menu a second time. // Do not use -chromeExecuteCommand: for tags < 0 -- that is, items that have // been refactored to use the dispatcher. if (commandId != IDC_SHOW_TOOLS_MENU && commandId > 0) { [self chromeExecuteCommand:sender]; } - if (commandId == IDC_TEMP_EDIT_BOOKMARK) - [sender setTag:IDC_TEMP_EDIT_BOOKMARK]; // Do any metrics logging for the command, and then close the menu. [_delegate commandWasSelected:commandId]; @@ -598,6 +595,12 @@ [cell.reloadButton addTarget:self.dispatcher action:@selector(reload) forControlEvents:UIControlEventTouchUpInside]; + [cell.starButton addTarget:self.dispatcher + action:@selector(bookmarkPage) + forControlEvents:UIControlEventTouchUpInside]; + [cell.starredButton addTarget:self.dispatcher + action:@selector(bookmarkPage) + forControlEvents:UIControlEventTouchUpInside]; for (UIButton* button in [cell allButtons]) { [button addTarget:self action:@selector(buttonPressed:)
diff --git a/ios/chrome/browser/ui/tools_menu/tools_menu_view_tools_cell.mm b/ios/chrome/browser/ui/tools_menu/tools_menu_view_tools_cell.mm index 7d4c069..9935171a 100644 --- a/ios/chrome/browser/ui/tools_menu/tools_menu_view_tools_cell.mm +++ b/ios/chrome/browser/ui/tools_menu/tools_menu_view_tools_cell.mm
@@ -12,12 +12,6 @@ #import "ios/chrome/browser/ui/uikit_ui_util.h" #include "ios/chrome/grit/ios_strings.h" -// TODO(crbug.com/228521): Remove this once the new command/metric handling is -// implemented. This is a temporary workaround to allow metrics recording to -// distinguish the action. The value used is in the dynamic range (< -// IDC_MinimumLabelValue) to avoid collisions. -#define IDC_TEMP_EDIT_BOOKMARK 3900 - #if !defined(__has_feature) || !__has_feature(objc_arc) #error "This file requires ARC support." #endif @@ -53,13 +47,13 @@ int star[2][3] = TOOLBAR_IDR_TWO_STATE(STAR); _starButton = [self newButtonForImageIds:star - commandID:IDC_BOOKMARK_PAGE + commandID:TOOLS_BOOKMARK_ITEM accessibilityLabelID:IDS_BOOKMARK_ADD_EDITOR_TITLE automationName:@"Add Bookmark"]; int star_pressed[2][3] = TOOLBAR_IDR_ONE_STATE(STAR_PRESSED); _starredButton = [self newButtonForImageIds:star_pressed - commandID:IDC_TEMP_EDIT_BOOKMARK + commandID:TOOLS_BOOKMARK_EDIT accessibilityLabelID:IDS_IOS_TOOLS_MENU_EDIT_BOOKMARK automationName:@"Edit Bookmark"]; @@ -78,7 +72,7 @@ int share[2][3] = TOOLBAR_IDR_THREE_STATE(SHARE); _shareButton = [self newButtonForImageIds:share - commandID:IDC_SHARE_PAGE + commandID:TOOLS_SHARE_ITEM accessibilityLabelID:IDS_IOS_TOOLS_MENU_SHARE automationName:@"Stop"]; int tools[2][3] = TOOLBAR_IDR_ONE_STATE(TOOLS_PRESSED);
diff --git a/ios/chrome/browser/ui/tools_menu/tools_popup_controller.mm b/ios/chrome/browser/ui/tools_menu/tools_popup_controller.mm index 02d7b2f6..b5b339f 100644 --- a/ios/chrome/browser/ui/tools_menu/tools_popup_controller.mm +++ b/ios/chrome/browser/ui/tools_menu/tools_popup_controller.mm
@@ -163,10 +163,10 @@ - (void)commandWasSelected:(int)commandID { // Record the corresponding metric. switch (commandID) { - case IDC_TEMP_EDIT_BOOKMARK: + case TOOLS_BOOKMARK_EDIT: base::RecordAction(UserMetricsAction("MobileMenuEditBookmark")); break; - case IDC_BOOKMARK_PAGE: + case TOOLS_BOOKMARK_ITEM: base::RecordAction(UserMetricsAction("MobileMenuAddToBookmarks")); break; case IDC_CLOSE_ALL_TABS: @@ -193,7 +193,7 @@ case TOOLS_RELOAD_ITEM: base::RecordAction(UserMetricsAction("MobileMenuReload")); break; - case IDC_SHARE_PAGE: + case TOOLS_SHARE_ITEM: base::RecordAction(UserMetricsAction("MobileMenuShare")); break; case IDC_REQUEST_DESKTOP_SITE:
diff --git a/ios/chrome/browser/ui/webui/BUILD.gn b/ios/chrome/browser/ui/webui/BUILD.gn index 48b462d..fcda20bd 100644 --- a/ios/chrome/browser/ui/webui/BUILD.gn +++ b/ios/chrome/browser/ui/webui/BUILD.gn
@@ -16,8 +16,6 @@ "ntp_tiles_internals_ui.h", "physical_web_ui.cc", "physical_web_ui.h", - "popular_sites_internals_ui.cc", - "popular_sites_internals_ui.h", "terms_ui.h", "terms_ui.mm", "version_handler.cc",
diff --git a/ios/chrome/browser/ui/webui/chrome_web_ui_ios_controller_factory.mm b/ios/chrome/browser/ui/webui/chrome_web_ui_ios_controller_factory.mm index 7153cfb1..510a5ab 100644 --- a/ios/chrome/browser/ui/webui/chrome_web_ui_ios_controller_factory.mm +++ b/ios/chrome/browser/ui/webui/chrome_web_ui_ios_controller_factory.mm
@@ -17,7 +17,6 @@ #include "ios/chrome/browser/ui/webui/ntp_tiles_internals_ui.h" #include "ios/chrome/browser/ui/webui/omaha_ui.h" #include "ios/chrome/browser/ui/webui/physical_web_ui.h" -#include "ios/chrome/browser/ui/webui/popular_sites_internals_ui.h" #include "ios/chrome/browser/ui/webui/signin_internals_ui_ios.h" #include "ios/chrome/browser/ui/webui/sync_internals/sync_internals_ui.h" #include "ios/chrome/browser/ui/webui/terms_ui.h" @@ -80,8 +79,6 @@ if (url_host == kChromeUIPhysicalWebHost) return &NewWebUIIOS<PhysicalWebUI>; } - if (url_host == kChromeUIPopularSitesInternalsHost) - return &NewWebUIIOS<PopularSitesInternalsUI>; if (url_host == kChromeUISignInInternalsHost) return &NewWebUIIOS<SignInInternalsUIIOS>; if (url_host == kChromeUISyncInternalsHost)
diff --git a/ios/chrome/browser/ui/webui/popular_sites_internals_ui.cc b/ios/chrome/browser/ui/webui/popular_sites_internals_ui.cc deleted file mode 100644 index d06f078..0000000 --- a/ios/chrome/browser/ui/webui/popular_sites_internals_ui.cc +++ /dev/null
@@ -1,96 +0,0 @@ -// Copyright 2016 The Chromium Authors. All rights reserved. -// Use of this source code is governed by a BSD-style license that can be -// found in the LICENSE file. - -#include "ios/chrome/browser/ui/webui/popular_sites_internals_ui.h" - -#include "base/memory/ptr_util.h" -#include "components/grit/components_resources.h" -#include "components/ntp_tiles/popular_sites.h" -#include "components/ntp_tiles/webui/popular_sites_internals_message_handler.h" -#include "components/ntp_tiles/webui/popular_sites_internals_message_handler_client.h" -#include "ios/chrome/browser/browser_state/chrome_browser_state.h" -#include "ios/chrome/browser/chrome_url_constants.h" -#include "ios/chrome/browser/ntp_tiles/ios_popular_sites_factory.h" -#include "ios/web/public/web_thread.h" -#include "ios/web/public/web_ui_ios_data_source.h" -#include "ios/web/public/webui/web_ui_ios.h" -#include "ios/web/public/webui/web_ui_ios_message_handler.h" - -namespace { - -// The implementation for the chrome://popular-sites-internals page. -class IOSPopularSitesInternalsMessageHandlerBridge - : public web::WebUIIOSMessageHandler, - public ntp_tiles::PopularSitesInternalsMessageHandlerClient { - public: - IOSPopularSitesInternalsMessageHandlerBridge() : handler_(this) {} - - private: - // web::WebUIIOSMessageHandler: - void RegisterMessages() override; - - // ntp_tiles::PopularSitesInternalsMessageHandlerClient - std::unique_ptr<ntp_tiles::PopularSites> MakePopularSites() override; - PrefService* GetPrefs() override; - void RegisterMessageCallback( - const std::string& message, - const base::Callback<void(const base::ListValue*)>& callback) override; - void CallJavascriptFunctionVector( - const std::string& name, - const std::vector<const base::Value*>& values) override; - - ntp_tiles::PopularSitesInternalsMessageHandler handler_; - - DISALLOW_COPY_AND_ASSIGN(IOSPopularSitesInternalsMessageHandlerBridge); -}; - -void IOSPopularSitesInternalsMessageHandlerBridge::RegisterMessages() { - handler_.RegisterMessages(); -} - -std::unique_ptr<ntp_tiles::PopularSites> -IOSPopularSitesInternalsMessageHandlerBridge::MakePopularSites() { - return IOSPopularSitesFactory::NewForBrowserState( - ios::ChromeBrowserState::FromWebUIIOS(web_ui())); -} - -PrefService* IOSPopularSitesInternalsMessageHandlerBridge::GetPrefs() { - return ios::ChromeBrowserState::FromWebUIIOS(web_ui())->GetPrefs(); -} - -void IOSPopularSitesInternalsMessageHandlerBridge::RegisterMessageCallback( - const std::string& message, - const base::Callback<void(const base::ListValue*)>& callback) { - web_ui()->RegisterMessageCallback(message, callback); -} - -void IOSPopularSitesInternalsMessageHandlerBridge::CallJavascriptFunctionVector( - const std::string& name, - const std::vector<const base::Value*>& values) { - web_ui()->CallJavascriptFunction(name, values); -} - -} // namespace - -web::WebUIIOSDataSource* CreatePopularSitesInternalsHTMLSource() { - web::WebUIIOSDataSource* source = - web::WebUIIOSDataSource::Create(kChromeUIPopularSitesInternalsHost); - - source->AddResourcePath("popular_sites_internals.js", - IDR_POPULAR_SITES_INTERNALS_JS); - source->AddResourcePath("popular_sites_internals.css", - IDR_POPULAR_SITES_INTERNALS_CSS); - source->SetDefaultResource(IDR_POPULAR_SITES_INTERNALS_HTML); - return source; -} - -PopularSitesInternalsUI::PopularSitesInternalsUI(web::WebUIIOS* web_ui) - : web::WebUIIOSController(web_ui) { - web::WebUIIOSDataSource::Add(ios::ChromeBrowserState::FromWebUIIOS(web_ui), - CreatePopularSitesInternalsHTMLSource()); - web_ui->AddMessageHandler( - base::MakeUnique<IOSPopularSitesInternalsMessageHandlerBridge>()); -} - -PopularSitesInternalsUI::~PopularSitesInternalsUI() {}
diff --git a/ios/chrome/browser/ui/webui/popular_sites_internals_ui.h b/ios/chrome/browser/ui/webui/popular_sites_internals_ui.h deleted file mode 100644 index a36f295..0000000 --- a/ios/chrome/browser/ui/webui/popular_sites_internals_ui.h +++ /dev/null
@@ -1,23 +0,0 @@ -// Copyright 2016 The Chromium Authors. All rights reserved. -// Use of this source code is governed by a BSD-style license that can be -// found in the LICENSE file. - -#ifndef IOS_CHROME_BROWSER_UI_WEBUI_POPULAR_SITES_INTERNALS_UI_H_ -#define IOS_CHROME_BROWSER_UI_WEBUI_POPULAR_SITES_INTERNALS_UI_H_ - -#include <string> - -#include "base/macros.h" -#include "ios/web/public/webui/web_ui_ios_controller.h" - -// The WebUI handler for chrome://physical-web. -class PopularSitesInternalsUI : public web::WebUIIOSController { - public: - explicit PopularSitesInternalsUI(web::WebUIIOS* web_ui); - ~PopularSitesInternalsUI() override; - - private: - DISALLOW_COPY_AND_ASSIGN(PopularSitesInternalsUI); -}; - -#endif // IOS_CHROME_BROWSER_UI_WEBUI_POPULAR_SITES_INTERNALS_UI_H_
diff --git a/ios/chrome/browser/web/navigation_egtest.mm b/ios/chrome/browser/web/navigation_egtest.mm index 084f3de..8ba939e 100644 --- a/ios/chrome/browser/web/navigation_egtest.mm +++ b/ios/chrome/browser/web/navigation_egtest.mm
@@ -471,11 +471,7 @@ std::string hashChangeContent = "FAIL_loadUrlHashChange"; [self addHashChangeListenerWithContent:hashChangeContent]; [ChromeEarlGrey loadURL:hashChangedWithHistoryURL]; - // TODO(crbug.com/714157): Remove matcher that waits. - [[EarlGrey - selectElementWithMatcher:chrome_test_util::WebViewNotContainingText( - hashChangeContent)] - assertWithMatcher:grey_notNil()]; + [ChromeEarlGrey waitForWebViewNotContainingText:hashChangeContent]; } // Loads a URL and replaces its location, then updates its location.hash
diff --git a/ios/chrome/browser/web/push_and_replace_state_navigation_egtest.mm b/ios/chrome/browser/web/push_and_replace_state_navigation_egtest.mm index 2b3870b..b67f2a08 100644 --- a/ios/chrome/browser/web/push_and_replace_state_navigation_egtest.mm +++ b/ios/chrome/browser/web/push_and_replace_state_navigation_egtest.mm
@@ -329,10 +329,7 @@ if (pageLoaded) { [ChromeEarlGrey waitForWebViewContainingText:"onload"]; } else { - id<GREYMatcher> pageLoadedMatcher = - chrome_test_util::WebViewNotContainingText("onload"); - [[EarlGrey selectElementWithMatcher:pageLoadedMatcher] - assertWithMatcher:grey_notNil()]; + [ChromeEarlGrey waitForWebViewNotContainingText:"onload"]; } if (status != NULL) {
diff --git a/ios/chrome/test/earl_grey/chrome_matchers.h b/ios/chrome/test/earl_grey/chrome_matchers.h index 6c4fb37..ec003bd 100644 --- a/ios/chrome/test/earl_grey/chrome_matchers.h +++ b/ios/chrome/test/earl_grey/chrome_matchers.h
@@ -31,9 +31,6 @@ // accessibility trait UIAccessibilityTraitStaticText. id<GREYMatcher> StaticTextWithAccessibilityLabel(NSString* label); -// Returns matcher for webview not containing |text|. -id<GREYMatcher> WebViewNotContainingText(std::string text); - // Returns matcher for WKWebView containing a blocked |image_id|. When blocked, // the image element will be smaller than actual image. id<GREYMatcher> WebViewContainingBlockedImage(std::string image_id);
diff --git a/ios/chrome/test/earl_grey/chrome_matchers.mm b/ios/chrome/test/earl_grey/chrome_matchers.mm index 3a951c9..67beef5 100644 --- a/ios/chrome/test/earl_grey/chrome_matchers.mm +++ b/ios/chrome/test/earl_grey/chrome_matchers.mm
@@ -95,10 +95,6 @@ l10n_util::GetNSStringWithFixup(message_id)); } -id<GREYMatcher> WebViewNotContainingText(std::string text) { - return web::WebViewNotContainingText(std::move(text), GetCurrentWebState()); -} - id<GREYMatcher> WebViewContainingBlockedImage(std::string image_id) { return web::WebViewContainingBlockedImage( std::move(image_id), chrome_test_util::GetCurrentWebState());
diff --git a/ios/clean/chrome/DEPS b/ios/clean/chrome/DEPS index e6eb2ee..d9539617 100644 --- a/ios/clean/chrome/DEPS +++ b/ios/clean/chrome/DEPS
@@ -3,6 +3,7 @@ "+ui/base", "+ios/chrome", "+ios/shared", + "+ios/testing/perf", "+ios/third_party", "+ios/web",
diff --git a/ios/clean/chrome/app/BUILD.gn b/ios/clean/chrome/app/BUILD.gn index 21655ec..e5d414ba 100644 --- a/ios/clean/chrome/app/BUILD.gn +++ b/ios/clean/chrome/app/BUILD.gn
@@ -85,6 +85,7 @@ "//ios/chrome/browser:browser_internal", "//ios/chrome/browser/crash_report", "//ios/chrome/common", + "//ios/testing/perf:startup", "//third_party/google_toolbox_for_mac", ] @@ -104,6 +105,7 @@ deps = [ "//base", "//ios/shared/chrome/browser/ui/coordinators", + "//ios/testing/perf:startup", ] } @@ -118,5 +120,6 @@ deps = [ ":application_state", "//ios/clean/chrome/app/steps", + "//ios/testing/perf:startup", ] }
diff --git a/ios/clean/chrome/app/app_delegate.mm b/ios/clean/chrome/app/app_delegate.mm index d83998a..1325e27 100644 --- a/ios/clean/chrome/app/app_delegate.mm +++ b/ios/clean/chrome/app/app_delegate.mm
@@ -9,6 +9,7 @@ #import "ios/clean/chrome/app/steps/launch_to_basic.h" #import "ios/clean/chrome/app/steps/launch_to_foreground.h" #import "ios/clean/chrome/app/steps/root_coordinator+application_step.h" +#import "ios/testing/perf/startupLoggers.h" #if !defined(__has_feature) || !__has_feature(objc_arc) #error "This file requires ARC support." @@ -26,6 +27,7 @@ - (BOOL)application:(UIApplication*)application didFinishLaunchingWithOptions:(NSDictionary*)launchOptions { + startup_loggers::RegisterAppDidFinishLaunchingTime(); self.applicationState = [[ApplicationState alloc] init]; self.applicationState.application = application; [self configureApplicationState]; @@ -35,6 +37,7 @@ } - (void)applicationDidBecomeActive:(UIApplication*)application { + startup_loggers::RegisterAppDidBecomeActiveTime(); } - (void)applicationWillResignActive:(UIApplication*)application {
diff --git a/ios/clean/chrome/app/main.mm b/ios/clean/chrome/app/main.mm index 7b81862..aa03753 100644 --- a/ios/clean/chrome/app/main.mm +++ b/ios/clean/chrome/app/main.mm
@@ -12,6 +12,7 @@ #include "ios/chrome/browser/crash_report/crash_keys.h" #include "ios/chrome/common/channel_info.h" #include "ios/clean/chrome/app/app_delegate.h" +#include "ios/testing/perf/startupLoggers.h" #if !defined(__has_feature) || !__has_feature(objc_arc) #error "This file requires ARC support." @@ -36,6 +37,7 @@ base::AtExitManager at_exit; IOSChromeMain::InitStartTime(); + startup_loggers::RegisterAppStartTime(); // Pre-launch actions are in their own autorelease pool so they get cleaned // up before the main app starts.
diff --git a/ios/clean/chrome/browser/ui/tab_collection/BUILD.gn b/ios/clean/chrome/browser/ui/tab_collection/BUILD.gn index 6239acd..e9bb6bd 100644 --- a/ios/clean/chrome/browser/ui/tab_collection/BUILD.gn +++ b/ios/clean/chrome/browser/ui/tab_collection/BUILD.gn
@@ -30,6 +30,7 @@ deps = [ "//base", "//ios/chrome/app/theme:theme_grit", + "//ios/chrome/browser/snapshots", "//ios/chrome/browser/ui", "//ios/chrome/browser/ui/tab_switcher", "//ios/clean/chrome/browser/ui/commands", @@ -40,6 +41,7 @@ source_set("unit_tests") { sources = [ "tab_collection_mediator_unittest.mm", + "tab_collection_tab_cell_unittest.mm", "tab_collection_view_controller_unittest.mm", ] deps = [ @@ -47,6 +49,8 @@ ":tab_collection_ui", "//base", "//base/test:test_support", + "//ios/chrome/browser/snapshots", + "//ios/chrome/browser/ui/tab_switcher", "//ios/chrome/browser/web", "//ios/chrome/browser/web_state_list", "//ios/chrome/browser/web_state_list:test_support", @@ -54,6 +58,7 @@ "//ios/web/public/test/fakes", "//testing/gtest", "//third_party/ocmock", + "//ui/base:test_support", "//url:url", ] configs += [ "//build/config/compiler:enable_arc" ]
diff --git a/ios/clean/chrome/browser/ui/tab_collection/tab_collection_tab_cell.h b/ios/clean/chrome/browser/ui/tab_collection/tab_collection_tab_cell.h index ed919d5..ad34a1b 100644 --- a/ios/clean/chrome/browser/ui/tab_collection/tab_collection_tab_cell.h +++ b/ios/clean/chrome/browser/ui/tab_collection/tab_collection_tab_cell.h
@@ -5,10 +5,9 @@ #ifndef IOS_CLEAN_CHROME_BROWSER_UI_TAB_COLLECTION_TAB_COLLECTION_TAB_CELL_H_ #define IOS_CLEAN_CHROME_BROWSER_UI_TAB_COLLECTION_TAB_COLLECTION_TAB_CELL_H_ -#import <UIKit/UIKit.h> - #import "ios/chrome/browser/ui/tab_switcher/tab_switcher_panel_cell.h" +@class SnapshotCache; @class TabCollectionItem; // Cell represents a tab for use in the tab collection. It has a title, favicon, @@ -16,7 +15,8 @@ // highlight in the tintColor. // PLACEHOLDER: Create custom implemementation rather than subclassing. @interface TabCollectionTabCell : TabSwitcherLocalSessionCell -@property(nonatomic, strong) TabCollectionItem* item; +- (void)configureCell:(TabCollectionItem*)item + snapshotCache:(SnapshotCache*)snapshotCache; @end #endif // IOS_CLEAN_CHROME_BROWSER_UI_TAB_COLLECTION_TAB_COLLECTION_TAB_CELL_H_
diff --git a/ios/clean/chrome/browser/ui/tab_collection/tab_collection_tab_cell.mm b/ios/clean/chrome/browser/ui/tab_collection/tab_collection_tab_cell.mm index f9c7914..2367e1c4 100644 --- a/ios/clean/chrome/browser/ui/tab_collection/tab_collection_tab_cell.mm +++ b/ios/clean/chrome/browser/ui/tab_collection/tab_collection_tab_cell.mm
@@ -4,6 +4,7 @@ #import "ios/clean/chrome/browser/ui/tab_collection/tab_collection_tab_cell.h" +#import "ios/chrome/browser/snapshots/snapshot_cache.h" #import "ios/chrome/browser/ui/tab_switcher/tab_switcher_button.h" #import "ios/chrome/browser/ui/uikit_ui_util.h" #include "ios/chrome/grit/ios_theme_resources.h" @@ -20,6 +21,7 @@ } @interface TabCollectionTabCell () +@property(nonatomic, strong) TabCollectionItem* item; @property(nonatomic, strong) UILabel* titleLabel; @property(nonatomic, strong) UIImageView* favicon; @property(nonatomic, strong) TabSwitcherButton* snapshotButton; @@ -38,19 +40,38 @@ return self; } -#pragma mark - Properties +#pragma mark - Cell lifecycle -- (void)setItem:(TabCollectionItem*)item { +- (void)prepareForReuse { + [super prepareForReuse]; + self.item = nil; +} + +#pragma mark - Public methods + +- (void)configureCell:(TabCollectionItem*)item + snapshotCache:(SnapshotCache*)snapshotCache { DCHECK(item); - _item = item; + self.item = item; self.titleLabel.text = item.title; self.snapshotButton.accessibilityIdentifier = [NSString stringWithFormat:@"%@_button", item.title]; self.contentView.accessibilityLabel = item.title; self.favicon.image = NativeImage(IDR_IOS_OMNIBOX_HTTP); + __weak TabCollectionTabCell* weakSelf = self; + [snapshotCache + retrieveImageForSessionID:self.item.tabID + callback:^(UIImage* snapshot) { + // PLACEHOLDER: This operation will be cancellable. + if ([weakSelf.item.tabID isEqualToString:item.tabID]) { + [weakSelf.snapshotButton + setImage:snapshot + forState:UIControlStateNormal]; + } + }]; } -#pragma mark - Private +#pragma mark - Private methods - (void)setupSelectedBackgroundView { self.selectedBackgroundView = [[UIView alloc] init];
diff --git a/ios/clean/chrome/browser/ui/tab_collection/tab_collection_tab_cell_unittest.mm b/ios/clean/chrome/browser/ui/tab_collection/tab_collection_tab_cell_unittest.mm new file mode 100644 index 0000000..23605ab --- /dev/null +++ b/ios/clean/chrome/browser/ui/tab_collection/tab_collection_tab_cell_unittest.mm
@@ -0,0 +1,104 @@ +// Copyright 2017 The Chromium Authors. All rights reserved. +// Use of this source code is governed by a BSD-style license that can be +// found in the LICENSE file. + +#import "ios/clean/chrome/browser/ui/tab_collection/tab_collection_tab_cell.h" + +#import <UIKit/UIKit.h> + +#include "base/test/ios/wait_util.h" +#import "ios/chrome/browser/snapshots/snapshot_cache.h" +#import "ios/chrome/browser/ui/tab_switcher/tab_switcher_button.h" +#import "ios/clean/chrome/browser/ui/tab_collection/tab_collection_item.h" +#include "testing/gtest/include/gtest/gtest.h" +#import "testing/gtest_mac.h" +#include "testing/platform_test.h" +#import "third_party/ocmock/OCMock/OCMock.h" +#include "third_party/ocmock/gtest_support.h" +#include "ui/base/test/ios/ui_image_test_utils.h" + +#if !defined(__has_feature) || !__has_feature(objc_arc) +#error "This file requires ARC support." +#endif + +@interface TestTabCell : TabCollectionTabCell +@property(nonatomic) UILabel* titleLabel; +@property(nonatomic) TabSwitcherButton* snapshotButton; +@end + +@implementation TestTabCell +@dynamic titleLabel; +@dynamic snapshotButton; +@end + +class TabCollectionTabCellTest : public PlatformTest { + public: + TabCollectionTabCellTest() { + cell_ = [[TestTabCell alloc] init]; + snapshotCache_ = OCMClassMock([SnapshotCache class]); + item_ = [[TabCollectionItem alloc] init]; + item_.tabID = @"1234"; + item_.title = @"Title"; + snapshot_ = ui::test::uiimage_utils::UIImageWithSizeAndSolidColor( + CGSizeMake(30, 40), [UIColor blueColor]); + } + ~TabCollectionTabCellTest() override {} + + protected: + TestTabCell* cell_; + id snapshotCache_; + TabCollectionItem* item_; + UIImage* snapshot_; +}; + +// Tests that -configureCell updates the title. +TEST_F(TabCollectionTabCellTest, TestConfigureTitle) { + EXPECT_EQ(nil, cell_.titleLabel.text); + [cell_ configureCell:item_ snapshotCache:snapshotCache_]; + EXPECT_NSEQ(@"Title", cell_.titleLabel.text); +} + +// Tests that -configureCell: does not change the cell's snapshot if the +// snapshotCache does not contain the image. +TEST_F(TabCollectionTabCellTest, TestSnapshotMissing) { + OCMStub([snapshotCache_ retrieveImageForSessionID:[OCMArg any] + callback:[OCMArg any]]) + .andDo(^(NSInvocation* invocation) { + void (^callback)(UIImage* image); + [invocation getArgument:&callback atIndex:3]; + callback(nil); + }); + [cell_ configureCell:item_ snapshotCache:snapshotCache_]; + EXPECT_EQ(nil, [cell_.snapshotButton imageForState:UIControlStateNormal]); +} + +// Tests that -configureCell: updates the cell's snapshot from the cache. +TEST_F(TabCollectionTabCellTest, TestSnapshotUpdated) { + OCMStub([snapshotCache_ retrieveImageForSessionID:[OCMArg any] + callback:[OCMArg any]]) + .andDo(^(NSInvocation* invocation) { + void (^callback)(UIImage* image); + [invocation getArgument:&callback atIndex:3]; + callback(snapshot_); + }); + [cell_ configureCell:item_ snapshotCache:snapshotCache_]; + UIImage* cellImage = + [cell_.snapshotButton imageForState:UIControlStateNormal]; + EXPECT_TRUE(ui::test::uiimage_utils::UIImagesAreEqual(snapshot_, cellImage)); +} + +// Tests that asynchronous snapshot retrieval does not set the image after +// -prepareForReuse. +TEST_F(TabCollectionTabCellTest, TestPrepareForReuse) { + OCMStub([snapshotCache_ retrieveImageForSessionID:[OCMArg any] + callback:[OCMArg any]]) + .andDo(^(NSInvocation* invocation) { + void (^callback)(UIImage* image); + [invocation getArgument:&callback atIndex:3]; + // -prepareForReuse is called before the callback. + [cell_ prepareForReuse]; + callback(snapshot_); + }); + [cell_ configureCell:item_ snapshotCache:snapshotCache_]; + EXPECT_EQ(nil, [cell_.snapshotButton imageForState:UIControlStateNormal]); +}
diff --git a/ios/clean/chrome/browser/ui/tab_collection/tab_collection_view_controller.h b/ios/clean/chrome/browser/ui/tab_collection/tab_collection_view_controller.h index 907f4b99..643b890 100644 --- a/ios/clean/chrome/browser/ui/tab_collection/tab_collection_view_controller.h +++ b/ios/clean/chrome/browser/ui/tab_collection/tab_collection_view_controller.h
@@ -9,6 +9,8 @@ #import "ios/clean/chrome/browser/ui/tab_collection/tab_collection_consumer.h" +@class SnapshotCache; + // Controller for a scrolling view displaying square cells that represent // the user's open tabs. @interface TabCollectionViewController @@ -18,6 +20,8 @@ // Model for collection view. @property(nonatomic, strong, readonly) NSMutableArray<TabCollectionItem*>* items; +// Cache used to retrieve snapshot images for tab cells. +@property(nonatomic, weak) SnapshotCache* snapshotCache; @end #endif // IOS_CLEAN_CHROME_BROWSER_UI_TAB_COLLECTION_TAB_COLLECTION_VIEW_CONTROLLER_H_
diff --git a/ios/clean/chrome/browser/ui/tab_collection/tab_collection_view_controller.mm b/ios/clean/chrome/browser/ui/tab_collection/tab_collection_view_controller.mm index dba8b4c..87b9107 100644 --- a/ios/clean/chrome/browser/ui/tab_collection/tab_collection_view_controller.mm +++ b/ios/clean/chrome/browser/ui/tab_collection/tab_collection_view_controller.mm
@@ -28,6 +28,7 @@ @synthesize tabs = _tabs; @synthesize items = _items; @synthesize selectedIndex = _selectedIndex; +@synthesize snapshotCache = _snapshotCache; #pragma mark - UIViewController @@ -118,7 +119,7 @@ [cell setSessionType:TabSwitcherSessionType::REGULAR_SESSION]; DCHECK_LE(indexPath.item, INT_MAX); int index = static_cast<int>(indexPath.item); - cell.item = self.items[index]; + [cell configureCell:self.items[index] snapshotCache:self.snapshotCache]; return cell; } @@ -133,7 +134,7 @@ #pragma mark - SessionCellDelegate - (TabSwitcherCache*)tabSwitcherCache { - // PLACEHOLDER: return image cache. + // PLACEHOLDER: SnapshotCache will be passed into the cell. return nil; } @@ -186,13 +187,14 @@ } - (void)replaceItemAtIndex:(int)index withItem:(TabCollectionItem*)item { + DCHECK(item); DCHECK_GE(index, 0); DCHECK_LT(static_cast<NSUInteger>(index), self.items.count); self.items[index] = item; TabCollectionTabCell* cell = base::mac::ObjCCastStrict<TabCollectionTabCell>( [self.tabs cellForItemAtIndexPath:[NSIndexPath indexPathForItem:index inSection:0]]); - cell.item = self.items[index]; + [cell configureCell:self.items[index] snapshotCache:self.snapshotCache]; } - (void)populateItems:(NSArray<TabCollectionItem*>*)items
diff --git a/ios/clean/chrome/browser/ui/tab_grid/BUILD.gn b/ios/clean/chrome/browser/ui/tab_grid/BUILD.gn index dffab41..6dce052d 100644 --- a/ios/clean/chrome/browser/ui/tab_grid/BUILD.gn +++ b/ios/clean/chrome/browser/ui/tab_grid/BUILD.gn
@@ -16,6 +16,7 @@ ":tab_grid_ui", "//base", "//ios/chrome/browser/browser_state", + "//ios/chrome/browser/snapshots", "//ios/chrome/browser/web_state_list", "//ios/clean/chrome/browser", "//ios/clean/chrome/browser/ui/commands",
diff --git a/ios/clean/chrome/browser/ui/tab_grid/tab_grid_coordinator.mm b/ios/clean/chrome/browser/ui/tab_grid/tab_grid_coordinator.mm index 1049789..26e1b554 100644 --- a/ios/clean/chrome/browser/ui/tab_grid/tab_grid_coordinator.mm +++ b/ios/clean/chrome/browser/ui/tab_grid/tab_grid_coordinator.mm
@@ -9,6 +9,7 @@ #include "base/mac/foundation_util.h" #include "base/strings/sys_string_conversions.h" #include "ios/chrome/browser/browser_state/chrome_browser_state.h" +#import "ios/chrome/browser/snapshots/snapshot_cache_factory.h" #import "ios/chrome/browser/web_state_list/web_state_list.h" #import "ios/clean/chrome/browser/ui/commands/context_menu_commands.h" #import "ios/clean/chrome/browser/ui/commands/settings_commands.h" @@ -43,6 +44,7 @@ @property(nonatomic, weak) TabCoordinator* activeTabCoordinator; @property(nonatomic, readonly) WebStateList& webStateList; @property(nonatomic, strong) TabGridMediator* mediator; +@property(nonatomic, readonly) SnapshotCache* snapshotCache; @end @implementation TabGridCoordinator @@ -58,6 +60,11 @@ return self.browser->web_state_list(); } +- (SnapshotCache*)snapshotCache { + return SnapshotCacheFactory::GetForBrowserState( + self.browser->browser_state()); +} + #pragma mark - BrowserCoordinator - (void)start { @@ -71,6 +78,7 @@ self.viewController = [[TabGridViewController alloc] init]; self.viewController.dispatcher = static_cast<id>(self.browser->dispatcher()); + self.viewController.snapshotCache = self.snapshotCache; self.mediator.consumer = self.viewController;
diff --git a/ios/clean/chrome/test/BUILD.gn b/ios/clean/chrome/test/BUILD.gn index f4a6f6aa..446e0c6c 100644 --- a/ios/clean/chrome/test/BUILD.gn +++ b/ios/clean/chrome/test/BUILD.gn
@@ -9,6 +9,7 @@ testonly = true deps = [ ":ios_clean_chrome_unittests", + "//ios/clean/chrome/test/perf:ios_clean_skeleton_perf_egtests", ] }
diff --git a/ios/clean/chrome/test/perf/BUILD.gn b/ios/clean/chrome/test/perf/BUILD.gn new file mode 100644 index 0000000..2be9ae9 --- /dev/null +++ b/ios/clean/chrome/test/perf/BUILD.gn
@@ -0,0 +1,80 @@ +# Copyright 2017 The Chromium Authors. All rights reserved. +# Use of this source code is governed by a BSD-style license that can be +# found in the LICENSE file. + +import("//build/config/ios/rules.gni") +import("//build/config/mac/base_rules.gni") +import("//build/mac/tweak_info_plist.gni") +import("//ios/build/chrome_build.gni") +import("//ios/third_party/earl_grey/ios_eg_test.gni") + +tweak_info_plist("info_plist") { + info_plists = [ + "//ios/chrome/app/resources/Info.plist", + "//ios/chrome/app/resources/ChromeAddition+Info.plist", + ] + if (ios_chrome_info_plist_additions != []) { + info_plists += ios_chrome_info_plist_additions + } + if (ios_encryption_export_compliance_code != "") { + info_plists += + [ "//ios/chrome/app/resources/EncryptionExportCompliance+Info.plist" ] + } + args = [ + "--breakpad=$breakpad_enabled_as_int", + "--branding=$chromium_short_name", + ] +} + +compile_plist("entitlements") { + format = "xml1" + plist_templates = [ "resources/Chrome.entitlements" ] + if (ios_chrome_entitlements_additions != []) { + # TODO(crbug.com/707206): Allow additional entitlements once the CSChromium + # mobile provisioning profiles have been updated. + # plist_templates += ios_chrome_entitlements_additions + } + substitutions = [ "IOS_BUNDLE_ID_PREFIX=$ios_app_bundle_id_prefix" ] + output_name = "$target_gen_dir/$chromium_short_name.entitlements" +} + +ios_eg_test("ios_clean_skeleton_perf_egtests") { + entitlements_target = ":entitlements" + info_plist_target = ":info_plist" + + sources = [ + "startup_egtests.mm", + ] + + deps = [ + "//ios/clean/chrome/app:main", + "//ios/testing/perf:startup", + ] + + bundle_deps = [ "//ios/chrome/app/resources" ] + + configs += [ "//build/config/compiler:enable_arc" ] + + extra_substitutions = [ + "CHROMIUM_HANDOFF_ID=$chromium_handoff_id", + "CHROMIUM_SHORT_NAME=$target_name", + "CHROMIUM_URL_SCHEME_1=$url_unsecure_scheme", + "CHROMIUM_URL_SCHEME_2=$url_secure_scheme", + "CHROMIUM_URL_SCHEME_3=$url_x_callback_scheme", + "CHROMIUM_URL_SCHEME_4=$url_channel_scheme", + "SSOAUTH_URL_SCHEME=$url_ssoauth_scheme", + ] + + if (ios_automatically_manage_certs) { + # Use the same bundle identifier for EarlGrey tests as for unit tests + # when managing certificates as the number of free certs is limited. + extra_substitutions += + [ "CHROMIUM_BUNDLE_ID=gtest.${ios_generic_test_bundle_id_suffix}" ] + } else { + extra_substitutions += [ "CHROMIUM_BUNDLE_ID=gtest.$target_name" ] + } + + if (ios_encryption_export_compliance_code != "") { + extra_substitutions += [ "ENCRYPTION_EXPORT_COMPLIANCE_CODE=$ios_encryption_export_compliance_code" ] + } +}
diff --git a/ios/clean/chrome/test/perf/resources/Chrome.entitlements b/ios/clean/chrome/test/perf/resources/Chrome.entitlements new file mode 100644 index 0000000..061639e --- /dev/null +++ b/ios/clean/chrome/test/perf/resources/Chrome.entitlements
@@ -0,0 +1,8 @@ +<?xml version="1.0" encoding="UTF-8"?> +<!DOCTYPE plist PUBLIC "-//Apple//DTD PLIST 1.0//EN" "http://www.apple.com/DTDs/PropertyList-1.0.dtd"> +<plist version="1.0"> +<dict> + <key>application-identifier</key> + <string>$(AppIdentifierPrefix)$(CFBundleIdentifier)</string> +</dict> +</plist>
diff --git a/ios/clean/chrome/test/perf/startup_egtests.mm b/ios/clean/chrome/test/perf/startup_egtests.mm new file mode 100644 index 0000000..c25e853 --- /dev/null +++ b/ios/clean/chrome/test/perf/startup_egtests.mm
@@ -0,0 +1,23 @@ +// Copyright 2017 The Chromium Authors. All rights reserved. +// Use of this source code is governed by a BSD-style license that can be +// found in the LICENSE file. + +#import <XCTest/XCTest.h> + +#import "ios/testing/perf/startupLoggers.h" + +#if !defined(__has_feature) || !__has_feature(objc_arc) +#error "This file requires ARC support." +#endif + +@interface StartupTestCase : XCTestCase +@end + +@implementation StartupTestCase + +// Simple test to launch the app and log startup data. +- (void)testColdStartUp { + XCTAssertTrue(startup_loggers::LogData(@"testColdStartUp")); +} + +@end
diff --git a/ios/net/cookies/cookie_store_ios.h b/ios/net/cookies/cookie_store_ios.h index 04a37f19..3877586 100644 --- a/ios/net/cookies/cookie_store_ios.h +++ b/ios/net/cookies/cookie_store_ios.h
@@ -5,6 +5,8 @@ #ifndef IOS_NET_COOKIES_COOKIE_STORE_IOS_H_ #define IOS_NET_COOKIES_COOKIE_STORE_IOS_H_ +#include <stdint.h> + #include <map> #include <memory> #include <string> @@ -253,7 +255,7 @@ // calling the provided callback. void UpdateCachesAfterSet(SetCookiesCallback callback, bool success); - void UpdateCachesAfterDelete(DeleteCallback callback, int num_deleted); + void UpdateCachesAfterDelete(DeleteCallback callback, uint32_t num_deleted); void UpdateCachesAfterClosure(base::OnceClosure callback); // Takes an NSArray of NSHTTPCookies as returns a net::CookieList.
diff --git a/ios/net/cookies/cookie_store_ios.mm b/ios/net/cookies/cookie_store_ios.mm index edb3bad..87baca6b 100644 --- a/ios/net/cookies/cookie_store_ios.mm +++ b/ios/net/cookies/cookie_store_ios.mm
@@ -861,7 +861,7 @@ } void CookieStoreIOS::UpdateCachesAfterDelete(DeleteCallback callback, - int num_deleted) { + uint32_t num_deleted) { DCHECK(thread_checker_.CalledOnValidThread()); UpdateCachesFromCookieMonster(); if (!callback.is_null())
diff --git a/ios/testing/perf/BUILD.gn b/ios/testing/perf/BUILD.gn new file mode 100644 index 0000000..13700de --- /dev/null +++ b/ios/testing/perf/BUILD.gn
@@ -0,0 +1,14 @@ +# Copyright 2017 The Chromium Authors. All rights reserved. +# Use of this source code is governed by a BSD-style license that can be +# found in the LICENSE file. + +source_set("startup") { + sources = [ + "startupLoggers.h", + "startupLoggers.mm", + ] + deps = [ + "//base", + ] + configs += [ "//build/config/compiler:enable_arc" ] +}
diff --git a/ios/testing/perf/startupLoggers.h b/ios/testing/perf/startupLoggers.h new file mode 100644 index 0000000..d16a2b2 --- /dev/null +++ b/ios/testing/perf/startupLoggers.h
@@ -0,0 +1,23 @@ +// Copyright 2017 The Chromium Authors. All rights reserved. +// Use of this source code is governed by a BSD-style license that can be +// found in the LICENSE file. + +#import <Foundation/Foundation.h> + +namespace startup_loggers { + +// Registers the current time variable. This function should be called when the +// app is launched. +void RegisterAppStartTime(); +// Registers the current time variable. This function should be called when the +// app gets didFinishLaunchingWithOptions notification. +void RegisterAppDidFinishLaunchingTime(); +// Registers the current time variable. Chrome does some lauch option steps +// after the app gets didFinishLaunchingWithOptions notification. This function +// should be called when the app gets applicationDidBecomeActive notification. +void RegisterAppDidBecomeActiveTime(); +// Returns whether data is successfully stored in the output json file. This +// function stores the time variables into a json file. +bool LogData(NSString* testName); + +} // namespace startup_loggers
diff --git a/ios/testing/perf/startupLoggers.mm b/ios/testing/perf/startupLoggers.mm new file mode 100644 index 0000000..389e919 --- /dev/null +++ b/ios/testing/perf/startupLoggers.mm
@@ -0,0 +1,70 @@ +// Copyright 2017 The Chromium Authors. All rights reserved. +// Use of this source code is governed by a BSD-style license that can be +// found in the LICENSE file. + +#import "ios/testing/perf/startupLoggers.h" +#include "base/time/time.h" + +#if !defined(__has_feature) || !__has_feature(objc_arc) +#error "This file requires ARC support." +#endif + +namespace startup_loggers { +// Stores the time of app startup states. +base::Time* g_start_time; +base::Time* g_finish_launching_time; +base::Time* g_become_active_time; + +void RegisterAppStartTime() { + DCHECK(!g_start_time); + g_start_time = new base::Time(base::Time::Now()); +} + +void RegisterAppDidFinishLaunchingTime() { + DCHECK(g_start_time); + DCHECK(!g_finish_launching_time); + g_finish_launching_time = new base::Time(base::Time::Now()); +} + +void RegisterAppDidBecomeActiveTime() { + DCHECK(g_start_time); + DCHECK(!g_become_active_time); + g_become_active_time = new base::Time(base::Time::Now()); +} + +bool LogData(NSString* testName) { + // Store the data into a format compatiable with infra scripts. + double finishLaunchingDuration = + g_finish_launching_time->ToDoubleT() - g_start_time->ToDoubleT(); + double becomeActiveDuration = + g_become_active_time->ToDoubleT() - g_start_time->ToDoubleT(); + NSDictionary* values = @{ + @"AppDidFinishLaunchingTime" : @(finishLaunchingDuration), + @"AppDidBecomeActiveTime" : @(becomeActiveDuration) + }; + NSDictionary* timingData = + @{ testName : @{@"unit" : @"seconds", @"value" : values} }; + NSDictionary* summary = @{@"Perf Data" : timingData}; + + // Converts data into json format. + NSError* error; + NSData* jsonData = + [NSJSONSerialization dataWithJSONObject:summary + options:NSJSONWritingPrettyPrinted + error:&error]; + if (error) { + return false; + } + + // Stores data into a json file under the app's document directory. + NSString* fileName = @"perf_result.json"; + NSArray<NSString*>* outputDirectories = NSSearchPathForDirectoriesInDomains( + NSDocumentDirectory, NSUserDomainMask, YES); + if ([outputDirectories count] == 0) { + return false; + } + NSString* outputPath = + [outputDirectories[0] stringByAppendingPathComponent:fileName]; + return [jsonData writeToFile:outputPath atomically:YES]; +} +}
diff --git a/media/base/decoder_factory.cc b/media/base/decoder_factory.cc index fa002d6..4b9b0b3 100644 --- a/media/base/decoder_factory.cc +++ b/media/base/decoder_factory.cc
@@ -19,6 +19,7 @@ void DecoderFactory::CreateVideoDecoders( scoped_refptr<base::SingleThreadTaskRunner> task_runner, GpuVideoAcceleratorFactories* gpu_factories, + MediaLog* media_log, std::vector<std::unique_ptr<VideoDecoder>>* video_decoders) {} } // namespace media
diff --git a/media/base/decoder_factory.h b/media/base/decoder_factory.h index 4d90ee3..7de18e0 100644 --- a/media/base/decoder_factory.h +++ b/media/base/decoder_factory.h
@@ -20,6 +20,7 @@ class AudioDecoder; class GpuVideoAcceleratorFactories; +class MediaLog; class VideoDecoder; // A factory class for creating audio and video decoders. @@ -39,6 +40,7 @@ virtual void CreateVideoDecoders( scoped_refptr<base::SingleThreadTaskRunner> task_runner, GpuVideoAcceleratorFactories* gpu_factories, + MediaLog* media_log, std::vector<std::unique_ptr<VideoDecoder>>* video_decoders); private:
diff --git a/media/base/ipc/media_param_traits_macros.h b/media/base/ipc/media_param_traits_macros.h index 79083bc..a127800c 100644 --- a/media/base/ipc/media_param_traits_macros.h +++ b/media/base/ipc/media_param_traits_macros.h
@@ -18,6 +18,7 @@ #include "media/base/demuxer_stream.h" #include "media/base/eme_constants.h" #include "media/base/encryption_scheme.h" +#include "media/base/media_log_event.h" #include "media/base/output_device_info.h" #include "media/base/sample_format.h" #include "media/base/subsample_entry.h" @@ -42,6 +43,15 @@ IPC_ENUM_TRAITS_MAX_VALUE(media::CdmKeyInformation::KeyStatus, media::CdmKeyInformation::KEY_STATUS_MAX) +IPC_ENUM_TRAITS_MAX_VALUE(media::CdmMessageType, + media::CdmMessageType::MESSAGE_TYPE_MAX) + +IPC_ENUM_TRAITS_MAX_VALUE(media::CdmPromise::Exception, + media::CdmPromise::EXCEPTION_MAX) + +IPC_ENUM_TRAITS_MAX_VALUE(media::CdmSessionType, + media::CdmSessionType::SESSION_TYPE_MAX) + IPC_ENUM_TRAITS_MAX_VALUE(media::ChannelLayout, media::CHANNEL_LAYOUT_MAX) IPC_ENUM_TRAITS_MAX_VALUE(media::ColorSpace, media::COLOR_SPACE_MAX) @@ -66,14 +76,8 @@ IPC_ENUM_TRAITS_MAX_VALUE(media::EncryptionScheme::CipherMode, media::EncryptionScheme::CipherMode::CIPHER_MODE_MAX) -IPC_ENUM_TRAITS_MAX_VALUE(media::CdmPromise::Exception, - media::CdmPromise::EXCEPTION_MAX) - -IPC_ENUM_TRAITS_MAX_VALUE(media::CdmMessageType, - media::CdmMessageType::MESSAGE_TYPE_MAX) - -IPC_ENUM_TRAITS_MAX_VALUE(media::CdmSessionType, - media::CdmSessionType::SESSION_TYPE_MAX) +IPC_ENUM_TRAITS_MAX_VALUE(media::MediaLogEvent::Type, + media::MediaLogEvent::TYPE_LAST) IPC_ENUM_TRAITS_MAX_VALUE(media::OutputDeviceStatus, media::OUTPUT_DEVICE_STATUS_MAX) @@ -114,6 +118,13 @@ IPC_STRUCT_TRAITS_MEMBER(system_code) IPC_STRUCT_TRAITS_END() +IPC_STRUCT_TRAITS_BEGIN(media::MediaLogEvent) + IPC_STRUCT_TRAITS_MEMBER(id) + IPC_STRUCT_TRAITS_MEMBER(type) + IPC_STRUCT_TRAITS_MEMBER(params) + IPC_STRUCT_TRAITS_MEMBER(time) +IPC_STRUCT_TRAITS_END() + IPC_STRUCT_TRAITS_BEGIN(media::SubsampleEntry) IPC_STRUCT_TRAITS_MEMBER(clear_bytes) IPC_STRUCT_TRAITS_MEMBER(cypher_bytes)
diff --git a/media/base/media_log.h b/media/base/media_log.h index d138fd6..08eadc5 100644 --- a/media/base/media_log.h +++ b/media/base/media_log.h
@@ -101,6 +101,10 @@ void SetDoubleProperty(const std::string& key, double value); void SetBooleanProperty(const std::string& key, bool value); + // Getter for |id_|. Used by MojoMediaLogService to construct MediaLogEvents + // to log into this MediaLog. + int32_t id() const { return id_; } + private: // A unique (to this process) id for this MediaLog. int32_t id_;
diff --git a/media/base/pipeline_impl.cc b/media/base/pipeline_impl.cc index d21c201..479e72c 100644 --- a/media/base/pipeline_impl.cc +++ b/media/base/pipeline_impl.cc
@@ -201,7 +201,6 @@ text_renderer_ended_(false), weak_factory_(this) { weak_this_ = weak_factory_.GetWeakPtr(); - media_log_->AddEvent(media_log_->CreatePipelineStateChangedEvent(kCreated)); } PipelineImpl::RendererWrapper::~RendererWrapper() {
diff --git a/media/base/test_helpers.cc b/media/base/test_helpers.cc index 73114df..aa89ecec 100644 --- a/media/base/test_helpers.cc +++ b/media/base/test_helpers.cc
@@ -180,6 +180,12 @@ return kLargeSize; } +AudioDecoderConfig TestAudioConfig::Normal() { + return AudioDecoderConfig(kCodecVorbis, kSampleFormatPlanarF32, + CHANNEL_LAYOUT_STEREO, 44100, EmptyExtraData(), + Unencrypted()); +} + // static AudioParameters TestAudioParameters::Normal() { return AudioParameters(AudioParameters::AUDIO_PCM_LOW_LATENCY,
diff --git a/media/base/test_helpers.h b/media/base/test_helpers.h index e54d0a4..dc0ff01 100644 --- a/media/base/test_helpers.h +++ b/media/base/test_helpers.h
@@ -101,6 +101,13 @@ DISALLOW_COPY_AND_ASSIGN(TestVideoConfig); }; +// Provides pre-canned AudioDecoderConfig. These types are used for tests that +// don't care about detailed parameters of the config. +class TestAudioConfig { + public: + static AudioDecoderConfig Normal(); +}; + // Provides pre-canned AudioParameters objects. class TestAudioParameters { public: @@ -171,10 +178,36 @@ "SourceBuffer with multiple tracks"); } +MATCHER_P2(NonkeyframePrecedesGopStartWarning, + keyframe_time_string, + nonkeyframe_time_string, + "") { + return CONTAINS_STRING( + arg, + "Warning: presentation time of most recently processed random access " + "point (" + + std::string(keyframe_time_string) + + " s) is later than the presentation time of a non-keyframe (" + + nonkeyframe_time_string + + " s) that depends on it. This type of random access point is not " + "well supported by MSE; buffered range reporting may be less " + "precise."); +} + MATCHER(StreamParsingFailed, "") { return CONTAINS_STRING(arg, "Append: stream parsing failed."); } +MATCHER(ParsedBuffersNotInDTSSequence, "") { + return CONTAINS_STRING(arg, "Parsed buffers not in DTS sequence"); +} + +MATCHER(ParsedDTSGreaterThanPTS, "") { + return CONTAINS_STRING(arg, "Parsed ") && + CONTAINS_STRING(arg, "frame has DTS ") && + CONTAINS_STRING(arg, ", which is after the frame's PTS"); +} + MATCHER_P(FoundStream, stream_type_string, "") { return CONTAINS_STRING( arg, "found_" + std::string(stream_type_string) + "_stream") && @@ -203,6 +236,12 @@ " track track_id=" + id); } +MATCHER_P2(FrameTypeMismatchesTrackType, frame_type, track_type, "") { + return CONTAINS_STRING(arg, std::string("Frame type ") + frame_type + + " doesn't match track buffer type " + + track_type); +} + MATCHER_P2(SkippingSpliceAtOrBefore, new_microseconds, existing_microseconds,
diff --git a/media/base/video_decoder_config.cc b/media/base/video_decoder_config.cc index 9599ff1..845c37a 100644 --- a/media/base/video_decoder_config.cc +++ b/media/base/video_decoder_config.cc
@@ -53,7 +53,8 @@ VideoDecoderConfig::VideoDecoderConfig() : codec_(kUnknownVideoCodec), profile_(VIDEO_CODEC_PROFILE_UNKNOWN), - format_(PIXEL_FORMAT_UNKNOWN) {} + format_(PIXEL_FORMAT_UNKNOWN), + color_space_(COLOR_SPACE_UNSPECIFIED) {} VideoDecoderConfig::VideoDecoderConfig( VideoCodec codec, @@ -79,7 +80,7 @@ color_space_info_ = color_space_info; } -VideoColorSpace VideoDecoderConfig::color_space_info() const { +const VideoColorSpace& VideoDecoderConfig::color_space_info() const { return color_space_info_; } @@ -87,7 +88,7 @@ hdr_metadata_ = hdr_metadata; } -base::Optional<HDRMetadata> VideoDecoderConfig::hdr_metadata() const { +const base::Optional<HDRMetadata>& VideoDecoderConfig::hdr_metadata() const { return hdr_metadata_; }
diff --git a/media/base/video_decoder_config.h b/media/base/video_decoder_config.h index ec6b315..80b5c8f 100644 --- a/media/base/video_decoder_config.h +++ b/media/base/video_decoder_config.h
@@ -89,14 +89,14 @@ // Deprecated. TODO(wolenetz): Remove. See https://crbug.com/665539. // Width and height of video frame immediately post-decode. Not all pixels // in this region are valid. - gfx::Size coded_size() const { return coded_size_; } + const gfx::Size& coded_size() const { return coded_size_; } // Region of |coded_size_| that is visible. - gfx::Rect visible_rect() const { return visible_rect_; } + const gfx::Rect& visible_rect() const { return visible_rect_; } // Final visible width and height of a video frame with aspect ratio taken // into account. - gfx::Size natural_size() const { return natural_size_; } + const gfx::Size& natural_size() const { return natural_size_; } // Optional byte data required to initialize video decoders, such as H.264 // AVCC data. @@ -114,10 +114,10 @@ } void set_color_space_info(const VideoColorSpace& color_space_info); - VideoColorSpace color_space_info() const; + const VideoColorSpace& color_space_info() const; void set_hdr_metadata(const HDRMetadata& hdr_metadata); - base::Optional<HDRMetadata> hdr_metadata() const; + const base::Optional<HDRMetadata>& hdr_metadata() const; // Sets the config to be encrypted or not encrypted manually. This can be // useful for decryptors that decrypts an encrypted stream to a clear stream.
diff --git a/media/blink/webmediaplayer_impl.cc b/media/blink/webmediaplayer_impl.cc index 28911b1..c558870 100644 --- a/media/blink/webmediaplayer_impl.cc +++ b/media/blink/webmediaplayer_impl.cc
@@ -290,6 +290,10 @@ media_log_->AddEvent(media_log_->CreateCreatedEvent( url::Origin(frame_->GetSecurityOrigin()).GetURL().spec())); + media_log_->SetStringProperty("frame_url", + frame_->GetDocument().Url().GetString().Utf8()); + media_log_->SetStringProperty("frame_title", + frame_->GetDocument().Title().Utf8()); if (params->initial_cdm()) SetCdm(params->initial_cdm());
diff --git a/media/filters/frame_processor.cc b/media/filters/frame_processor.cc index 41d79c8..b770e68 100644 --- a/media/filters/frame_processor.cc +++ b/media/filters/frame_processor.cc
@@ -18,6 +18,7 @@ const int kMaxDroppedPrerollWarnings = 10; const int kMaxDtsBeyondPtsWarnings = 10; const int kMaxMuxedSequenceModeWarnings = 1; +const int kMaxNumNonkeyframePrecedesGopStartWarnings = 1; // Helper class to capture per-track details needed by a frame processor. Some // of this information may be duplicated in the short-term in the associated @@ -26,7 +27,7 @@ // http://www.w3.org/TR/media-source/#track-buffers. class MseTrackBuffer { public: - explicit MseTrackBuffer(ChunkDemuxerStream* stream); + MseTrackBuffer(ChunkDemuxerStream* stream, MediaLog* media_log); ~MseTrackBuffer(); // Get/set |last_decode_timestamp_|. @@ -104,6 +105,14 @@ // also FrameProcessor::ProcessFrame(). DecodeTimestamp last_processed_decode_timestamp_; + // This is used to understand if the stream parser is producing random access + // points that are not SAP Type 1, whose support is likely going to be + // deprecated from MSE API pending real-world usage data. This is kNoTimestamp + // if no frames have been enqueued ever or since the last + // NotifyStartOfCodedFrameGroup() or Reset(). Otherwise, this is the most + // recently enqueued keyframe's presentation timestamp. + base::TimeDelta last_keyframe_presentation_timestamp_; + // The coded frame duration of the last coded frame appended in the current // coded frame group. Initially kNoTimestamp, meaning "unset". base::TimeDelta last_frame_duration_; @@ -128,16 +137,24 @@ // clears it. StreamParser::BufferQueue processed_frames_; + // MediaLog for reporting messages and properties to debug content and engine. + MediaLog* media_log_; + + // Counter that limits spam to |media_log_| for MseTrackBuffer warnings. + int num_nonkeyframe_precedes_gop_start_warnings_ = 0; + DISALLOW_COPY_AND_ASSIGN(MseTrackBuffer); }; -MseTrackBuffer::MseTrackBuffer(ChunkDemuxerStream* stream) +MseTrackBuffer::MseTrackBuffer(ChunkDemuxerStream* stream, MediaLog* media_log) : last_decode_timestamp_(kNoDecodeTimestamp()), last_processed_decode_timestamp_(DecodeTimestamp()), + last_keyframe_presentation_timestamp_(kNoTimestamp), last_frame_duration_(kNoTimestamp), highest_presentation_timestamp_(kNoTimestamp), needs_random_access_point_(true), - stream_(stream) { + stream_(stream), + media_log_(media_log) { DCHECK(stream_); } @@ -152,6 +169,7 @@ last_frame_duration_ = kNoTimestamp; highest_presentation_timestamp_ = kNoTimestamp; needs_random_access_point_ = true; + last_keyframe_presentation_timestamp_ = kNoTimestamp; } void MseTrackBuffer::SetHighestPresentationTimestampIfIncreased( @@ -164,6 +182,28 @@ void MseTrackBuffer::EnqueueProcessedFrame( const scoped_refptr<StreamParserBuffer>& frame) { + if (frame->is_key_frame()) { + last_keyframe_presentation_timestamp_ = frame->timestamp(); + } else { + DCHECK(last_keyframe_presentation_timestamp_ != kNoTimestamp); + // This is just one case of potentially problematic GOP structures, though + // others are more clearly disallowed in at least some of the MSE bytestream + // specs, especially ISOBMFF. + if (frame->timestamp() < last_keyframe_presentation_timestamp_) { + LIMITED_MEDIA_LOG(DEBUG, media_log_, + num_nonkeyframe_precedes_gop_start_warnings_, + kMaxNumNonkeyframePrecedesGopStartWarnings) + << "Warning: presentation time of most recently processed random " + "access point (" + << last_keyframe_presentation_timestamp_ + << ") is later than the presentation time of a non-keyframe (" + << frame->timestamp() + << ") that depends on it. This type of random access point is not " + "well supported by MSE; buffered range reporting may be less " + "precise."; + } + } + last_processed_decode_timestamp_ = frame->GetDecodeTimestamp(); processed_frames_.push_back(frame); } @@ -182,6 +222,7 @@ } void MseTrackBuffer::NotifyStartOfCodedFrameGroup(DecodeTimestamp start_time) { + last_keyframe_presentation_timestamp_ = kNoTimestamp; last_processed_decode_timestamp_ = start_time; stream_->OnStartOfCodedFrameGroup(start_time); } @@ -294,7 +335,7 @@ return false; } - track_buffers_[id] = base::MakeUnique<MseTrackBuffer>(stream); + track_buffers_[id] = base::MakeUnique<MseTrackBuffer>(stream, media_log_); return true; }
diff --git a/media/filters/frame_processor_unittest.cc b/media/filters/frame_processor_unittest.cc index 7c5fb88..1240e7b2 100644 --- a/media/filters/frame_processor_unittest.cc +++ b/media/filters/frame_processor_unittest.cc
@@ -20,6 +20,7 @@ #include "media/base/media_log.h" #include "media/base/media_util.h" #include "media/base/mock_filters.h" +#include "media/base/mock_media_log.h" #include "media/base/test_helpers.h" #include "media/base/timestamp_constants.h" #include "media/filters/chunk_demuxer.h" @@ -263,7 +264,7 @@ } base::MessageLoop message_loop_; - MediaLog media_log_; + StrictMock<MockMediaLog> media_log_; StrictMock<FrameProcessorTestCallbackHelper> callbacks_; std::unique_ptr<FrameProcessor> frame_processor_; @@ -336,6 +337,7 @@ const auto& audio_buffers = StringToBufferQueue("0K", audio_id_, DemuxerStream::VIDEO); buffer_queue_map.insert(std::make_pair(audio_id_, audio_buffers)); + EXPECT_MEDIA_LOG(FrameTypeMismatchesTrackType("video", "1")); ASSERT_FALSE( frame_processor_->ProcessFrames(buffer_queue_map, append_window_start_, append_window_end_, ×tamp_offset_)); @@ -352,6 +354,7 @@ const auto& audio_buffers = StringToBufferQueue("10K 0K", audio_id_, DemuxerStream::AUDIO); buffer_queue_map.insert(std::make_pair(audio_id_, audio_buffers)); + EXPECT_MEDIA_LOG(ParsedBuffersNotInDTSSequence()); ASSERT_FALSE( frame_processor_->ProcessFrames(buffer_queue_map, append_window_start_, append_window_end_, ×tamp_offset_)); @@ -536,8 +539,10 @@ // (a0,a10,a20,a30,a40);(v0,v10,v20,v30) InSequence s; AddTestTracks(HAS_AUDIO | HAS_VIDEO); - if (GetParam()) + if (GetParam()) { frame_processor_->SetSequenceMode(true); + EXPECT_MEDIA_LOG(MuxedSequenceModeWarning()); + } EXPECT_CALL(callbacks_, PossibleDurationIncrease(frame_duration_ * 3)); ProcessFrames("0K 10K", "0K 10 20"); @@ -568,6 +573,7 @@ bool using_sequence_mode = GetParam(); if (using_sequence_mode) { frame_processor_->SetSequenceMode(true); + EXPECT_MEDIA_LOG(MuxedSequenceModeWarning()); EXPECT_CALL(callbacks_, PossibleDurationIncrease(frame_duration_ * 7)); } else { EXPECT_CALL(callbacks_, PossibleDurationIncrease(frame_duration_ * 6)); @@ -603,6 +609,8 @@ AddTestTracks(HAS_AUDIO | HAS_VIDEO); bool using_sequence_mode = GetParam(); frame_processor_->SetSequenceMode(using_sequence_mode); + if (using_sequence_mode) + EXPECT_MEDIA_LOG(MuxedSequenceModeWarning()); // Start a coded frame group at time 100ms. Note the jagged start still uses // the coded frame group's start time as the range start for both streams. @@ -722,6 +730,7 @@ // applied to frames beginning at the first frame after the discontinuity // caused by the video append at 160K, below. SetTimestampOffset(frame_duration_ * 10); + EXPECT_MEDIA_LOG(MuxedSequenceModeWarning()); } EXPECT_CALL(callbacks_, PossibleDurationIncrease(frame_duration_ * 14)); ProcessFrames("100K 110K 120K", "110K 120K 130K"); @@ -906,6 +915,8 @@ InSequence s; AddTestTracks(HAS_AUDIO); bool using_sequence_mode = GetParam(); + + EXPECT_MEDIA_LOG(ParsedDTSGreaterThanPTS()).Times(2); if (using_sequence_mode) { frame_processor_->SetSequenceMode(true); EXPECT_CALL(callbacks_, PossibleDurationIncrease( @@ -941,9 +952,12 @@ // partial front trim, to prevent incorrect introduction of a discontinuity // and potentially a non-keyframe video frame to be processed next after the // discontinuity. + bool using_sequence_mode = GetParam(); InSequence s; AddTestTracks(HAS_AUDIO | HAS_VIDEO); - frame_processor_->SetSequenceMode(GetParam()); + frame_processor_->SetSequenceMode(using_sequence_mode); + if (using_sequence_mode) + EXPECT_MEDIA_LOG(MuxedSequenceModeWarning()); EXPECT_CALL(callbacks_, PossibleDurationIncrease(frame_duration_)); ProcessFrames("", "0K"); EXPECT_CALL(callbacks_, PossibleDurationIncrease(frame_duration_)); @@ -1027,6 +1041,45 @@ last_read_parser_buffer->preroll_buffer()->duration()); } +TEST_P(FrameProcessorTest, + OOOKeyframePrecededByDependantNonKeyframeShouldWarn) { + bool is_sequence_mode = GetParam(); + InSequence s; + AddTestTracks(HAS_VIDEO); + frame_processor_->SetSequenceMode(is_sequence_mode); + + if (is_sequence_mode) { + // Allow room in the timeline for the last video append (40|70, below) in + // this test to remain within default append window [0, +Infinity]. Moving + // the sequence mode appends to begin at time 50ms, the same time as the + // first append, below, also results in identical expectation checks for + // buffered ranges and buffer reads for both segments and sequence modes. + SetTimestampOffset(frame_duration_ * 5); + } + + EXPECT_CALL(callbacks_, PossibleDurationIncrease(frame_duration_ * 7)); + ProcessFrames("", "50K 60"); + + CheckExpectedRangesByTimestamp(video_.get(), "{ [50,70) }"); + + EXPECT_MEDIA_LOG(ParsedDTSGreaterThanPTS()); + EXPECT_MEDIA_LOG(NonkeyframePrecedesGopStartWarning("0.05", "0.04")); + EXPECT_CALL(callbacks_, PossibleDurationIncrease(frame_duration_ * 7)); + ProcessFrames("", "40|70"); // PTS=40, DTS=70 + + // Verify DTS-based range is increased. + // TODO(wolenetz): Update this expectation to be { [50,70] } when switching to + // managing and reporting buffered ranges by PTS intervals instead of DTS + // intervals. This reflects the expectation that PTS start is not "pulled + // backward" for the new frame at PTS=40 because current spec text doesn't + // support SAP Type 2; it has no steps in the coded frame processing algorithm + // that would do that "pulling backward". See https://crbug.com/718641 and + // https://github.com/w3c/media-source/issues/187. + CheckExpectedRangesByTimestamp(video_.get(), "{ [50,80) }"); + seek(video_.get(), base::TimeDelta()); + CheckReadsThenReadStalls(video_.get(), "50 60 40"); +} + INSTANTIATE_TEST_CASE_P(SequenceMode, FrameProcessorTest, Values(true)); INSTANTIATE_TEST_CASE_P(SegmentsMode, FrameProcessorTest, Values(false));
diff --git a/media/filters/gpu_video_decoder.cc b/media/filters/gpu_video_decoder.cc index 8afb950..c92214f 100644 --- a/media/filters/gpu_video_decoder.cc +++ b/media/filters/gpu_video_decoder.cc
@@ -83,21 +83,15 @@ enum { kMaxInFlightDecodes = 4 }; struct GpuVideoDecoder::PendingDecoderBuffer { - PendingDecoderBuffer(std::unique_ptr<SHMBuffer> s, + PendingDecoderBuffer(std::unique_ptr<base::SharedMemory> s, const scoped_refptr<DecoderBuffer>& b, const DecodeCB& done_cb) - : shm_buffer(std::move(s)), buffer(b), done_cb(done_cb) {} - std::unique_ptr<SHMBuffer> shm_buffer; + : shared_memory(std::move(s)), buffer(b), done_cb(done_cb) {} + std::unique_ptr<base::SharedMemory> shared_memory; scoped_refptr<DecoderBuffer> buffer; DecodeCB done_cb; }; -GpuVideoDecoder::SHMBuffer::SHMBuffer(std::unique_ptr<base::SharedMemory> m, - size_t s) - : shm(std::move(m)), size(s) {} - -GpuVideoDecoder::SHMBuffer::~SHMBuffer() {} - GpuVideoDecoder::BufferData::BufferData(int32_t bbid, base::TimeDelta ts, const gfx::Rect& vr, @@ -439,17 +433,17 @@ } size_t size = buffer->data_size(); - std::unique_ptr<SHMBuffer> shm_buffer = GetSHM(size); - if (!shm_buffer) { + auto shared_memory = GetSharedMemory(size); + if (!shared_memory) { bound_decode_cb.Run(DecodeStatus::DECODE_ERROR); return; } - memcpy(shm_buffer->shm->memory(), buffer->data(), size); + memcpy(shared_memory->memory(), buffer->data(), size); // AndroidVideoDecodeAccelerator needs the timestamp to output frames in // presentation order. BitstreamBuffer bitstream_buffer(next_bitstream_buffer_id_, - shm_buffer->shm->handle(), size, 0, + shared_memory->handle(), size, 0, buffer->timestamp()); if (buffer->decrypt_config()) @@ -461,7 +455,7 @@ !base::ContainsKey(bitstream_buffers_in_decoder_, bitstream_buffer.id())); bitstream_buffers_in_decoder_.emplace( bitstream_buffer.id(), - PendingDecoderBuffer(std::move(shm_buffer), buffer, decode_cb)); + PendingDecoderBuffer(std::move(shared_memory), buffer, decode_cb)); DCHECK_LE(static_cast<int>(bitstream_buffers_in_decoder_.size()), kMaxInFlightDecodes); RecordBufferData(bitstream_buffer, *buffer.get()); @@ -748,27 +742,24 @@ vda_->ReusePictureBuffer(picture_buffer_id); } -std::unique_ptr<GpuVideoDecoder::SHMBuffer> GpuVideoDecoder::GetSHM( +std::unique_ptr<base::SharedMemory> GpuVideoDecoder::GetSharedMemory( size_t min_size) { DCheckGpuVideoAcceleratorFactoriesTaskRunnerIsCurrent(); if (available_shm_segments_.empty() || - available_shm_segments_.back()->size < min_size) { + available_shm_segments_.back()->mapped_size() < min_size) { size_t size_to_allocate = std::max(min_size, kSharedMemorySegmentBytes); - std::unique_ptr<base::SharedMemory> shm = - factories_->CreateSharedMemory(size_to_allocate); // CreateSharedMemory() can return NULL during Shutdown. - if (!shm) - return NULL; - return base::MakeUnique<SHMBuffer>(std::move(shm), size_to_allocate); + return factories_->CreateSharedMemory(size_to_allocate); } - std::unique_ptr<SHMBuffer> ret(std::move(available_shm_segments_.back())); + auto ret = std::move(available_shm_segments_.back()); available_shm_segments_.pop_back(); return ret; } -void GpuVideoDecoder::PutSHM(std::unique_ptr<SHMBuffer> shm_buffer) { +void GpuVideoDecoder::PutSharedMemory( + std::unique_ptr<base::SharedMemory> shared_memory) { DCheckGpuVideoAcceleratorFactoriesTaskRunnerIsCurrent(); - available_shm_segments_.push_back(std::move(shm_buffer)); + available_shm_segments_.push_back(std::move(shared_memory)); } void GpuVideoDecoder::NotifyEndOfBitstreamBuffer(int32_t id) { @@ -783,7 +774,7 @@ return; } - PutSHM(std::move(it->second.shm_buffer)); + PutSharedMemory(std::move(it->second.shared_memory)); it->second.done_cb.Run(state_ == kError ? DecodeStatus::DECODE_ERROR : DecodeStatus::OK); bitstream_buffers_in_decoder_.erase(it);
diff --git a/media/filters/gpu_video_decoder.h b/media/filters/gpu_video_decoder.h index 4463a0e..c765d31c 100644 --- a/media/filters/gpu_video_decoder.h +++ b/media/filters/gpu_video_decoder.h
@@ -90,14 +90,6 @@ kError }; - // A shared memory segment and its allocated size. - struct SHMBuffer { - SHMBuffer(std::unique_ptr<base::SharedMemory> m, size_t s); - ~SHMBuffer(); - std::unique_ptr<base::SharedMemory> shm; - size_t size; - }; - // A SHMBuffer and the DecoderBuffer its data came from. struct PendingDecoderBuffer; @@ -125,10 +117,10 @@ // Request a shared-memory segment of at least |min_size| bytes. Will // allocate as necessary. - std::unique_ptr<SHMBuffer> GetSHM(size_t min_size); + std::unique_ptr<base::SharedMemory> GetSharedMemory(size_t min_size); // Return a shared-memory segment to the available pool. - void PutSHM(std::unique_ptr<SHMBuffer> shm_buffer); + void PutSharedMemory(std::unique_ptr<base::SharedMemory> shm_buffer); // Destroy all PictureBuffers in |buffers|, and delete their textures. void DestroyPictureBuffers(PictureBufferMap* buffers); @@ -187,7 +179,7 @@ // Shared-memory buffer pool. Since allocating SHM segments requires a // round-trip to the browser process, we keep allocation out of the // steady-state of the decoder. - std::vector<std::unique_ptr<SHMBuffer>> available_shm_segments_; + std::vector<std::unique_ptr<base::SharedMemory>> available_shm_segments_; // Placeholder sync token that was created and validated after the most // recent picture buffers were created.
diff --git a/media/gpu/BUILD.gn b/media/gpu/BUILD.gn index 6066206a..5a4cc5dd7 100644 --- a/media/gpu/BUILD.gn +++ b/media/gpu/BUILD.gn
@@ -133,6 +133,8 @@ "fake_jpeg_decode_accelerator.h", "fake_video_decode_accelerator.cc", "fake_video_decode_accelerator.h", + "gles2_decoder_helper.cc", + "gles2_decoder_helper.h", "gpu_video_accelerator_util.cc", "gpu_video_accelerator_util.h", "gpu_video_decode_accelerator_factory.cc",
diff --git a/media/gpu/gles2_decoder_helper.cc b/media/gpu/gles2_decoder_helper.cc new file mode 100644 index 0000000..25726f9a --- /dev/null +++ b/media/gpu/gles2_decoder_helper.cc
@@ -0,0 +1,124 @@ +// Copyright 2017 The Chromium Authors. All rights reserved. +// Use of this source code is governed by a BSD-style license that can be +// found in the LICENSE file. + +#include "media/gpu/gles2_decoder_helper.h" + +#include "base/macros.h" +#include "base/memory/ptr_util.h" +#include "base/threading/thread_checker.h" +#include "gpu/command_buffer/common/mailbox.h" +#include "gpu/command_buffer/service/context_group.h" +#include "gpu/command_buffer/service/gles2_cmd_decoder.h" +#include "gpu/command_buffer/service/mailbox_manager.h" +#include "gpu/command_buffer/service/texture_manager.h" +#include "ui/gl/gl_context.h" + +namespace media { + +class GLES2DecoderHelperImpl : public GLES2DecoderHelper { + public: + explicit GLES2DecoderHelperImpl(gpu::gles2::GLES2Decoder* decoder) + : decoder_(decoder) {} + + bool MakeContextCurrent() override { + DCHECK_CALLED_ON_VALID_THREAD(thread_checker_); + return decoder_->MakeCurrent(); + } + + scoped_refptr<gpu::gles2::TextureRef> CreateTexture(GLenum target, + GLenum internal_format, + GLsizei width, + GLsizei height, + GLenum format, + GLenum type) override { + DCHECK_CALLED_ON_VALID_THREAD(thread_checker_); + DCHECK(decoder_->GetGLContext()->IsCurrent(nullptr)); + gpu::gles2::ContextGroup* group = decoder_->GetContextGroup(); + gpu::gles2::TextureManager* texture_manager = group->texture_manager(); + // TODO(sandersd): Support GLES2DecoderPassthroughImpl. + DCHECK(texture_manager); + + // We can't use texture_manager->CreateTexture(), since it requires a unique + // |client_id|. Instead we create the texture directly, and create our own + // TextureRef for it. + GLuint texture_id; + glGenTextures(1, &texture_id); + glBindTexture(target, texture_id); + + scoped_refptr<gpu::gles2::TextureRef> texture_ref = + gpu::gles2::TextureRef::Create(texture_manager, 0, texture_id); + texture_manager->SetTarget(texture_ref.get(), target); + texture_manager->SetLevelInfo(texture_ref.get(), // ref + target, // target + 0, // level + internal_format, // internal_format + width, // width + height, // height + 1, // depth + 0, // border + format, // format + type, // type + gfx::Rect()); // cleared_rect + + texture_manager->SetParameteri(__func__, decoder_->GetErrorState(), + texture_ref.get(), GL_TEXTURE_MAG_FILTER, + GL_LINEAR); + texture_manager->SetParameteri(__func__, decoder_->GetErrorState(), + texture_ref.get(), GL_TEXTURE_MIN_FILTER, + GL_LINEAR); + + texture_manager->SetParameteri(__func__, decoder_->GetErrorState(), + texture_ref.get(), GL_TEXTURE_WRAP_S, + GL_CLAMP_TO_EDGE); + texture_manager->SetParameteri(__func__, decoder_->GetErrorState(), + texture_ref.get(), GL_TEXTURE_WRAP_T, + GL_CLAMP_TO_EDGE); + + texture_manager->SetParameteri(__func__, decoder_->GetErrorState(), + texture_ref.get(), GL_TEXTURE_BASE_LEVEL, 0); + texture_manager->SetParameteri(__func__, decoder_->GetErrorState(), + texture_ref.get(), GL_TEXTURE_MAX_LEVEL, 0); + + // TODO(sandersd): Do we always want to allocate for GL_TEXTURE_2D? + if (target == GL_TEXTURE_2D) { + glTexImage2D(target, // target + 0, // level + internal_format, // internal_format + width, // width + height, // height + 0, // border + format, // format + type, // type + nullptr); // data + } + + decoder_->RestoreActiveTextureUnitBinding(target); + return texture_ref; + } + + gpu::Mailbox CreateMailbox(gpu::gles2::TextureRef* texture_ref) override { + DCHECK_CALLED_ON_VALID_THREAD(thread_checker_); + gpu::gles2::ContextGroup* group = decoder_->GetContextGroup(); + gpu::gles2::MailboxManager* mailbox_manager = group->mailbox_manager(); + gpu::Mailbox mailbox = gpu::Mailbox::Generate(); + mailbox_manager->ProduceTexture(mailbox, texture_ref->texture()); + return mailbox; + } + + private: + gpu::gles2::GLES2Decoder* decoder_; + THREAD_CHECKER(thread_checker_); + + DISALLOW_COPY_AND_ASSIGN(GLES2DecoderHelperImpl); +}; + +// static +std::unique_ptr<GLES2DecoderHelper> GLES2DecoderHelper::Create( + gpu::gles2::GLES2Decoder* decoder) { + if (!decoder) + return nullptr; + return base::MakeUnique<GLES2DecoderHelperImpl>(decoder); +} + +} // namespace media
diff --git a/media/gpu/gles2_decoder_helper.h b/media/gpu/gles2_decoder_helper.h new file mode 100644 index 0000000..60f8dfae --- /dev/null +++ b/media/gpu/gles2_decoder_helper.h
@@ -0,0 +1,59 @@ +// Copyright 2017 The Chromium Authors. All rights reserved. +// Use of this source code is governed by a BSD-style license that can be +// found in the LICENSE file. + +#ifndef MEDIA_GPU_GLES2_DECODER_HELPER_H_ +#define MEDIA_GPU_GLES2_DECODER_HELPER_H_ + +#include <stdint.h> + +#include <memory> + +#include "base/memory/ref_counted.h" +#include "base/optional.h" +#include "media/gpu/media_gpu_export.h" +#include "ui/gl/gl_bindings.h" + +namespace gpu { +struct Mailbox; +namespace gles2 { +class GLES2Decoder; +class TextureRef; +} // namespace gles2 +} // namespace gpu + +namespace media { + +// Utility methods to simplify working with a gpu::gles2::GLES2Decoder from +// inside VDAs. +class MEDIA_GPU_EXPORT GLES2DecoderHelper { + public: + static std::unique_ptr<GLES2DecoderHelper> Create( + gpu::gles2::GLES2Decoder* decoder); + + virtual ~GLES2DecoderHelper() {} + + // TODO(sandersd): Provide scoped version? + virtual bool MakeContextCurrent() = 0; + + // Creates a texture and configures it as a video frame (linear filtering, + // clamp to edge, no mipmaps). The context must be current. + // + // See glTexImage2D() for parameter definitions. + // + // Returns nullptr on failure, but there are currently no failure paths. + virtual scoped_refptr<gpu::gles2::TextureRef> CreateTexture( + GLenum target, + GLenum internal_format, + GLsizei width, + GLsizei height, + GLenum format, + GLenum type) = 0; + + // Creates a mailbox for a texture. + virtual gpu::Mailbox CreateMailbox(gpu::gles2::TextureRef* texture_ref) = 0; +}; + +} // namespace media + +#endif // MEDIA_GPU_GLES2_DECODER_HELPER_H_
diff --git a/media/gpu/ipc/client/gpu_video_encode_accelerator_host.cc b/media/gpu/ipc/client/gpu_video_encode_accelerator_host.cc index 3f18bc0..9e4fe86 100644 --- a/media/gpu/ipc/client/gpu_video_encode_accelerator_host.cc +++ b/media/gpu/ipc/client/gpu_video_encode_accelerator_host.cc
@@ -223,9 +223,8 @@ Error error, const std::string& message) { DCHECK_CALLED_ON_VALID_SEQUENCE(sequence_checker_); - DLOG(ERROR) << "Error from " << location.function_name() << "(" - << location.file_name() << ":" << location.line_number() << ") " - << message << " (error = " << error << ")"; + DLOG(ERROR) << "Error from " << location.ToString() << ", " << message + << " (error = " << error << ")"; // Post the error notification back to this thread, to avoid re-entrancy. media_task_runner_->PostTask( FROM_HERE, base::Bind(&GpuVideoEncodeAcceleratorHost::OnNotifyError, @@ -249,10 +248,10 @@ DVLOG(2) << __func__ << " input_count=" << input_count << ", input_coded_size=" << input_coded_size.ToString() << ", output_buffer_size=" << output_buffer_size; - if (client_) { - client_->RequireBitstreamBuffers(input_count, input_coded_size, - output_buffer_size); - } + if (!client_) + return; + client_->RequireBitstreamBuffers(input_count, input_coded_size, + output_buffer_size); } void GpuVideoEncodeAcceleratorHost::OnNotifyInputDone(int32_t frame_id) { @@ -283,9 +282,10 @@ DCHECK_CALLED_ON_VALID_SEQUENCE(sequence_checker_); DVLOG(3) << __func__ << " bitstream_buffer_id=" << bitstream_buffer_id << ", payload_size=" << payload_size << ", key_frame=" << key_frame; - if (client_) - client_->BitstreamBufferReady(bitstream_buffer_id, payload_size, key_frame, - timestamp); + if (!client_) + return; + client_->BitstreamBufferReady(bitstream_buffer_id, payload_size, key_frame, + timestamp); } void GpuVideoEncodeAcceleratorHost::OnNotifyError(Error error) {
diff --git a/media/mojo/BUILD.gn b/media/mojo/BUILD.gn index 224db04..6b9e99f 100644 --- a/media/mojo/BUILD.gn +++ b/media/mojo/BUILD.gn
@@ -74,6 +74,9 @@ "common/media_type_converters_unittest.cc", "common/mojo_decoder_buffer_converter_unittest.cc", "common/mojo_shared_buffer_video_frame_unittest.cc", + "interfaces/audio_decoder_config_struct_traits_unittest.cc", + "interfaces/encryption_scheme_struct_traits_unittest.cc", + "interfaces/video_decoder_config_struct_traits_unittest.cc", "interfaces/video_frame_struct_traits_unittest.cc", "services/mojo_audio_output_stream_unittest.cc", "services/mojo_cdm_allocator_unittest.cc",
diff --git a/media/mojo/clients/BUILD.gn b/media/mojo/clients/BUILD.gn index a299b51d..407b7dd9 100644 --- a/media/mojo/clients/BUILD.gn +++ b/media/mojo/clients/BUILD.gn
@@ -35,6 +35,8 @@ "mojo_decryptor.h", "mojo_demuxer_stream_impl.cc", "mojo_demuxer_stream_impl.h", + "mojo_media_log_service.cc", + "mojo_media_log_service.h", "mojo_renderer.cc", "mojo_renderer.h", "mojo_renderer_factory.cc",
diff --git a/media/mojo/clients/mojo_audio_decoder.cc b/media/mojo/clients/mojo_audio_decoder.cc index 2023236..94a86b3 100644 --- a/media/mojo/clients/mojo_audio_decoder.cc +++ b/media/mojo/clients/mojo_audio_decoder.cc
@@ -70,7 +70,7 @@ // Using base::Unretained(this) is safe because |this| owns |remote_decoder_|, // and the callback won't be dispatched if |remote_decoder_| is destroyed. remote_decoder_->Initialize( - mojom::AudioDecoderConfig::From(config), cdm_id, + config, cdm_id, base::Bind(&MojoAudioDecoder::OnInitialized, base::Unretained(this))); }
diff --git a/media/mojo/clients/mojo_decoder_factory.cc b/media/mojo/clients/mojo_decoder_factory.cc index e187d48e..1a9e6e8b 100644 --- a/media/mojo/clients/mojo_decoder_factory.cc +++ b/media/mojo/clients/mojo_decoder_factory.cc
@@ -38,13 +38,14 @@ void MojoDecoderFactory::CreateVideoDecoders( scoped_refptr<base::SingleThreadTaskRunner> task_runner, GpuVideoAcceleratorFactories* gpu_factories, + MediaLog* media_log, std::vector<std::unique_ptr<VideoDecoder>>* video_decoders) { #if BUILDFLAG(ENABLE_MOJO_VIDEO_DECODER) mojom::VideoDecoderPtr remote_decoder; service_manager::GetInterface<mojom::VideoDecoder>(interface_provider_, &remote_decoder); video_decoders->push_back(base::MakeUnique<MojoVideoDecoder>( - task_runner, gpu_factories, std::move(remote_decoder))); + task_runner, gpu_factories, media_log, std::move(remote_decoder))); #endif }
diff --git a/media/mojo/clients/mojo_decoder_factory.h b/media/mojo/clients/mojo_decoder_factory.h index edf3546..cd6725ed 100644 --- a/media/mojo/clients/mojo_decoder_factory.h +++ b/media/mojo/clients/mojo_decoder_factory.h
@@ -25,6 +25,7 @@ void CreateVideoDecoders( scoped_refptr<base::SingleThreadTaskRunner> task_runner, GpuVideoAcceleratorFactories* gpu_factories, + MediaLog* media_log, std::vector<std::unique_ptr<VideoDecoder>>* video_decoders) final; private:
diff --git a/media/mojo/clients/mojo_decryptor.cc b/media/mojo/clients/mojo_decryptor.cc index 4b57ed9a1..9297175 100644 --- a/media/mojo/clients/mojo_decryptor.cc +++ b/media/mojo/clients/mojo_decryptor.cc
@@ -102,8 +102,7 @@ DVLOG(1) << __func__; DCHECK(thread_checker_.CalledOnValidThread()); - remote_decryptor_->InitializeAudioDecoder( - mojom::AudioDecoderConfig::From(config), init_cb); + remote_decryptor_->InitializeAudioDecoder(config, init_cb); } void MojoDecryptor::InitializeVideoDecoder(const VideoDecoderConfig& config, @@ -111,8 +110,7 @@ DVLOG(1) << __func__; DCHECK(thread_checker_.CalledOnValidThread()); - remote_decryptor_->InitializeVideoDecoder( - mojom::VideoDecoderConfig::From(config), init_cb); + remote_decryptor_->InitializeVideoDecoder(config, init_cb); } void MojoDecryptor::DecryptAndDecodeAudio(
diff --git a/media/mojo/clients/mojo_demuxer_stream_impl.cc b/media/mojo/clients/mojo_demuxer_stream_impl.cc index 8d51802..89d4772 100644 --- a/media/mojo/clients/mojo_demuxer_stream_impl.cc +++ b/media/mojo/clients/mojo_demuxer_stream_impl.cc
@@ -29,18 +29,16 @@ // This is called when our DemuxerStreamClient has connected itself and is // ready to receive messages. Send an initial config and notify it that // we are now ready for business. -void MojoDemuxerStreamImpl::Initialize(const InitializeCallback& callback) { +void MojoDemuxerStreamImpl::Initialize(InitializeCallback callback) { DVLOG(2) << __func__; // Prepare the initial config. - mojom::AudioDecoderConfigPtr audio_config; - mojom::VideoDecoderConfigPtr video_config; + base::Optional<AudioDecoderConfig> audio_config; + base::Optional<VideoDecoderConfig> video_config; if (stream_->type() == Type::AUDIO) { - audio_config = - mojom::AudioDecoderConfig::From(stream_->audio_decoder_config()); + audio_config = stream_->audio_decoder_config(); } else if (stream_->type() == Type::VIDEO) { - video_config = - mojom::VideoDecoderConfig::From(stream_->video_decoder_config()); + video_config = stream_->video_decoder_config(); } else { NOTREACHED() << "Unsupported stream type: " << stream_->type(); return; @@ -50,13 +48,14 @@ mojo_decoder_buffer_writer_ = MojoDecoderBufferWriter::Create(stream_->type(), &remote_consumer_handle); - callback.Run(stream_->type(), std::move(remote_consumer_handle), - std::move(audio_config), std::move(video_config)); + std::move(callback).Run(stream_->type(), std::move(remote_consumer_handle), + audio_config, video_config); } -void MojoDemuxerStreamImpl::Read(const ReadCallback& callback) { +void MojoDemuxerStreamImpl::Read(ReadCallback callback) { stream_->Read(base::Bind(&MojoDemuxerStreamImpl::OnBufferReady, - weak_factory_.GetWeakPtr(), callback)); + weak_factory_.GetWeakPtr(), + base::Passed(&callback))); } void MojoDemuxerStreamImpl::EnableBitstreamConverter() { @@ -64,35 +63,33 @@ } void MojoDemuxerStreamImpl::OnBufferReady( - const ReadCallback& callback, + ReadCallback callback, Status status, const scoped_refptr<media::DecoderBuffer>& buffer) { - mojom::AudioDecoderConfigPtr audio_config; - mojom::VideoDecoderConfigPtr video_config; + base::Optional<AudioDecoderConfig> audio_config; + base::Optional<VideoDecoderConfig> video_config; if (status == Status::kConfigChanged) { DVLOG(2) << __func__ << ": ConfigChange!"; // Send the config change so our client can read it once it parses the // Status obtained via Run() below. if (stream_->type() == Type::AUDIO) { - audio_config = - mojom::AudioDecoderConfig::From(stream_->audio_decoder_config()); + audio_config = stream_->audio_decoder_config(); } else if (stream_->type() == Type::VIDEO) { - video_config = - mojom::VideoDecoderConfig::From(stream_->video_decoder_config()); + video_config = stream_->video_decoder_config(); } else { NOTREACHED() << "Unsupported config change encountered for type: " << stream_->type(); } - callback.Run(Status::kConfigChanged, mojom::DecoderBufferPtr(), - std::move(audio_config), std::move(video_config)); + std::move(callback).Run(Status::kConfigChanged, mojom::DecoderBufferPtr(), + audio_config, video_config); return; } if (status == Status::kAborted) { - callback.Run(Status::kAborted, mojom::DecoderBufferPtr(), - std::move(audio_config), std::move(video_config)); + std::move(callback).Run(Status::kAborted, mojom::DecoderBufferPtr(), + audio_config, video_config); return; } @@ -101,16 +98,16 @@ mojom::DecoderBufferPtr mojo_buffer = mojo_decoder_buffer_writer_->WriteDecoderBuffer(buffer); if (!mojo_buffer) { - callback.Run(Status::kAborted, mojom::DecoderBufferPtr(), - std::move(audio_config), std::move(video_config)); + std::move(callback).Run(Status::kAborted, mojom::DecoderBufferPtr(), + audio_config, video_config); return; } // TODO(dalecurtis): Once we can write framed data to the DataPipe, fill via // the producer handle and then read more to keep the pipe full. Waiting for // space can be accomplished using an AsyncWaiter. - callback.Run(status, std::move(mojo_buffer), std::move(audio_config), - std::move(video_config)); + std::move(callback).Run(status, std::move(mojo_buffer), audio_config, + video_config); } } // namespace media
diff --git a/media/mojo/clients/mojo_demuxer_stream_impl.h b/media/mojo/clients/mojo_demuxer_stream_impl.h index 684c262..4524b1d5 100644 --- a/media/mojo/clients/mojo_demuxer_stream_impl.h +++ b/media/mojo/clients/mojo_demuxer_stream_impl.h
@@ -32,8 +32,8 @@ // mojom::DemuxerStream implementation. // InitializeCallback and ReadCallback are defined in // mojom::DemuxerStream. - void Initialize(const InitializeCallback& callback) override; - void Read(const ReadCallback& callback) override; + void Initialize(InitializeCallback callback) override; + void Read(ReadCallback callback) override; void EnableBitstreamConverter() override; // Sets an error handler that will be called if a connection error occurs on @@ -46,7 +46,7 @@ using Type = media::DemuxerStream::Type; using Status = media::DemuxerStream::Status; - void OnBufferReady(const ReadCallback& callback, + void OnBufferReady(ReadCallback callback, Status status, const scoped_refptr<media::DecoderBuffer>& buffer);
diff --git a/media/mojo/clients/mojo_media_log_service.cc b/media/mojo/clients/mojo_media_log_service.cc new file mode 100644 index 0000000..5403543 --- /dev/null +++ b/media/mojo/clients/mojo_media_log_service.cc
@@ -0,0 +1,40 @@ +// Copyright 2017 The Chromium Authors. All rights reserved. +// Use of this source code is governed by a BSD-style license that can be +// found in the LICENSE file. + +#include "media/mojo/clients/mojo_media_log_service.h" + +#include <memory> + +#include "base/logging.h" +#include "base/memory/ptr_util.h" +#include "media/base/media_log_event.h" + +namespace media { + +MojoMediaLogService::MojoMediaLogService(media::MediaLog* media_log) + : media_log_(media_log) { + DVLOG(1) << __func__; + DCHECK(media_log_); +} + +MojoMediaLogService::~MojoMediaLogService() { + DVLOG(1) << __func__; +} + +void MojoMediaLogService::AddEvent(const media::MediaLogEvent& event) { + DVLOG(1) << __func__; + + // Make a copy so that we can transfer ownership to |media_log_|. + std::unique_ptr<media::MediaLogEvent> modified_event = + base::MakeUnique<media::MediaLogEvent>(event); + + // |id| is player-unique per-process, but the remote side does not know the + // correct value (nor would we necessarily trust it). Overwrite with the + // correct value. + modified_event->id = media_log_->id(); + + media_log_->AddEvent(std::move(modified_event)); +} + +} // namespace media
diff --git a/media/mojo/clients/mojo_media_log_service.h b/media/mojo/clients/mojo_media_log_service.h new file mode 100644 index 0000000..80d2a3a --- /dev/null +++ b/media/mojo/clients/mojo_media_log_service.h
@@ -0,0 +1,33 @@ +// Copyright 2017 The Chromium Authors. All rights reserved. +// Use of this source code is governed by a BSD-style license that can be +// found in the LICENSE file. + +#ifndef MEDIA_MOJO_CLIENTS_MOJO_MEDIA_LOG_SERVICE_H_ +#define MEDIA_MOJO_CLIENTS_MOJO_MEDIA_LOG_SERVICE_H_ + +#include <stdint.h> + +#include "base/macros.h" +#include "media/base/media_log.h" +#include "media/mojo/interfaces/media_log.mojom.h" + +namespace media { + +// Implementation of a mojom::MediaLog service which wraps a media::MediaLog. +class MojoMediaLogService : public mojom::MediaLog { + public: + explicit MojoMediaLogService(media::MediaLog* media_log); + ~MojoMediaLogService() final; + + // mojom::MediaLog implementation + void AddEvent(const media::MediaLogEvent& event) final; + + private: + media::MediaLog* media_log_; + + DISALLOW_COPY_AND_ASSIGN(MojoMediaLogService); +}; + +} // namespace media + +#endif // MEDIA_MOJO_CLIENTS_MOJO_MEDIA_LOG_SERVICE_H_
diff --git a/media/mojo/clients/mojo_renderer_unittest.cc b/media/mojo/clients/mojo_renderer_unittest.cc index 6b54148f..222543f 100644 --- a/media/mojo/clients/mojo_renderer_unittest.cc +++ b/media/mojo/clients/mojo_renderer_unittest.cc
@@ -105,6 +105,7 @@ void CreateAudioStream() { audio_stream_ = CreateStream(DemuxerStream::AUDIO); + audio_stream_->set_audio_decoder_config(TestAudioConfig::Normal()); streams_.push_back(audio_stream_.get()); EXPECT_CALL(demuxer_, GetAllStreams()).WillRepeatedly(Return(streams_)); }
diff --git a/media/mojo/clients/mojo_video_decoder.cc b/media/mojo/clients/mojo_video_decoder.cc index 37135b8a..637bf89 100644 --- a/media/mojo/clients/mojo_video_decoder.cc +++ b/media/mojo/clients/mojo_video_decoder.cc
@@ -26,11 +26,14 @@ MojoVideoDecoder::MojoVideoDecoder( scoped_refptr<base::SingleThreadTaskRunner> task_runner, GpuVideoAcceleratorFactories* gpu_factories, + MediaLog* media_log, mojom::VideoDecoderPtr remote_decoder) : task_runner_(task_runner), remote_decoder_info_(remote_decoder.PassInterface()), gpu_factories_(gpu_factories), client_binding_(this), + media_log_service_(media_log), + media_log_binding_(&media_log_service_), weak_factory_(this) { DVLOG(1) << __func__; } @@ -67,7 +70,7 @@ init_cb_ = init_cb; output_cb_ = output_cb; remote_decoder_->Initialize( - mojom::VideoDecoderConfig::From(config), low_delay, + config, low_delay, base::Bind(&MojoVideoDecoder::OnInitializeDone, base::Unretained(this))); } @@ -198,10 +201,12 @@ remote_decoder_.set_connection_error_handler( base::Bind(&MojoVideoDecoder::Stop, base::Unretained(this))); - // TODO(sandersd): Does this need its own error handler? mojom::VideoDecoderClientAssociatedPtrInfo client_ptr_info; client_binding_.Bind(mojo::MakeRequest(&client_ptr_info)); + mojom::MediaLogAssociatedPtrInfo media_log_ptr_info; + media_log_binding_.Bind(mojo::MakeRequest(&media_log_ptr_info)); + // TODO(sandersd): Better buffer sizing. mojo::ScopedDataPipeConsumerHandle remote_consumer_handle; mojo_decoder_buffer_writer_ = MojoDecoderBufferWriter::Create( @@ -217,9 +222,9 @@ } } - remote_decoder_->Construct(std::move(client_ptr_info), - std::move(remote_consumer_handle), - std::move(command_buffer_id)); + remote_decoder_->Construct( + std::move(client_ptr_info), std::move(media_log_ptr_info), + std::move(remote_consumer_handle), std::move(command_buffer_id)); } void MojoVideoDecoder::Stop() {
diff --git a/media/mojo/clients/mojo_video_decoder.h b/media/mojo/clients/mojo_video_decoder.h index 1f2f9f8..c8d9d27 100644 --- a/media/mojo/clients/mojo_video_decoder.h +++ b/media/mojo/clients/mojo_video_decoder.h
@@ -9,6 +9,7 @@ #include "base/memory/ref_counted.h" #include "base/memory/weak_ptr.h" #include "media/base/video_decoder.h" +#include "media/mojo/clients/mojo_media_log_service.h" #include "media/mojo/interfaces/video_decoder.mojom.h" #include "mojo/public/cpp/bindings/associated_binding.h" @@ -19,6 +20,7 @@ namespace media { class GpuVideoAcceleratorFactories; +class MediaLog; class MojoDecoderBufferWriter; // A VideoDecoder, for use in the renderer process, that proxies to a @@ -30,6 +32,7 @@ public: MojoVideoDecoder(scoped_refptr<base::SingleThreadTaskRunner> task_runner, GpuVideoAcceleratorFactories* gpu_factories, + MediaLog* media_log, mojom::VideoDecoderPtr remote_decoder); ~MojoVideoDecoder() final; @@ -87,7 +90,9 @@ std::unique_ptr<MojoDecoderBufferWriter> mojo_decoder_buffer_writer_; bool remote_decoder_bound_ = false; bool has_connection_error_ = false; - mojo::AssociatedBinding<VideoDecoderClient> client_binding_; + mojo::AssociatedBinding<mojom::VideoDecoderClient> client_binding_; + MojoMediaLogService media_log_service_; + mojo::AssociatedBinding<mojom::MediaLog> media_log_binding_; bool initialized_ = false; bool needs_bitstream_conversion_ = false;
diff --git a/media/mojo/common/media_type_converters.cc b/media/mojo/common/media_type_converters.cc index 5571a8b..d1f584c 100644 --- a/media/mojo/common/media_type_converters.cc +++ b/media/mojo/common/media_type_converters.cc
@@ -17,7 +17,6 @@ #include "media/base/decrypt_config.h" #include "media/base/encryption_scheme.h" #include "media/base/subsample_entry.h" -#include "media/base/video_decoder_config.h" #include "mojo/public/cpp/system/buffer.h" namespace mojo { @@ -36,44 +35,6 @@ }; // static -media::mojom::PatternPtr -TypeConverter<media::mojom::PatternPtr, media::EncryptionScheme::Pattern>:: - Convert(const media::EncryptionScheme::Pattern& input) { - media::mojom::PatternPtr mojo_pattern(media::mojom::Pattern::New()); - mojo_pattern->encrypt_blocks = input.encrypt_blocks(); - mojo_pattern->skip_blocks = input.skip_blocks(); - return mojo_pattern; -} - -// static -media::EncryptionScheme::Pattern TypeConverter< - media::EncryptionScheme::Pattern, - media::mojom::PatternPtr>::Convert(const media::mojom::PatternPtr& input) { - return media::EncryptionScheme::Pattern(input->encrypt_blocks, - input->skip_blocks); -} - -// static -media::mojom::EncryptionSchemePtr TypeConverter< - media::mojom::EncryptionSchemePtr, - media::EncryptionScheme>::Convert(const media::EncryptionScheme& input) { - media::mojom::EncryptionSchemePtr mojo_encryption_scheme( - media::mojom::EncryptionScheme::New()); - mojo_encryption_scheme->mode = input.mode(); - mojo_encryption_scheme->pattern = - media::mojom::Pattern::From(input.pattern()); - return mojo_encryption_scheme; -} - -// static -media::EncryptionScheme -TypeConverter<media::EncryptionScheme, media::mojom::EncryptionSchemePtr>:: - Convert(const media::mojom::EncryptionSchemePtr& input) { - return media::EncryptionScheme( - input->mode, input->pattern.To<media::EncryptionScheme::Pattern>()); -} - -// static media::mojom::DecryptConfigPtr TypeConverter<media::mojom::DecryptConfigPtr, media::DecryptConfig>::Convert( const media::DecryptConfig& input) { @@ -183,8 +144,7 @@ config->extra_data = input.extra_data(); config->seek_preroll = input.seek_preroll(); config->codec_delay = input.codec_delay(); - config->encryption_scheme = - media::mojom::EncryptionScheme::From(input.encryption_scheme()); + config->encryption_scheme = input.encryption_scheme(); return config; } @@ -195,45 +155,8 @@ media::AudioDecoderConfig config; config.Initialize(input->codec, input->sample_format, input->channel_layout, input->samples_per_second, input->extra_data, - input->encryption_scheme.To<media::EncryptionScheme>(), - input->seek_preroll, input->codec_delay); - return config; -} - -// static -media::mojom::VideoDecoderConfigPtr -TypeConverter<media::mojom::VideoDecoderConfigPtr, media::VideoDecoderConfig>:: - Convert(const media::VideoDecoderConfig& input) { - media::mojom::VideoDecoderConfigPtr config( - media::mojom::VideoDecoderConfig::New()); - config->codec = input.codec(); - config->profile = input.profile(); - config->format = input.format(); - config->color_space = input.color_space(); - config->coded_size = input.coded_size(); - config->visible_rect = input.visible_rect(); - config->natural_size = input.natural_size(); - config->extra_data = input.extra_data(); - config->encryption_scheme = - media::mojom::EncryptionScheme::From(input.encryption_scheme()); - config->color_space_info = input.color_space_info(); - if (input.hdr_metadata()) - config->hdr_metadata = *input.hdr_metadata(); - return config; -} - -// static -media::VideoDecoderConfig -TypeConverter<media::VideoDecoderConfig, media::mojom::VideoDecoderConfigPtr>:: - Convert(const media::mojom::VideoDecoderConfigPtr& input) { - media::VideoDecoderConfig config; - config.Initialize(input->codec, input->profile, input->format, - input->color_space, input->coded_size, input->visible_rect, - input->natural_size, input->extra_data, - input->encryption_scheme.To<media::EncryptionScheme>()); - config.set_color_space_info(input->color_space_info); - if (input->hdr_metadata) - config.set_hdr_metadata(*input->hdr_metadata); + input->encryption_scheme, input->seek_preroll, + input->codec_delay); return config; }
diff --git a/media/mojo/common/media_type_converters.h b/media/mojo/common/media_type_converters.h index c10c277..d99cf1b66 100644 --- a/media/mojo/common/media_type_converters.h +++ b/media/mojo/common/media_type_converters.h
@@ -17,8 +17,6 @@ class AudioDecoderConfig; class DecoderBuffer; class DecryptConfig; -class EncryptionScheme; -class VideoDecoderConfig; struct CdmConfig; struct CdmKeyInformation; } @@ -28,19 +26,6 @@ namespace mojo { template <> -struct TypeConverter<media::mojom::EncryptionSchemePtr, - media::EncryptionScheme> { - static media::mojom::EncryptionSchemePtr Convert( - const media::EncryptionScheme& input); -}; -template <> -struct TypeConverter<media::EncryptionScheme, - media::mojom::EncryptionSchemePtr> { - static media::EncryptionScheme Convert( - const media::mojom::EncryptionSchemePtr& input); -}; - -template <> struct TypeConverter<media::mojom::DecryptConfigPtr, media::DecryptConfig> { static media::mojom::DecryptConfigPtr Convert( const media::DecryptConfig& input); @@ -79,19 +64,6 @@ }; template <> -struct TypeConverter<media::mojom::VideoDecoderConfigPtr, - media::VideoDecoderConfig> { - static media::mojom::VideoDecoderConfigPtr Convert( - const media::VideoDecoderConfig& input); -}; -template <> -struct TypeConverter<media::VideoDecoderConfig, - media::mojom::VideoDecoderConfigPtr> { - static media::VideoDecoderConfig Convert( - const media::mojom::VideoDecoderConfigPtr& input); -}; - -template <> struct TypeConverter<media::mojom::CdmKeyInformationPtr, media::CdmKeyInformation> { static media::mojom::CdmKeyInformationPtr Convert(
diff --git a/media/mojo/common/media_type_converters_unittest.cc b/media/mojo/common/media_type_converters_unittest.cc index 7ba0fa5..3d5d2a5 100644 --- a/media/mojo/common/media_type_converters_unittest.cc +++ b/media/mojo/common/media_type_converters_unittest.cc
@@ -24,10 +24,6 @@ namespace { -static const gfx::Size kCodedSize(320, 240); -static const gfx::Rect kVisibleRect(320, 240); -static const gfx::Size kNaturalSize(320, 240); - void CompareBytes(uint8_t* original_data, uint8_t* result_data, size_t length) { EXPECT_GT(length, 0u); EXPECT_EQ(memcmp(original_data, result_data, length), 0); @@ -167,112 +163,6 @@ EXPECT_TRUE(buffer->decrypt_config()->iv().empty()); } -// TODO(tim): Check other properties. - -TEST(MediaTypeConvertersTest, ConvertAudioDecoderConfig_Normal) { - const uint8_t kExtraData[] = "config extra data"; - const std::vector<uint8_t> kExtraDataVector( - &kExtraData[0], &kExtraData[0] + arraysize(kExtraData)); - - AudioDecoderConfig config; - config.Initialize(kCodecAAC, kSampleFormatU8, CHANNEL_LAYOUT_SURROUND, 48000, - kExtraDataVector, Unencrypted(), base::TimeDelta(), 0); - mojom::AudioDecoderConfigPtr ptr(mojom::AudioDecoderConfig::From(config)); - EXPECT_FALSE(ptr->extra_data.empty()); - AudioDecoderConfig result(ptr.To<AudioDecoderConfig>()); - EXPECT_TRUE(result.Matches(config)); -} - -TEST(MediaTypeConvertersTest, ConvertAudioDecoderConfig_EmptyExtraData) { - AudioDecoderConfig config; - config.Initialize(kCodecAAC, kSampleFormatU8, CHANNEL_LAYOUT_SURROUND, 48000, - EmptyExtraData(), Unencrypted(), base::TimeDelta(), 0); - mojom::AudioDecoderConfigPtr ptr(mojom::AudioDecoderConfig::From(config)); - EXPECT_TRUE(ptr->extra_data.empty()); - AudioDecoderConfig result(ptr.To<AudioDecoderConfig>()); - EXPECT_TRUE(result.Matches(config)); -} - -TEST(MediaTypeConvertersTest, ConvertAudioDecoderConfig_Encrypted) { - AudioDecoderConfig config; - config.Initialize(kCodecAAC, kSampleFormatU8, CHANNEL_LAYOUT_SURROUND, 48000, - EmptyExtraData(), AesCtrEncryptionScheme(), - base::TimeDelta(), 0); - mojom::AudioDecoderConfigPtr ptr(mojom::AudioDecoderConfig::From(config)); - AudioDecoderConfig result(ptr.To<AudioDecoderConfig>()); - EXPECT_TRUE(result.Matches(config)); -} - -TEST(MediaTypeConvertersTest, ConvertVideoDecoderConfig_Normal) { - const uint8_t kExtraData[] = "config extra data"; - const std::vector<uint8_t> kExtraDataVector( - &kExtraData[0], &kExtraData[0] + arraysize(kExtraData)); - - VideoDecoderConfig config(kCodecVP8, VP8PROFILE_ANY, PIXEL_FORMAT_YV12, - COLOR_SPACE_UNSPECIFIED, kCodedSize, kVisibleRect, - kNaturalSize, kExtraDataVector, Unencrypted()); - mojom::VideoDecoderConfigPtr ptr(mojom::VideoDecoderConfig::From(config)); - EXPECT_FALSE(ptr->extra_data.empty()); - VideoDecoderConfig result(ptr.To<VideoDecoderConfig>()); - EXPECT_TRUE(result.Matches(config)); -} - -TEST(MediaTypeConvertersTest, ConvertVideoDecoderConfig_EmptyExtraData) { - VideoDecoderConfig config(kCodecVP8, VP8PROFILE_ANY, PIXEL_FORMAT_YV12, - COLOR_SPACE_UNSPECIFIED, kCodedSize, kVisibleRect, - kNaturalSize, EmptyExtraData(), Unencrypted()); - mojom::VideoDecoderConfigPtr ptr(mojom::VideoDecoderConfig::From(config)); - EXPECT_TRUE(ptr->extra_data.empty()); - VideoDecoderConfig result(ptr.To<VideoDecoderConfig>()); - EXPECT_TRUE(result.Matches(config)); -} - -TEST(MediaTypeConvertersTest, ConvertVideoDecoderConfig_Encrypted) { - VideoDecoderConfig config(kCodecVP8, VP8PROFILE_ANY, PIXEL_FORMAT_YV12, - COLOR_SPACE_UNSPECIFIED, kCodedSize, kVisibleRect, - kNaturalSize, EmptyExtraData(), - AesCtrEncryptionScheme()); - mojom::VideoDecoderConfigPtr ptr(mojom::VideoDecoderConfig::From(config)); - VideoDecoderConfig result(ptr.To<VideoDecoderConfig>()); - EXPECT_TRUE(result.Matches(config)); -} - -TEST(MediaTypeConvertersTest, ConvertVideoDecoderConfig_ColorSpaceInfo) { - VideoDecoderConfig config(kCodecVP8, VP8PROFILE_ANY, PIXEL_FORMAT_YV12, - COLOR_SPACE_UNSPECIFIED, kCodedSize, kVisibleRect, - kNaturalSize, EmptyExtraData(), Unencrypted()); - config.set_color_space_info(VideoColorSpace( - VideoColorSpace::PrimaryID::BT2020, - VideoColorSpace::TransferID::SMPTEST2084, - VideoColorSpace::MatrixID::BT2020_CL, gfx::ColorSpace::RangeID::LIMITED)); - mojom::VideoDecoderConfigPtr ptr(mojom::VideoDecoderConfig::From(config)); - VideoDecoderConfig result(ptr.To<VideoDecoderConfig>()); - EXPECT_TRUE(result.Matches(config)); -} - -TEST(MediaTypeConvertersTest, ConvertVideoDecoderConfig_HDRMetadata) { - VideoDecoderConfig config(kCodecVP8, VP8PROFILE_ANY, PIXEL_FORMAT_YV12, - COLOR_SPACE_UNSPECIFIED, kCodedSize, kVisibleRect, - kNaturalSize, EmptyExtraData(), Unencrypted()); - HDRMetadata hdr_metadata; - hdr_metadata.max_frame_average_light_level = 123; - hdr_metadata.max_content_light_level = 456; - hdr_metadata.mastering_metadata.primary_r.set_x(0.1f); - hdr_metadata.mastering_metadata.primary_r.set_y(0.2f); - hdr_metadata.mastering_metadata.primary_g.set_x(0.3f); - hdr_metadata.mastering_metadata.primary_g.set_y(0.4f); - hdr_metadata.mastering_metadata.primary_b.set_x(0.5f); - hdr_metadata.mastering_metadata.primary_b.set_y(0.6f); - hdr_metadata.mastering_metadata.white_point.set_x(0.7f); - hdr_metadata.mastering_metadata.white_point.set_y(0.8f); - hdr_metadata.mastering_metadata.luminance_max = 1000; - hdr_metadata.mastering_metadata.luminance_min = 0; - config.set_hdr_metadata(hdr_metadata); - mojom::VideoDecoderConfigPtr ptr(mojom::VideoDecoderConfig::From(config)); - VideoDecoderConfig result(ptr.To<VideoDecoderConfig>()); - EXPECT_TRUE(result.Matches(config)); -} - TEST(MediaTypeConvertersTest, ConvertCdmConfig) { CdmConfig config; config.allow_distinctive_identifier = true; @@ -334,20 +224,4 @@ CompareAudioBuffers(kSampleFormatPlanarF32, buffer, result); } -TEST(MediaTypeConvertersTest, ConvertEncryptionSchemeAesCbcWithPattern) { - // Original. - EncryptionScheme scheme(EncryptionScheme::CIPHER_MODE_AES_CBC, - EncryptionScheme::Pattern(1, 9)); - - // Convert to and back. - mojom::EncryptionSchemePtr ptr(mojom::EncryptionScheme::From(scheme)); - EncryptionScheme result(ptr.To<EncryptionScheme>()); - - EXPECT_TRUE(result.Matches(scheme)); - - // Verify a couple of negative cases. - EXPECT_FALSE(result.Matches(Unencrypted())); - EXPECT_FALSE(result.Matches(AesCtrEncryptionScheme())); -} - } // namespace media
diff --git a/media/mojo/interfaces/BUILD.gn b/media/mojo/interfaces/BUILD.gn index 9055e38e..ad90949 100644 --- a/media/mojo/interfaces/BUILD.gn +++ b/media/mojo/interfaces/BUILD.gn
@@ -13,6 +13,7 @@ "decryptor.mojom", "demuxer_stream.mojom", "interface_factory.mojom", + "media_log.mojom", "media_service.mojom", "media_types.mojom", "output_protection.mojom", @@ -41,9 +42,6 @@ "//url/mojo:url_mojom_gurl", "//url/mojo:url_mojom_origin", ] - - # TODO(crbug.com/714018): Convert the implementation to use OnceCallback. - use_once_callback = false } mojom("constants") {
diff --git a/media/mojo/interfaces/audio_decoder_config.typemap b/media/mojo/interfaces/audio_decoder_config.typemap new file mode 100644 index 0000000..a2d7d1a --- /dev/null +++ b/media/mojo/interfaces/audio_decoder_config.typemap
@@ -0,0 +1,27 @@ +# Copyright 2017 The Chromium Authors. All rights reserved. +# Use of this source code is governed by a BSD-style license that can be +# found in the LICENSE file. + +mojom = "//media/mojo/interfaces/media_types.mojom" + +public_headers = [ "//media/base/audio_decoder_config.h" ] + +traits_headers = + [ "//media/mojo/interfaces/audio_decoder_config_struct_traits.h" ] + +sources = [ + "//media/mojo/interfaces/audio_decoder_config_struct_traits.cc", +] + +public_deps = [ + "//base", + "//media", +] + +deps = [ + "//media/base/ipc", + "//mojo/common:struct_traits", +] + +# See media_types.typemap for enum mappings. +type_mappings = [ "media.mojom.AudioDecoderConfig=media::AudioDecoderConfig" ]
diff --git a/media/mojo/interfaces/audio_decoder_config_struct_traits.cc b/media/mojo/interfaces/audio_decoder_config_struct_traits.cc new file mode 100644 index 0000000..192e269 --- /dev/null +++ b/media/mojo/interfaces/audio_decoder_config_struct_traits.cc
@@ -0,0 +1,48 @@ +// Copyright 2017 The Chromium Authors. All rights reserved. +// Use of this source code is governed by a BSD-style license that can be +// found in the LICENSE file. + +#include "media/mojo/interfaces/audio_decoder_config_struct_traits.h" + +namespace mojo { + +// static +bool StructTraits<media::mojom::AudioDecoderConfigDataView, + media::AudioDecoderConfig>:: + Read(media::mojom::AudioDecoderConfigDataView input, + media::AudioDecoderConfig* output) { + media::AudioCodec codec; + if (!input.ReadCodec(&codec)) + return false; + + media::SampleFormat sample_format; + if (!input.ReadSampleFormat(&sample_format)) + return false; + + media::ChannelLayout channel_layout; + if (!input.ReadChannelLayout(&channel_layout)) + return false; + + std::vector<uint8_t> extra_data; + if (!input.ReadExtraData(&extra_data)) + return false; + + media::EncryptionScheme encryption_scheme; + if (!input.ReadEncryptionScheme(&encryption_scheme)) + return false; + + base::TimeDelta seek_preroll; + if (!input.ReadSeekPreroll(&seek_preroll)) + return false; + + output->Initialize(codec, sample_format, channel_layout, + input.samples_per_second(), extra_data, encryption_scheme, + seek_preroll, input.codec_delay()); + + if (!output->IsValidConfig()) + return false; + + return true; +} + +} // namespace mojo \ No newline at end of file
diff --git a/media/mojo/interfaces/audio_decoder_config_struct_traits.h b/media/mojo/interfaces/audio_decoder_config_struct_traits.h new file mode 100644 index 0000000..81b95bc --- /dev/null +++ b/media/mojo/interfaces/audio_decoder_config_struct_traits.h
@@ -0,0 +1,61 @@ +// Copyright 2017 The Chromium Authors. All rights reserved. +// Use of this source code is governed by a BSD-style license that can be +// found in the LICENSE file. + +#ifndef MEDIA_MOJO_INTERFACES_AUDIO_DECODER_CONFIG_STRUCT_TRAITS_H_ +#define MEDIA_MOJO_INTERFACES_AUDIO_DECODER_CONFIG_STRUCT_TRAITS_H_ + +#include "media/base/audio_decoder_config.h" +#include "media/base/ipc/media_param_traits.h" +#include "media/mojo/interfaces/encryption_scheme_struct_traits.h" +#include "media/mojo/interfaces/media_types.mojom.h" +#include "mojo/common/common_custom_types_struct_traits.h" + +namespace mojo { + +template <> +struct StructTraits<media::mojom::AudioDecoderConfigDataView, + media::AudioDecoderConfig> { + static media::AudioCodec codec(const media::AudioDecoderConfig& input) { + return input.codec(); + } + + static media::SampleFormat sample_format( + const media::AudioDecoderConfig& input) { + return input.sample_format(); + } + + static media::ChannelLayout channel_layout( + const media::AudioDecoderConfig& input) { + return input.channel_layout(); + } + + static int samples_per_second(const media::AudioDecoderConfig& input) { + return input.samples_per_second(); + } + + static const std::vector<uint8_t>& extra_data( + const media::AudioDecoderConfig& input) { + return input.extra_data(); + } + + static base::TimeDelta seek_preroll(const media::AudioDecoderConfig& input) { + return input.seek_preroll(); + } + + static int codec_delay(const media::AudioDecoderConfig& input) { + return input.codec_delay(); + } + + static const media::EncryptionScheme& encryption_scheme( + const media::AudioDecoderConfig& input) { + return input.encryption_scheme(); + } + + static bool Read(media::mojom::AudioDecoderConfigDataView input, + media::AudioDecoderConfig* output); +}; + +} // namespace mojo + +#endif // MEDIA_MOJO_INTERFACES_AUDIO_DECODER_CONFIG_STRUCT_TRAITS_H_
diff --git a/media/mojo/interfaces/audio_decoder_config_struct_traits_unittest.cc b/media/mojo/interfaces/audio_decoder_config_struct_traits_unittest.cc new file mode 100644 index 0000000..0ff6756 --- /dev/null +++ b/media/mojo/interfaces/audio_decoder_config_struct_traits_unittest.cc
@@ -0,0 +1,58 @@ +// Copyright 2017 The Chromium Authors. All rights reserved. +// Use of this source code is governed by a BSD-style license that can be +// found in the LICENSE file. + +#include "media/mojo/interfaces/audio_decoder_config_struct_traits.h" + +#include <utility> + +#include "base/macros.h" +#include "media/base/audio_decoder_config.h" +#include "media/base/media_util.h" +#include "testing/gtest/include/gtest/gtest.h" + +namespace media { + +TEST(AudioDecoderConfigStructTraitsTest, ConvertAudioDecoderConfig_Normal) { + const uint8_t kExtraData[] = "input extra data"; + const std::vector<uint8_t> kExtraDataVector( + &kExtraData[0], &kExtraData[0] + arraysize(kExtraData)); + + AudioDecoderConfig input; + input.Initialize(kCodecAAC, kSampleFormatU8, CHANNEL_LAYOUT_SURROUND, 48000, + kExtraDataVector, Unencrypted(), base::TimeDelta(), 0); + std::vector<uint8_t> data = + media::mojom::AudioDecoderConfig::Serialize(&input); + AudioDecoderConfig output; + EXPECT_TRUE( + media::mojom::AudioDecoderConfig::Deserialize(std::move(data), &output)); + EXPECT_TRUE(output.Matches(input)); +} + +TEST(AudioDecoderConfigStructTraitsTest, + ConvertAudioDecoderConfig_EmptyExtraData) { + AudioDecoderConfig input; + input.Initialize(kCodecAAC, kSampleFormatU8, CHANNEL_LAYOUT_SURROUND, 48000, + EmptyExtraData(), Unencrypted(), base::TimeDelta(), 0); + std::vector<uint8_t> data = + media::mojom::AudioDecoderConfig::Serialize(&input); + AudioDecoderConfig output; + EXPECT_TRUE( + media::mojom::AudioDecoderConfig::Deserialize(std::move(data), &output)); + EXPECT_TRUE(output.Matches(input)); +} + +TEST(AudioDecoderConfigStructTraitsTest, ConvertAudioDecoderConfig_Encrypted) { + AudioDecoderConfig input; + input.Initialize(kCodecAAC, kSampleFormatU8, CHANNEL_LAYOUT_SURROUND, 48000, + EmptyExtraData(), AesCtrEncryptionScheme(), + base::TimeDelta(), 0); + std::vector<uint8_t> data = + media::mojom::AudioDecoderConfig::Serialize(&input); + AudioDecoderConfig output; + EXPECT_TRUE( + media::mojom::AudioDecoderConfig::Deserialize(std::move(data), &output)); + EXPECT_TRUE(output.Matches(input)); +} + +} // namespace media
diff --git a/media/mojo/interfaces/encryption_scheme.typemap b/media/mojo/interfaces/encryption_scheme.typemap new file mode 100644 index 0000000..13a2c655 --- /dev/null +++ b/media/mojo/interfaces/encryption_scheme.typemap
@@ -0,0 +1,27 @@ +# Copyright 2017 The Chromium Authors. All rights reserved. +# Use of this source code is governed by a BSD-style license that can be +# found in the LICENSE file. + +mojom = "//media/mojo/interfaces/media_types.mojom" + +public_headers = [ "//media/base/encryption_scheme.h" ] + +traits_headers = [ "//media/mojo/interfaces/encryption_scheme_struct_traits.h" ] + +sources = [ + "//media/mojo/interfaces/encryption_scheme_struct_traits.cc", +] + +public_deps = [ + "//media", +] + +deps = [ + "//media/base/ipc", +] + +# See media_types.typemap for enum mappings. +type_mappings = [ + "media.mojom.Pattern=media::EncryptionScheme::Pattern", + "media.mojom.EncryptionScheme=media::EncryptionScheme", +]
diff --git a/media/mojo/interfaces/encryption_scheme_struct_traits.cc b/media/mojo/interfaces/encryption_scheme_struct_traits.cc new file mode 100644 index 0000000..e2052a93 --- /dev/null +++ b/media/mojo/interfaces/encryption_scheme_struct_traits.cc
@@ -0,0 +1,37 @@ +// Copyright 2017 The Chromium Authors. All rights reserved. +// Use of this source code is governed by a BSD-style license that can be +// found in the LICENSE file. + +#include "media/mojo/interfaces/encryption_scheme_struct_traits.h" + +namespace mojo { + +// static +bool StructTraits<media::mojom::PatternDataView, + media::EncryptionScheme::Pattern>:: + Read(media::mojom::PatternDataView input, + media::EncryptionScheme::Pattern* output) { + *output = media::EncryptionScheme::Pattern(input.encrypt_blocks(), + input.skip_blocks()); + return true; +} + +// static +bool StructTraits< + media::mojom::EncryptionSchemeDataView, + media::EncryptionScheme>::Read(media::mojom::EncryptionSchemeDataView input, + media::EncryptionScheme* output) { + media::EncryptionScheme::CipherMode mode; + if (!input.ReadMode(&mode)) + return false; + + media::EncryptionScheme::Pattern pattern; + if (!input.ReadPattern(&pattern)) + return false; + + *output = media::EncryptionScheme(mode, pattern); + + return true; +} + +} // namespace mojo \ No newline at end of file
diff --git a/media/mojo/interfaces/encryption_scheme_struct_traits.h b/media/mojo/interfaces/encryption_scheme_struct_traits.h new file mode 100644 index 0000000..7eaa35a --- /dev/null +++ b/media/mojo/interfaces/encryption_scheme_struct_traits.h
@@ -0,0 +1,49 @@ +// Copyright 2017 The Chromium Authors. All rights reserved. +// Use of this source code is governed by a BSD-style license that can be +// found in the LICENSE file. + +#ifndef MEDIA_MOJO_INTERFACES_ENCRYPTION_SCHEME_STRUCT_TRAITS_H_ +#define MEDIA_MOJO_INTERFACES_ENCRYPTION_SCHEME_STRUCT_TRAITS_H_ + +#include "media/base/encryption_scheme.h" +#include "media/base/ipc/media_param_traits.h" +#include "media/mojo/interfaces/media_types.mojom.h" + +namespace mojo { + +template <> +struct StructTraits<media::mojom::PatternDataView, + media::EncryptionScheme::Pattern> { + static uint32_t encrypt_blocks( + const media::EncryptionScheme::Pattern& input) { + return input.encrypt_blocks(); + } + + static uint32_t skip_blocks(const media::EncryptionScheme::Pattern& input) { + return input.skip_blocks(); + } + + static bool Read(media::mojom::PatternDataView input, + media::EncryptionScheme::Pattern* output); +}; + +template <> +struct StructTraits<media::mojom::EncryptionSchemeDataView, + media::EncryptionScheme> { + static media::EncryptionScheme::CipherMode mode( + const media::EncryptionScheme& input) { + return input.mode(); + } + + static media::EncryptionScheme::Pattern pattern( + const media::EncryptionScheme& input) { + return input.pattern(); + } + + static bool Read(media::mojom::EncryptionSchemeDataView input, + media::EncryptionScheme* output); +}; + +} // namespace mojo + +#endif // MEDIA_MOJO_INTERFACES_ENCRYPTION_SCHEME_STRUCT_TRAITS_H_
diff --git a/media/mojo/interfaces/encryption_scheme_struct_traits_unittest.cc b/media/mojo/interfaces/encryption_scheme_struct_traits_unittest.cc new file mode 100644 index 0000000..cb017a3f --- /dev/null +++ b/media/mojo/interfaces/encryption_scheme_struct_traits_unittest.cc
@@ -0,0 +1,31 @@ +// Copyright 2017 The Chromium Authors. All rights reserved. +// Use of this source code is governed by a BSD-style license that can be +// found in the LICENSE file. + +#include "media/mojo/interfaces/encryption_scheme_struct_traits.h" + +#include <utility> + +#include "media/base/encryption_scheme.h" +#include "media/base/media_util.h" +#include "testing/gtest/include/gtest/gtest.h" + +namespace media { + +TEST(EncryptionSchemeStructTraitsTest, + ConvertEncryptionSchemeAesCbcWithPattern) { + EncryptionScheme input(EncryptionScheme::CIPHER_MODE_AES_CBC, + EncryptionScheme::Pattern(1, 9)); + std::vector<uint8_t> data = media::mojom::EncryptionScheme::Serialize(&input); + + EncryptionScheme output; + EXPECT_TRUE( + media::mojom::EncryptionScheme::Deserialize(std::move(data), &output)); + EXPECT_TRUE(output.Matches(input)); + + // Verify a couple of negative cases. + EXPECT_FALSE(output.Matches(Unencrypted())); + EXPECT_FALSE(output.Matches(AesCtrEncryptionScheme())); +} + +} // namespace media
diff --git a/media/mojo/interfaces/media_log.mojom b/media/mojo/interfaces/media_log.mojom new file mode 100644 index 0000000..05f3b64 --- /dev/null +++ b/media/mojo/interfaces/media_log.mojom
@@ -0,0 +1,11 @@ +// Copyright 2017 The Chromium Authors. All rights reserved. +// Use of this source code is governed by a BSD-style license that can be +// found in the LICENSE file. + +module media.mojom; + +import "media/mojo/interfaces/media_types.mojom"; + +interface MediaLog { + AddEvent(MediaLogEvent event); +};
diff --git a/media/mojo/interfaces/media_types.mojom b/media/mojo/interfaces/media_types.mojom index 5448756c..bb40ad4f 100644 --- a/media/mojo/interfaces/media_types.mojom +++ b/media/mojo/interfaces/media_types.mojom
@@ -8,21 +8,29 @@ import "mojo/common/time.mojom"; import "ui/gfx/geometry/mojo/geometry.mojom"; +// See media/base/audio_codecs.h for descriptions. +[Native] +enum AudioCodec; + // See media/base/buffering_state.h for descriptions. [Native] enum BufferingState; +// See media/base/channel_layout.h for descriptions. +[Native] +enum ChannelLayout; + +// See media/base/video_types.h for descriptions. +[Native] +enum ColorSpace; + // See media/base/decode_status.h for descriptions. [Native] enum DecodeStatus; -// See media/base/audio_codecs.h for descriptions. +// See media/base/media_log_event.h for description. [Native] -enum AudioCodec; - -// See media/base/channel_layout.h for descriptions. -[Native] -enum ChannelLayout; +struct MediaLogEvent; // See media/base/output_device_info.h for descriptions. [Native] @@ -32,14 +40,6 @@ [Native] enum SampleFormat; -// See media/base/video_types.h for descriptions. -[Native] -enum VideoPixelFormat; - -// See media/base/video_types.h for descriptions. -[Native] -enum ColorSpace; - // See media/base/video_codecs.h for descriptions. [Native] enum VideoCodec; @@ -48,6 +48,10 @@ [Native] enum VideoCodecProfile; +// See media/base/video_types.h for descriptions. +[Native] +enum VideoPixelFormat; + // This defines a mojo transport format for media::EncryptionScheme::Pattern // See media/base/encryption_scheme.h for description. struct Pattern {
diff --git a/media/mojo/interfaces/media_types.typemap b/media/mojo/interfaces/media_types.typemap index cc8b655..f885864 100644 --- a/media/mojo/interfaces/media_types.typemap +++ b/media/mojo/interfaces/media_types.typemap
@@ -11,6 +11,7 @@ "//media/base/decode_status.h", "//media/base/encryption_scheme.h", "//media/base/hdr_metadata.h", + "//media/base/media_log_event.h", "//media/base/output_device_info.h", "//media/base/sample_format.h", "//media/base/subsample_entry.h", @@ -35,6 +36,7 @@ "media.mojom.ColorSpace=media::ColorSpace", "media.mojom.DecodeStatus=media::DecodeStatus", "media.mojom.EncryptionScheme.CipherMode=media::EncryptionScheme::CipherMode", + "media.mojom.MediaLogEvent=media::MediaLogEvent", "media.mojom.OutputDeviceStatus=media::OutputDeviceStatus", "media.mojom.SampleFormat=media::SampleFormat", "media.mojom.SubsampleEntry=media::SubsampleEntry",
diff --git a/media/mojo/interfaces/typemaps.gni b/media/mojo/interfaces/typemaps.gni index f485f00..1785024 100644 --- a/media/mojo/interfaces/typemaps.gni +++ b/media/mojo/interfaces/typemaps.gni
@@ -3,13 +3,16 @@ # found in the LICENSE file. typemaps = [ + "//media/mojo/interfaces/audio_decoder_config.typemap", "//media/mojo/interfaces/audio_parameters.typemap", "//media/mojo/interfaces/content_decryption_module.typemap", "//media/mojo/interfaces/decryptor.typemap", "//media/mojo/interfaces/demuxer_stream.typemap", + "//media/mojo/interfaces/encryption_scheme.typemap", "//media/mojo/interfaces/hdr_metadata.typemap", "//media/mojo/interfaces/media_types.typemap", "//media/mojo/interfaces/pipeline_statistics.typemap", "//media/mojo/interfaces/video_color_space.typemap", + "//media/mojo/interfaces/video_decoder_config.typemap", "//media/mojo/interfaces/video_frame.typemap", ]
diff --git a/media/mojo/interfaces/video_decoder.mojom b/media/mojo/interfaces/video_decoder.mojom index 36ae91f..3b1430d 100644 --- a/media/mojo/interfaces/video_decoder.mojom +++ b/media/mojo/interfaces/video_decoder.mojom
@@ -5,6 +5,7 @@ module media.mojom; import "gpu/ipc/common/sync_token.mojom"; +import "media/mojo/interfaces/media_log.mojom"; import "media/mojo/interfaces/media_types.mojom"; import "mojo/common/unguessable_token.mojom"; @@ -28,6 +29,7 @@ // TODO(sandersd): Rename to Initialize() if/when // media::VideoDecoder::Initialize() is renamed to Configure(). Construct(associated VideoDecoderClient client, + associated MediaLog media_log, handle<data_pipe_consumer> decoder_buffer_pipe, CommandBufferId? command_buffer_id);
diff --git a/media/mojo/interfaces/video_decoder_config.typemap b/media/mojo/interfaces/video_decoder_config.typemap new file mode 100644 index 0000000..41fbc5b --- /dev/null +++ b/media/mojo/interfaces/video_decoder_config.typemap
@@ -0,0 +1,27 @@ +# Copyright 2017 The Chromium Authors. All rights reserved. +# Use of this source code is governed by a BSD-style license that can be +# found in the LICENSE file. + +mojom = "//media/mojo/interfaces/media_types.mojom" + +public_headers = [ "//media/base/video_decoder_config.h" ] + +traits_headers = + [ "//media/mojo/interfaces/video_decoder_config_struct_traits.h" ] + +sources = [ + "video_decoder_config_struct_traits.cc", +] + +public_deps = [ + "//base", + "//media", +] + +deps = [ + "//media/base/ipc", + "//ui/gfx/geometry/mojo:struct_traits", +] + +# See media_types.typemap for enum mappings. +type_mappings = [ "media.mojom.VideoDecoderConfig=media::VideoDecoderConfig" ]
diff --git a/media/mojo/interfaces/video_decoder_config_struct_traits.cc b/media/mojo/interfaces/video_decoder_config_struct_traits.cc new file mode 100644 index 0000000..3e2c2457 --- /dev/null +++ b/media/mojo/interfaces/video_decoder_config_struct_traits.cc
@@ -0,0 +1,72 @@ +// Copyright 2017 The Chromium Authors. All rights reserved. +// Use of this source code is governed by a BSD-style license that can be +// found in the LICENSE file. + +#include "media/mojo/interfaces/video_decoder_config_struct_traits.h" + +namespace mojo { + +// static +bool StructTraits<media::mojom::VideoDecoderConfigDataView, + media::VideoDecoderConfig>:: + Read(media::mojom::VideoDecoderConfigDataView input, + media::VideoDecoderConfig* output) { + media::VideoCodec codec; + if (!input.ReadCodec(&codec)) + return false; + + media::VideoCodecProfile profile; + if (!input.ReadProfile(&profile)) + return false; + + media::VideoPixelFormat format; + if (!input.ReadFormat(&format)) + return false; + + media::ColorSpace color_space; + if (!input.ReadColorSpace(&color_space)) + return false; + + gfx::Size coded_size; + if (!input.ReadCodedSize(&coded_size)) + return false; + + gfx::Rect visible_rect; + if (!input.ReadVisibleRect(&visible_rect)) + return false; + + gfx::Size natural_size; + if (!input.ReadNaturalSize(&natural_size)) + return false; + + std::vector<uint8_t> extra_data; + if (!input.ReadExtraData(&extra_data)) + return false; + + media::EncryptionScheme encryption_scheme; + if (!input.ReadEncryptionScheme(&encryption_scheme)) + return false; + + media::VideoColorSpace color_space_info; + if (!input.ReadColorSpaceInfo(&color_space_info)) + return false; + + base::Optional<media::HDRMetadata> hdr_metadata; + if (!input.ReadHdrMetadata(&hdr_metadata)) + return false; + + output->Initialize(codec, profile, format, color_space, coded_size, + visible_rect, natural_size, extra_data, encryption_scheme); + + output->set_color_space_info(color_space_info); + + if (hdr_metadata) + output->set_hdr_metadata(hdr_metadata.value()); + + if (!output->IsValidConfig()) + return false; + + return true; +} + +} // namespace mojo \ No newline at end of file
diff --git a/media/mojo/interfaces/video_decoder_config_struct_traits.h b/media/mojo/interfaces/video_decoder_config_struct_traits.h new file mode 100644 index 0000000..c6cbb52 --- /dev/null +++ b/media/mojo/interfaces/video_decoder_config_struct_traits.h
@@ -0,0 +1,77 @@ +// Copyright 2017 The Chromium Authors. All rights reserved. +// Use of this source code is governed by a BSD-style license that can be +// found in the LICENSE file. + +#ifndef MEDIA_MOJO_INTERFACES_VIDEO_DECODER_CONFIG_STRUCT_TRAITS_H_ +#define MEDIA_MOJO_INTERFACES_VIDEO_DECODER_CONFIG_STRUCT_TRAITS_H_ + +#include "media/base/ipc/media_param_traits.h" +#include "media/base/video_decoder_config.h" +#include "media/mojo/interfaces/encryption_scheme_struct_traits.h" +#include "media/mojo/interfaces/hdr_metadata_struct_traits.h" +#include "media/mojo/interfaces/media_types.mojom.h" +#include "media/mojo/interfaces/video_color_space_struct_traits.h" +#include "ui/gfx/geometry/mojo/geometry_struct_traits.h" + +namespace mojo { + +template <> +struct StructTraits<media::mojom::VideoDecoderConfigDataView, + media::VideoDecoderConfig> { + static media::VideoCodec codec(const media::VideoDecoderConfig& input) { + return input.codec(); + } + + static media::VideoCodecProfile profile( + const media::VideoDecoderConfig& input) { + return input.profile(); + } + + static media::VideoPixelFormat format( + const media::VideoDecoderConfig& input) { + return input.format(); + } + + static media::ColorSpace color_space(const media::VideoDecoderConfig& input) { + return input.color_space(); + } + + static const gfx::Size& coded_size(const media::VideoDecoderConfig& input) { + return input.coded_size(); + } + + static const gfx::Rect& visible_rect(const media::VideoDecoderConfig& input) { + return input.visible_rect(); + } + + static const gfx::Size& natural_size(const media::VideoDecoderConfig& input) { + return input.natural_size(); + } + + static const std::vector<uint8_t>& extra_data( + const media::VideoDecoderConfig& input) { + return input.extra_data(); + } + + static const media::EncryptionScheme& encryption_scheme( + const media::VideoDecoderConfig& input) { + return input.encryption_scheme(); + } + + static const media::VideoColorSpace& color_space_info( + const media::VideoDecoderConfig& input) { + return input.color_space_info(); + } + + static const base::Optional<media::HDRMetadata>& hdr_metadata( + const media::VideoDecoderConfig& input) { + return input.hdr_metadata(); + } + + static bool Read(media::mojom::VideoDecoderConfigDataView input, + media::VideoDecoderConfig* output); +}; + +} // namespace mojo + +#endif // MEDIA_MOJO_INTERFACES_VIDEO_DECODER_CONFIG_STRUCT_TRAITS_H_
diff --git a/media/mojo/interfaces/video_decoder_config_struct_traits_unittest.cc b/media/mojo/interfaces/video_decoder_config_struct_traits_unittest.cc new file mode 100644 index 0000000..3b49841 --- /dev/null +++ b/media/mojo/interfaces/video_decoder_config_struct_traits_unittest.cc
@@ -0,0 +1,135 @@ +// Copyright 2017 The Chromium Authors. All rights reserved. +// Use of this source code is governed by a BSD-style license that can be +// found in the LICENSE file. + +#include "media/mojo/interfaces/video_decoder_config_struct_traits.h" + +#include <utility> + +#include "base/macros.h" +#include "media/base/media_util.h" +#include "media/base/video_decoder_config.h" +#include "testing/gtest/include/gtest/gtest.h" + +namespace media { + +namespace { + +static const gfx::Size kCodedSize(320, 240); +static const gfx::Rect kVisibleRect(320, 240); +static const gfx::Size kNaturalSize(320, 240); + +} // namespace + +TEST(VideoDecoderConfigStructTraitsTest, ConvertVideoDecoderConfig_Normal) { + const uint8_t kExtraData[] = "config extra data"; + const std::vector<uint8_t> kExtraDataVector( + &kExtraData[0], &kExtraData[0] + arraysize(kExtraData)); + VideoDecoderConfig input(kCodecVP8, VP8PROFILE_ANY, PIXEL_FORMAT_YV12, + COLOR_SPACE_UNSPECIFIED, kCodedSize, kVisibleRect, + kNaturalSize, kExtraDataVector, Unencrypted()); + std::vector<uint8_t> data = + media::mojom::VideoDecoderConfig::Serialize(&input); + VideoDecoderConfig output; + EXPECT_TRUE( + media::mojom::VideoDecoderConfig::Deserialize(std::move(data), &output)); + EXPECT_TRUE(output.Matches(input)); +} + +TEST(VideoDecoderConfigStructTraitsTest, + ConvertVideoDecoderConfig_EmptyExtraData) { + VideoDecoderConfig input(kCodecVP8, VP8PROFILE_ANY, PIXEL_FORMAT_YV12, + COLOR_SPACE_UNSPECIFIED, kCodedSize, kVisibleRect, + kNaturalSize, EmptyExtraData(), Unencrypted()); + std::vector<uint8_t> data = + media::mojom::VideoDecoderConfig::Serialize(&input); + VideoDecoderConfig output; + EXPECT_TRUE( + media::mojom::VideoDecoderConfig::Deserialize(std::move(data), &output)); + EXPECT_TRUE(output.Matches(input)); +} + +TEST(VideoDecoderConfigStructTraitsTest, ConvertVideoDecoderConfig_Encrypted) { + VideoDecoderConfig input(kCodecVP8, VP8PROFILE_ANY, PIXEL_FORMAT_YV12, + COLOR_SPACE_UNSPECIFIED, kCodedSize, kVisibleRect, + kNaturalSize, EmptyExtraData(), + AesCtrEncryptionScheme()); + std::vector<uint8_t> data = + media::mojom::VideoDecoderConfig::Serialize(&input); + VideoDecoderConfig output; + EXPECT_TRUE( + media::mojom::VideoDecoderConfig::Deserialize(std::move(data), &output)); + EXPECT_TRUE(output.Matches(input)); +} + +TEST(VideoDecoderConfigStructTraitsTest, + ConvertVideoDecoderConfig_ColorSpaceInfo) { + VideoDecoderConfig input(kCodecVP8, VP8PROFILE_ANY, PIXEL_FORMAT_YV12, + COLOR_SPACE_UNSPECIFIED, kCodedSize, kVisibleRect, + kNaturalSize, EmptyExtraData(), Unencrypted()); + input.set_color_space_info(VideoColorSpace( + VideoColorSpace::PrimaryID::BT2020, + VideoColorSpace::TransferID::SMPTEST2084, + VideoColorSpace::MatrixID::BT2020_CL, gfx::ColorSpace::RangeID::LIMITED)); + std::vector<uint8_t> data = + media::mojom::VideoDecoderConfig::Serialize(&input); + VideoDecoderConfig output; + EXPECT_TRUE( + media::mojom::VideoDecoderConfig::Deserialize(std::move(data), &output)); + EXPECT_TRUE(output.Matches(input)); +} + +TEST(VideoDecoderConfigStructTraitsTest, + ConvertVideoDecoderConfig_HDRMetadata) { + VideoDecoderConfig input(kCodecVP8, VP8PROFILE_ANY, PIXEL_FORMAT_YV12, + COLOR_SPACE_UNSPECIFIED, kCodedSize, kVisibleRect, + kNaturalSize, EmptyExtraData(), Unencrypted()); + HDRMetadata hdr_metadata; + hdr_metadata.max_frame_average_light_level = 123; + hdr_metadata.max_content_light_level = 456; + hdr_metadata.mastering_metadata.primary_r.set_x(0.1f); + hdr_metadata.mastering_metadata.primary_r.set_y(0.2f); + hdr_metadata.mastering_metadata.primary_g.set_x(0.3f); + hdr_metadata.mastering_metadata.primary_g.set_y(0.4f); + hdr_metadata.mastering_metadata.primary_b.set_x(0.5f); + hdr_metadata.mastering_metadata.primary_b.set_y(0.6f); + hdr_metadata.mastering_metadata.white_point.set_x(0.7f); + hdr_metadata.mastering_metadata.white_point.set_y(0.8f); + hdr_metadata.mastering_metadata.luminance_max = 1000; + hdr_metadata.mastering_metadata.luminance_min = 0; + input.set_hdr_metadata(hdr_metadata); + std::vector<uint8_t> data = + media::mojom::VideoDecoderConfig::Serialize(&input); + VideoDecoderConfig output; + EXPECT_TRUE( + media::mojom::VideoDecoderConfig::Deserialize(std::move(data), &output)); + EXPECT_TRUE(output.Matches(input)); +} + +TEST(VideoDecoderConfigStructTraitsTest, + ConvertVideoDecoderConfig_InvalidConfigs) { + // Create an invalid empty config. + VideoDecoderConfig input; + EXPECT_FALSE(input.IsValidConfig()); + + std::vector<uint8_t> data = + media::mojom::VideoDecoderConfig::Serialize(&input); + VideoDecoderConfig output; + + // Deserialize should only pass for valid configs. + EXPECT_FALSE( + media::mojom::VideoDecoderConfig::Deserialize(std::move(data), &output)); + + // Next try an non-empty invalid config. Natural size must not be zero. + const gfx::Size kInvalidNaturalSize(0, 0); + input.Initialize(kCodecVP8, VP8PROFILE_ANY, PIXEL_FORMAT_YV12, + COLOR_SPACE_UNSPECIFIED, kCodedSize, kVisibleRect, + kInvalidNaturalSize, EmptyExtraData(), Unencrypted()); + EXPECT_FALSE(input.IsValidConfig()); + + // Deserialize should again fail due to invalid config. + EXPECT_FALSE( + media::mojom::VideoDecoderConfig::Deserialize(std::move(data), &output)); +} + +} // namespace media
diff --git a/media/mojo/services/BUILD.gn b/media/mojo/services/BUILD.gn index 87b60ed..8cd21c59 100644 --- a/media/mojo/services/BUILD.gn +++ b/media/mojo/services/BUILD.gn
@@ -55,6 +55,8 @@ "mojo_demuxer_stream_adapter.h", "mojo_media_client.cc", "mojo_media_client.h", + "mojo_media_log.cc", + "mojo_media_log.h", "mojo_provision_fetcher.cc", "mojo_provision_fetcher.h", "mojo_renderer_service.cc",
diff --git a/media/mojo/services/gpu_mojo_media_client.cc b/media/mojo/services/gpu_mojo_media_client.cc index 786b64c..b46d574 100644 --- a/media/mojo/services/gpu_mojo_media_client.cc +++ b/media/mojo/services/gpu_mojo_media_client.cc
@@ -68,6 +68,7 @@ std::unique_ptr<VideoDecoder> GpuMojoMediaClient::CreateVideoDecoder( scoped_refptr<base::SingleThreadTaskRunner> task_runner, + MediaLog* media_log, mojom::CommandBufferIdPtr command_buffer_id, OutputWithReleaseMailboxCB output_cb) { static_cast<void>(media_gpu_channel_manager_);
diff --git a/media/mojo/services/gpu_mojo_media_client.h b/media/mojo/services/gpu_mojo_media_client.h index 9be197bc..a3c6cb40 100644 --- a/media/mojo/services/gpu_mojo_media_client.h +++ b/media/mojo/services/gpu_mojo_media_client.h
@@ -31,6 +31,7 @@ scoped_refptr<base::SingleThreadTaskRunner> task_runner) final; std::unique_ptr<VideoDecoder> CreateVideoDecoder( scoped_refptr<base::SingleThreadTaskRunner> task_runner, + MediaLog* media_log, mojom::CommandBufferIdPtr command_buffer_id, OutputWithReleaseMailboxCB output_cb) final; std::unique_ptr<CdmFactory> CreateCdmFactory(
diff --git a/media/mojo/services/mojo_audio_decoder_service.cc b/media/mojo/services/mojo_audio_decoder_service.cc index 2fd18de..c11f536 100644 --- a/media/mojo/services/mojo_audio_decoder_service.cc +++ b/media/mojo/services/mojo_audio_decoder_service.cc
@@ -32,42 +32,40 @@ client_.Bind(std::move(client)); } -void MojoAudioDecoderService::Initialize( - mojom::AudioDecoderConfigPtr config, - int32_t cdm_id, - const InitializeCallback& callback) { - DVLOG(1) << __func__ << " " - << config.To<media::AudioDecoderConfig>().AsHumanReadableString(); +void MojoAudioDecoderService::Initialize(const AudioDecoderConfig& config, + int32_t cdm_id, + InitializeCallback callback) { + DVLOG(1) << __func__ << " " << config.AsHumanReadableString(); // Get CdmContext from cdm_id if the stream is encrypted. CdmContext* cdm_context = nullptr; scoped_refptr<ContentDecryptionModule> cdm; - if (config.To<media::AudioDecoderConfig>().is_encrypted()) { + if (config.is_encrypted()) { if (!mojo_cdm_service_context_) { DVLOG(1) << "CDM service context not available."; - callback.Run(false, false); + std::move(callback).Run(false, false); return; } cdm = mojo_cdm_service_context_->GetCdm(cdm_id); if (!cdm) { DVLOG(1) << "CDM not found for CDM id: " << cdm_id; - callback.Run(false, false); + std::move(callback).Run(false, false); return; } cdm_context = cdm->GetCdmContext(); if (!cdm_context) { DVLOG(1) << "CDM context not available for CDM id: " << cdm_id; - callback.Run(false, false); + std::move(callback).Run(false, false); return; } } decoder_->Initialize( - config.To<media::AudioDecoderConfig>(), cdm_context, - base::Bind(&MojoAudioDecoderService::OnInitialized, weak_this_, callback, - cdm), + config, cdm_context, + base::Bind(&MojoAudioDecoderService::OnInitialized, weak_this_, + base::Passed(&callback), cdm), base::Bind(&MojoAudioDecoderService::OnAudioBufferReady, weak_this_)); } @@ -80,31 +78,31 @@ } void MojoAudioDecoderService::Decode(mojom::DecoderBufferPtr buffer, - const DecodeCallback& callback) { + DecodeCallback callback) { DVLOG(3) << __func__; mojo_decoder_buffer_reader_->ReadDecoderBuffer( std::move(buffer), base::BindOnce(&MojoAudioDecoderService::OnReadDone, - weak_this_, callback)); + weak_this_, std::move(callback))); } -void MojoAudioDecoderService::Reset(const ResetCallback& callback) { +void MojoAudioDecoderService::Reset(ResetCallback callback) { DVLOG(1) << __func__; - decoder_->Reset( - base::Bind(&MojoAudioDecoderService::OnResetDone, weak_this_, callback)); + decoder_->Reset(base::Bind(&MojoAudioDecoderService::OnResetDone, weak_this_, + base::Passed(&callback))); } void MojoAudioDecoderService::OnInitialized( - const InitializeCallback& callback, + InitializeCallback callback, scoped_refptr<ContentDecryptionModule> cdm, bool success) { DVLOG(1) << __func__ << " success:" << success; if (success) { cdm_ = cdm; - callback.Run(success, decoder_->NeedsBitstreamConversion()); + std::move(callback).Run(success, decoder_->NeedsBitstreamConversion()); } else { // Do not call decoder_->NeedsBitstreamConversion() if init failed. - callback.Run(false, false); + std::move(callback).Run(false, false); } } @@ -112,28 +110,28 @@ // to avoid running the |callback| after connection error happens and |this| is // deleted. It's not safe to run the |callback| after a connection error. -void MojoAudioDecoderService::OnReadDone(const DecodeCallback& callback, +void MojoAudioDecoderService::OnReadDone(DecodeCallback callback, scoped_refptr<DecoderBuffer> buffer) { DVLOG(3) << __func__ << " success:" << !!buffer; if (!buffer) { - callback.Run(DecodeStatus::DECODE_ERROR); + std::move(callback).Run(DecodeStatus::DECODE_ERROR); return; } decoder_->Decode(buffer, base::Bind(&MojoAudioDecoderService::OnDecodeStatus, - weak_this_, callback)); + weak_this_, base::Passed(&callback))); } -void MojoAudioDecoderService::OnDecodeStatus(const DecodeCallback& callback, +void MojoAudioDecoderService::OnDecodeStatus(DecodeCallback callback, media::DecodeStatus status) { DVLOG(3) << __func__ << " status:" << status; - callback.Run(status); + std::move(callback).Run(status); } -void MojoAudioDecoderService::OnResetDone(const ResetCallback& callback) { +void MojoAudioDecoderService::OnResetDone(ResetCallback callback) { DVLOG(1) << __func__; - callback.Run(); + std::move(callback).Run(); } void MojoAudioDecoderService::OnAudioBufferReady(
diff --git a/media/mojo/services/mojo_audio_decoder_service.h b/media/mojo/services/mojo_audio_decoder_service.h index 6230892..37b27957 100644 --- a/media/mojo/services/mojo_audio_decoder_service.h +++ b/media/mojo/services/mojo_audio_decoder_service.h
@@ -32,32 +32,29 @@ // mojom::AudioDecoder implementation void Construct(mojom::AudioDecoderClientAssociatedPtrInfo client) final; - void Initialize(mojom::AudioDecoderConfigPtr config, + void Initialize(const AudioDecoderConfig& config, int32_t cdm_id, - const InitializeCallback& callback) final; + InitializeCallback callback) final; void SetDataSource(mojo::ScopedDataPipeConsumerHandle receive_pipe) final; - void Decode(mojom::DecoderBufferPtr buffer, - const DecodeCallback& callback) final; + void Decode(mojom::DecoderBufferPtr buffer, DecodeCallback callback) final; - void Reset(const ResetCallback& callback) final; + void Reset(ResetCallback callback) final; private: // Called by |decoder_| upon finishing initialization. - void OnInitialized(const InitializeCallback& callback, + void OnInitialized(InitializeCallback callback, scoped_refptr<ContentDecryptionModule> cdm, bool success); - void OnReadDone(const DecodeCallback& callback, - scoped_refptr<DecoderBuffer> buffer); + void OnReadDone(DecodeCallback callback, scoped_refptr<DecoderBuffer> buffer); // Called by |decoder_| when DecoderBuffer is accepted or rejected. - void OnDecodeStatus(const DecodeCallback& callback, - media::DecodeStatus status); + void OnDecodeStatus(DecodeCallback callback, media::DecodeStatus status); // Called by |decoder_| when reset sequence is finished. - void OnResetDone(const ResetCallback& callback); + void OnResetDone(ResetCallback callback); // Called by |decoder_| for each decoded buffer. void OnAudioBufferReady(const scoped_refptr<AudioBuffer>& audio_buffer);
diff --git a/media/mojo/services/mojo_audio_output_stream_provider.cc b/media/mojo/services/mojo_audio_output_stream_provider.cc index 6141a48..01ec1422 100644 --- a/media/mojo/services/mojo_audio_output_stream_provider.cc +++ b/media/mojo/services/mojo_audio_output_stream_provider.cc
@@ -30,7 +30,7 @@ void MojoAudioOutputStreamProvider::Acquire( mojom::AudioOutputStreamRequest stream_request, const AudioParameters& params, - const AcquireCallback& callback) { + AcquireCallback callback) { DCHECK(thread_checker_.CalledOnValidThread()); if (audio_output_) { LOG(ERROR) << "Output acquired twice.";
diff --git a/media/mojo/services/mojo_audio_output_stream_provider.h b/media/mojo/services/mojo_audio_output_stream_provider.h index 5a1b2f5..2d014d6 100644 --- a/media/mojo/services/mojo_audio_output_stream_provider.h +++ b/media/mojo/services/mojo_audio_output_stream_provider.h
@@ -41,7 +41,7 @@ // mojom::AudioOutputStreamProvider implementation. void Acquire(mojom::AudioOutputStreamRequest stream_request, const AudioParameters& params, - const AcquireCallback& acquire_callback) override; + AcquireCallback acquire_callback) override; // Called when |audio_output_| had an error. void OnError();
diff --git a/media/mojo/services/mojo_cdm_promise.cc b/media/mojo/services/mojo_cdm_promise.cc index da9ae8c..01b013be 100644 --- a/media/mojo/services/mojo_cdm_promise.cc +++ b/media/mojo/services/mojo_cdm_promise.cc
@@ -27,8 +27,8 @@ } template <typename... T> -MojoCdmPromise<T...>::MojoCdmPromise(const CallbackType& callback) - : callback_(callback) { +MojoCdmPromise<T...>::MojoCdmPromise(CallbackType callback) + : callback_(std::move(callback)) { DCHECK(!callback_.is_null()); } @@ -46,8 +46,7 @@ MarkPromiseSettled(); mojom::CdmPromiseResultPtr cdm_promise_result(mojom::CdmPromiseResult::New()); cdm_promise_result->success = true; - callback_.Run(std::move(cdm_promise_result), result...); - callback_.Reset(); + std::move(callback_).Run(std::move(cdm_promise_result), result...); } template <typename... T> @@ -55,8 +54,8 @@ uint32_t system_code, const std::string& error_message) { MarkPromiseSettled(); - callback_.Run(GetRejectResult(exception, system_code, error_message), T()...); - callback_.Reset(); + std::move(callback_).Run( + GetRejectResult(exception, system_code, error_message), T()...); } template class MojoCdmPromise<>;
diff --git a/media/mojo/services/mojo_cdm_promise.h b/media/mojo/services/mojo_cdm_promise.h index cfb7930..dcd5e2f 100644 --- a/media/mojo/services/mojo_cdm_promise.h +++ b/media/mojo/services/mojo_cdm_promise.h
@@ -19,9 +19,9 @@ class MojoCdmPromise : public CdmPromiseTemplate<T...> { public: using CallbackType = - base::Callback<void(mojom::CdmPromiseResultPtr, const T&...)>; + base::OnceCallback<void(mojom::CdmPromiseResultPtr, const T&...)>; - explicit MojoCdmPromise(const CallbackType& callback); + explicit MojoCdmPromise(CallbackType callback); ~MojoCdmPromise() final; // CdmPromiseTemplate<> implementation.
diff --git a/media/mojo/services/mojo_cdm_service.cc b/media/mojo/services/mojo_cdm_service.cc index 29c3e78..98257c09 100644 --- a/media/mojo/services/mojo_cdm_service.cc +++ b/media/mojo/services/mojo_cdm_service.cc
@@ -55,7 +55,7 @@ void MojoCdmService::Initialize(const std::string& key_system, const std::string& security_origin, mojom::CdmConfigPtr cdm_config, - const InitializeCallback& callback) { + InitializeCallback callback) { DVLOG(1) << __func__ << ": " << key_system; DCHECK(!cdm_); @@ -66,57 +66,60 @@ base::Bind(&MojoCdmService::OnSessionClosed, weak_this), base::Bind(&MojoCdmService::OnSessionKeysChange, weak_this), base::Bind(&MojoCdmService::OnSessionExpirationUpdate, weak_this), - base::Bind(&MojoCdmService::OnCdmCreated, weak_this, callback)); + base::Bind(&MojoCdmService::OnCdmCreated, weak_this, + base::Passed(&callback))); } void MojoCdmService::SetServerCertificate( const std::vector<uint8_t>& certificate_data, - const SetServerCertificateCallback& callback) { + SetServerCertificateCallback callback) { DVLOG(2) << __func__; - cdm_->SetServerCertificate(certificate_data, - base::MakeUnique<SimpleMojoCdmPromise>(callback)); + cdm_->SetServerCertificate( + certificate_data, + base::MakeUnique<SimpleMojoCdmPromise>(std::move(callback))); } void MojoCdmService::CreateSessionAndGenerateRequest( CdmSessionType session_type, EmeInitDataType init_data_type, const std::vector<uint8_t>& init_data, - const CreateSessionAndGenerateRequestCallback& callback) { + CreateSessionAndGenerateRequestCallback callback) { DVLOG(2) << __func__; cdm_->CreateSessionAndGenerateRequest( session_type, init_data_type, init_data, - base::MakeUnique<NewSessionMojoCdmPromise>(callback)); + base::MakeUnique<NewSessionMojoCdmPromise>(std::move(callback))); } void MojoCdmService::LoadSession(CdmSessionType session_type, const std::string& session_id, - const LoadSessionCallback& callback) { + LoadSessionCallback callback) { DVLOG(2) << __func__; - cdm_->LoadSession(session_type, session_id, - base::MakeUnique<NewSessionMojoCdmPromise>(callback)); + cdm_->LoadSession( + session_type, session_id, + base::MakeUnique<NewSessionMojoCdmPromise>(std::move(callback))); } void MojoCdmService::UpdateSession(const std::string& session_id, const std::vector<uint8_t>& response, - const UpdateSessionCallback& callback) { + UpdateSessionCallback callback) { DVLOG(2) << __func__; - cdm_->UpdateSession( - session_id, response, - std::unique_ptr<SimpleCdmPromise>(new SimpleMojoCdmPromise(callback))); + cdm_->UpdateSession(session_id, response, + std::unique_ptr<SimpleCdmPromise>( + new SimpleMojoCdmPromise(std::move(callback)))); } void MojoCdmService::CloseSession(const std::string& session_id, - const CloseSessionCallback& callback) { + CloseSessionCallback callback) { DVLOG(2) << __func__; - cdm_->CloseSession(session_id, - base::MakeUnique<SimpleMojoCdmPromise>(callback)); + cdm_->CloseSession( + session_id, base::MakeUnique<SimpleMojoCdmPromise>(std::move(callback))); } void MojoCdmService::RemoveSession(const std::string& session_id, - const RemoveSessionCallback& callback) { + RemoveSessionCallback callback) { DVLOG(2) << __func__; - cdm_->RemoveSession(session_id, - base::MakeUnique<SimpleMojoCdmPromise>(callback)); + cdm_->RemoveSession( + session_id, base::MakeUnique<SimpleMojoCdmPromise>(std::move(callback))); } scoped_refptr<ContentDecryptionModule> MojoCdmService::GetCdm() { @@ -124,7 +127,7 @@ } void MojoCdmService::OnCdmCreated( - const InitializeCallback& callback, + InitializeCallback callback, const scoped_refptr<::media::ContentDecryptionModule>& cdm, const std::string& error_message) { mojom::CdmPromiseResultPtr cdm_promise_result(mojom::CdmPromiseResult::New()); @@ -136,7 +139,7 @@ cdm_promise_result->exception = CdmPromise::Exception::NOT_SUPPORTED_ERROR; cdm_promise_result->system_code = 0; cdm_promise_result->error_message = error_message; - callback.Run(std::move(cdm_promise_result), 0, nullptr); + std::move(callback).Run(std::move(cdm_promise_result), 0, nullptr); return; } @@ -158,8 +161,8 @@ DVLOG(1) << __func__ << ": CDM successfully created with ID " << cdm_id_; cdm_promise_result->success = true; - callback.Run(std::move(cdm_promise_result), cdm_id_, - std::move(decryptor_service)); + std::move(callback).Run(std::move(cdm_promise_result), cdm_id_, + std::move(decryptor_service)); } void MojoCdmService::OnSessionMessage(const std::string& session_id,
diff --git a/media/mojo/services/mojo_cdm_service.h b/media/mojo/services/mojo_cdm_service.h index cd77fe24..c7b7c82 100644 --- a/media/mojo/services/mojo_cdm_service.h +++ b/media/mojo/services/mojo_cdm_service.h
@@ -53,31 +53,31 @@ void Initialize(const std::string& key_system, const std::string& security_origin, mojom::CdmConfigPtr cdm_config, - const InitializeCallback& callback) final; + InitializeCallback callback) final; void SetServerCertificate(const std::vector<uint8_t>& certificate_data, - const SetServerCertificateCallback& callback) final; + SetServerCertificateCallback callback) final; void CreateSessionAndGenerateRequest( CdmSessionType session_type, EmeInitDataType init_data_type, const std::vector<uint8_t>& init_data, - const CreateSessionAndGenerateRequestCallback& callback) final; + CreateSessionAndGenerateRequestCallback callback) final; void LoadSession(CdmSessionType session_type, const std::string& session_id, - const LoadSessionCallback& callback) final; + LoadSessionCallback callback) final; void UpdateSession(const std::string& session_id, const std::vector<uint8_t>& response, - const UpdateSessionCallback& callback) final; + UpdateSessionCallback callback) final; void CloseSession(const std::string& session_id, - const CloseSessionCallback& callback) final; + CloseSessionCallback callback) final; void RemoveSession(const std::string& session_id, - const RemoveSessionCallback& callback) final; + RemoveSessionCallback callback) final; // Get CDM to be used by the media pipeline. scoped_refptr<::media::ContentDecryptionModule> GetCdm(); private: // Callback for CdmFactory::Create(). - void OnCdmCreated(const InitializeCallback& callback, + void OnCdmCreated(InitializeCallback callback, const scoped_refptr<::media::ContentDecryptionModule>& cdm, const std::string& error_message);
diff --git a/media/mojo/services/mojo_decryptor_service.cc b/media/mojo/services/mojo_decryptor_service.cc index 0e140b7..e96a74b 100644 --- a/media/mojo/services/mojo_decryptor_service.cc +++ b/media/mojo/services/mojo_decryptor_service.cc
@@ -71,11 +71,12 @@ void MojoDecryptorService::Decrypt(StreamType stream_type, mojom::DecoderBufferPtr encrypted, - const DecryptCallback& callback) { + DecryptCallback callback) { DVLOG(3) << __func__; mojo_decoder_buffer_reader_->ReadDecoderBuffer( - std::move(encrypted), base::BindOnce(&MojoDecryptorService::OnReadDone, - weak_this_, stream_type, callback)); + std::move(encrypted), + base::BindOnce(&MojoDecryptorService::OnReadDone, weak_this_, stream_type, + std::move(callback))); } void MojoDecryptorService::CancelDecrypt(StreamType stream_type) { @@ -84,41 +85,39 @@ } void MojoDecryptorService::InitializeAudioDecoder( - mojom::AudioDecoderConfigPtr config, - const InitializeAudioDecoderCallback& callback) { + const AudioDecoderConfig& config, + InitializeAudioDecoderCallback callback) { DVLOG(1) << __func__; decryptor_->InitializeAudioDecoder( - config.To<AudioDecoderConfig>(), - base::Bind(&MojoDecryptorService::OnAudioDecoderInitialized, weak_this_, - callback)); + config, base::Bind(&MojoDecryptorService::OnAudioDecoderInitialized, + weak_this_, base::Passed(&callback))); } void MojoDecryptorService::InitializeVideoDecoder( - mojom::VideoDecoderConfigPtr config, - const InitializeVideoDecoderCallback& callback) { + const VideoDecoderConfig& config, + InitializeVideoDecoderCallback callback) { DVLOG(1) << __func__; decryptor_->InitializeVideoDecoder( - config.To<VideoDecoderConfig>(), - base::Bind(&MojoDecryptorService::OnVideoDecoderInitialized, weak_this_, - callback)); + config, base::Bind(&MojoDecryptorService::OnVideoDecoderInitialized, + weak_this_, base::Passed(&callback))); } void MojoDecryptorService::DecryptAndDecodeAudio( mojom::DecoderBufferPtr encrypted, - const DecryptAndDecodeAudioCallback& callback) { + DecryptAndDecodeAudioCallback callback) { DVLOG(3) << __func__; mojo_decoder_buffer_reader_->ReadDecoderBuffer( - std::move(encrypted), - base::BindOnce(&MojoDecryptorService::OnAudioRead, weak_this_, callback)); + std::move(encrypted), base::BindOnce(&MojoDecryptorService::OnAudioRead, + weak_this_, std::move(callback))); } void MojoDecryptorService::DecryptAndDecodeVideo( mojom::DecoderBufferPtr encrypted, - const DecryptAndDecodeVideoCallback& callback) { + DecryptAndDecodeVideoCallback callback) { DVLOG(3) << __func__; mojo_decoder_buffer_reader_->ReadDecoderBuffer( - std::move(encrypted), - base::BindOnce(&MojoDecryptorService::OnVideoRead, weak_this_, callback)); + std::move(encrypted), base::BindOnce(&MojoDecryptorService::OnVideoRead, + weak_this_, std::move(callback))); } void MojoDecryptorService::ResetDecoder(StreamType stream_type) { @@ -132,20 +131,20 @@ } void MojoDecryptorService::OnReadDone(StreamType stream_type, - const DecryptCallback& callback, + DecryptCallback callback, scoped_refptr<DecoderBuffer> buffer) { if (!buffer) { - callback.Run(Status::kError, nullptr); + std::move(callback).Run(Status::kError, nullptr); return; } - decryptor_->Decrypt( - stream_type, std::move(buffer), - base::Bind(&MojoDecryptorService::OnDecryptDone, weak_this_, callback)); + decryptor_->Decrypt(stream_type, std::move(buffer), + base::Bind(&MojoDecryptorService::OnDecryptDone, + weak_this_, base::Passed(&callback))); } void MojoDecryptorService::OnDecryptDone( - const DecryptCallback& callback, + DecryptCallback callback, Status status, const scoped_refptr<DecoderBuffer>& buffer) { DVLOG_IF(1, status != Status::kSuccess) << __func__ << "(" << status << ")"; @@ -153,62 +152,61 @@ if (!buffer) { DCHECK_NE(status, Status::kSuccess); - callback.Run(status, nullptr); + std::move(callback).Run(status, nullptr); return; } mojom::DecoderBufferPtr mojo_buffer = mojo_decoder_buffer_writer_->WriteDecoderBuffer(buffer); if (!mojo_buffer) { - callback.Run(Status::kError, nullptr); + std::move(callback).Run(Status::kError, nullptr); return; } - callback.Run(status, std::move(mojo_buffer)); + std::move(callback).Run(status, std::move(mojo_buffer)); } void MojoDecryptorService::OnAudioDecoderInitialized( - const InitializeAudioDecoderCallback& callback, + InitializeAudioDecoderCallback callback, bool success) { DVLOG(1) << __func__ << "(" << success << ")"; - callback.Run(success); + std::move(callback).Run(success); } void MojoDecryptorService::OnVideoDecoderInitialized( - const InitializeVideoDecoderCallback& callback, + InitializeVideoDecoderCallback callback, bool success) { DVLOG(1) << __func__ << "(" << success << ")"; - callback.Run(success); + std::move(callback).Run(success); } -void MojoDecryptorService::OnAudioRead( - const DecryptAndDecodeAudioCallback& callback, - scoped_refptr<DecoderBuffer> buffer) { +void MojoDecryptorService::OnAudioRead(DecryptAndDecodeAudioCallback callback, + scoped_refptr<DecoderBuffer> buffer) { if (!buffer) { - callback.Run(Status::kError, std::vector<mojom::AudioBufferPtr>()); + std::move(callback).Run(Status::kError, + std::vector<mojom::AudioBufferPtr>()); return; } decryptor_->DecryptAndDecodeAudio( - std::move(buffer), - base::Bind(&MojoDecryptorService::OnAudioDecoded, weak_this_, callback)); + std::move(buffer), base::Bind(&MojoDecryptorService::OnAudioDecoded, + weak_this_, base::Passed(&callback))); } -void MojoDecryptorService::OnVideoRead( - const DecryptAndDecodeVideoCallback& callback, - scoped_refptr<DecoderBuffer> buffer) { +void MojoDecryptorService::OnVideoRead(DecryptAndDecodeVideoCallback callback, + scoped_refptr<DecoderBuffer> buffer) { if (!buffer) { - callback.Run(Status::kError, nullptr, nullptr); + std::move(callback).Run(Status::kError, nullptr, nullptr); return; } decryptor_->DecryptAndDecodeVideo( - std::move(buffer), - base::Bind(&MojoDecryptorService::OnVideoDecoded, weak_this_, callback)); + std::move(buffer), base::Bind(&MojoDecryptorService::OnVideoDecoded, + weak_this_, base::Passed(&callback))); } void MojoDecryptorService::OnAudioDecoded( - const DecryptAndDecodeAudioCallback& callback, + DecryptAndDecodeAudioCallback callback, Status status, const media::Decryptor::AudioFrames& frames) { DVLOG_IF(1, status != Status::kSuccess) << __func__ << "(" << status << ")"; @@ -220,11 +218,11 @@ for (const auto& frame : frames) audio_buffers.push_back(mojom::AudioBuffer::From(frame)); - callback.Run(status, std::move(audio_buffers)); + std::move(callback).Run(status, std::move(audio_buffers)); } void MojoDecryptorService::OnVideoDecoded( - const DecryptAndDecodeVideoCallback& callback, + DecryptAndDecodeVideoCallback callback, Status status, const scoped_refptr<VideoFrame>& frame) { DVLOG_IF(1, status != Status::kSuccess) << __func__ << "(" << status << ")"; @@ -232,7 +230,7 @@ if (!frame) { DCHECK_NE(status, Status::kSuccess); - callback.Run(status, nullptr, nullptr); + std::move(callback).Run(status, nullptr, nullptr); return; } @@ -244,7 +242,7 @@ mojo::MakeRequest(&releaser)); } - callback.Run(status, std::move(frame), std::move(releaser)); + std::move(callback).Run(status, std::move(frame), std::move(releaser)); } } // namespace media
diff --git a/media/mojo/services/mojo_decryptor_service.h b/media/mojo/services/mojo_decryptor_service.h index e3f9909..be49029 100644 --- a/media/mojo/services/mojo_decryptor_service.h +++ b/media/mojo/services/mojo_decryptor_service.h
@@ -46,49 +46,45 @@ mojo::ScopedDataPipeProducerHandle transmit_pipe) final; void Decrypt(StreamType stream_type, mojom::DecoderBufferPtr encrypted, - const DecryptCallback& callback) final; + DecryptCallback callback) final; void CancelDecrypt(StreamType stream_type) final; - void InitializeAudioDecoder( - mojom::AudioDecoderConfigPtr config, - const InitializeAudioDecoderCallback& callback) final; - void InitializeVideoDecoder( - mojom::VideoDecoderConfigPtr config, - const InitializeVideoDecoderCallback& callback) final; - void DecryptAndDecodeAudio( - mojom::DecoderBufferPtr encrypted, - const DecryptAndDecodeAudioCallback& callback) final; - void DecryptAndDecodeVideo( - mojom::DecoderBufferPtr encrypted, - const DecryptAndDecodeVideoCallback& callback) final; + void InitializeAudioDecoder(const AudioDecoderConfig& config, + InitializeAudioDecoderCallback callback) final; + void InitializeVideoDecoder(const VideoDecoderConfig& config, + InitializeVideoDecoderCallback callback) final; + void DecryptAndDecodeAudio(mojom::DecoderBufferPtr encrypted, + DecryptAndDecodeAudioCallback callback) final; + void DecryptAndDecodeVideo(mojom::DecoderBufferPtr encrypted, + DecryptAndDecodeVideoCallback callback) final; void ResetDecoder(StreamType stream_type) final; void DeinitializeDecoder(StreamType stream_type) final; private: void OnReadDone(StreamType stream_type, - const DecryptCallback& callback, + DecryptCallback callback, scoped_refptr<DecoderBuffer> buffer); // Callback executed once Decrypt() is done. - void OnDecryptDone(const DecryptCallback& callback, + void OnDecryptDone(DecryptCallback callback, Status status, const scoped_refptr<DecoderBuffer>& buffer); // Callbacks executed once decoder initialized. - void OnAudioDecoderInitialized(const InitializeAudioDecoderCallback& callback, + void OnAudioDecoderInitialized(InitializeAudioDecoderCallback callback, bool success); - void OnVideoDecoderInitialized(const InitializeVideoDecoderCallback& callback, + void OnVideoDecoderInitialized(InitializeVideoDecoderCallback callback, bool success); - void OnAudioRead(const DecryptAndDecodeAudioCallback& callback, + void OnAudioRead(DecryptAndDecodeAudioCallback callback, scoped_refptr<DecoderBuffer> buffer); - void OnVideoRead(const DecryptAndDecodeVideoCallback& callback, + void OnVideoRead(DecryptAndDecodeVideoCallback callback, scoped_refptr<DecoderBuffer> buffer); // Callbacks executed when DecryptAndDecode are done. - void OnAudioDecoded(const DecryptAndDecodeAudioCallback& callback, + void OnAudioDecoded(DecryptAndDecodeAudioCallback callback, Status status, const media::Decryptor::AudioFrames& frames); - void OnVideoDecoded(const DecryptAndDecodeVideoCallback& callback, + void OnVideoDecoded(DecryptAndDecodeVideoCallback callback, Status status, const scoped_refptr<VideoFrame>& frame);
diff --git a/media/mojo/services/mojo_demuxer_stream_adapter.cc b/media/mojo/services/mojo_demuxer_stream_adapter.cc index 17a73eb1..23e0a7ca 100644 --- a/media/mojo/services/mojo_demuxer_stream_adapter.cc +++ b/media/mojo/services/mojo_demuxer_stream_adapter.cc
@@ -74,8 +74,8 @@ void MojoDemuxerStreamAdapter::OnStreamReady( Type type, mojo::ScopedDataPipeConsumerHandle consumer_handle, - mojom::AudioDecoderConfigPtr audio_config, - mojom::VideoDecoderConfigPtr video_config) { + const base::Optional<AudioDecoderConfig>& audio_config, + const base::Optional<VideoDecoderConfig>& video_config) { DVLOG(1) << __func__; DCHECK_EQ(UNKNOWN, type_); DCHECK(consumer_handle.is_valid()); @@ -93,8 +93,8 @@ void MojoDemuxerStreamAdapter::OnBufferReady( Status status, mojom::DecoderBufferPtr buffer, - mojom::AudioDecoderConfigPtr audio_config, - mojom::VideoDecoderConfigPtr video_config) { + const base::Optional<AudioDecoderConfig>& audio_config, + const base::Optional<VideoDecoderConfig>& video_config) { DVLOG(3) << __func__; DCHECK(!read_cb_.is_null()); DCHECK_NE(type_, UNKNOWN); @@ -127,18 +127,18 @@ } void MojoDemuxerStreamAdapter::UpdateConfig( - mojom::AudioDecoderConfigPtr audio_config, - mojom::VideoDecoderConfigPtr video_config) { + const base::Optional<AudioDecoderConfig>& audio_config, + const base::Optional<VideoDecoderConfig>& video_config) { DCHECK_NE(type_, UNKNOWN); switch(type_) { case AUDIO: DCHECK(audio_config && !video_config); - audio_config_ = audio_config.To<AudioDecoderConfig>(); + audio_config_ = audio_config.value(); break; case VIDEO: DCHECK(video_config && !audio_config); - video_config_ = video_config.To<VideoDecoderConfig>(); + video_config_ = video_config.value(); break; default: NOTREACHED();
diff --git a/media/mojo/services/mojo_demuxer_stream_adapter.h b/media/mojo/services/mojo_demuxer_stream_adapter.h index 4db24ec..8350899 100644 --- a/media/mojo/services/mojo_demuxer_stream_adapter.h +++ b/media/mojo/services/mojo_demuxer_stream_adapter.h
@@ -10,6 +10,7 @@ #include "base/macros.h" #include "base/memory/weak_ptr.h" +#include "base/optional.h" #include "media/base/audio_decoder_config.h" #include "media/base/demuxer_stream.h" #include "media/base/video_decoder_config.h" @@ -48,20 +49,20 @@ private: void OnStreamReady(Type type, mojo::ScopedDataPipeConsumerHandle consumer_handle, - mojom::AudioDecoderConfigPtr audio_config, - mojom::VideoDecoderConfigPtr video_config); + const base::Optional<AudioDecoderConfig>& audio_config, + const base::Optional<VideoDecoderConfig>& video_config); // The callback from |demuxer_stream_| that a read operation has completed. // |read_cb| is a callback from the client who invoked Read() on |this|. void OnBufferReady(Status status, mojom::DecoderBufferPtr buffer, - mojom::AudioDecoderConfigPtr audio_config, - mojom::VideoDecoderConfigPtr video_config); + const base::Optional<AudioDecoderConfig>& audio_config, + const base::Optional<VideoDecoderConfig>& video_config); void OnBufferRead(scoped_refptr<DecoderBuffer> buffer); - void UpdateConfig(mojom::AudioDecoderConfigPtr audio_config, - mojom::VideoDecoderConfigPtr video_config); + void UpdateConfig(const base::Optional<AudioDecoderConfig>& audio_config, + const base::Optional<VideoDecoderConfig>& video_config); // See constructor for descriptions. mojom::DemuxerStreamPtr demuxer_stream_;
diff --git a/media/mojo/services/mojo_media_client.cc b/media/mojo/services/mojo_media_client.cc index 6c9207a..2f2e0818 100644 --- a/media/mojo/services/mojo_media_client.cc +++ b/media/mojo/services/mojo_media_client.cc
@@ -28,6 +28,7 @@ std::unique_ptr<VideoDecoder> MojoMediaClient::CreateVideoDecoder( scoped_refptr<base::SingleThreadTaskRunner> task_runner, + MediaLog* media_log, mojom::CommandBufferIdPtr command_buffer_id, OutputWithReleaseMailboxCB output_cb) { return nullptr;
diff --git a/media/mojo/services/mojo_media_client.h b/media/mojo/services/mojo_media_client.h index a3e64921..d96798f 100644 --- a/media/mojo/services/mojo_media_client.h +++ b/media/mojo/services/mojo_media_client.h
@@ -63,6 +63,7 @@ // See https://crbug.com/733828. virtual std::unique_ptr<VideoDecoder> CreateVideoDecoder( scoped_refptr<base::SingleThreadTaskRunner> task_runner, + MediaLog* media_log, mojom::CommandBufferIdPtr command_buffer_id, OutputWithReleaseMailboxCB output_cb);
diff --git a/media/mojo/services/mojo_media_log.cc b/media/mojo/services/mojo_media_log.cc new file mode 100644 index 0000000..f13f13e --- /dev/null +++ b/media/mojo/services/mojo_media_log.cc
@@ -0,0 +1,28 @@ +// Copyright 2017 The Chromium Authors. All rights reserved. +// Use of this source code is governed by a BSD-style license that can be +// found in the LICENSE file. + +#include "media/mojo/services/mojo_media_log.h" + +#include "base/logging.h" + +namespace media { + +// TODO(sandersd): Do we need to respond to the channel closing? +MojoMediaLog::MojoMediaLog( + mojo::AssociatedInterfacePtr<mojom::MediaLog> remote_media_log) + : remote_media_log_(std::move(remote_media_log)) { + DVLOG(1) << __func__; +} + +MojoMediaLog::~MojoMediaLog() { + DVLOG(1) << __func__; +} + +void MojoMediaLog::AddEvent(std::unique_ptr<MediaLogEvent> event) { + DVLOG(1) << __func__; + DCHECK(event); + remote_media_log_->AddEvent(*event); +} + +} // namespace media
diff --git a/media/mojo/services/mojo_media_log.h b/media/mojo/services/mojo_media_log.h new file mode 100644 index 0000000..bf46c38 --- /dev/null +++ b/media/mojo/services/mojo_media_log.h
@@ -0,0 +1,35 @@ +// Copyright 2017 The Chromium Authors. All rights reserved. +// Use of this source code is governed by a BSD-style license that can be +// found in the LICENSE file. + +#ifndef MEDIA_MOJO_SERVICES_MOJO_MEDIA_LOG_H_ +#define MEDIA_MOJO_SERVICES_MOJO_MEDIA_LOG_H_ + +#include <memory> + +#include "base/macros.h" +#include "media/base/media_log.h" +#include "media/mojo/interfaces/media_log.mojom.h" +#include "mojo/public/cpp/bindings/associated_interface_ptr.h" + +namespace media { + +class MojoMediaLog final : public MediaLog { + public: + // TODO(sandersd): Template on Ptr type to support non-associated. + explicit MojoMediaLog( + mojo::AssociatedInterfacePtr<mojom::MediaLog> remote_media_log); + ~MojoMediaLog() final; + + // MediaLog implementation. + void AddEvent(std::unique_ptr<MediaLogEvent> event) override; + + private: + mojo::AssociatedInterfacePtr<mojom::MediaLog> remote_media_log_; + + DISALLOW_COPY_AND_ASSIGN(MojoMediaLog); +}; + +} // namespace media + +#endif // MEDIA_MOJO_SERVICES_MOJO_MEDIA_LOG_H_
diff --git a/media/mojo/services/mojo_renderer_service.cc b/media/mojo/services/mojo_renderer_service.cc index 81661f86..7f45af51 100644 --- a/media/mojo/services/mojo_renderer_service.cc +++ b/media/mojo/services/mojo_renderer_service.cc
@@ -80,7 +80,7 @@ base::Optional<std::vector<mojom::DemuxerStreamPtr>> streams, const base::Optional<GURL>& media_url, const base::Optional<GURL>& first_party_for_cookies, - const InitializeCallback& callback) { + InitializeCallback callback) { DVLOG(1) << __func__; DCHECK_EQ(state_, STATE_UNINITIALIZED); @@ -90,8 +90,8 @@ if (media_url == base::nullopt) { DCHECK(streams.has_value()); media_resource_.reset(new MediaResourceShim( - std::move(*streams), - base::Bind(&MojoRendererService::OnStreamReady, weak_this_, callback))); + std::move(*streams), base::Bind(&MojoRendererService::OnStreamReady, + weak_this_, base::Passed(&callback)))); return; } @@ -102,17 +102,17 @@ renderer_->Initialize( media_resource_.get(), this, base::Bind(&MojoRendererService::OnRendererInitializeDone, weak_this_, - callback)); + base::Passed(&callback))); } -void MojoRendererService::Flush(const FlushCallback& callback) { +void MojoRendererService::Flush(FlushCallback callback) { DVLOG(2) << __func__; DCHECK_EQ(state_, STATE_PLAYING); state_ = STATE_FLUSHING; CancelPeriodicMediaTimeUpdates(); - renderer_->Flush( - base::Bind(&MojoRendererService::OnFlushCompleted, weak_this_, callback)); + renderer_->Flush(base::Bind(&MojoRendererService::OnFlushCompleted, + weak_this_, base::Passed(&callback))); } void MojoRendererService::StartPlayingFrom(base::TimeDelta time_delta) { @@ -132,11 +132,10 @@ renderer_->SetVolume(volume); } -void MojoRendererService::SetCdm(int32_t cdm_id, - const SetCdmCallback& callback) { +void MojoRendererService::SetCdm(int32_t cdm_id, SetCdmCallback callback) { if (!mojo_cdm_service_context_) { DVLOG(1) << "CDM service context not available."; - callback.Run(false); + std::move(callback).Run(false); return; } @@ -144,19 +143,20 @@ mojo_cdm_service_context_->GetCdm(cdm_id); if (!cdm) { DVLOG(1) << "CDM not found: " << cdm_id; - callback.Run(false); + std::move(callback).Run(false); return; } CdmContext* cdm_context = cdm->GetCdmContext(); if (!cdm_context) { DVLOG(1) << "CDM context not available: " << cdm_id; - callback.Run(false); + std::move(callback).Run(false); return; } - renderer_->SetCdm(cdm_context, base::Bind(&MojoRendererService::OnCdmAttached, - weak_this_, cdm, callback)); + renderer_->SetCdm(cdm_context, + base::Bind(&MojoRendererService::OnCdmAttached, weak_this_, + cdm, base::Passed(&callback))); } void MojoRendererService::OnError(PipelineStatus error) { @@ -201,29 +201,29 @@ } void MojoRendererService::OnStreamReady( - const base::Callback<void(bool)>& callback) { + base::OnceCallback<void(bool)> callback) { DCHECK_EQ(state_, STATE_INITIALIZING); renderer_->Initialize( media_resource_.get(), this, base::Bind(&MojoRendererService::OnRendererInitializeDone, weak_this_, - callback)); + base::Passed(&callback))); } void MojoRendererService::OnRendererInitializeDone( - const base::Callback<void(bool)>& callback, + base::OnceCallback<void(bool)> callback, PipelineStatus status) { DVLOG(1) << __func__; DCHECK_EQ(state_, STATE_INITIALIZING); if (status != PIPELINE_OK) { state_ = STATE_ERROR; - callback.Run(false); + std::move(callback).Run(false); return; } state_ = STATE_PLAYING; - callback.Run(true); + std::move(callback).Run(true); } void MojoRendererService::UpdateMediaTime(bool force) { @@ -256,27 +256,27 @@ base::Bind(&MojoRendererService::UpdateMediaTime, weak_this_, false)); } -void MojoRendererService::OnFlushCompleted(const FlushCallback& callback) { +void MojoRendererService::OnFlushCompleted(FlushCallback callback) { DVLOG(1) << __func__; DCHECK_EQ(state_, STATE_FLUSHING); state_ = STATE_PLAYING; - callback.Run(); + std::move(callback).Run(); } void MojoRendererService::OnCdmAttached( scoped_refptr<ContentDecryptionModule> cdm, - const base::Callback<void(bool)>& callback, + base::OnceCallback<void(bool)> callback, bool success) { DVLOG(1) << __func__ << "(" << success << ")"; if (success) cdm_ = cdm; - callback.Run(success); + std::move(callback).Run(success); } void MojoRendererService::InitiateScopedSurfaceRequest( - const InitiateScopedSurfaceRequestCallback& callback) { + InitiateScopedSurfaceRequestCallback callback) { if (initiate_surface_request_cb_.is_null()) { // |renderer_| is likely not of type MediaPlayerRenderer. // This is an unexpected call, and the connection should be closed. @@ -289,7 +289,7 @@ return; } - callback.Run(initiate_surface_request_cb_.Run()); + std::move(callback).Run(initiate_surface_request_cb_.Run()); } } // namespace media
diff --git a/media/mojo/services/mojo_renderer_service.h b/media/mojo/services/mojo_renderer_service.h index 734af43..9d2a83c 100644 --- a/media/mojo/services/mojo_renderer_service.h +++ b/media/mojo/services/mojo_renderer_service.h
@@ -66,14 +66,14 @@ base::Optional<std::vector<mojom::DemuxerStreamPtr>> streams, const base::Optional<GURL>& media_url, const base::Optional<GURL>& first_party_for_cookies, - const InitializeCallback& callback) final; - void Flush(const FlushCallback& callback) final; + InitializeCallback callback) final; + void Flush(FlushCallback callback) final; void StartPlayingFrom(base::TimeDelta time_delta) final; void SetPlaybackRate(double playback_rate) final; void SetVolume(float volume) final; - void SetCdm(int32_t cdm_id, const SetCdmCallback& callback) final; + void SetCdm(int32_t cdm_id, SetCdmCallback callback) final; void InitiateScopedSurfaceRequest( - const InitiateScopedSurfaceRequestCallback& callback) final; + InitiateScopedSurfaceRequestCallback callback) final; void set_bad_message_cb(base::Closure bad_message_cb) { bad_message_cb_ = bad_message_cb; @@ -100,10 +100,10 @@ // Called when the MediaResourceShim is ready to go (has a config, // pipe handle, etc) and can be handed off to a renderer for use. - void OnStreamReady(const base::Callback<void(bool)>& callback); + void OnStreamReady(base::OnceCallback<void(bool)> callback); // Called when |audio_renderer_| initialization has completed. - void OnRendererInitializeDone(const base::Callback<void(bool)>& callback, + void OnRendererInitializeDone(base::OnceCallback<void(bool)> callback, PipelineStatus status); // Periodically polls the media time from the renderer and notifies the client @@ -115,11 +115,11 @@ void SchedulePeriodicMediaTimeUpdates(); // Callback executed once Flush() completes. - void OnFlushCompleted(const FlushCallback& callback); + void OnFlushCompleted(FlushCallback callback); // Callback executed once SetCdm() completes. void OnCdmAttached(scoped_refptr<ContentDecryptionModule> cdm, - const base::Callback<void(bool)>& callback, + base::OnceCallback<void(bool)> callback, bool success); base::WeakPtr<MojoCdmServiceContext> mojo_cdm_service_context_;
diff --git a/media/mojo/services/mojo_video_decoder_service.cc b/media/mojo/services/mojo_video_decoder_service.cc index 2c4885c..1c4d1ef 100644 --- a/media/mojo/services/mojo_video_decoder_service.cc +++ b/media/mojo/services/mojo_video_decoder_service.cc
@@ -16,6 +16,7 @@ #include "media/mojo/common/media_type_converters.h" #include "media/mojo/common/mojo_decoder_buffer_converter.h" #include "media/mojo/services/mojo_media_client.h" +#include "media/mojo/services/mojo_media_log.h" #include "mojo/public/c/system/types.h" #include "mojo/public/cpp/system/buffer.h" #include "mojo/public/cpp/system/handle.h" @@ -32,6 +33,7 @@ void MojoVideoDecoderService::Construct( mojom::VideoDecoderClientAssociatedPtrInfo client, + mojom::MediaLogAssociatedPtrInfo media_log, mojo::ScopedDataPipeConsumerHandle decoder_buffer_pipe, mojom::CommandBufferIdPtr command_buffer_id) { DVLOG(1) << __func__; @@ -41,92 +43,96 @@ return; } - decoder_ = mojo_media_client_->CreateVideoDecoder( - base::ThreadTaskRunnerHandle::Get(), std::move(command_buffer_id), - base::Bind(&MojoVideoDecoderService::OnDecoderOutput, weak_this_)); - client_.Bind(std::move(client)); + mojom::MediaLogAssociatedPtr media_log_ptr; + media_log_ptr.Bind(std::move(media_log)); + media_log_ = base::MakeUnique<MojoMediaLog>(std::move(media_log_ptr)); + mojo_decoder_buffer_reader_.reset( new MojoDecoderBufferReader(std::move(decoder_buffer_pipe))); + + decoder_ = mojo_media_client_->CreateVideoDecoder( + base::ThreadTaskRunnerHandle::Get(), media_log_.get(), + std::move(command_buffer_id), + base::Bind(&MojoVideoDecoderService::OnDecoderOutput, weak_this_)); } -void MojoVideoDecoderService::Initialize(mojom::VideoDecoderConfigPtr config, +void MojoVideoDecoderService::Initialize(const VideoDecoderConfig& config, bool low_delay, - const InitializeCallback& callback) { + InitializeCallback callback) { DVLOG(1) << __func__; if (!decoder_) { - callback.Run(false, false, 1); + std::move(callback).Run(false, false, 1); return; } decoder_->Initialize( - config.To<VideoDecoderConfig>(), low_delay, nullptr, + config, low_delay, nullptr, base::Bind(&MojoVideoDecoderService::OnDecoderInitialized, weak_this_, - callback), + base::Passed(&callback)), base::Bind(&MojoVideoDecoderService::OnDecoderOutput, weak_this_, MojoMediaClient::ReleaseMailboxCB())); } void MojoVideoDecoderService::Decode(mojom::DecoderBufferPtr buffer, - const DecodeCallback& callback) { + DecodeCallback callback) { DVLOG(2) << __func__; if (!decoder_) { - callback.Run(DecodeStatus::DECODE_ERROR); + std::move(callback).Run(DecodeStatus::DECODE_ERROR); return; } mojo_decoder_buffer_reader_->ReadDecoderBuffer( std::move(buffer), base::BindOnce(&MojoVideoDecoderService::OnDecoderRead, - weak_this_, callback)); + weak_this_, std::move(callback))); } -void MojoVideoDecoderService::Reset(const ResetCallback& callback) { +void MojoVideoDecoderService::Reset(ResetCallback callback) { DVLOG(1) << __func__; if (!decoder_) { - callback.Run(); + std::move(callback).Run(); return; } decoder_->Reset(base::Bind(&MojoVideoDecoderService::OnDecoderReset, - weak_this_, callback)); + weak_this_, base::Passed(&callback))); } -void MojoVideoDecoderService::OnDecoderInitialized( - const InitializeCallback& callback, - bool success) { +void MojoVideoDecoderService::OnDecoderInitialized(InitializeCallback callback, + bool success) { DVLOG(1) << __func__; DCHECK(decoder_); - callback.Run(success, decoder_->NeedsBitstreamConversion(), - decoder_->GetMaxDecodeRequests()); + std::move(callback).Run(success, decoder_->NeedsBitstreamConversion(), + decoder_->GetMaxDecodeRequests()); } void MojoVideoDecoderService::OnDecoderRead( - const DecodeCallback& callback, + DecodeCallback callback, scoped_refptr<DecoderBuffer> buffer) { if (!buffer) { // TODO(sandersd): Close the channel. - callback.Run(DecodeStatus::DECODE_ERROR); + std::move(callback).Run(DecodeStatus::DECODE_ERROR); return; } decoder_->Decode( buffer, base::Bind(&MojoVideoDecoderService::OnDecoderDecoded, weak_this_, - callback)); + base::Passed(&callback))); } -void MojoVideoDecoderService::OnDecoderDecoded(const DecodeCallback& callback, +void MojoVideoDecoderService::OnDecoderDecoded(DecodeCallback callback, DecodeStatus status) { DVLOG(2) << __func__; - callback.Run(status); + std::move(callback).Run(status); } -void MojoVideoDecoderService::OnDecoderReset(const ResetCallback& callback) { +void MojoVideoDecoderService::OnDecoderReset(ResetCallback callback) { DVLOG(1) << __func__; - callback.Run(); + std::move(callback).Run(); } void MojoVideoDecoderService::OnDecoderOutput(
diff --git a/media/mojo/services/mojo_video_decoder_service.h b/media/mojo/services/mojo_video_decoder_service.h index 54e91a2c..93bf6edb 100644 --- a/media/mojo/services/mojo_video_decoder_service.h +++ b/media/mojo/services/mojo_video_decoder_service.h
@@ -24,6 +24,7 @@ class DecoderBuffer; class MojoDecoderBufferReader; class MojoMediaClient; +class MojoMediaLog; class VideoDecoder; class VideoFrame; @@ -36,14 +37,14 @@ // mojom::VideoDecoder implementation void Construct(mojom::VideoDecoderClientAssociatedPtrInfo client, + mojom::MediaLogAssociatedPtrInfo media_log, mojo::ScopedDataPipeConsumerHandle decoder_buffer_pipe, mojom::CommandBufferIdPtr command_buffer_id) final; - void Initialize(mojom::VideoDecoderConfigPtr config, + void Initialize(const VideoDecoderConfig& config, bool low_delay, - const InitializeCallback& callback) final; - void Decode(mojom::DecoderBufferPtr buffer, - const DecodeCallback& callback) final; - void Reset(const ResetCallback& callback) final; + InitializeCallback callback) final; + void Decode(mojom::DecoderBufferPtr buffer, DecodeCallback callback) final; + void Reset(ResetCallback callback) final; void OnReleaseMailbox(const base::UnguessableToken& release_token, const gpu::SyncToken& release_sync_token) final; @@ -52,16 +53,17 @@ // running mojom::VideoDecoder callbacks after connection error happens and // |this| is deleted. It's not safe to run the callbacks after a connection // error. - void OnDecoderInitialized(const InitializeCallback& callback, bool success); - void OnDecoderRead(const DecodeCallback& callback, + void OnDecoderInitialized(InitializeCallback callback, bool success); + void OnDecoderRead(DecodeCallback callback, scoped_refptr<DecoderBuffer> buffer); - void OnDecoderDecoded(const DecodeCallback& callback, DecodeStatus status); - void OnDecoderReset(const ResetCallback& callback); + void OnDecoderDecoded(DecodeCallback callback, DecodeStatus status); + void OnDecoderReset(ResetCallback callback); void OnDecoderOutput(MojoMediaClient::ReleaseMailboxCB, const scoped_refptr<VideoFrame>& frame); mojom::VideoDecoderClientAssociatedPtr client_; + std::unique_ptr<MojoMediaLog> media_log_; std::unique_ptr<MojoDecoderBufferReader> mojo_decoder_buffer_reader_; MojoMediaClient* mojo_media_client_;
diff --git a/media/renderers/default_renderer_factory.cc b/media/renderers/default_renderer_factory.cc index 2410d1b..814c5fbd 100644 --- a/media/renderers/default_renderer_factory.cc +++ b/media/renderers/default_renderer_factory.cc
@@ -79,7 +79,7 @@ if (decoder_factory_) { decoder_factory_->CreateVideoDecoders(media_task_runner, gpu_factories, - &video_decoders); + media_log_, &video_decoders); } video_decoders.push_back(base::MakeUnique<GpuVideoDecoder>( gpu_factories, request_overlay_info_cb, media_log_));
diff --git a/net/cookies/cookie_monster.cc b/net/cookies/cookie_monster.cc index d084a239..8145802 100644 --- a/net/cookies/cookie_monster.cc +++ b/net/cookies/cookie_monster.cc
@@ -610,18 +610,18 @@ } // Task class for DeleteAllCreatedBetween call. -class CookieMonster::DeleteAllCreatedBetweenTask : public DeleteTask<int> { +class CookieMonster::DeleteAllCreatedBetweenTask : public DeleteTask<uint32_t> { public: DeleteAllCreatedBetweenTask(CookieMonster* cookie_monster, const Time& delete_begin, const Time& delete_end, DeleteCallback callback) - : DeleteTask<int>(cookie_monster, std::move(callback)), + : DeleteTask<uint32_t>(cookie_monster, std::move(callback)), delete_begin_(delete_begin), delete_end_(delete_end) {} // DeleteTask: - int RunDeleteTask() override; + uint32_t RunDeleteTask() override; protected: ~DeleteAllCreatedBetweenTask() override {} @@ -633,14 +633,14 @@ DISALLOW_COPY_AND_ASSIGN(DeleteAllCreatedBetweenTask); }; -int CookieMonster::DeleteAllCreatedBetweenTask::RunDeleteTask() { +uint32_t CookieMonster::DeleteAllCreatedBetweenTask::RunDeleteTask() { return this->cookie_monster()->DeleteAllCreatedBetween(delete_begin_, delete_end_); } // Task class for DeleteAllCreatedBetweenWithPredicate call. class CookieMonster::DeleteAllCreatedBetweenWithPredicateTask - : public DeleteTask<int> { + : public DeleteTask<uint32_t> { public: DeleteAllCreatedBetweenWithPredicateTask( CookieMonster* cookie_monster, @@ -648,13 +648,13 @@ Time delete_end, base::Callback<bool(const CanonicalCookie&)> predicate, DeleteCallback callback) - : DeleteTask<int>(cookie_monster, std::move(callback)), + : DeleteTask<uint32_t>(cookie_monster, std::move(callback)), delete_begin_(delete_begin), delete_end_(delete_end), predicate_(predicate) {} // DeleteTask: - int RunDeleteTask() override; + uint32_t RunDeleteTask() override; protected: ~DeleteAllCreatedBetweenWithPredicateTask() override {} @@ -667,21 +667,23 @@ DISALLOW_COPY_AND_ASSIGN(DeleteAllCreatedBetweenWithPredicateTask); }; -int CookieMonster::DeleteAllCreatedBetweenWithPredicateTask::RunDeleteTask() { +uint32_t +CookieMonster::DeleteAllCreatedBetweenWithPredicateTask::RunDeleteTask() { return this->cookie_monster()->DeleteAllCreatedBetweenWithPredicate( delete_begin_, delete_end_, predicate_); } // Task class for DeleteCanonicalCookie call. -class CookieMonster::DeleteCanonicalCookieTask : public DeleteTask<int> { +class CookieMonster::DeleteCanonicalCookieTask : public DeleteTask<uint32_t> { public: DeleteCanonicalCookieTask(CookieMonster* cookie_monster, const CanonicalCookie& cookie, DeleteCallback callback) - : DeleteTask<int>(cookie_monster, std::move(callback)), cookie_(cookie) {} + : DeleteTask<uint32_t>(cookie_monster, std::move(callback)), + cookie_(cookie) {} // DeleteTask: - int RunDeleteTask() override; + uint32_t RunDeleteTask() override; protected: ~DeleteCanonicalCookieTask() override {} @@ -692,7 +694,7 @@ DISALLOW_COPY_AND_ASSIGN(DeleteCanonicalCookieTask); }; -int CookieMonster::DeleteCanonicalCookieTask::RunDeleteTask() { +uint32_t CookieMonster::DeleteCanonicalCookieTask::RunDeleteTask() { return this->cookie_monster()->DeleteCanonicalCookie(cookie_); } @@ -873,14 +875,14 @@ } // Task class for DeleteSessionCookies call. -class CookieMonster::DeleteSessionCookiesTask : public DeleteTask<int> { +class CookieMonster::DeleteSessionCookiesTask : public DeleteTask<uint32_t> { public: DeleteSessionCookiesTask(CookieMonster* cookie_monster, DeleteCallback callback) - : DeleteTask<int>(cookie_monster, std::move(callback)) {} + : DeleteTask<uint32_t>(cookie_monster, std::move(callback)) {} // DeleteTask: - int RunDeleteTask() override; + uint32_t RunDeleteTask() override; protected: ~DeleteSessionCookiesTask() override {} @@ -889,7 +891,7 @@ DISALLOW_COPY_AND_ASSIGN(DeleteSessionCookiesTask); }; -int CookieMonster::DeleteSessionCookiesTask::RunDeleteTask() { +uint32_t CookieMonster::DeleteSessionCookiesTask::RunDeleteTask() { return this->cookie_monster()->DeleteSessionCookies(); } @@ -1207,11 +1209,11 @@ return cookies; } -int CookieMonster::DeleteAllCreatedBetween(const Time& delete_begin, - const Time& delete_end) { +uint32_t CookieMonster::DeleteAllCreatedBetween(const Time& delete_begin, + const Time& delete_end) { DCHECK(thread_checker_.CalledOnValidThread()); - int num_deleted = 0; + uint32_t num_deleted = 0; for (CookieMap::iterator it = cookies_.begin(); it != cookies_.end();) { CookieMap::iterator curit = it; CanonicalCookie* cc = curit->second.get(); @@ -1228,11 +1230,11 @@ return num_deleted; } -int CookieMonster::DeleteAllCreatedBetweenWithPredicate( +uint32_t CookieMonster::DeleteAllCreatedBetweenWithPredicate( const base::Time& delete_begin, const base::Time& delete_end, const base::Callback<bool(const CanonicalCookie&)>& predicate) { - int num_deleted = 0; + uint32_t num_deleted = 0; for (CookieMap::iterator it = cookies_.begin(); it != cookies_.end();) { CookieMap::iterator curit = it; CanonicalCookie* cc = curit->second.get(); @@ -1315,7 +1317,7 @@ } } -int CookieMonster::DeleteCanonicalCookie(const CanonicalCookie& cookie) { +uint32_t CookieMonster::DeleteCanonicalCookie(const CanonicalCookie& cookie) { DCHECK(thread_checker_.CalledOnValidThread()); for (CookieMapItPair its = cookies_.equal_range(GetKey(cookie.Domain())); @@ -1323,10 +1325,10 @@ // The creation date acts as the unique index... if (its.first->second->CreationDate() == cookie.CreationDate()) { InternalDeleteCookie(its.first, true, DELETE_COOKIE_CANONICAL); - return 1; + return 1u; } } - return 0; + return 0u; } bool CookieMonster::SetCookieWithCreationTime(const GURL& url, @@ -1347,10 +1349,10 @@ CookieOptions()); } -int CookieMonster::DeleteSessionCookies() { +uint32_t CookieMonster::DeleteSessionCookies() { DCHECK(thread_checker_.CalledOnValidThread()); - int num_deleted = 0; + uint32_t num_deleted = 0; for (CookieMap::iterator it = cookies_.begin(); it != cookies_.end();) { CookieMap::iterator curit = it; CanonicalCookie* cc = curit->second.get();
diff --git a/net/cookies/cookie_monster.h b/net/cookies/cookie_monster.h index 7fb91e44..13ebf88 100644 --- a/net/cookies/cookie_monster.h +++ b/net/cookies/cookie_monster.h
@@ -444,11 +444,11 @@ CookieList GetCookieListWithOptions(const GURL& url, const CookieOptions& options); - int DeleteAllCreatedBetween(const base::Time& delete_begin, - const base::Time& delete_end); + uint32_t DeleteAllCreatedBetween(const base::Time& delete_begin, + const base::Time& delete_end); // Predicate will be called with the calling thread. - int DeleteAllCreatedBetweenWithPredicate( + uint32_t DeleteAllCreatedBetweenWithPredicate( const base::Time& delete_begin, const base::Time& delete_end, const base::Callback<bool(const CanonicalCookie&)>& predicate); @@ -462,13 +462,13 @@ void DeleteCookie(const GURL& url, const std::string& cookie_name); - int DeleteCanonicalCookie(const CanonicalCookie& cookie); + uint32_t DeleteCanonicalCookie(const CanonicalCookie& cookie); bool SetCookieWithCreationTime(const GURL& url, const std::string& cookie_line, const base::Time& creation_time); - int DeleteSessionCookies(); + uint32_t DeleteSessionCookies(); // The first access to the cookie store initializes it. This method should be // called before any access to the cookie store.
diff --git a/net/cookies/cookie_monster_unittest.cc b/net/cookies/cookie_monster_unittest.cc index aace43f..5dd66bad 100644 --- a/net/cookies/cookie_monster_unittest.cc +++ b/net/cookies/cookie_monster_unittest.cc
@@ -4,6 +4,8 @@ #include "net/cookies/cookie_monster.h" +#include <stdint.h> + #include <algorithm> #include <memory> #include <string> @@ -163,28 +165,29 @@ return callback.result(); } - int DeleteAllCreatedBetween(CookieMonster* cm, - const base::Time& delete_begin, - const base::Time& delete_end) { + uint32_t DeleteAllCreatedBetween(CookieMonster* cm, + const base::Time& delete_begin, + const base::Time& delete_end) { DCHECK(cm); - ResultSavingCookieCallback<int> callback; + ResultSavingCookieCallback<uint32_t> callback; cm->DeleteAllCreatedBetweenAsync( delete_begin, delete_end, - base::Bind(&ResultSavingCookieCallback<int>::Run, + base::Bind(&ResultSavingCookieCallback<uint32_t>::Run, base::Unretained(&callback))); callback.WaitUntilDone(); return callback.result(); } - int DeleteAllCreatedBetweenWithPredicate(CookieMonster* cm, - const base::Time delete_begin, - const base::Time delete_end, - const CookiePredicate& predicate) { + uint32_t DeleteAllCreatedBetweenWithPredicate( + CookieMonster* cm, + const base::Time delete_begin, + const base::Time delete_end, + const CookiePredicate& predicate) { DCHECK(cm); - ResultSavingCookieCallback<int> callback; + ResultSavingCookieCallback<uint32_t> callback; cm->DeleteAllCreatedBetweenWithPredicateAsync( delete_begin, delete_end, predicate, - base::Bind(&ResultSavingCookieCallback<int>::Run, + base::Bind(&ResultSavingCookieCallback<uint32_t>::Run, base::Unretained(&callback))); callback.WaitUntilDone(); return callback.result(); @@ -1356,7 +1359,7 @@ EXPECT_EQ("A=B; C=D", GetCookiesWithOptions(cm.get(), http_www_foo_.url(), options)); - EXPECT_EQ(2, DeleteAll(cm.get())); + EXPECT_EQ(2u, DeleteAll(cm.get())); EXPECT_EQ("", GetCookiesWithOptions(cm.get(), http_www_foo_.url(), options)); EXPECT_EQ(0u, store->commands().size()); @@ -1367,7 +1370,7 @@ ASSERT_EQ(1u, store->commands().size()); EXPECT_EQ(CookieStoreCommand::ADD, store->commands()[0].type); - EXPECT_EQ(1, DeleteAll(cm.get())); // sync_to_store = true. + EXPECT_EQ(1u, DeleteAll(cm.get())); // sync_to_store = true. ASSERT_EQ(2u, store->commands().size()); EXPECT_EQ(CookieStoreCommand::REMOVE, store->commands()[1].type); @@ -1379,8 +1382,8 @@ Time now = Time::Now(); // Nothing has been added so nothing should be deleted. - EXPECT_EQ(0, DeleteAllCreatedBetween(cm.get(), now - TimeDelta::FromDays(99), - Time())); + EXPECT_EQ(0u, DeleteAllCreatedBetween(cm.get(), now - TimeDelta::FromDays(99), + Time())); // Create 5 cookies with different creation dates. EXPECT_TRUE( @@ -1395,23 +1398,23 @@ now - TimeDelta::FromDays(7))); // Try to delete threedays and the daybefore. - EXPECT_EQ(2, DeleteAllCreatedBetween(cm.get(), now - TimeDelta::FromDays(3), - now - TimeDelta::FromDays(1))); + EXPECT_EQ(2u, DeleteAllCreatedBetween(cm.get(), now - TimeDelta::FromDays(3), + now - TimeDelta::FromDays(1))); // Try to delete yesterday, also make sure that delete_end is not // inclusive. EXPECT_EQ( - 1, DeleteAllCreatedBetween(cm.get(), now - TimeDelta::FromDays(2), now)); + 1u, DeleteAllCreatedBetween(cm.get(), now - TimeDelta::FromDays(2), now)); // Make sure the delete_begin is inclusive. EXPECT_EQ( - 1, DeleteAllCreatedBetween(cm.get(), now - TimeDelta::FromDays(7), now)); + 1u, DeleteAllCreatedBetween(cm.get(), now - TimeDelta::FromDays(7), now)); // Delete the last (now) item. - EXPECT_EQ(1, DeleteAllCreatedBetween(cm.get(), Time(), Time())); + EXPECT_EQ(1u, DeleteAllCreatedBetween(cm.get(), Time(), Time())); // Really make sure everything is gone. - EXPECT_EQ(0, DeleteAll(cm.get())); + EXPECT_EQ(0u, DeleteAll(cm.get())); } TEST_F(CookieMonsterTest, @@ -1428,8 +1431,8 @@ // Nothing has been added so nothing should be deleted. EXPECT_EQ( - 0, DeleteAllCreatedBetweenWithPredicate( - cm.get(), now - TimeDelta::FromDays(99), Time(), true_predicate)); + 0u, DeleteAllCreatedBetweenWithPredicate( + cm.get(), now - TimeDelta::FromDays(99), Time(), true_predicate)); // Create 5 cookies with different creation dates. EXPECT_TRUE( @@ -1445,24 +1448,24 @@ // Try to delete threedays and the daybefore, but we should do nothing due // to the predicate. - EXPECT_EQ(0, DeleteAllCreatedBetweenWithPredicate( - cm.get(), now - TimeDelta::FromDays(3), - now - TimeDelta::FromDays(1), false_predicate)); + EXPECT_EQ(0u, DeleteAllCreatedBetweenWithPredicate( + cm.get(), now - TimeDelta::FromDays(3), + now - TimeDelta::FromDays(1), false_predicate)); // Same as above with a null predicate, so it shouldn't delete anything. - EXPECT_EQ(0, DeleteAllCreatedBetweenWithPredicate( - cm.get(), now - TimeDelta::FromDays(3), - now - TimeDelta::FromDays(1), CookiePredicate())); + EXPECT_EQ(0u, DeleteAllCreatedBetweenWithPredicate( + cm.get(), now - TimeDelta::FromDays(3), + now - TimeDelta::FromDays(1), CookiePredicate())); // Same as above, but we use the true_predicate, so it works. - EXPECT_EQ(2, DeleteAllCreatedBetweenWithPredicate( - cm.get(), now - TimeDelta::FromDays(3), - now - TimeDelta::FromDays(1), true_predicate)); + EXPECT_EQ(2u, DeleteAllCreatedBetweenWithPredicate( + cm.get(), now - TimeDelta::FromDays(3), + now - TimeDelta::FromDays(1), true_predicate)); // Try to delete yesterday, also make sure that delete_end is not // inclusive. - EXPECT_EQ(0, + EXPECT_EQ(0u, DeleteAllCreatedBetweenWithPredicate( cm.get(), now - TimeDelta::FromDays(2), now, false_predicate)); - EXPECT_EQ(1, + EXPECT_EQ(1u, DeleteAllCreatedBetweenWithPredicate( cm.get(), now - TimeDelta::FromDays(2), now, true_predicate)); // Check our cookie values. @@ -1475,18 +1478,18 @@ << expected_cookie->DebugString(); // Make sure the delete_begin is inclusive. - EXPECT_EQ(0, + EXPECT_EQ(0u, DeleteAllCreatedBetweenWithPredicate( cm.get(), now - TimeDelta::FromDays(7), now, false_predicate)); - EXPECT_EQ(1, + EXPECT_EQ(1u, DeleteAllCreatedBetweenWithPredicate( cm.get(), now - TimeDelta::FromDays(7), now, true_predicate)); // Delete the last (now) item. - EXPECT_EQ(0, DeleteAllCreatedBetweenWithPredicate(cm.get(), Time(), Time(), - false_predicate)); - EXPECT_EQ(1, DeleteAllCreatedBetweenWithPredicate(cm.get(), Time(), Time(), - true_predicate)); + EXPECT_EQ(0u, DeleteAllCreatedBetweenWithPredicate(cm.get(), Time(), Time(), + false_predicate)); + EXPECT_EQ(1u, DeleteAllCreatedBetweenWithPredicate(cm.get(), Time(), Time(), + true_predicate)); expected_cookie = CanonicalCookie::Create(http_www_foo_.url(), "T-0=Now", now, CookieOptions()); EXPECT_THAT(test_cookie, CookieEquals(*expected_cookie)) @@ -1495,7 +1498,7 @@ << expected_cookie->DebugString(); // Really make sure everything is gone. - EXPECT_EQ(0, DeleteAll(cm.get())); + EXPECT_EQ(0u, DeleteAll(cm.get())); } static const base::TimeDelta kLastAccessThreshold = @@ -1937,8 +1940,8 @@ CookiePredicate value_matcher = base::Bind(&CookieValuePredicate, kTrueValue); PopulateCmForPredicateCheck(cm.get()); - EXPECT_EQ(7, DeleteAllCreatedBetweenWithPredicate( - cm.get(), base::Time(), base::Time::Now(), value_matcher)); + EXPECT_EQ(7u, DeleteAllCreatedBetweenWithPredicate( + cm.get(), base::Time(), base::Time::Now(), value_matcher)); EXPECT_EQ("dom_2=B; dom_3=C; host_3=C", GetCookies(cm.get(), GURL(kTopLevelDomainPlus3))); @@ -2300,8 +2303,8 @@ store->set_store_load_commands(true); std::unique_ptr<CookieMonster> cm(new CookieMonster(store.get(), nullptr)); - ResultSavingCookieCallback<int> delete_callback; - cm->DeleteAllAsync(base::Bind(&ResultSavingCookieCallback<int>::Run, + ResultSavingCookieCallback<uint32_t> delete_callback; + cm->DeleteAllAsync(base::Bind(&ResultSavingCookieCallback<uint32_t>::Run, base::Unretained(&delete_callback))); GetCookieListCallback get_cookie_list_callback; @@ -2323,7 +2326,7 @@ store->commands()[0].loaded_callback.Run(std::move(cookies)); delete_callback.WaitUntilDone(); - EXPECT_EQ(1, delete_callback.result()); + EXPECT_EQ(1u, delete_callback.result()); get_cookie_list_callback.WaitUntilDone(); EXPECT_EQ(0u, get_cookie_list_callback.cookies().size()); @@ -2764,7 +2767,7 @@ EXPECT_TRUE(SetCookie(cm.get(), http_www_foo_.url(), "X=Y; path=/")); ASSERT_EQ(0, store->flush_count()); - EXPECT_EQ(1, DeleteAll(cm.get())); + EXPECT_EQ(1u, DeleteAll(cm.get())); EXPECT_EQ(1, store->flush_count()); }
diff --git a/net/cookies/cookie_store.h b/net/cookies/cookie_store.h index 9ef7535..1a4d3d4 100644 --- a/net/cookies/cookie_store.h +++ b/net/cookies/cookie_store.h
@@ -7,6 +7,8 @@ #ifndef NET_COOKIES_COOKIE_STORE_H_ #define NET_COOKIES_COOKIE_STORE_H_ +#include <stdint.h> + #include <memory> #include <string> #include <vector> @@ -69,7 +71,7 @@ typedef base::OnceCallback<void(const std::string& cookie)> GetCookiesCallback; typedef base::OnceCallback<void(bool success)> SetCookiesCallback; - typedef base::OnceCallback<void(int num_deleted)> DeleteCallback; + typedef base::OnceCallback<void(uint32_t num_deleted)> DeleteCallback; typedef base::Callback<void(const CanonicalCookie& cookie, ChangeCause cause)> CookieChangedCallback;
diff --git a/net/cookies/cookie_store_unittest.h b/net/cookies/cookie_store_unittest.h index 4aa2a3c..56ee4248 100644 --- a/net/cookies/cookie_store_unittest.h +++ b/net/cookies/cookie_store_unittest.h
@@ -5,6 +5,8 @@ #ifndef NET_COOKIES_COOKIE_STORE_UNITTEST_H_ #define NET_COOKIES_COOKIE_STORE_UNITTEST_H_ +#include <stdint.h> + #include <set> #include <string> #include <vector> @@ -226,60 +228,59 @@ callback.WaitUntilDone(); } - int DeleteCanonicalCookie(CookieStore* cs, const CanonicalCookie& cookie) { + uint32_t DeleteCanonicalCookie(CookieStore* cs, + const CanonicalCookie& cookie) { DCHECK(cs); - ResultSavingCookieCallback<int> callback; + ResultSavingCookieCallback<uint32_t> callback; cs->DeleteCanonicalCookieAsync( - cookie, base::Bind(&ResultSavingCookieCallback<int>::Run, + cookie, base::Bind(&ResultSavingCookieCallback<uint32_t>::Run, base::Unretained(&callback))); callback.WaitUntilDone(); return callback.result(); } - int DeleteCreatedBetween(CookieStore* cs, - const base::Time& delete_begin, - const base::Time& delete_end) { + uint32_t DeleteCreatedBetween(CookieStore* cs, + const base::Time& delete_begin, + const base::Time& delete_end) { DCHECK(cs); - ResultSavingCookieCallback<int> callback; + ResultSavingCookieCallback<uint32_t> callback; cs->DeleteAllCreatedBetweenAsync( delete_begin, delete_end, - base::Bind( - &ResultSavingCookieCallback<int>::Run, - base::Unretained(&callback))); - callback.WaitUntilDone(); - return callback.result(); - } - - int DeleteAllCreatedBetweenWithPredicate( - CookieStore* cs, - const base::Time delete_begin, - const base::Time delete_end, - const CookieStore::CookiePredicate& predicate) { - DCHECK(cs); - ResultSavingCookieCallback<int> callback; - cs->DeleteAllCreatedBetweenWithPredicateAsync( - delete_begin, delete_end, predicate, - base::Bind(&ResultSavingCookieCallback<int>::Run, + base::Bind(&ResultSavingCookieCallback<uint32_t>::Run, base::Unretained(&callback))); callback.WaitUntilDone(); return callback.result(); } - int DeleteSessionCookies(CookieStore* cs) { + uint32_t DeleteAllCreatedBetweenWithPredicate( + CookieStore* cs, + const base::Time delete_begin, + const base::Time delete_end, + const CookieStore::CookiePredicate& predicate) { DCHECK(cs); - ResultSavingCookieCallback<int> callback; - cs->DeleteSessionCookiesAsync( - base::Bind( - &ResultSavingCookieCallback<int>::Run, - base::Unretained(&callback))); + ResultSavingCookieCallback<uint32_t> callback; + cs->DeleteAllCreatedBetweenWithPredicateAsync( + delete_begin, delete_end, predicate, + base::Bind(&ResultSavingCookieCallback<uint32_t>::Run, + base::Unretained(&callback))); callback.WaitUntilDone(); return callback.result(); } - int DeleteAll(CookieStore* cs) { + uint32_t DeleteSessionCookies(CookieStore* cs) { DCHECK(cs); - ResultSavingCookieCallback<int> callback; - cs->DeleteAllAsync(base::Bind(&ResultSavingCookieCallback<int>::Run, + ResultSavingCookieCallback<uint32_t> callback; + cs->DeleteSessionCookiesAsync( + base::Bind(&ResultSavingCookieCallback<uint32_t>::Run, + base::Unretained(&callback))); + callback.WaitUntilDone(); + return callback.result(); + } + + uint32_t DeleteAll(CookieStore* cs) { + DCHECK(cs); + ResultSavingCookieCallback<uint32_t> callback; + cs->DeleteAllAsync(base::Bind(&ResultSavingCookieCallback<uint32_t>::Run, base::Unretained(&callback))); callback.WaitUntilDone(); return callback.result(); @@ -1216,7 +1217,7 @@ EXPECT_EQ(2u, this->GetAllCookies(cs).size()); // Delete both, and make sure it works - EXPECT_EQ(2, this->DeleteAll(cs)); + EXPECT_EQ(2u, this->DeleteAll(cs)); EXPECT_EQ(0u, this->GetAllCookies(cs).size()); } @@ -1238,14 +1239,14 @@ this->GetCookies(cs, this->http_www_foo_.url())); // Remove cookies in empty intervals. - EXPECT_EQ(0, this->DeleteCreatedBetween(cs, last_month, last_minute)); - EXPECT_EQ(0, this->DeleteCreatedBetween(cs, next_minute, next_month)); + EXPECT_EQ(0u, this->DeleteCreatedBetween(cs, last_month, last_minute)); + EXPECT_EQ(0u, this->DeleteCreatedBetween(cs, next_minute, next_month)); // Check that the cookie is still there. this->MatchCookieLines("A=B", this->GetCookies(cs, this->http_www_foo_.url())); // Remove the cookie with an interval defined by two dates. - EXPECT_EQ(1, this->DeleteCreatedBetween(cs, last_minute, next_minute)); + EXPECT_EQ(1u, this->DeleteCreatedBetween(cs, last_minute, next_minute)); // Check that the cookie disappeared. this->MatchCookieLines(std::string(), this->GetCookies(cs, this->http_www_foo_.url())); @@ -1257,7 +1258,7 @@ this->GetCookies(cs, this->http_www_foo_.url())); // Remove the cookie with a null ending time. - EXPECT_EQ(1, this->DeleteCreatedBetween(cs, last_minute, base::Time())); + EXPECT_EQ(1u, this->DeleteCreatedBetween(cs, last_minute, base::Time())); // Check that the cookie disappeared. this->MatchCookieLines(std::string(), this->GetCookies(cs, this->http_www_foo_.url())); @@ -1284,7 +1285,7 @@ EXPECT_TRUE(this->SetCookie(cs, this->https_www_foo_.url(), "E=B")); // Delete cookies. - EXPECT_EQ(2, // Deletes A=B, E=B + EXPECT_EQ(2u, // Deletes A=B, E=B this->DeleteAllCreatedBetweenWithPredicate( cs, now, base::Time::Max(), base::Bind(&CookieHasValue, desired_value))); @@ -1294,20 +1295,21 @@ this->GetCookies(cs, this->https_www_foo_.url())); // Now check that using a null predicate will do nothing. - EXPECT_EQ(0, this->DeleteAllCreatedBetweenWithPredicate( - cs, now, base::Time::Max(), CookieStore::CookiePredicate())); + EXPECT_EQ(0u, + this->DeleteAllCreatedBetweenWithPredicate( + cs, now, base::Time::Max(), CookieStore::CookiePredicate())); // Finally, check that we don't delete cookies when our time range is off. desired_value = "D"; - EXPECT_EQ(0, this->DeleteAllCreatedBetweenWithPredicate( - cs, last_month, last_minute, - base::Bind(&CookieHasValue, desired_value))); + EXPECT_EQ(0u, this->DeleteAllCreatedBetweenWithPredicate( + cs, last_month, last_minute, + base::Bind(&CookieHasValue, desired_value))); this->MatchCookieLines("C=D;Y=Z", this->GetCookies(cs, this->https_www_foo_.url())); // Same thing, but with a good time range. - EXPECT_EQ(1, this->DeleteAllCreatedBetweenWithPredicate( - cs, now, base::Time::Max(), - base::Bind(&CookieHasValue, desired_value))); + EXPECT_EQ(1u, this->DeleteAllCreatedBetweenWithPredicate( + cs, now, base::Time::Max(), + base::Bind(&CookieHasValue, desired_value))); this->MatchCookieLines("Y=Z", this->GetCookies(cs, this->https_www_foo_.url())); } @@ -1440,14 +1442,14 @@ EXPECT_EQ(1u, list.size()); EXPECT_EQ("", list[0].Name()); EXPECT_EQ("a", list[0].Value()); - EXPECT_EQ(1, this->DeleteAll(cs)); + EXPECT_EQ(1u, this->DeleteAll(cs)); EXPECT_TRUE(this->SetCookieWithOptions(cs, url_foo, "=b", options)); list = this->GetAllCookiesForURL(cs, url_foo); EXPECT_EQ(1u, list.size()); EXPECT_EQ("", list[0].Name()); EXPECT_EQ("b", list[0].Value()); - EXPECT_EQ(1, this->DeleteAll(cs)); + EXPECT_EQ(1u, this->DeleteAll(cs)); } TYPED_TEST_P(CookieStoreTest, CookieOrdering) { @@ -1570,20 +1572,20 @@ CookieList cookies = this->GetCookieListWithOptions( cs, this->www_foo_foo_.url(), CookieOptions()); ASSERT_EQ(1u, cookies.size()); - EXPECT_EQ(1, this->DeleteCanonicalCookie(cs, cookies[0])); + EXPECT_EQ(1u, this->DeleteCanonicalCookie(cs, cookies[0])); EXPECT_EQ(1u, this->GetAllCookies(cs).size()); EXPECT_EQ("", this->GetCookies(cs, this->www_foo_foo_.url())); EXPECT_EQ("A=C", this->GetCookies(cs, this->www_foo_bar_.url())); // Deleting the "/foo" cookie again should fail. - EXPECT_EQ(0, this->DeleteCanonicalCookie(cs, cookies[0])); + EXPECT_EQ(0u, this->DeleteCanonicalCookie(cs, cookies[0])); // Try to delete the "/bar" cookie after overwriting it with a new cookie. cookies = this->GetCookieListWithOptions(cs, this->www_foo_bar_.url(), CookieOptions()); ASSERT_EQ(1u, cookies.size()); EXPECT_TRUE(this->SetCookie(cs, this->http_www_foo_.url(), "A=D;Path=/bar")); - EXPECT_EQ(0, this->DeleteCanonicalCookie(cs, cookies[0])); + EXPECT_EQ(0u, this->DeleteCanonicalCookie(cs, cookies[0])); EXPECT_EQ(1u, this->GetAllCookies(cs).size()); EXPECT_EQ("A=D", this->GetCookies(cs, this->www_foo_bar_.url())); @@ -1591,7 +1593,7 @@ cookies = this->GetCookieListWithOptions(cs, this->www_foo_bar_.url(), CookieOptions()); ASSERT_EQ(1u, cookies.size()); - EXPECT_EQ(1, this->DeleteCanonicalCookie(cs, cookies[0])); + EXPECT_EQ(1u, this->DeleteCanonicalCookie(cs, cookies[0])); EXPECT_EQ(0u, this->GetAllCookies(cs).size()); EXPECT_EQ("", this->GetCookies(cs, this->www_foo_bar_.url())); }
diff --git a/net/log/file_net_log_observer.cc b/net/log/file_net_log_observer.cc index 0c05f9e1..7f78c9f 100644 --- a/net/log/file_net_log_observer.cc +++ b/net/log/file_net_log_observer.cc
@@ -16,10 +16,10 @@ #include "base/files/file_util.h" #include "base/json/json_writer.h" #include "base/logging.h" -#include "base/single_thread_task_runner.h" +#include "base/sequenced_task_runner.h" #include "base/strings/string_number_conversions.h" #include "base/synchronization/lock.h" -#include "base/threading/thread.h" +#include "base/task_scheduler/post_task.h" #include "base/values.h" #include "net/log/net_log_capture_mode.h" #include "net/log/net_log_entry.h" @@ -28,10 +28,21 @@ namespace { -// Number of events that can build up in |write_queue_| before file thread -// is triggered to drain the queue. +// Number of events that can build up in |write_queue_| before a task is posted +// to the file task runner to flush them to disk. const int kNumWriteQueueEvents = 15; +scoped_refptr<base::SequencedTaskRunner> CreateFileTaskRunner() { + // The tasks posted to this sequenced task runner do synchronous File I/O for + // the purposes of writing NetLog files. + // + // These intentionally block shutdown to ensure the log file has finished + // being written. + return base::CreateSequencedTaskRunnerWithTraits( + {base::MayBlock(), base::TaskPriority::USER_VISIBLE, + base::TaskShutdownBehavior::BLOCK_SHUTDOWN}); +} + } // namespace namespace net { @@ -41,14 +52,14 @@ // WriteQueue receives events from FileNetLogObserver on the main thread and // holds them in a queue until they are drained from the queue and written to -// file on the file thread. +// file on the file task runner. // // WriteQueue contains the resources shared between the main thread and the -// file thread. |lock_| must be acquired to read or write to |queue_| and +// file task runner. |lock_| must be acquired to read or write to |queue_| and // |memory_|. // // WriteQueue is refcounted and should be destroyed once all events on the -// file thread have finished executing. +// file task runner have finished executing. class FileNetLogObserver::WriteQueue : public base::RefCountedThreadSafe<WriteQueue> { public: @@ -73,17 +84,17 @@ ~WriteQueue(); - // Queue of events to be written shared between main thread and file thread. - // Main thread adds events to the queue and the file thread drains them and - // writes the events to file. + // Queue of events to be written, shared between main thread and file task + // runner. Main thread adds events to the queue and the file task runner + // drains them and writes the events to file. // // |lock_| must be acquired to read or write to this. EventQueue queue_; // Tracks how much memory is being used by the virtual write queue. // Incremented in AddEntryToQueue() when events are added to the - // buffer, and decremented when SwapQueue() is called and the file thread's - // local queue is swapped with the shared write queue. + // buffer, and decremented when SwapQueue() is called and the file task + // runner's local queue is swapped with the shared write queue. // // |lock_| must be acquired to read or write to this. size_t memory_; @@ -95,14 +106,14 @@ // Protects access to |queue_| and |memory_|. // // A lock is necessary because |queue_| and |memory_| are shared between the - // file thread and the main thread. NetLog's lock protects OnAddEntry(), + // file task runner and the main thread. NetLog's lock protects OnAddEntry(), // which calls AddEntryToQueue(), but it does not protect access to the // observer's member variables. Thus, a race condition exists if a thread is - // calling OnAddEntry() at the same time that the file thread is accessing - // |memory_| and |queue_| to write events to file. The |queue_| and |memory_| - // counter are necessary to bound the amount of memory that is used for the - // queue in the event that the file thread lags significantly behind the main - // thread in writing events to file. + // calling OnAddEntry() at the same time that the file task runner is + // accessing |memory_| and |queue_| to write events to file. The |queue_| and + // |memory_| counter are necessary to bound the amount of memory that is used + // for the queue in the event that the file task runner lags significantly + // behind the main thread in writing events to file. base::Lock lock_; DISALLOW_COPY_AND_ASSIGN(WriteQueue); @@ -138,14 +149,14 @@ // This implementation of FileWriter is used when the observer is in bounded // mode. // BoundedFileWriter can be constructed on any thread, and afterwards is only -// accessed on the file thread. +// accessed on the file task runner. class FileNetLogObserver::BoundedFileWriter : public FileNetLogObserver::FileWriter { public: BoundedFileWriter(const base::FilePath& directory, size_t max_file_size, size_t total_num_files, - scoped_refptr<base::SingleThreadTaskRunner> task_runner); + scoped_refptr<base::SequencedTaskRunner> task_runner); ~BoundedFileWriter() override; @@ -180,8 +191,8 @@ // the constant file. const size_t max_file_size_; - // Task runner from the file thread. - const scoped_refptr<base::SingleThreadTaskRunner> task_runner_; + // Task runner for doing file operations. + const scoped_refptr<base::SequencedTaskRunner> task_runner_; DISALLOW_COPY_AND_ASSIGN(BoundedFileWriter); }; @@ -189,12 +200,12 @@ // This implementation of FileWriter is used when the observer is in unbounded // mode. // UnboundedFileWriter can be constructed on any thread, and afterwards is only -// accessed on the file thread. +// accessed on the file task runner. class FileNetLogObserver::UnboundedFileWriter : public FileNetLogObserver::FileWriter { public: UnboundedFileWriter(const base::FilePath& path, - scoped_refptr<base::SingleThreadTaskRunner> task_runner); + scoped_refptr<base::SequencedTaskRunner> task_runner); ~UnboundedFileWriter() override; @@ -211,19 +222,22 @@ // Is set to true after the first event is written to the log file. bool first_event_written_; - // Task runner from the file thread. - const scoped_refptr<base::SingleThreadTaskRunner> task_runner_; + // Task runner for doing file operations. + const scoped_refptr<base::SequencedTaskRunner> task_runner_; DISALLOW_COPY_AND_ASSIGN(UnboundedFileWriter); }; std::unique_ptr<FileNetLogObserver> FileNetLogObserver::CreateBounded( - scoped_refptr<base::SingleThreadTaskRunner> file_task_runner, const base::FilePath& directory, size_t max_total_size, size_t total_num_files, std::unique_ptr<base::Value> constants) { DCHECK_GT(total_num_files, 0u); + + scoped_refptr<base::SequencedTaskRunner> file_task_runner = + CreateFileTaskRunner(); + // The BoundedFileWriter uses a soft limit to write events to file that allows // the size of the file to exceed the limit, but the WriteQueue uses a hard // limit which the size of |WriteQueue::queue_| cannot exceed. Thus, the @@ -248,9 +262,11 @@ } std::unique_ptr<FileNetLogObserver> FileNetLogObserver::CreateUnbounded( - scoped_refptr<base::SingleThreadTaskRunner> file_task_runner, const base::FilePath& log_path, std::unique_ptr<base::Value> constants) { + scoped_refptr<base::SequencedTaskRunner> file_task_runner = + CreateFileTaskRunner(); + std::unique_ptr<FileWriter> file_writer( new UnboundedFileWriter(log_path, file_task_runner)); @@ -268,9 +284,9 @@ net_log()->DeprecatedRemoveObserver(this); file_task_runner_->PostTask( FROM_HERE, base::Bind(&FileNetLogObserver::FileWriter::DeleteAllFiles, - base::Unretained(file_writer_))); + base::Unretained(file_writer_.get()))); } - file_task_runner_->DeleteSoon(FROM_HERE, file_writer_); + file_task_runner_->DeleteSoon(FROM_HERE, file_writer_.release()); } void FileNetLogObserver::StartObserving(NetLog* net_log, @@ -279,14 +295,22 @@ } void FileNetLogObserver::StopObserving(std::unique_ptr<base::Value> polled_data, - const base::Closure& callback) { + base::OnceClosure optional_callback) { net_log()->DeprecatedRemoveObserver(this); - file_task_runner_->PostTaskAndReply( - FROM_HERE, base::Bind(&FileNetLogObserver::FileWriter::FlushThenStop, - base::Unretained(file_writer_), write_queue_, - base::Passed(&polled_data)), - callback); + base::OnceClosure bound_flush_then_stop = + base::Bind(&FileNetLogObserver::FileWriter::FlushThenStop, + base::Unretained(file_writer_.get()), write_queue_, + base::Passed(&polled_data)); + + // Note that PostTaskAndReply() requires a non-null closure. + if (!optional_callback.is_null()) { + file_task_runner_->PostTaskAndReply(FROM_HERE, + std::move(bound_flush_then_stop), + std::move(optional_callback)); + } else { + file_task_runner_->PostTask(FROM_HERE, std::move(bound_flush_then_stop)); + } } void FileNetLogObserver::OnAddEntry(const NetLogEntry& entry) { @@ -298,31 +322,32 @@ size_t queue_size = write_queue_->AddEntryToQueue(std::move(json)); - // If events build up in |write_queue_|, trigger the file thread to drain + // If events build up in |write_queue_|, trigger the file task runner to drain // the queue. Because only 1 item is added to the queue at a time, if // queue_size > kNumWriteQueueEvents a task has already been posted, or will // be posted. if (queue_size == kNumWriteQueueEvents) { file_task_runner_->PostTask( - FROM_HERE, base::Bind(&FileNetLogObserver::FileWriter::Flush, - base::Unretained(file_writer_), write_queue_)); + FROM_HERE, + base::Bind(&FileNetLogObserver::FileWriter::Flush, + base::Unretained(file_writer_.get()), write_queue_)); } } FileNetLogObserver::FileNetLogObserver( - scoped_refptr<base::SingleThreadTaskRunner> file_task_runner, + scoped_refptr<base::SequencedTaskRunner> file_task_runner, std::unique_ptr<FileWriter> file_writer, scoped_refptr<WriteQueue> write_queue, std::unique_ptr<base::Value> constants) : file_task_runner_(std::move(file_task_runner)), write_queue_(std::move(write_queue)), - file_writer_(file_writer.release()) { + file_writer_(std::move(file_writer)) { if (!constants) constants = GetNetConstants(); file_task_runner_->PostTask( - FROM_HERE, - base::Bind(&FileNetLogObserver::FileWriter::Initialize, - base::Unretained(file_writer_), base::Passed(&constants))); + FROM_HERE, base::Bind(&FileNetLogObserver::FileWriter::Initialize, + base::Unretained(file_writer_.get()), + base::Passed(&constants))); } FileNetLogObserver::WriteQueue::WriteQueue(size_t memory_max) @@ -367,12 +392,12 @@ const base::FilePath& directory, size_t max_file_size, size_t total_num_files, - scoped_refptr<base::SingleThreadTaskRunner> task_runner) + scoped_refptr<base::SequencedTaskRunner> task_runner) : directory_(directory), total_num_files_(total_num_files), current_file_idx_(0), max_file_size_(max_file_size), - task_runner_(task_runner) { + task_runner_(std::move(task_runner)) { event_files_.resize(total_num_files_); } @@ -473,8 +498,8 @@ FileNetLogObserver::UnboundedFileWriter::UnboundedFileWriter( const base::FilePath& path, - scoped_refptr<base::SingleThreadTaskRunner> task_runner) - : file_path_(path), task_runner_(task_runner) {} + scoped_refptr<base::SequencedTaskRunner> task_runner) + : file_path_(path), task_runner_(std::move(task_runner)) {} FileNetLogObserver::UnboundedFileWriter::~UnboundedFileWriter() {}
diff --git a/net/log/file_net_log_observer.h b/net/log/file_net_log_observer.h index 2b2b3a8..fc1fd8a 100644 --- a/net/log/file_net_log_observer.h +++ b/net/log/file_net_log_observer.h
@@ -15,7 +15,7 @@ namespace base { class Value; class FilePath; -class SingleThreadTaskRunner; +class SequencedTaskRunner; } // namespace base namespace net { @@ -42,17 +42,12 @@ // large this file can grow; all events added will be written to the file. // // The consumer must call StartObserving before calling StopObserving, and must -// call each method exactly once in the lifetime of the observer. StartObserving -// and StopObserving must be called on the same thread, but there is no -// restriction on which thread is used. +// call each method exactly once in the lifetime of the observer. class NET_EXPORT FileNetLogObserver : public NetLog::ThreadSafeObserver { public: // Creates a FileNetLogObserver in bounded mode. // - // |file_task_runner| indicates the task runner that should be used to post - // tasks from the main thread to the file thread. - // - // |directory| is the directory where the log files will be. + // |directory| is the directory where the log files will be written to. // // |max_total_size| is the approximate limit on the cumulative size of all // netlog files. @@ -64,7 +59,6 @@ // the log. It should generally be a modified version of GetNetConstants(). // If not present, the output of GetNetConstants() will be used. static std::unique_ptr<FileNetLogObserver> CreateBounded( - scoped_refptr<base::SingleThreadTaskRunner> file_task_runner, const base::FilePath& directory, size_t max_total_size, size_t total_num_files, @@ -72,16 +66,12 @@ // Creates a FileNetLogObserver in unbounded mode. // - // |file_task_runner| indicates the task runner that should be used to post - // tasks from the main thread to the file thread. - // - // |log_path| is where the log file will be. + // |log_path| is where the log file will be written to. // // |constants| is an optional legend for decoding constant values used in // the log. It should generally be a modified version of GetNetConstants(). // If not present, the output of GetNetConstants() will be used. static std::unique_ptr<FileNetLogObserver> CreateUnbounded( - scoped_refptr<base::SingleThreadTaskRunner> file_task_runner, const base::FilePath& log_path, std::unique_ptr<base::Value> constants); @@ -98,11 +88,11 @@ // |polled_data| is an optional argument used to add additional network stack // state to the log. // - // |callback| will be run on whichever thread StopObserving() was called on - // once all file writing is complete and the netlog files can be accessed - // safely. + // If non-null, |optional_callback| will be run on whichever thread + // StopObserving() was called on once all file writing is complete and the + // netlog files can be accessed safely. void StopObserving(std::unique_ptr<base::Value> polled_data, - const base::Closure& callback); + base::OnceClosure optional_callback); // NetLog::ThreadSafeObserver void OnAddEntry(const NetLogEntry& entry) override; @@ -113,29 +103,26 @@ class BoundedFileWriter; class UnboundedFileWriter; - FileNetLogObserver( - scoped_refptr<base::SingleThreadTaskRunner> file_task_runner, - std::unique_ptr<FileWriter> file_writer, - scoped_refptr<WriteQueue> write_queue, - std::unique_ptr<base::Value> constants); + FileNetLogObserver(scoped_refptr<base::SequencedTaskRunner> file_task_runner, + std::unique_ptr<FileWriter> file_writer, + scoped_refptr<WriteQueue> write_queue, + std::unique_ptr<base::Value> constants); - scoped_refptr<base::SingleThreadTaskRunner> file_task_runner_; + scoped_refptr<base::SequencedTaskRunner> file_task_runner_; - // The |write_queue_| object is shared between the file thread and the main - // thread, and should be alive for the entirety of the observer's lifetime. - // It should be destroyed once both the observer has been destroyed and all - // tasks posted to the file thread have completed. + // The |write_queue_| object is shared between the file task runner and the + // main thread, and should be alive for the entirety of the observer's + // lifetime. It should be destroyed once both the observer has been destroyed + // and all tasks posted to the file task runner have completed. scoped_refptr<WriteQueue> write_queue_; - // This is the owning reference to a file thread object. The observer is - // responsible for destroying the file thread object by posting a task from - // the main thread to the file thread to destroy the FileWriter when the - // observer is destroyed. + // The FileNetLogObserver is shared between the main thread and + // |file_task_runner_|. // - // The use of base::Unretained with |file_writer_| to post tasks to the file - // thread is safe because the FileWriter object will be alive until the - // observer's destruction. - FileWriter* file_writer_; + // Conceptually FileNetLogObserver owns it, however on destruction its + // deletion is deferred until outstanding tasks on |file_task_runner_| have + // finished (since it is posted using base::Unretained()). + std::unique_ptr<FileWriter> file_writer_; DISALLOW_COPY_AND_ASSIGN(FileNetLogObserver); };
diff --git a/net/log/file_net_log_observer_unittest.cc b/net/log/file_net_log_observer_unittest.cc index 0cbf7d1..75082a766 100644 --- a/net/log/file_net_log_observer_unittest.cc +++ b/net/log/file_net_log_observer_unittest.cc
@@ -21,6 +21,7 @@ #include "base/message_loop/message_loop.h" #include "base/strings/string_util.h" #include "base/strings/stringprintf.h" +#include "base/task_scheduler/task_scheduler.h" #include "base/threading/thread.h" #include "base/values.h" #include "net/base/test_completion_callback.h" @@ -159,21 +160,16 @@ ASSERT_TRUE(temp_dir_.CreateUniqueTempDir()); bounded_log_dir_ = temp_dir_.GetPath(); unbounded_log_path_ = bounded_log_dir_.AppendASCII("net-log.json"); - file_thread_.reset(new base::Thread("NetLog File Thread")); - file_thread_->StartWithOptions( - base::Thread::Options(base::MessageLoop::TYPE_DEFAULT, 0)); - ASSERT_TRUE(file_thread_->WaitUntilThreadStarted()); } void CreateAndStartObserving(std::unique_ptr<base::Value> constants) { bool bounded = GetParam(); if (bounded) { logger_ = FileNetLogObserver::CreateBounded( - file_thread_->task_runner(), bounded_log_dir_, kLargeFileSize, - kTotalNumFiles, std::move(constants)); + bounded_log_dir_, kLargeFileSize, kTotalNumFiles, + std::move(constants)); } else { - logger_ = FileNetLogObserver::CreateUnbounded(file_thread_->task_runner(), - unbounded_log_path_, + logger_ = FileNetLogObserver::CreateUnbounded(unbounded_log_path_, std::move(constants)); } @@ -194,6 +190,11 @@ } bool LogFilesExist() { + // The log files are written by a sequenced task runner. Drain all the + // scheduled tasks to ensure that the file writing ones have run before + // checking if they exist. + base::TaskScheduler::GetInstance()->FlushForTesting(); + bool bounded = GetParam(); if (bounded) { if (base::PathExists(bounded_log_dir_.AppendASCII("constants.json")) || @@ -212,7 +213,6 @@ protected: NetLog net_log_; - std::unique_ptr<base::Thread> file_thread_; std::unique_ptr<FileNetLogObserver> logger_; private: @@ -227,18 +227,13 @@ void SetUp() override { ASSERT_TRUE(temp_dir_.CreateUniqueTempDir()); bounded_log_dir_ = temp_dir_.GetPath(); - file_thread_.reset(new base::Thread("NetLog File Thread")); - file_thread_->StartWithOptions( - base::Thread::Options(base::MessageLoop::TYPE_DEFAULT, 0)); - ASSERT_TRUE(file_thread_->WaitUntilThreadStarted()); } void CreateAndStartObserving(std::unique_ptr<base::Value> constants, int total_file_size, int num_files) { logger_ = FileNetLogObserver::CreateBounded( - file_thread_->task_runner(), bounded_log_dir_, total_file_size, - num_files, std::move(constants)); + bounded_log_dir_, total_file_size, num_files, std::move(constants)); logger_->StartObserving(&net_log_, NetLogCaptureMode::Default()); } @@ -263,7 +258,6 @@ protected: NetLog net_log_; - std::unique_ptr<base::Thread> file_thread_; std::unique_ptr<FileNetLogObserver> logger_; private: @@ -276,18 +270,41 @@ FileNetLogObserverTest, ::testing::Values(true, false)); +// Tests deleting a FileNetLogObserver without first calling StopObserving(). TEST_P(FileNetLogObserverTest, ObserverDestroyedWithoutStopObserving) { CreateAndStartObserving(nullptr); // Send dummy event AddEntries(logger_.get(), 1, kDummyEventSize); - logger_.reset(); - file_thread_.reset(); + // The log files should have been started. + ASSERT_TRUE(LogFilesExist()); + logger_.reset(); + + // When the logger is re-set without having called StopObserving(), the + // partially written log files are deleted. ASSERT_FALSE(LogFilesExist()); } +// Tests calling StopObserving() with a null closure. +TEST_P(FileNetLogObserverTest, StopObservingNullClosure) { + CreateAndStartObserving(nullptr); + + // Send dummy event + AddEntries(logger_.get(), 1, kDummyEventSize); + + // The log files should have been started. + ASSERT_TRUE(LogFilesExist()); + + logger_->StopObserving(nullptr, base::OnceClosure()); + + logger_.reset(); + + // Since the logger was explicitly stopped, its files should still exist. + ASSERT_TRUE(LogFilesExist()); +} + TEST_P(FileNetLogObserverTest, GeneratesValidJSONWithNoEvents) { TestClosure closure; @@ -801,7 +818,7 @@ TEST_P(FileNetLogObserverTest, AddEventsFromMultipleThreadsWithStopObserving) { const size_t kNumThreads = 10; std::vector<std::unique_ptr<base::Thread>> threads(kNumThreads); - // Start all the threads. Waiting for them to start is to hopefuly improve + // Start all the threads. Waiting for them to start is to hopefully improve // the odds of hitting interesting races once events start being added. for (size_t i = 0; i < threads.size(); ++i) { threads[i] = base::MakeUnique<base::Thread>( @@ -828,13 +845,15 @@ // Join all the threads. threads.clear(); + + ASSERT_TRUE(LogFilesExist()); } TEST_P(FileNetLogObserverTest, AddEventsFromMultipleThreadsWithoutStopObserving) { const size_t kNumThreads = 10; std::vector<std::unique_ptr<base::Thread>> threads(kNumThreads); - // Start all the threads. Waiting for them to start is to hopefuly improve + // Start all the threads. Waiting for them to start is to hopefully improve // the odds of hitting interesting races once events start being added. for (size_t i = 0; i < threads.size(); ++i) { threads[i] = base::MakeUnique<base::Thread>( @@ -859,6 +878,9 @@ // Join all the threads. threads.clear(); + + // The log file doesn't exist since StopObserving() was not called. + ASSERT_FALSE(LogFilesExist()); } } // namespace
diff --git a/net/tools/transport_security_state_generator/input_file_parsers.cc b/net/tools/transport_security_state_generator/input_file_parsers.cc index 2a8d3d8..691b403 100644 --- a/net/tools/transport_security_state_generator/input_file_parsers.cc +++ b/net/tools/transport_security_state_generator/input_file_parsers.cc
@@ -167,6 +167,12 @@ } // namespace bool ParseCertificatesFile(base::StringPiece certs_input, Pinsets* pinsets) { + if (certs_input.find("\r\n") != base::StringPiece::npos) { + LOG(ERROR) << "CRLF line-endings found in the pins file. All files must " + "use LF (unix style) line-endings."; + return false; + } + std::string line; CertificateParserState current_state = CertificateParserState::PRE_NAME;
diff --git a/ppapi/proxy/audio_encoder_resource.h b/ppapi/proxy/audio_encoder_resource.h index 0290d21be..acdd774 100644 --- a/ppapi/proxy/audio_encoder_resource.h +++ b/ppapi/proxy/audio_encoder_resource.h
@@ -9,7 +9,6 @@ #include "base/macros.h" #include "base/memory/ref_counted.h" -#include "base/memory/scoped_vector.h" #include "ppapi/proxy/connection.h" #include "ppapi/proxy/plugin_resource.h" #include "ppapi/shared_impl/media_stream_buffer_manager.h"
diff --git a/ppapi/proxy/video_decoder_resource.cc b/ppapi/proxy/video_decoder_resource.cc index 26fee481..495d257 100644 --- a/ppapi/proxy/video_decoder_resource.cc +++ b/ppapi/proxy/video_decoder_resource.cc
@@ -238,14 +238,10 @@ return PP_ERROR_NOMEMORY; available_shm_buffers_.push_back(shm_buffer.get()); - if (shm_buffers_.size() < kMaximumPendingDecodes) { - shm_buffers_.push_back(shm_buffer.release()); - } else { - // Delete manually since ScopedVector won't delete the existing element if - // we just assign it. - delete shm_buffers_[shm_id]; - shm_buffers_[shm_id] = shm_buffer.release(); - } + if (shm_buffers_.size() < kMaximumPendingDecodes) + shm_buffers_.push_back(std::move(shm_buffer)); + else + shm_buffers_[shm_id] = std::move(shm_buffer); } // At this point we should have shared memory to hold the plugin's buffer. @@ -486,7 +482,7 @@ return; } // Make the shm buffer available. - available_shm_buffers_.push_back(shm_buffers_[shm_id]); + available_shm_buffers_.push_back(shm_buffers_[shm_id].get()); // If the plugin is waiting, let it call Decode again. if (decode_callback_.get()) { scoped_refptr<TrackedCallback> callback;
diff --git a/ppapi/proxy/video_decoder_resource.h b/ppapi/proxy/video_decoder_resource.h index adb3f05..0fd70400 100644 --- a/ppapi/proxy/video_decoder_resource.h +++ b/ppapi/proxy/video_decoder_resource.h
@@ -9,11 +9,11 @@ #include <memory> #include <queue> +#include <vector> #include "base/containers/hash_tables.h" #include "base/macros.h" #include "base/memory/ref_counted.h" -#include "base/memory/scoped_vector.h" #include "ppapi/proxy/connection.h" #include "ppapi/proxy/plugin_resource.h" #include "ppapi/proxy/ppapi_proxy_export.h" @@ -143,8 +143,8 @@ void DeleteGLTexture(uint32_t texture_id); void WriteNextPicture(); - // ScopedVector to own the shared memory buffers. - ScopedVector<ShmBuffer> shm_buffers_; + // The shared memory buffers. + std::vector<std::unique_ptr<ShmBuffer>> shm_buffers_; // List of available shared memory buffers. typedef std::vector<ShmBuffer*> ShmBufferList;
diff --git a/ppapi/proxy/video_encoder_resource.cc b/ppapi/proxy/video_encoder_resource.cc index 0f7c890..10aa8fa 100644 --- a/ppapi/proxy/video_encoder_resource.cc +++ b/ppapi/proxy/video_encoder_resource.cc
@@ -401,10 +401,10 @@ new base::SharedMemory(shm_handles[i], true)); CHECK(shm->Map(buffer_length)); - ShmBuffer* buffer = new ShmBuffer(i, std::move(shm)); - shm_buffers_.push_back(buffer); + auto buffer = base::MakeUnique<ShmBuffer>(i, std::move(shm)); bitstream_buffer_map_.insert( std::make_pair(buffer->shm->memory(), buffer->id)); + shm_buffers_.push_back(std::move(buffer)); } }
diff --git a/ppapi/proxy/video_encoder_resource.h b/ppapi/proxy/video_encoder_resource.h index 59877d3..e04c513 100644 --- a/ppapi/proxy/video_encoder_resource.h +++ b/ppapi/proxy/video_encoder_resource.h
@@ -9,10 +9,10 @@ #include <deque> #include <memory> +#include <vector> #include "base/macros.h" #include "base/memory/ref_counted.h" -#include "base/memory/scoped_vector.h" #include "ppapi/proxy/connection.h" #include "ppapi/proxy/plugin_resource.h" #include "ppapi/shared_impl/media_stream_buffer_manager.h" @@ -46,7 +46,7 @@ ShmBuffer(uint32_t id, std::unique_ptr<base::SharedMemory> shm); ~ShmBuffer(); - // Index of the buffer in the ScopedVector. Buffers have the same id in + // Index of the buffer in the vector. Buffers have the same id in // the plugin and the host. uint32_t id; std::unique_ptr<base::SharedMemory> shm; @@ -56,7 +56,7 @@ BitstreamBuffer(uint32_t id, uint32_t size, bool key_frame); ~BitstreamBuffer(); - // Index of the buffer in the ScopedVector. Same as ShmBuffer::id. + // Index of the buffer in the vector. Same as ShmBuffer::id. uint32_t id; uint32_t size; bool key_frame; @@ -141,7 +141,7 @@ VideoFrameMap; VideoFrameMap video_frames_; - ScopedVector<ShmBuffer> shm_buffers_; + std::vector<std::unique_ptr<ShmBuffer>> shm_buffers_; std::deque<BitstreamBuffer> available_bitstream_buffers_; typedef std::map<void*, uint32_t> BitstreamBufferMap;
diff --git a/ppapi/proxy/video_encoder_resource_unittest.cc b/ppapi/proxy/video_encoder_resource_unittest.cc index 5dc29c2..447643cf 100644 --- a/ppapi/proxy/video_encoder_resource_unittest.cc +++ b/ppapi/proxy/video_encoder_resource_unittest.cc
@@ -6,7 +6,9 @@ #include <stdint.h> +#include <memory> #include <utility> +#include <vector> #include "base/memory/shared_memory.h" #include "base/process/process.h" @@ -290,7 +292,7 @@ void SendBitstreamBuffers(const ResourceMessageCallParams& params, uint32_t buffer_length) { std::vector<SerializedHandle> handles; - for (base::SharedMemory* mem : shared_memory_bitstreams_) { + for (const auto& mem : shared_memory_bitstreams_) { ASSERT_EQ(mem->requested_size(), buffer_length); base::SharedMemoryHandle handle = mem->handle().Duplicate(); ASSERT_TRUE(handle.IsValid()); @@ -423,7 +425,7 @@ const PPB_VideoEncoder_0_2* encoder_iface_; const PPB_VideoEncoder_0_1* encoder_iface_0_1_; - ScopedVector<base::SharedMemory> shared_memory_bitstreams_; + std::vector<std::unique_ptr<base::SharedMemory>> shared_memory_bitstreams_; MediaStreamBufferManager video_frames_manager_; };
diff --git a/services/metrics/public/cpp/ukm_recorder.h b/services/metrics/public/cpp/ukm_recorder.h index fcefa5b..ef1802f 100644 --- a/services/metrics/public/cpp/ukm_recorder.h +++ b/services/metrics/public/cpp/ukm_recorder.h
@@ -20,6 +20,7 @@ class ContextualSearchRankerLoggerImpl; class PluginInfoMessageFilter; +class ProcessMemoryMetricsEmitter; class UkmPageLoadMetricsObserver; class LocalNetworkRequestsPageLoadMetricsObserver; @@ -89,6 +90,7 @@ friend autofill::AutofillMetrics; friend payments::JourneyLogger; friend ContextualSearchRankerLoggerImpl; + friend ProcessMemoryMetricsEmitter; friend PluginInfoMessageFilter; friend UkmPageLoadMetricsObserver; friend LocalNetworkRequestsPageLoadMetricsObserver;
diff --git a/testing/buildbot/chromium.fyi.json b/testing/buildbot/chromium.fyi.json index df6a60f..d9d6dbc 100644 --- a/testing/buildbot/chromium.fyi.json +++ b/testing/buildbot/chromium.fyi.json
@@ -2781,6 +2781,524 @@ } ] }, + "Chromium Win 10 GCE Tests": { + "gtest_tests": [ + { + "swarming": { + "can_use_on_swarming_builders": true + }, + "test": "accessibility_unittests" + }, + { + "swarming": { + "can_use_on_swarming_builders": true + }, + "test": "app_shell_unittests" + }, + { + "swarming": { + "can_use_on_swarming_builders": true + }, + "test": "aura_unittests" + }, + { + "swarming": { + "can_use_on_swarming_builders": true + }, + "test": "base_unittests" + }, + { + "swarming": { + "can_use_on_swarming_builders": true + }, + "test": "battor_agent_unittests" + }, + { + "swarming": { + "can_use_on_swarming_builders": true + }, + "test": "boringssl_crypto_tests" + }, + { + "swarming": { + "can_use_on_swarming_builders": true + }, + "test": "boringssl_ssl_tests" + }, + { + "swarming": { + "can_use_on_swarming_builders": true, + "shards": 10 + }, + "test": "browser_tests" + }, + { + "args": [ + "--enable-browser-side-navigation" + ], + "name": "browser_side_navigation_browser_tests", + "swarming": { + "can_use_on_swarming_builders": true, + "shards": 10 + }, + "test": "browser_tests" + }, + { + "swarming": { + "can_use_on_swarming_builders": true + }, + "test": "cacheinvalidation_unittests" + }, + { + "swarming": { + "can_use_on_swarming_builders": true + }, + "test": "capture_unittests" + }, + { + "swarming": { + "can_use_on_swarming_builders": true + }, + "test": "cast_unittests" + }, + { + "swarming": { + "can_use_on_swarming_builders": true + }, + "test": "cc_unittests" + }, + { + "swarming": { + "can_use_on_swarming_builders": true + }, + "test": "chrome_app_unittests" + }, + { + "swarming": { + "can_use_on_swarming_builders": true + }, + "test": "chrome_elf_unittests" + }, + { + "swarming": { + "can_use_on_swarming_builders": true + }, + "test": "chromedriver_unittests" + }, + { + "swarming": { + "can_use_on_swarming_builders": true + }, + "test": "components_browsertests" + }, + { + "args": [ + "--enable-browser-side-navigation" + ], + "name": "browser_side_navigation_components_browsertests", + "swarming": { + "can_use_on_swarming_builders": true + }, + "test": "components_browsertests" + }, + { + "swarming": { + "can_use_on_swarming_builders": true + }, + "test": "components_unittests" + }, + { + "args": [ + "--enable-browser-side-navigation" + ], + "name": "browser_side_navigation_components_unittests", + "swarming": { + "can_use_on_swarming_builders": true + }, + "test": "components_unittests" + }, + { + "swarming": { + "can_use_on_swarming_builders": true + }, + "test": "compositor_unittests" + }, + { + "swarming": { + "can_use_on_swarming_builders": true + }, + "test": "content_browsertests" + }, + { + "args": [ + "--enable-browser-side-navigation" + ], + "name": "browser_side_navigation_content_browsertests", + "swarming": { + "can_use_on_swarming_builders": true + }, + "test": "content_browsertests" + }, + { + "swarming": { + "can_use_on_swarming_builders": true + }, + "test": "content_unittests" + }, + { + "args": [ + "--enable-browser-side-navigation" + ], + "name": "browser_side_navigation_content_unittests", + "swarming": { + "can_use_on_swarming_builders": true + }, + "test": "content_unittests" + }, + { + "swarming": { + "can_use_on_swarming_builders": true + }, + "test": "courgette_unittests" + }, + { + "swarming": { + "can_use_on_swarming_builders": true + }, + "test": "crypto_unittests" + }, + { + "swarming": { + "can_use_on_swarming_builders": true + }, + "test": "device_unittests" + }, + { + "swarming": { + "can_use_on_swarming_builders": true + }, + "test": "display_unittests" + }, + { + "swarming": { + "can_use_on_swarming_builders": true + }, + "test": "events_unittests" + }, + { + "swarming": { + "can_use_on_swarming_builders": true + }, + "test": "extensions_browsertests" + }, + { + "args": [ + "--enable-browser-side-navigation" + ], + "name": "browser_side_navigation_extensions_browsertests", + "swarming": { + "can_use_on_swarming_builders": true + }, + "test": "extensions_browsertests" + }, + { + "swarming": { + "can_use_on_swarming_builders": true + }, + "test": "extensions_unittests" + }, + { + "swarming": { + "can_use_on_swarming_builders": true + }, + "test": "gcm_unit_tests" + }, + { + "swarming": { + "can_use_on_swarming_builders": true + }, + "test": "gfx_unittests" + }, + { + "swarming": { + "can_use_on_swarming_builders": true + }, + "test": "gn_unittests" + }, + { + "swarming": { + "can_use_on_swarming_builders": true + }, + "test": "google_apis_unittests" + }, + { + "swarming": { + "can_use_on_swarming_builders": true + }, + "test": "gpu_ipc_service_unittests" + }, + { + "swarming": { + "can_use_on_swarming_builders": true + }, + "test": "gpu_unittests" + }, + { + "swarming": { + "can_use_on_swarming_builders": true + }, + "test": "headless_browsertests" + }, + { + "args": [ + "--enable-browser-side-navigation" + ], + "name": "browser_side_navigation_headless_browsertests", + "swarming": { + "can_use_on_swarming_builders": true + }, + "test": "headless_browsertests" + }, + { + "swarming": { + "can_use_on_swarming_builders": true + }, + "test": "headless_unittests" + }, + { + "swarming": { + "can_use_on_swarming_builders": true + }, + "test": "install_static_unittests" + }, + { + "swarming": { + "can_use_on_swarming_builders": true + }, + "test": "installer_util_unittests" + }, + { + "swarming": { + "can_use_on_swarming_builders": true + }, + "test": "ipc_tests" + }, + { + "swarming": { + "can_use_on_swarming_builders": true + }, + "test": "jingle_unittests" + }, + { + "swarming": { + "can_use_on_swarming_builders": true + }, + "test": "keyboard_unittests" + }, + { + "swarming": { + "can_use_on_swarming_builders": true + }, + "test": "latency_unittests" + }, + { + "swarming": { + "can_use_on_swarming_builders": true + }, + "test": "libjingle_xmpp_unittests" + }, + { + "swarming": { + "can_use_on_swarming_builders": true + }, + "test": "media_blink_unittests" + }, + { + "swarming": { + "can_use_on_swarming_builders": true + }, + "test": "media_unittests" + }, + { + "swarming": { + "can_use_on_swarming_builders": true + }, + "test": "message_center_unittests" + }, + { + "swarming": { + "can_use_on_swarming_builders": true + }, + "test": "midi_unittests" + }, + { + "swarming": { + "can_use_on_swarming_builders": true + }, + "test": "mojo_common_unittests" + }, + { + "swarming": { + "can_use_on_swarming_builders": true + }, + "test": "mojo_public_bindings_unittests" + }, + { + "swarming": { + "can_use_on_swarming_builders": true + }, + "test": "mojo_public_system_unittests" + }, + { + "swarming": { + "can_use_on_swarming_builders": true + }, + "test": "mojo_system_unittests" + }, + { + "swarming": { + "can_use_on_swarming_builders": true + }, + "test": "nacl_loader_unittests" + }, + { + "swarming": { + "can_use_on_swarming_builders": true + }, + "test": "native_theme_unittests" + }, + { + "swarming": { + "can_use_on_swarming_builders": true + }, + "test": "net_unittests" + }, + { + "swarming": { + "can_use_on_swarming_builders": true + }, + "test": "pdf_unittests" + }, + { + "swarming": { + "can_use_on_swarming_builders": true + }, + "test": "ppapi_unittests" + }, + { + "swarming": { + "can_use_on_swarming_builders": true + }, + "test": "printing_unittests" + }, + { + "swarming": { + "can_use_on_swarming_builders": true + }, + "test": "remoting_unittests" + }, + { + "swarming": { + "can_use_on_swarming_builders": true + }, + "test": "sbox_integration_tests" + }, + { + "swarming": { + "can_use_on_swarming_builders": true + }, + "test": "sbox_unittests" + }, + { + "swarming": { + "can_use_on_swarming_builders": true + }, + "test": "sbox_validation_tests" + }, + { + "swarming": { + "can_use_on_swarming_builders": true + }, + "test": "services_unittests" + }, + { + "swarming": { + "can_use_on_swarming_builders": true + }, + "test": "setup_unittests" + }, + { + "swarming": { + "can_use_on_swarming_builders": true + }, + "test": "skia_unittests" + }, + { + "swarming": { + "can_use_on_swarming_builders": true + }, + "test": "sql_unittests" + }, + { + "swarming": { + "can_use_on_swarming_builders": true + }, + "test": "storage_unittests" + }, + { + "swarming": { + "can_use_on_swarming_builders": true + }, + "test": "sync_integration_tests" + }, + { + "swarming": { + "can_use_on_swarming_builders": true + }, + "test": "ui_base_unittests" + }, + { + "swarming": { + "can_use_on_swarming_builders": true + }, + "test": "ui_touch_selection_unittests" + }, + { + "swarming": { + "can_use_on_swarming_builders": true + }, + "test": "unit_tests" + }, + { + "args": [ + "--enable-browser-side-navigation" + ], + "name": "browser_side_navigation_unit_tests", + "swarming": { + "can_use_on_swarming_builders": true + }, + "test": "unit_tests" + }, + { + "swarming": { + "can_use_on_swarming_builders": true + }, + "test": "url_unittests" + }, + { + "swarming": { + "can_use_on_swarming_builders": true + }, + "test": "views_unittests" + }, + { + "swarming": { + "can_use_on_swarming_builders": true + }, + "test": "wm_unittests" + } + ] + }, "ClangToTAndroid x64": { "gtest_tests": [ {
diff --git a/third_party/WebKit/LayoutTests/FlagExpectations/enable-blink-features=LayoutNG b/third_party/WebKit/LayoutTests/FlagExpectations/enable-blink-features=LayoutNG index 928eb277..d9455d02 100644 --- a/third_party/WebKit/LayoutTests/FlagExpectations/enable-blink-features=LayoutNG +++ b/third_party/WebKit/LayoutTests/FlagExpectations/enable-blink-features=LayoutNG
@@ -9,15 +9,15 @@ crbug.com/591099 accessibility/adjacent-continuations-cause-assertion-failure.html [ Failure ] crbug.com/591099 accessibility/adopt-node-causes-crash.html [ Failure ] crbug.com/591099 accessibility/anonymous-render-block-in-continuation-causes-crash.html [ Crash Failure ] -crbug.com/591099 accessibility/aom-relation-properties.html [ Crash ] -crbug.com/591099 accessibility/aom-string-properties.html [ Crash ] -crbug.com/591099 accessibility/aom.html [ Crash ] -crbug.com/591099 accessibility/aria-activedescendant-events.html [ Crash ] -crbug.com/591099 accessibility/aria-activedescendant.html [ Crash ] +crbug.com/591099 accessibility/aom-relation-properties.html [ Crash Pass ] +crbug.com/591099 accessibility/aom-string-properties.html [ Crash Pass ] +crbug.com/591099 accessibility/aom.html [ Crash Pass ] +crbug.com/591099 accessibility/aria-activedescendant-events.html [ Crash Pass ] +crbug.com/591099 accessibility/aria-activedescendant.html [ Crash Failure ] crbug.com/591099 accessibility/aria-checkbox-checked-mixed.html [ Failure ] crbug.com/591099 accessibility/aria-checkbox-checked.html [ Failure ] crbug.com/591099 accessibility/aria-checkbox-sends-notification.html [ Failure ] -crbug.com/591099 accessibility/aria-combobox-activedescendant.html [ Crash ] +crbug.com/591099 accessibility/aria-combobox-activedescendant.html [ Crash Pass ] crbug.com/591099 accessibility/aria-controls-with-tabs.html [ Crash Failure ] crbug.com/591099 accessibility/aria-controls.html [ Crash Failure ] crbug.com/591099 accessibility/aria-describedby-on-input.html [ Crash Failure ] @@ -25,7 +25,7 @@ crbug.com/591099 accessibility/aria-fallback-roles.html [ Failure ] crbug.com/591099 accessibility/aria-flowto.html [ Failure ] crbug.com/591099 accessibility/aria-hidden-children-not-in-text-from-content.html [ Failure ] -crbug.com/591099 accessibility/aria-hidden-hides-all-elements.html [ Crash ] +crbug.com/591099 accessibility/aria-hidden-hides-all-elements.html [ Crash Failure ] crbug.com/591099 accessibility/aria-hidden-update.html [ Failure ] crbug.com/591099 accessibility/aria-hidden-updates-alldescendants.html [ Failure ] crbug.com/591099 accessibility/aria-hidden-with-elements.html [ Crash Failure ] @@ -51,18 +51,18 @@ crbug.com/591099 accessibility/aria-text-role.html [ Failure ] crbug.com/591099 accessibility/aria-toggle-button-with-title.html [ Failure ] crbug.com/591099 accessibility/aria-used-on-image-maps.html [ Failure ] -crbug.com/591099 accessibility/bounds-calc.html [ Crash ] +crbug.com/591099 accessibility/bounds-calc.html [ Crash Failure ] crbug.com/591099 accessibility/br-element-has-correct-title.html [ Failure ] crbug.com/591099 accessibility/button-title-uses-inner-img-alt.html [ Failure ] crbug.com/591099 accessibility/calling-accessibility-methods-with-pending-layout-causes-crash.html [ Failure ] crbug.com/591099 accessibility/canvas-accessibilitynodeobject.html [ Failure ] crbug.com/591099 accessibility/canvas-description-and-role.html [ Failure ] crbug.com/591099 accessibility/canvas-fallback-content-2.html [ Crash Timeout ] -crbug.com/591099 accessibility/canvas-fallback-content-labels.html [ Crash ] +crbug.com/591099 accessibility/canvas-fallback-content-labels.html [ Crash Failure ] crbug.com/591099 accessibility/canvas-fallback-content.html [ Failure ] crbug.com/591099 accessibility/chromium-only-roles.html [ Failure ] -crbug.com/591099 accessibility/click-event.html [ Crash ] -crbug.com/591099 accessibility/clickable.html [ Crash ] +crbug.com/591099 accessibility/click-event.html [ Crash Pass ] +crbug.com/591099 accessibility/clickable.html [ Crash Failure ] crbug.com/591099 accessibility/color-well.html [ Failure ] crbug.com/591099 accessibility/computed-name.html [ Crash Timeout ] crbug.com/591099 accessibility/computed-role.html [ Crash Timeout ] @@ -80,13 +80,13 @@ crbug.com/591099 accessibility/crashing-a-tag-in-map.html [ Failure ] crbug.com/591099 accessibility/css-generated-content.html [ Failure ] crbug.com/591099 accessibility/css-styles.html [ Crash Failure ] -crbug.com/591099 accessibility/description-calc-aria-describedby.html [ Crash ] -crbug.com/591099 accessibility/description-calc-inputs.html [ Crash ] -crbug.com/591099 accessibility/description-calc-native-markup-input-buttons.html [ Crash ] +crbug.com/591099 accessibility/description-calc-aria-describedby.html [ Crash Pass ] +crbug.com/591099 accessibility/description-calc-inputs.html [ Crash Pass ] +crbug.com/591099 accessibility/description-calc-native-markup-input-buttons.html [ Crash Pass ] crbug.com/591099 accessibility/dimensions-include-descendants.html [ Failure ] -crbug.com/591099 accessibility/disabled-controls-not-focusable.html [ Crash ] +crbug.com/591099 accessibility/disabled-controls-not-focusable.html [ Crash Failure ] crbug.com/591099 accessibility/display-inline-block-crash.html [ Failure ] -crbug.com/591099 accessibility/display-none-change.html [ Crash ] +crbug.com/591099 accessibility/display-none-change.html [ Crash Pass ] crbug.com/591099 accessibility/display-table-cell-causes-crash.html [ Failure ] crbug.com/591099 accessibility/div-within-anchors-causes-crash.html [ Failure ] crbug.com/591099 accessibility/dl-role.html [ Failure ] @@ -99,11 +99,11 @@ crbug.com/591099 accessibility/focusable-div.html [ Crash Failure ] crbug.com/591099 accessibility/hang-in-isignored.html [ Failure ] crbug.com/591099 accessibility/heading-level.html [ Failure ] -crbug.com/591099 accessibility/image-inside-link.html [ Crash ] +crbug.com/591099 accessibility/image-inside-link.html [ Crash Pass ] crbug.com/591099 accessibility/image-link-inline-cont.html [ Failure ] crbug.com/591099 accessibility/image-link.html [ Failure ] crbug.com/591099 accessibility/image-map-title-causes-crash.html [ Failure ] -crbug.com/591099 accessibility/image-map-update-parent-crash.html [ Crash ] +crbug.com/591099 accessibility/image-map-update-parent-crash.html [ Crash Failure ] crbug.com/591099 accessibility/image-map-with-indirect-area-crash.html [ Failure Pass ] crbug.com/591099 accessibility/image-map1.html [ Failure ] crbug.com/591099 accessibility/img-alt-tag-only-whitespace.html [ Failure ] @@ -119,63 +119,63 @@ crbug.com/591099 accessibility/inline-text-textarea.html [ Crash Failure ] crbug.com/591099 accessibility/inline-text-word-boundaries.html [ Failure ] crbug.com/591099 accessibility/inline-text-word-boundary-causes-crash.html [ Failure ] -crbug.com/591099 accessibility/input-aria-required.html [ Crash ] +crbug.com/591099 accessibility/input-aria-required.html [ Crash Failure ] crbug.com/591099 accessibility/input-file-causes-crash.html [ Crash Failure ] crbug.com/591099 accessibility/input-image-alt.html [ Failure ] -crbug.com/591099 accessibility/input-mixed.html [ Crash ] +crbug.com/591099 accessibility/input-mixed.html [ Crash Pass ] crbug.com/591099 accessibility/input-type-password-value-and-selection.html [ Crash Timeout ] crbug.com/591099 accessibility/input-type-range-aria-value.html [ Failure ] -crbug.com/591099 accessibility/input-type-range-value-change-event.html [ Crash ] +crbug.com/591099 accessibility/input-type-range-value-change-event.html [ Crash Pass ] crbug.com/591099 accessibility/input-type-range-value-change.html [ Failure ] crbug.com/591099 accessibility/input-type-text-caret-position.html [ Crash Failure ] crbug.com/591099 accessibility/input-type-text-selection.html [ Crash Failure Timeout ] -crbug.com/591099 accessibility/input-type-text-value-change-event.html [ Crash ] +crbug.com/591099 accessibility/input-type-text-value-change-event.html [ Crash Pass ] crbug.com/591099 accessibility/insert-selected-option-into-select-causes-crash.html [ Failure ] crbug.com/591099 accessibility/is-richly-editable.html [ Crash Failure ] crbug.com/591099 accessibility/label-element-press.html [ Failure ] crbug.com/591099 accessibility/label-for-control-hittest.html [ Failure ] crbug.com/591099 accessibility/language-attribute.html [ Failure ] crbug.com/591099 accessibility/legend.html [ Failure ] -crbug.com/591099 accessibility/line-for-index-endless-loop.html [ Crash ] +crbug.com/591099 accessibility/line-for-index-endless-loop.html [ Crash Pass ] crbug.com/591099 accessibility/link-inside-button-accessible-text.html [ Failure ] crbug.com/591099 accessibility/link-inside-label.html [ Failure ] crbug.com/591099 accessibility/listbox-enabled-states.html [ Failure ] -crbug.com/591099 accessibility/listbox-focus.html [ Crash ] +crbug.com/591099 accessibility/listbox-focus.html [ Crash Pass ] crbug.com/591099 accessibility/listitem-presentation-inherited.html [ Crash Failure ] crbug.com/591099 accessibility/main-element.html [ Failure ] crbug.com/591099 accessibility/media-controls.html [ Failure ] crbug.com/591099 accessibility/menu-item-crash.html [ Failure ] -crbug.com/591099 accessibility/menu-list-open.html [ Crash ] -crbug.com/591099 accessibility/menu-list-optgroup.html [ Crash ] +crbug.com/591099 accessibility/menu-list-open.html [ Crash Pass ] +crbug.com/591099 accessibility/menu-list-optgroup.html [ Crash Pass ] crbug.com/591099 accessibility/menu-list-popup-reuses-objects.html [ Failure ] crbug.com/591099 accessibility/menu-list-selection-changed.html [ Failure ] crbug.com/591099 accessibility/menu-list-sends-change-notification.html [ Failure ] crbug.com/591099 accessibility/meter-value.html [ Failure ] crbug.com/591099 accessibility/misspellings.html [ Timeout ] crbug.com/591099 accessibility/multiselect-list-reports-active-option.html [ Failure ] -crbug.com/591099 accessibility/name-calc-aria-label.html [ Crash ] -crbug.com/591099 accessibility/name-calc-aria-labelledby.html [ Crash ] -crbug.com/591099 accessibility/name-calc-aria-owns.html [ Crash ] -crbug.com/591099 accessibility/name-calc-figure.html [ Crash ] -crbug.com/591099 accessibility/name-calc-img.html [ Crash ] -crbug.com/591099 accessibility/name-calc-inputs.html [ Crash ] -crbug.com/591099 accessibility/name-calc-native-markup-buttons.html [ Crash ] -crbug.com/591099 accessibility/name-calc-native-markup-input-buttons.html [ Crash ] -crbug.com/591099 accessibility/name-calc-presentational.html [ Crash ] -crbug.com/591099 accessibility/name-calc-svg.html [ Crash ] -crbug.com/591099 accessibility/name-calc-visibility.html [ Crash ] +crbug.com/591099 accessibility/name-calc-aria-label.html [ Crash Pass ] +crbug.com/591099 accessibility/name-calc-aria-labelledby.html [ Crash Pass ] +crbug.com/591099 accessibility/name-calc-aria-owns.html [ Crash Pass ] +crbug.com/591099 accessibility/name-calc-figure.html [ Crash Pass ] +crbug.com/591099 accessibility/name-calc-img.html [ Crash Failure ] +crbug.com/591099 accessibility/name-calc-inputs.html [ Crash Pass ] +crbug.com/591099 accessibility/name-calc-native-markup-buttons.html [ Crash Pass ] +crbug.com/591099 accessibility/name-calc-native-markup-input-buttons.html [ Crash Pass ] +crbug.com/591099 accessibility/name-calc-presentational.html [ Crash Pass ] +crbug.com/591099 accessibility/name-calc-svg.html [ Crash Pass ] +crbug.com/591099 accessibility/name-calc-visibility.html [ Crash Pass ] crbug.com/591099 accessibility/nested-layout-crash.html [ Crash Failure ] crbug.com/591099 accessibility/non-native-image-crash.html [ Failure ] crbug.com/591099 accessibility/not-ignore-landmark-roles.html [ Failure ] crbug.com/591099 accessibility/notification-listeners.html [ Failure ] -crbug.com/591099 accessibility/option-aria-checked.html [ Crash ] -crbug.com/591099 accessibility/other-aria-attribute-change-sends-notification.html [ Crash ] +crbug.com/591099 accessibility/option-aria-checked.html [ Crash Pass ] +crbug.com/591099 accessibility/other-aria-attribute-change-sends-notification.html [ Crash Failure ] crbug.com/591099 accessibility/platform-name.html [ Failure ] crbug.com/591099 accessibility/presentation-owned-elements.html [ Crash Failure ] crbug.com/591099 accessibility/presentational-elements-with-focus.html [ Crash Failure ] -crbug.com/591099 accessibility/presentational-leaf.html [ Crash ] +crbug.com/591099 accessibility/presentational-leaf.html [ Crash Pass ] crbug.com/591099 accessibility/press-works-on-control-types.html [ Failure ] -crbug.com/591099 accessibility/press-works-on-text-fields.html [ Crash ] +crbug.com/591099 accessibility/press-works-on-text-fields.html [ Crash Pass ] crbug.com/591099 accessibility/radio-button-title-label.html [ Failure ] crbug.com/591099 accessibility/readonly.html [ Crash Failure ] crbug.com/591099 accessibility/removed-anonymous-block-child-causes-crash.html [ Failure ] @@ -200,7 +200,7 @@ crbug.com/591099 accessibility/selection-change-notification-textarea.html [ Crash Failure ] crbug.com/591099 accessibility/selection-states.html [ Failure ] crbug.com/591099 accessibility/set-selection-whitespace.html [ Failure ] -crbug.com/591099 accessibility/spin-button-detach.html [ Crash ] +crbug.com/591099 accessibility/spin-button-detach.html [ Crash Failure ] crbug.com/591099 accessibility/spinbutton-value.html [ Failure ] crbug.com/591099 accessibility/svg-bounds.html [ Failure ] crbug.com/591099 accessibility/svg-image.html [ Crash Failure ] @@ -218,12 +218,12 @@ crbug.com/591099 accessibility/table-row-with-aria-role.html [ Failure ] crbug.com/591099 accessibility/table-with-empty-thead-causes-crash.html [ Failure ] crbug.com/591099 accessibility/table-with-hidden-head-section.html [ Failure ] -crbug.com/591099 accessibility/text-change-notification.html [ Crash ] +crbug.com/591099 accessibility/text-change-notification.html [ Crash Failure ] crbug.com/591099 accessibility/textarea-caret-position.html [ Crash Timeout ] crbug.com/591099 accessibility/textarea-line-for-index.html [ Crash Failure ] crbug.com/591099 accessibility/textarea-selection.html [ Crash Failure ] crbug.com/591099 accessibility/textbox-role-on-contenteditable-crash.html [ Failure ] -crbug.com/591099 accessibility/title-ui-element-correctness.html [ Crash ] +crbug.com/591099 accessibility/title-ui-element-correctness.html [ Crash Failure ] crbug.com/591099 accessibility/updating-attribute-in-table-causes-crash.html [ Failure ] crbug.com/591099 accessibility/whitespace-in-name-calc.html [ Crash Failure Pass ] crbug.com/591099 animations/3d/change-transform-in-end-event.html [ Failure Pass ] @@ -231,103 +231,103 @@ crbug.com/591099 animations/animation-css-rule-types.html [ Failure ] crbug.com/591099 animations/animation-events-create.html [ Failure ] crbug.com/591099 animations/animations-parsing.html [ Timeout ] -crbug.com/591099 animations/animations-responsive-to-color-change.html [ Crash ] -crbug.com/591099 animations/clear-svg-animation-effects.html [ Crash ] -crbug.com/591099 animations/composition/background-position-composition.html [ Crash ] -crbug.com/591099 animations/composition/caret-color-composition.html [ Crash ] -crbug.com/591099 animations/composition/stroke-dasharray-composition.html [ Crash ] +crbug.com/591099 animations/animations-responsive-to-color-change.html [ Crash Pass ] +crbug.com/591099 animations/clear-svg-animation-effects.html [ Crash Pass ] +crbug.com/591099 animations/composition/background-position-composition.html [ Crash Pass ] +crbug.com/591099 animations/composition/caret-color-composition.html [ Crash Pass ] +crbug.com/591099 animations/composition/stroke-dasharray-composition.html [ Crash Pass ] crbug.com/591099 animations/computed-style.html [ Failure ] -crbug.com/591099 animations/css-animation-overrides-svg-presentation-attribute-animation.html [ Crash ] +crbug.com/591099 animations/css-animation-overrides-svg-presentation-attribute-animation.html [ Crash Pass ] crbug.com/591099 animations/delay-start-event.html [ Failure ] -crbug.com/591099 animations/display-change-does-not-terminate-animation.html [ Crash ] +crbug.com/591099 animations/display-change-does-not-terminate-animation.html [ Crash Failure ] crbug.com/591099 animations/display-inline-style-adjust.html [ Failure ] crbug.com/591099 animations/display-none-cancel-computedstyle.html [ Failure ] crbug.com/591099 animations/display-none-terminates-animation.html [ Failure ] crbug.com/591099 animations/inline-element-animation-end-hit-test.html [ Failure ] -crbug.com/591099 animations/interpolation/backdrop-filter-interpolation.html [ Crash ] -crbug.com/591099 animations/interpolation/background-color-interpolation.html [ Crash ] -crbug.com/591099 animations/interpolation/background-image-interpolation.html [ Crash ] -crbug.com/591099 animations/interpolation/background-position-interpolation.html [ Crash ] -crbug.com/591099 animations/interpolation/background-position-origin-interpolation.html [ Crash ] -crbug.com/591099 animations/interpolation/background-size-interpolation.html [ Crash ] -crbug.com/591099 animations/interpolation/border-color-interpolation.html [ Crash ] -crbug.com/591099 animations/interpolation/border-image-outset-interpolation.html [ Crash ] -crbug.com/591099 animations/interpolation/border-image-slice-interpolation.html [ Crash ] -crbug.com/591099 animations/interpolation/border-image-source-interpolation.html [ Crash ] -crbug.com/591099 animations/interpolation/border-image-width-interpolation.html [ Crash ] -crbug.com/591099 animations/interpolation/border-radius-interpolation.html [ Crash ] -crbug.com/591099 animations/interpolation/border-spacing-interpolation.html [ Crash ] -crbug.com/591099 animations/interpolation/border-width-interpolation.html [ Crash ] -crbug.com/591099 animations/interpolation/bottom-interpolation.html [ Crash ] -crbug.com/591099 animations/interpolation/box-shadow-interpolation.html [ Crash ] -crbug.com/591099 animations/interpolation/calc-interpolation.html [ Crash ] -crbug.com/591099 animations/interpolation/caret-color-interpolation.html [ Crash ] -crbug.com/591099 animations/interpolation/clip-interpolation.html [ Crash ] -crbug.com/591099 animations/interpolation/color-interpolation.html [ Crash ] -crbug.com/591099 animations/interpolation/filter-interpolation.html [ Crash ] -crbug.com/591099 animations/interpolation/font-size-adjust-interpolation.html [ Crash ] -crbug.com/591099 animations/interpolation/font-size-interpolation-unset.html [ Crash ] -crbug.com/591099 animations/interpolation/font-size-interpolation.html [ Crash ] -crbug.com/591099 animations/interpolation/font-size-zoom-interpolation.html [ Crash ] -crbug.com/591099 animations/interpolation/font-weight-interpolation.html [ Crash ] -crbug.com/591099 animations/interpolation/height-interpolation.html [ Crash ] -crbug.com/591099 animations/interpolation/line-height-interpolation.html [ Crash ] -crbug.com/591099 animations/interpolation/margin-interpolation.html [ Crash ] -crbug.com/591099 animations/interpolation/max-height-interpolation.html [ Crash ] -crbug.com/591099 animations/interpolation/min-height-interpolation.html [ Crash ] -crbug.com/591099 animations/interpolation/object-position-interpolation.html [ Crash ] -crbug.com/591099 animations/interpolation/offset-rotate-interpolation.html [ Crash ] -crbug.com/591099 animations/interpolation/opacity-interpolation.html [ Crash ] -crbug.com/591099 animations/interpolation/outline-color-interpolation.html [ Crash ] -crbug.com/591099 animations/interpolation/outline-offset-interpolation.html [ Crash ] -crbug.com/591099 animations/interpolation/outline-width-interpolation.html [ Crash ] -crbug.com/591099 animations/interpolation/padding-interpolation.html [ Crash ] -crbug.com/591099 animations/interpolation/perspective-interpolation.html [ Crash ] -crbug.com/591099 animations/interpolation/perspective-origin-interpolation.html [ Crash ] -crbug.com/591099 animations/interpolation/position-interpolation.html [ Crash ] -crbug.com/591099 animations/interpolation/sample-interpolation-test.html [ Crash ] -crbug.com/591099 animations/interpolation/svg-baseline-shift-interpolation.html [ Crash ] -crbug.com/591099 animations/interpolation/svg-cx-interpolation.html [ Crash ] -crbug.com/591099 animations/interpolation/svg-cy-interpolation.html [ Crash ] -crbug.com/591099 animations/interpolation/svg-d-interpolation.html [ Crash ] -crbug.com/591099 animations/interpolation/svg-fill-interpolation.html [ Crash ] -crbug.com/591099 animations/interpolation/svg-fill-opacity-interpolation.html [ Crash ] -crbug.com/591099 animations/interpolation/svg-flood-color-interpolation.html [ Crash ] -crbug.com/591099 animations/interpolation/svg-flood-opacity-interpolation.html [ Crash ] -crbug.com/591099 animations/interpolation/svg-lighting-color-interpolation.html [ Crash ] -crbug.com/591099 animations/interpolation/svg-r-interpolation.html [ Crash ] -crbug.com/591099 animations/interpolation/svg-rx-interpolation.html [ Crash ] -crbug.com/591099 animations/interpolation/svg-ry-interpolation.html [ Crash ] -crbug.com/591099 animations/interpolation/svg-stop-color-interpolation.html [ Crash ] -crbug.com/591099 animations/interpolation/svg-stop-opacity-interpolation.html [ Crash ] -crbug.com/591099 animations/interpolation/svg-stroke-dasharray-interpolation.html [ Crash ] -crbug.com/591099 animations/interpolation/svg-stroke-dashoffset-interpolation.html [ Crash ] -crbug.com/591099 animations/interpolation/svg-stroke-interpolation.html [ Crash ] -crbug.com/591099 animations/interpolation/svg-stroke-miterlimit-interpolation.html [ Crash ] -crbug.com/591099 animations/interpolation/svg-stroke-opacity-interpolation.html [ Crash ] -crbug.com/591099 animations/interpolation/svg-stroke-width-interpolation.html [ Crash ] -crbug.com/591099 animations/interpolation/text-decoration-color-interpolation.html [ Crash ] -crbug.com/591099 animations/interpolation/text-shadow-interpolation.html [ Crash ] -crbug.com/591099 animations/interpolation/top-interpolation.html [ Crash ] -crbug.com/591099 animations/interpolation/transform-interpolation.html [ Crash ] -crbug.com/591099 animations/interpolation/transform-origin-interpolation.html [ Crash ] -crbug.com/591099 animations/interpolation/vertical-align-interpolation.html [ Crash ] -crbug.com/591099 animations/interpolation/viewport-unit-interpolation.html [ Crash ] -crbug.com/591099 animations/interpolation/webkit-background-size-interpolation.html [ Crash ] -crbug.com/591099 animations/interpolation/webkit-clip-path-interpolation.html [ Crash ] -crbug.com/591099 animations/interpolation/webkit-column-rule-color-interpolation.html [ Crash ] -crbug.com/591099 animations/interpolation/webkit-mask-box-image-outset-interpolation.html [ Crash ] -crbug.com/591099 animations/interpolation/webkit-mask-box-image-slice-interpolation.html [ Crash ] -crbug.com/591099 animations/interpolation/webkit-mask-box-image-source-interpolation.html [ Crash ] -crbug.com/591099 animations/interpolation/webkit-mask-box-image-width-interpolation.html [ Crash ] -crbug.com/591099 animations/interpolation/webkit-mask-image-interpolation.html [ Crash ] -crbug.com/591099 animations/interpolation/webkit-mask-position-interpolation.html [ Crash ] -crbug.com/591099 animations/interpolation/webkit-mask-size-interpolation.html [ Crash ] -crbug.com/591099 animations/interpolation/webkit-perspective-interpolation.html [ Crash ] -crbug.com/591099 animations/interpolation/webkit-perspective-origin-interpolation.html [ Crash ] -crbug.com/591099 animations/interpolation/webkit-text-stroke-color-interpolation.html [ Crash ] -crbug.com/591099 animations/interpolation/webkit-transform-interpolation.html [ Crash ] -crbug.com/591099 animations/interpolation/webkit-transform-origin-interpolation.html [ Crash ] +crbug.com/591099 animations/interpolation/backdrop-filter-interpolation.html [ Crash Timeout ] +crbug.com/591099 animations/interpolation/background-color-interpolation.html [ Crash Pass ] +crbug.com/591099 animations/interpolation/background-image-interpolation.html [ Crash Timeout ] +crbug.com/591099 animations/interpolation/background-position-interpolation.html [ Crash Pass ] +crbug.com/591099 animations/interpolation/background-position-origin-interpolation.html [ Crash Pass ] +crbug.com/591099 animations/interpolation/background-size-interpolation.html [ Crash Pass ] +crbug.com/591099 animations/interpolation/border-color-interpolation.html [ Crash Pass ] +crbug.com/591099 animations/interpolation/border-image-outset-interpolation.html [ Crash Pass ] +crbug.com/591099 animations/interpolation/border-image-slice-interpolation.html [ Crash Pass ] +crbug.com/591099 animations/interpolation/border-image-source-interpolation.html [ Crash Pass ] +crbug.com/591099 animations/interpolation/border-image-width-interpolation.html [ Crash Timeout ] +crbug.com/591099 animations/interpolation/border-radius-interpolation.html [ Crash Pass ] +crbug.com/591099 animations/interpolation/border-spacing-interpolation.html [ Crash Pass ] +crbug.com/591099 animations/interpolation/border-width-interpolation.html [ Crash Pass ] +crbug.com/591099 animations/interpolation/bottom-interpolation.html [ Crash Pass ] +crbug.com/591099 animations/interpolation/box-shadow-interpolation.html [ Crash Pass ] +crbug.com/591099 animations/interpolation/calc-interpolation.html [ Crash Pass ] +crbug.com/591099 animations/interpolation/caret-color-interpolation.html [ Crash Pass ] +crbug.com/591099 animations/interpolation/clip-interpolation.html [ Crash Pass ] +crbug.com/591099 animations/interpolation/color-interpolation.html [ Crash Pass ] +crbug.com/591099 animations/interpolation/filter-interpolation.html [ Crash Pass ] +crbug.com/591099 animations/interpolation/font-size-adjust-interpolation.html [ Crash Pass ] +crbug.com/591099 animations/interpolation/font-size-interpolation-unset.html [ Crash Pass ] +crbug.com/591099 animations/interpolation/font-size-interpolation.html [ Crash Pass ] +crbug.com/591099 animations/interpolation/font-size-zoom-interpolation.html [ Crash Pass ] +crbug.com/591099 animations/interpolation/font-weight-interpolation.html [ Crash Pass ] +crbug.com/591099 animations/interpolation/height-interpolation.html [ Crash Pass ] +crbug.com/591099 animations/interpolation/line-height-interpolation.html [ Crash Timeout ] +crbug.com/591099 animations/interpolation/margin-interpolation.html [ Crash Pass ] +crbug.com/591099 animations/interpolation/max-height-interpolation.html [ Crash Pass ] +crbug.com/591099 animations/interpolation/min-height-interpolation.html [ Crash Pass ] +crbug.com/591099 animations/interpolation/object-position-interpolation.html [ Crash Pass ] +crbug.com/591099 animations/interpolation/offset-rotate-interpolation.html [ Crash Pass ] +crbug.com/591099 animations/interpolation/opacity-interpolation.html [ Crash Pass ] +crbug.com/591099 animations/interpolation/outline-color-interpolation.html [ Crash Pass ] +crbug.com/591099 animations/interpolation/outline-offset-interpolation.html [ Crash Pass ] +crbug.com/591099 animations/interpolation/outline-width-interpolation.html [ Crash Pass ] +crbug.com/591099 animations/interpolation/padding-interpolation.html [ Crash Pass ] +crbug.com/591099 animations/interpolation/perspective-interpolation.html [ Crash Pass ] +crbug.com/591099 animations/interpolation/perspective-origin-interpolation.html [ Crash Pass ] +crbug.com/591099 animations/interpolation/position-interpolation.html [ Crash Pass ] +crbug.com/591099 animations/interpolation/sample-interpolation-test.html [ Crash Pass ] +crbug.com/591099 animations/interpolation/svg-baseline-shift-interpolation.html [ Crash Pass ] +crbug.com/591099 animations/interpolation/svg-cx-interpolation.html [ Crash Pass ] +crbug.com/591099 animations/interpolation/svg-cy-interpolation.html [ Crash Pass ] +crbug.com/591099 animations/interpolation/svg-d-interpolation.html [ Crash Timeout ] +crbug.com/591099 animations/interpolation/svg-fill-interpolation.html [ Crash Pass ] +crbug.com/591099 animations/interpolation/svg-fill-opacity-interpolation.html [ Crash Pass ] +crbug.com/591099 animations/interpolation/svg-flood-color-interpolation.html [ Crash Pass ] +crbug.com/591099 animations/interpolation/svg-flood-opacity-interpolation.html [ Crash Pass ] +crbug.com/591099 animations/interpolation/svg-lighting-color-interpolation.html [ Crash Pass ] +crbug.com/591099 animations/interpolation/svg-r-interpolation.html [ Crash Pass ] +crbug.com/591099 animations/interpolation/svg-rx-interpolation.html [ Crash Pass ] +crbug.com/591099 animations/interpolation/svg-ry-interpolation.html [ Crash Pass ] +crbug.com/591099 animations/interpolation/svg-stop-color-interpolation.html [ Crash Pass ] +crbug.com/591099 animations/interpolation/svg-stop-opacity-interpolation.html [ Crash Pass ] +crbug.com/591099 animations/interpolation/svg-stroke-dasharray-interpolation.html [ Crash Timeout ] +crbug.com/591099 animations/interpolation/svg-stroke-dashoffset-interpolation.html [ Crash Pass ] +crbug.com/591099 animations/interpolation/svg-stroke-interpolation.html [ Crash Pass ] +crbug.com/591099 animations/interpolation/svg-stroke-miterlimit-interpolation.html [ Crash Pass ] +crbug.com/591099 animations/interpolation/svg-stroke-opacity-interpolation.html [ Crash Pass ] +crbug.com/591099 animations/interpolation/svg-stroke-width-interpolation.html [ Crash Pass ] +crbug.com/591099 animations/interpolation/text-decoration-color-interpolation.html [ Crash Pass ] +crbug.com/591099 animations/interpolation/text-shadow-interpolation.html [ Crash Pass ] +crbug.com/591099 animations/interpolation/top-interpolation.html [ Crash Pass ] +crbug.com/591099 animations/interpolation/transform-interpolation.html [ Crash Timeout ] +crbug.com/591099 animations/interpolation/transform-origin-interpolation.html [ Crash Pass ] +crbug.com/591099 animations/interpolation/vertical-align-interpolation.html [ Crash Pass ] +crbug.com/591099 animations/interpolation/viewport-unit-interpolation.html [ Crash Pass ] +crbug.com/591099 animations/interpolation/webkit-background-size-interpolation.html [ Crash Pass ] +crbug.com/591099 animations/interpolation/webkit-clip-path-interpolation.html [ Crash Timeout ] +crbug.com/591099 animations/interpolation/webkit-column-rule-color-interpolation.html [ Crash Pass ] +crbug.com/591099 animations/interpolation/webkit-mask-box-image-outset-interpolation.html [ Crash Pass ] +crbug.com/591099 animations/interpolation/webkit-mask-box-image-slice-interpolation.html [ Crash Pass ] +crbug.com/591099 animations/interpolation/webkit-mask-box-image-source-interpolation.html [ Crash Pass ] +crbug.com/591099 animations/interpolation/webkit-mask-box-image-width-interpolation.html [ Crash Pass ] +crbug.com/591099 animations/interpolation/webkit-mask-image-interpolation.html [ Crash Pass ] +crbug.com/591099 animations/interpolation/webkit-mask-position-interpolation.html [ Crash Pass ] +crbug.com/591099 animations/interpolation/webkit-mask-size-interpolation.html [ Crash Pass ] +crbug.com/591099 animations/interpolation/webkit-perspective-interpolation.html [ Crash Pass ] +crbug.com/591099 animations/interpolation/webkit-perspective-origin-interpolation.html [ Crash Pass ] +crbug.com/591099 animations/interpolation/webkit-text-stroke-color-interpolation.html [ Crash Pass ] +crbug.com/591099 animations/interpolation/webkit-transform-interpolation.html [ Crash Timeout ] +crbug.com/591099 animations/interpolation/webkit-transform-origin-interpolation.html [ Crash Pass ] crbug.com/591099 animations/keyframes-rule.html [ Failure ] crbug.com/591099 animations/lazy-detached-animation-stop.html [ Failure ] crbug.com/591099 animations/negative-delay-events.html [ Failure ] @@ -336,7 +336,7 @@ crbug.com/591099 animations/prefixed/animation-inherit-initial-unprefixed.html [ Failure ] crbug.com/591099 animations/prefixed/keyframes-cssom-prefixed-02.html [ Failure ] crbug.com/591099 animations/prefixed/keyframes-cssom-unprefixed-02.html [ Failure ] -crbug.com/591099 animations/responsive/d-responsive.html [ Crash ] +crbug.com/591099 animations/responsive/d-responsive.html [ Crash Pass ] crbug.com/591099 animations/responsive/line-height-responsive.html [ Pass Timeout ] crbug.com/591099 animations/rotate-transform-equivalent.html [ Failure ] crbug.com/591099 animations/skew-notsequential-compositor.html [ Failure ] @@ -344,171 +344,171 @@ crbug.com/591099 animations/stability/animation-iteration-event-destroy-renderer.html [ Failure ] crbug.com/591099 animations/stability/animation-on-inline-crash.html [ Failure ] crbug.com/591099 animations/stability/animation-start-event-destroy-renderer.html [ Failure ] -crbug.com/591099 animations/stability/base-render-style-crash.html [ Crash ] -crbug.com/591099 animations/stability/checkbox-padding-animation-crash.html [ Crash ] +crbug.com/591099 animations/stability/base-render-style-crash.html [ Crash Pass ] +crbug.com/591099 animations/stability/checkbox-padding-animation-crash.html [ Crash Pass ] crbug.com/591099 animations/stability/element-animate-float-crash.html [ Failure Pass ] crbug.com/591099 animations/stability/empty-keyframe-animation-composited.html [ Failure ] crbug.com/591099 animations/stability/empty-keyframes-composited.html [ Failure ] crbug.com/591099 animations/stability/empty-keyframes.html [ Failure ] crbug.com/591099 animations/stability/import-crash.html [ Failure ] crbug.com/591099 animations/stability/length-zero-percent-crash.html [ Failure Pass ] -crbug.com/591099 animations/stability/option-element-crash.html [ Crash ] -crbug.com/591099 animations/stability/option-opacity-inherit-crash.html [ Crash ] +crbug.com/591099 animations/stability/option-element-crash.html [ Crash Pass ] +crbug.com/591099 animations/stability/option-opacity-inherit-crash.html [ Crash Pass ] crbug.com/591099 animations/stability/pause-crash.html [ Failure ] -crbug.com/591099 animations/stability/svg-element-css-animation-crash.html [ Crash ] -crbug.com/591099 animations/stability/svg-length-unittype-crash.html [ Crash ] +crbug.com/591099 animations/stability/svg-element-css-animation-crash.html [ Crash Pass ] +crbug.com/591099 animations/stability/svg-length-unittype-crash.html [ Crash Pass ] crbug.com/591099 animations/stability/zero-duration-infinite-iterations.html [ Failure ] crbug.com/591099 animations/stability/zero-duration-large-start-delay.html [ Failure ] crbug.com/591099 animations/state-at-end-event.html [ Failure Pass ] -crbug.com/591099 animations/svg-attribute-composition/svg-amplitude-composition.html [ Crash ] -crbug.com/591099 animations/svg-attribute-composition/svg-azimuth-composition.html [ Crash ] -crbug.com/591099 animations/svg-attribute-composition/svg-baseFrequency-composition.html [ Crash ] -crbug.com/591099 animations/svg-attribute-composition/svg-bias-composition.html [ Crash ] -crbug.com/591099 animations/svg-attribute-composition/svg-cx-cy-composition.html [ Crash ] -crbug.com/591099 animations/svg-attribute-composition/svg-d-composition.html [ Crash ] -crbug.com/591099 animations/svg-attribute-composition/svg-diffuseConstant-composition.html [ Crash ] -crbug.com/591099 animations/svg-attribute-composition/svg-divisor-composition.html [ Crash ] -crbug.com/591099 animations/svg-attribute-composition/svg-dx-dy-length-list-composition.html [ Crash ] -crbug.com/591099 animations/svg-attribute-composition/svg-dx-dy-number-composition.html [ Crash ] -crbug.com/591099 animations/svg-attribute-composition/svg-elevation-composition.html [ Crash ] -crbug.com/591099 animations/svg-attribute-composition/svg-exponent-composition.html [ Crash ] -crbug.com/591099 animations/svg-attribute-composition/svg-fx-fy-composition.html [ Crash ] -crbug.com/591099 animations/svg-attribute-composition/svg-gradientTransform-composition.html [ Crash ] -crbug.com/591099 animations/svg-attribute-composition/svg-height-composition.html [ Crash ] -crbug.com/591099 animations/svg-attribute-composition/svg-intercept-composition.html [ Crash ] -crbug.com/591099 animations/svg-attribute-composition/svg-k1-k2-k3-k4-composition.html [ Crash ] -crbug.com/591099 animations/svg-attribute-composition/svg-kernelMatrix-composition.html [ Crash ] -crbug.com/591099 animations/svg-attribute-composition/svg-kernelUnitLength-composition.html [ Crash ] -crbug.com/591099 animations/svg-attribute-composition/svg-limitingConeAngle-composition.html [ Crash ] -crbug.com/591099 animations/svg-attribute-composition/svg-markerHeight-composition.html [ Crash ] -crbug.com/591099 animations/svg-attribute-composition/svg-markerWidth-composition.html [ Crash ] -crbug.com/591099 animations/svg-attribute-composition/svg-mode-composition.html [ Crash ] -crbug.com/591099 animations/svg-attribute-composition/svg-numOctaves-composition.html [ Crash ] -crbug.com/591099 animations/svg-attribute-composition/svg-offset-composition.html [ Crash ] -crbug.com/591099 animations/svg-attribute-composition/svg-order-composition.html [ Crash ] -crbug.com/591099 animations/svg-attribute-composition/svg-orient-composition.html [ Crash ] -crbug.com/591099 animations/svg-attribute-composition/svg-pathLength-composition.html [ Crash ] -crbug.com/591099 animations/svg-attribute-composition/svg-patternTransform-composition.html [ Crash ] -crbug.com/591099 animations/svg-attribute-composition/svg-points-composition.html [ Crash ] -crbug.com/591099 animations/svg-attribute-composition/svg-pointsAtX-pointsAtY-pointsAtZ-composition.html [ Crash ] -crbug.com/591099 animations/svg-attribute-composition/svg-r-composition.html [ Crash ] -crbug.com/591099 animations/svg-attribute-composition/svg-radius-composition.html [ Crash ] -crbug.com/591099 animations/svg-attribute-composition/svg-refX-refY-composition.html [ Crash ] -crbug.com/591099 animations/svg-attribute-composition/svg-rotate-composition.html [ Crash ] -crbug.com/591099 animations/svg-attribute-composition/svg-rx-composition.html [ Crash ] -crbug.com/591099 animations/svg-attribute-composition/svg-scale-composition.html [ Crash ] -crbug.com/591099 animations/svg-attribute-composition/svg-seed-composition.html [ Crash ] -crbug.com/591099 animations/svg-attribute-composition/svg-slope-composition.html [ Crash ] -crbug.com/591099 animations/svg-attribute-composition/svg-specularConstant-composition.html [ Crash ] -crbug.com/591099 animations/svg-attribute-composition/svg-specularExponent-composition.html [ Crash ] -crbug.com/591099 animations/svg-attribute-composition/svg-startOffset-composition.html [ Crash ] -crbug.com/591099 animations/svg-attribute-composition/svg-stdDeviation-composition.html [ Crash ] -crbug.com/591099 animations/svg-attribute-composition/svg-surfaceScale-composition.html [ Crash ] -crbug.com/591099 animations/svg-attribute-composition/svg-tableValues-composition.html [ Crash ] -crbug.com/591099 animations/svg-attribute-composition/svg-targetX-targetY-composition.html [ Crash ] -crbug.com/591099 animations/svg-attribute-composition/svg-textLength-composition.html [ Crash ] -crbug.com/591099 animations/svg-attribute-composition/svg-transform-composition-distinct.html [ Crash ] -crbug.com/591099 animations/svg-attribute-composition/svg-transform-composition-list.html [ Crash ] -crbug.com/591099 animations/svg-attribute-composition/svg-transform-composition.html [ Crash ] -crbug.com/591099 animations/svg-attribute-composition/svg-transform-matrix.html [ Crash ] -crbug.com/591099 animations/svg-attribute-composition/svg-values-composition.html [ Crash ] -crbug.com/591099 animations/svg-attribute-composition/svg-viewBox-composition.html [ Crash ] -crbug.com/591099 animations/svg-attribute-composition/svg-width-composition.html [ Crash ] -crbug.com/591099 animations/svg-attribute-composition/svg-x-composition.html [ Crash ] -crbug.com/591099 animations/svg-attribute-composition/svg-x-list-composition.html [ Crash ] -crbug.com/591099 animations/svg-attribute-composition/svg-x1-x2-y1-y2-composition.html [ Crash ] -crbug.com/591099 animations/svg-attribute-composition/svg-y-composition.html [ Crash ] -crbug.com/591099 animations/svg-attribute-composition/svg-y-list-composition.html [ Crash ] -crbug.com/591099 animations/svg-attribute-composition/svg-z-composition.html [ Crash ] -crbug.com/591099 animations/svg-attribute-interpolation/svg-amplitude-interpolation.html [ Crash ] -crbug.com/591099 animations/svg-attribute-interpolation/svg-azimuth-interpolation.html [ Crash ] -crbug.com/591099 animations/svg-attribute-interpolation/svg-baseFrequency-interpolation.html [ Crash ] -crbug.com/591099 animations/svg-attribute-interpolation/svg-bias-interpolation.html [ Crash ] -crbug.com/591099 animations/svg-attribute-interpolation/svg-calc-interpolation.html [ Crash ] -crbug.com/591099 animations/svg-attribute-interpolation/svg-class-interpolation.html [ Crash ] -crbug.com/591099 animations/svg-attribute-interpolation/svg-clipPathUnits-interpolation.html [ Crash ] -crbug.com/591099 animations/svg-attribute-interpolation/svg-cx-cy-interpolation.html [ Crash ] -crbug.com/591099 animations/svg-attribute-interpolation/svg-d-interpolation.html [ Crash ] -crbug.com/591099 animations/svg-attribute-interpolation/svg-diffuseConstant-interpolation.html [ Crash ] -crbug.com/591099 animations/svg-attribute-interpolation/svg-divisor-interpolation.html [ Crash ] -crbug.com/591099 animations/svg-attribute-interpolation/svg-dx-dy-length-list-interpolation.html [ Crash ] -crbug.com/591099 animations/svg-attribute-interpolation/svg-dx-dy-number-interpolation.html [ Crash ] -crbug.com/591099 animations/svg-attribute-interpolation/svg-edgeMode-interpolation.html [ Crash ] -crbug.com/591099 animations/svg-attribute-interpolation/svg-elevation-interpolation.html [ Crash ] -crbug.com/591099 animations/svg-attribute-interpolation/svg-exponent-interpolation.html [ Crash ] -crbug.com/591099 animations/svg-attribute-interpolation/svg-filterUnits-interpolation.html [ Crash ] -crbug.com/591099 animations/svg-attribute-interpolation/svg-fx-fy-interpolation.html [ Crash ] -crbug.com/591099 animations/svg-attribute-interpolation/svg-gradientTransform-interpolation.html [ Crash ] -crbug.com/591099 animations/svg-attribute-interpolation/svg-gradientUnits-interpolation.html [ Crash ] -crbug.com/591099 animations/svg-attribute-interpolation/svg-height-interpolation.html [ Crash ] -crbug.com/591099 animations/svg-attribute-interpolation/svg-href-interpolation.html [ Crash ] -crbug.com/591099 animations/svg-attribute-interpolation/svg-in-interpolation.html [ Crash ] -crbug.com/591099 animations/svg-attribute-interpolation/svg-intercept-interpolation.html [ Crash ] -crbug.com/591099 animations/svg-attribute-interpolation/svg-k1-k2-k3-k4-interpolation.html [ Crash ] -crbug.com/591099 animations/svg-attribute-interpolation/svg-kernelMatrix-interpolation.html [ Crash ] -crbug.com/591099 animations/svg-attribute-interpolation/svg-kernelUnitLength-interpolation.html [ Crash ] -crbug.com/591099 animations/svg-attribute-interpolation/svg-lengthAdjust-interpolation.html [ Crash ] -crbug.com/591099 animations/svg-attribute-interpolation/svg-limitingConeAngle-interpolation.html [ Crash ] -crbug.com/591099 animations/svg-attribute-interpolation/svg-markerHeight-interpolation.html [ Crash ] -crbug.com/591099 animations/svg-attribute-interpolation/svg-markerUnits-interpolation.html [ Crash ] -crbug.com/591099 animations/svg-attribute-interpolation/svg-markerWidth-interpolation.html [ Crash ] -crbug.com/591099 animations/svg-attribute-interpolation/svg-maskContentUnits-interpolation.html [ Crash ] -crbug.com/591099 animations/svg-attribute-interpolation/svg-maskUnits-interpolation.html [ Crash ] -crbug.com/591099 animations/svg-attribute-interpolation/svg-method-interpolation.html [ Crash ] -crbug.com/591099 animations/svg-attribute-interpolation/svg-mode-interpolation.html [ Crash ] -crbug.com/591099 animations/svg-attribute-interpolation/svg-numOctaves-interpolation.html [ Crash ] -crbug.com/591099 animations/svg-attribute-interpolation/svg-offset-interpolation.html [ Crash ] -crbug.com/591099 animations/svg-attribute-interpolation/svg-operator-interpolation.html [ Crash ] -crbug.com/591099 animations/svg-attribute-interpolation/svg-order-interpolation.html [ Crash ] -crbug.com/591099 animations/svg-attribute-interpolation/svg-orient-interpolation.html [ Crash ] -crbug.com/591099 animations/svg-attribute-interpolation/svg-pathLength-interpolation.html [ Crash ] -crbug.com/591099 animations/svg-attribute-interpolation/svg-patternContentUnits-interpolation.html [ Crash ] -crbug.com/591099 animations/svg-attribute-interpolation/svg-patternTransform-interpolation.html [ Crash ] -crbug.com/591099 animations/svg-attribute-interpolation/svg-patternUnits-interpolation.html [ Crash ] -crbug.com/591099 animations/svg-attribute-interpolation/svg-points-interpolation.html [ Crash ] -crbug.com/591099 animations/svg-attribute-interpolation/svg-pointsAtX-pointsAtY-pointsAtZ-interpolation.html [ Crash ] -crbug.com/591099 animations/svg-attribute-interpolation/svg-preserveAlpha-interpolation.html [ Crash ] -crbug.com/591099 animations/svg-attribute-interpolation/svg-preserveAspectRatio-interpolation.html [ Crash ] -crbug.com/591099 animations/svg-attribute-interpolation/svg-primitiveUnits-interpolation.html [ Crash ] -crbug.com/591099 animations/svg-attribute-interpolation/svg-r-interpolation.html [ Crash ] -crbug.com/591099 animations/svg-attribute-interpolation/svg-radius-interpolation.html [ Crash ] -crbug.com/591099 animations/svg-attribute-interpolation/svg-refX-refY-interpolation.html [ Crash ] -crbug.com/591099 animations/svg-attribute-interpolation/svg-result-interpolation.html [ Crash ] -crbug.com/591099 animations/svg-attribute-interpolation/svg-rotate-interpolation.html [ Crash ] -crbug.com/591099 animations/svg-attribute-interpolation/svg-rx-interpolation.html [ Crash ] -crbug.com/591099 animations/svg-attribute-interpolation/svg-scale-interpolation.html [ Crash ] -crbug.com/591099 animations/svg-attribute-interpolation/svg-seed-interpolation.html [ Crash ] -crbug.com/591099 animations/svg-attribute-interpolation/svg-slope-interpolation.html [ Crash ] -crbug.com/591099 animations/svg-attribute-interpolation/svg-spacing-interpolation.html [ Crash ] -crbug.com/591099 animations/svg-attribute-interpolation/svg-specularConstant-interpolation.html [ Crash ] -crbug.com/591099 animations/svg-attribute-interpolation/svg-specularExponent-interpolation.html [ Crash ] -crbug.com/591099 animations/svg-attribute-interpolation/svg-spreadMethod-interpolation.html [ Crash ] -crbug.com/591099 animations/svg-attribute-interpolation/svg-startOffset-interpolation.html [ Crash ] -crbug.com/591099 animations/svg-attribute-interpolation/svg-stdDeviation-interpolation.html [ Crash ] -crbug.com/591099 animations/svg-attribute-interpolation/svg-stitchTiles-interpolation.html [ Crash ] -crbug.com/591099 animations/svg-attribute-interpolation/svg-surfaceScale-interpolation.html [ Crash ] -crbug.com/591099 animations/svg-attribute-interpolation/svg-tableValues-interpolation.html [ Crash ] -crbug.com/591099 animations/svg-attribute-interpolation/svg-target-interpolation.html [ Crash ] -crbug.com/591099 animations/svg-attribute-interpolation/svg-targetX-targetY-interpolation.html [ Crash ] -crbug.com/591099 animations/svg-attribute-interpolation/svg-textLength-interpolation.html [ Crash ] -crbug.com/591099 animations/svg-attribute-interpolation/svg-transform-interpolation.html [ Crash ] -crbug.com/591099 animations/svg-attribute-interpolation/svg-type-interpolation.html [ Crash ] -crbug.com/591099 animations/svg-attribute-interpolation/svg-values-interpolation.html [ Crash ] -crbug.com/591099 animations/svg-attribute-interpolation/svg-viewBox-interpolation.html [ Crash ] -crbug.com/591099 animations/svg-attribute-interpolation/svg-width-interpolation.html [ Crash ] -crbug.com/591099 animations/svg-attribute-interpolation/svg-x-list-interpolation.html [ Crash ] -crbug.com/591099 animations/svg-attribute-interpolation/svg-x-y-interpolation.html [ Crash ] -crbug.com/591099 animations/svg-attribute-interpolation/svg-x1-x2-y1-y2-interpolation.html [ Crash ] -crbug.com/591099 animations/svg-attribute-interpolation/svg-xChannelSelector-interpolation.html [ Crash ] -crbug.com/591099 animations/svg-attribute-interpolation/svg-y-list-interpolation.html [ Crash ] -crbug.com/591099 animations/svg-attribute-interpolation/svg-z-interpolation.html [ Crash ] -crbug.com/591099 animations/svg-attribute-responsive/svg-d-responsive.html [ Crash ] -crbug.com/591099 animations/svg-attribute-responsive/svg-points-responsive.html [ Crash ] -crbug.com/591099 animations/svg-attribute-responsive/svg-tableValues-responsive.html [ Crash ] -crbug.com/591099 animations/svg-attribute-responsive/svg-transform-responsive.html [ Crash ] -crbug.com/591099 animations/svg-attribute-responsive/svg-x-list-responsive.html [ Crash ] -crbug.com/591099 animations/svg-presentation-attribute-animation.html [ Crash ] -crbug.com/591099 animations/svg-responsive-to-timing-updates.html [ Crash ] +crbug.com/591099 animations/svg-attribute-composition/svg-amplitude-composition.html [ Crash Pass ] +crbug.com/591099 animations/svg-attribute-composition/svg-azimuth-composition.html [ Crash Pass ] +crbug.com/591099 animations/svg-attribute-composition/svg-baseFrequency-composition.html [ Crash Pass ] +crbug.com/591099 animations/svg-attribute-composition/svg-bias-composition.html [ Crash Pass ] +crbug.com/591099 animations/svg-attribute-composition/svg-cx-cy-composition.html [ Crash Pass ] +crbug.com/591099 animations/svg-attribute-composition/svg-d-composition.html [ Crash Pass ] +crbug.com/591099 animations/svg-attribute-composition/svg-diffuseConstant-composition.html [ Crash Pass ] +crbug.com/591099 animations/svg-attribute-composition/svg-divisor-composition.html [ Crash Pass ] +crbug.com/591099 animations/svg-attribute-composition/svg-dx-dy-length-list-composition.html [ Crash Pass ] +crbug.com/591099 animations/svg-attribute-composition/svg-dx-dy-number-composition.html [ Crash Pass ] +crbug.com/591099 animations/svg-attribute-composition/svg-elevation-composition.html [ Crash Pass ] +crbug.com/591099 animations/svg-attribute-composition/svg-exponent-composition.html [ Crash Pass ] +crbug.com/591099 animations/svg-attribute-composition/svg-fx-fy-composition.html [ Crash Pass ] +crbug.com/591099 animations/svg-attribute-composition/svg-gradientTransform-composition.html [ Crash Pass ] +crbug.com/591099 animations/svg-attribute-composition/svg-height-composition.html [ Crash Pass ] +crbug.com/591099 animations/svg-attribute-composition/svg-intercept-composition.html [ Crash Pass ] +crbug.com/591099 animations/svg-attribute-composition/svg-k1-k2-k3-k4-composition.html [ Crash Pass ] +crbug.com/591099 animations/svg-attribute-composition/svg-kernelMatrix-composition.html [ Crash Pass ] +crbug.com/591099 animations/svg-attribute-composition/svg-kernelUnitLength-composition.html [ Crash Pass ] +crbug.com/591099 animations/svg-attribute-composition/svg-limitingConeAngle-composition.html [ Crash Pass ] +crbug.com/591099 animations/svg-attribute-composition/svg-markerHeight-composition.html [ Crash Pass ] +crbug.com/591099 animations/svg-attribute-composition/svg-markerWidth-composition.html [ Crash Pass ] +crbug.com/591099 animations/svg-attribute-composition/svg-mode-composition.html [ Crash Pass ] +crbug.com/591099 animations/svg-attribute-composition/svg-numOctaves-composition.html [ Crash Pass ] +crbug.com/591099 animations/svg-attribute-composition/svg-offset-composition.html [ Crash Pass ] +crbug.com/591099 animations/svg-attribute-composition/svg-order-composition.html [ Crash Pass ] +crbug.com/591099 animations/svg-attribute-composition/svg-orient-composition.html [ Crash Pass ] +crbug.com/591099 animations/svg-attribute-composition/svg-pathLength-composition.html [ Crash Pass ] +crbug.com/591099 animations/svg-attribute-composition/svg-patternTransform-composition.html [ Crash Pass ] +crbug.com/591099 animations/svg-attribute-composition/svg-points-composition.html [ Crash Pass ] +crbug.com/591099 animations/svg-attribute-composition/svg-pointsAtX-pointsAtY-pointsAtZ-composition.html [ Crash Pass ] +crbug.com/591099 animations/svg-attribute-composition/svg-r-composition.html [ Crash Pass ] +crbug.com/591099 animations/svg-attribute-composition/svg-radius-composition.html [ Crash Pass ] +crbug.com/591099 animations/svg-attribute-composition/svg-refX-refY-composition.html [ Crash Pass ] +crbug.com/591099 animations/svg-attribute-composition/svg-rotate-composition.html [ Crash Pass ] +crbug.com/591099 animations/svg-attribute-composition/svg-rx-composition.html [ Crash Pass ] +crbug.com/591099 animations/svg-attribute-composition/svg-scale-composition.html [ Crash Pass ] +crbug.com/591099 animations/svg-attribute-composition/svg-seed-composition.html [ Crash Pass ] +crbug.com/591099 animations/svg-attribute-composition/svg-slope-composition.html [ Crash Pass ] +crbug.com/591099 animations/svg-attribute-composition/svg-specularConstant-composition.html [ Crash Pass ] +crbug.com/591099 animations/svg-attribute-composition/svg-specularExponent-composition.html [ Crash Pass ] +crbug.com/591099 animations/svg-attribute-composition/svg-startOffset-composition.html [ Crash Pass ] +crbug.com/591099 animations/svg-attribute-composition/svg-stdDeviation-composition.html [ Crash Pass ] +crbug.com/591099 animations/svg-attribute-composition/svg-surfaceScale-composition.html [ Crash Pass ] +crbug.com/591099 animations/svg-attribute-composition/svg-tableValues-composition.html [ Crash Pass ] +crbug.com/591099 animations/svg-attribute-composition/svg-targetX-targetY-composition.html [ Crash Pass ] +crbug.com/591099 animations/svg-attribute-composition/svg-textLength-composition.html [ Crash Pass ] +crbug.com/591099 animations/svg-attribute-composition/svg-transform-composition-distinct.html [ Crash Pass ] +crbug.com/591099 animations/svg-attribute-composition/svg-transform-composition-list.html [ Crash Pass ] +crbug.com/591099 animations/svg-attribute-composition/svg-transform-composition.html [ Crash Pass ] +crbug.com/591099 animations/svg-attribute-composition/svg-transform-matrix.html [ Crash Pass ] +crbug.com/591099 animations/svg-attribute-composition/svg-values-composition.html [ Crash Pass ] +crbug.com/591099 animations/svg-attribute-composition/svg-viewBox-composition.html [ Crash Pass ] +crbug.com/591099 animations/svg-attribute-composition/svg-width-composition.html [ Crash Pass ] +crbug.com/591099 animations/svg-attribute-composition/svg-x-composition.html [ Crash Pass ] +crbug.com/591099 animations/svg-attribute-composition/svg-x-list-composition.html [ Crash Pass ] +crbug.com/591099 animations/svg-attribute-composition/svg-x1-x2-y1-y2-composition.html [ Crash Pass ] +crbug.com/591099 animations/svg-attribute-composition/svg-y-composition.html [ Crash Pass ] +crbug.com/591099 animations/svg-attribute-composition/svg-y-list-composition.html [ Crash Pass ] +crbug.com/591099 animations/svg-attribute-composition/svg-z-composition.html [ Crash Pass ] +crbug.com/591099 animations/svg-attribute-interpolation/svg-amplitude-interpolation.html [ Crash Pass ] +crbug.com/591099 animations/svg-attribute-interpolation/svg-azimuth-interpolation.html [ Crash Pass ] +crbug.com/591099 animations/svg-attribute-interpolation/svg-baseFrequency-interpolation.html [ Crash Pass ] +crbug.com/591099 animations/svg-attribute-interpolation/svg-bias-interpolation.html [ Crash Pass ] +crbug.com/591099 animations/svg-attribute-interpolation/svg-calc-interpolation.html [ Crash Pass ] +crbug.com/591099 animations/svg-attribute-interpolation/svg-class-interpolation.html [ Crash Pass ] +crbug.com/591099 animations/svg-attribute-interpolation/svg-clipPathUnits-interpolation.html [ Crash Pass ] +crbug.com/591099 animations/svg-attribute-interpolation/svg-cx-cy-interpolation.html [ Crash Pass ] +crbug.com/591099 animations/svg-attribute-interpolation/svg-d-interpolation.html [ Crash Timeout ] +crbug.com/591099 animations/svg-attribute-interpolation/svg-diffuseConstant-interpolation.html [ Crash Pass ] +crbug.com/591099 animations/svg-attribute-interpolation/svg-divisor-interpolation.html [ Crash Pass ] +crbug.com/591099 animations/svg-attribute-interpolation/svg-dx-dy-length-list-interpolation.html [ Crash Pass ] +crbug.com/591099 animations/svg-attribute-interpolation/svg-dx-dy-number-interpolation.html [ Crash Pass ] +crbug.com/591099 animations/svg-attribute-interpolation/svg-edgeMode-interpolation.html [ Crash Pass ] +crbug.com/591099 animations/svg-attribute-interpolation/svg-elevation-interpolation.html [ Crash Pass ] +crbug.com/591099 animations/svg-attribute-interpolation/svg-exponent-interpolation.html [ Crash Pass ] +crbug.com/591099 animations/svg-attribute-interpolation/svg-filterUnits-interpolation.html [ Crash Pass ] +crbug.com/591099 animations/svg-attribute-interpolation/svg-fx-fy-interpolation.html [ Crash Pass ] +crbug.com/591099 animations/svg-attribute-interpolation/svg-gradientTransform-interpolation.html [ Crash Pass ] +crbug.com/591099 animations/svg-attribute-interpolation/svg-gradientUnits-interpolation.html [ Crash Pass ] +crbug.com/591099 animations/svg-attribute-interpolation/svg-height-interpolation.html [ Crash Pass ] +crbug.com/591099 animations/svg-attribute-interpolation/svg-href-interpolation.html [ Crash Pass ] +crbug.com/591099 animations/svg-attribute-interpolation/svg-in-interpolation.html [ Crash Pass ] +crbug.com/591099 animations/svg-attribute-interpolation/svg-intercept-interpolation.html [ Crash Pass ] +crbug.com/591099 animations/svg-attribute-interpolation/svg-k1-k2-k3-k4-interpolation.html [ Crash Pass ] +crbug.com/591099 animations/svg-attribute-interpolation/svg-kernelMatrix-interpolation.html [ Crash Pass ] +crbug.com/591099 animations/svg-attribute-interpolation/svg-kernelUnitLength-interpolation.html [ Crash Pass ] +crbug.com/591099 animations/svg-attribute-interpolation/svg-lengthAdjust-interpolation.html [ Crash Pass ] +crbug.com/591099 animations/svg-attribute-interpolation/svg-limitingConeAngle-interpolation.html [ Crash Pass ] +crbug.com/591099 animations/svg-attribute-interpolation/svg-markerHeight-interpolation.html [ Crash Pass ] +crbug.com/591099 animations/svg-attribute-interpolation/svg-markerUnits-interpolation.html [ Crash Pass ] +crbug.com/591099 animations/svg-attribute-interpolation/svg-markerWidth-interpolation.html [ Crash Pass ] +crbug.com/591099 animations/svg-attribute-interpolation/svg-maskContentUnits-interpolation.html [ Crash Pass ] +crbug.com/591099 animations/svg-attribute-interpolation/svg-maskUnits-interpolation.html [ Crash Pass ] +crbug.com/591099 animations/svg-attribute-interpolation/svg-method-interpolation.html [ Crash Pass ] +crbug.com/591099 animations/svg-attribute-interpolation/svg-mode-interpolation.html [ Crash Pass ] +crbug.com/591099 animations/svg-attribute-interpolation/svg-numOctaves-interpolation.html [ Crash Pass ] +crbug.com/591099 animations/svg-attribute-interpolation/svg-offset-interpolation.html [ Crash Pass ] +crbug.com/591099 animations/svg-attribute-interpolation/svg-operator-interpolation.html [ Crash Pass ] +crbug.com/591099 animations/svg-attribute-interpolation/svg-order-interpolation.html [ Crash Pass ] +crbug.com/591099 animations/svg-attribute-interpolation/svg-orient-interpolation.html [ Crash Pass ] +crbug.com/591099 animations/svg-attribute-interpolation/svg-pathLength-interpolation.html [ Crash Pass ] +crbug.com/591099 animations/svg-attribute-interpolation/svg-patternContentUnits-interpolation.html [ Crash Pass ] +crbug.com/591099 animations/svg-attribute-interpolation/svg-patternTransform-interpolation.html [ Crash Pass ] +crbug.com/591099 animations/svg-attribute-interpolation/svg-patternUnits-interpolation.html [ Crash Pass ] +crbug.com/591099 animations/svg-attribute-interpolation/svg-points-interpolation.html [ Crash Pass ] +crbug.com/591099 animations/svg-attribute-interpolation/svg-pointsAtX-pointsAtY-pointsAtZ-interpolation.html [ Crash Pass ] +crbug.com/591099 animations/svg-attribute-interpolation/svg-preserveAlpha-interpolation.html [ Crash Pass ] +crbug.com/591099 animations/svg-attribute-interpolation/svg-preserveAspectRatio-interpolation.html [ Crash Pass ] +crbug.com/591099 animations/svg-attribute-interpolation/svg-primitiveUnits-interpolation.html [ Crash Pass ] +crbug.com/591099 animations/svg-attribute-interpolation/svg-r-interpolation.html [ Crash Pass ] +crbug.com/591099 animations/svg-attribute-interpolation/svg-radius-interpolation.html [ Crash Pass ] +crbug.com/591099 animations/svg-attribute-interpolation/svg-refX-refY-interpolation.html [ Crash Pass ] +crbug.com/591099 animations/svg-attribute-interpolation/svg-result-interpolation.html [ Crash Pass ] +crbug.com/591099 animations/svg-attribute-interpolation/svg-rotate-interpolation.html [ Crash Pass ] +crbug.com/591099 animations/svg-attribute-interpolation/svg-rx-interpolation.html [ Crash Pass ] +crbug.com/591099 animations/svg-attribute-interpolation/svg-scale-interpolation.html [ Crash Pass ] +crbug.com/591099 animations/svg-attribute-interpolation/svg-seed-interpolation.html [ Crash Pass ] +crbug.com/591099 animations/svg-attribute-interpolation/svg-slope-interpolation.html [ Crash Pass ] +crbug.com/591099 animations/svg-attribute-interpolation/svg-spacing-interpolation.html [ Crash Pass ] +crbug.com/591099 animations/svg-attribute-interpolation/svg-specularConstant-interpolation.html [ Crash Pass ] +crbug.com/591099 animations/svg-attribute-interpolation/svg-specularExponent-interpolation.html [ Crash Pass ] +crbug.com/591099 animations/svg-attribute-interpolation/svg-spreadMethod-interpolation.html [ Crash Pass ] +crbug.com/591099 animations/svg-attribute-interpolation/svg-startOffset-interpolation.html [ Crash Pass ] +crbug.com/591099 animations/svg-attribute-interpolation/svg-stdDeviation-interpolation.html [ Crash Pass ] +crbug.com/591099 animations/svg-attribute-interpolation/svg-stitchTiles-interpolation.html [ Crash Pass ] +crbug.com/591099 animations/svg-attribute-interpolation/svg-surfaceScale-interpolation.html [ Crash Pass ] +crbug.com/591099 animations/svg-attribute-interpolation/svg-tableValues-interpolation.html [ Crash Pass ] +crbug.com/591099 animations/svg-attribute-interpolation/svg-target-interpolation.html [ Crash Pass ] +crbug.com/591099 animations/svg-attribute-interpolation/svg-targetX-targetY-interpolation.html [ Crash Pass ] +crbug.com/591099 animations/svg-attribute-interpolation/svg-textLength-interpolation.html [ Crash Pass ] +crbug.com/591099 animations/svg-attribute-interpolation/svg-transform-interpolation.html [ Crash Pass ] +crbug.com/591099 animations/svg-attribute-interpolation/svg-type-interpolation.html [ Crash Pass ] +crbug.com/591099 animations/svg-attribute-interpolation/svg-values-interpolation.html [ Crash Pass ] +crbug.com/591099 animations/svg-attribute-interpolation/svg-viewBox-interpolation.html [ Crash Pass ] +crbug.com/591099 animations/svg-attribute-interpolation/svg-width-interpolation.html [ Crash Pass ] +crbug.com/591099 animations/svg-attribute-interpolation/svg-x-list-interpolation.html [ Crash Pass ] +crbug.com/591099 animations/svg-attribute-interpolation/svg-x-y-interpolation.html [ Crash Pass ] +crbug.com/591099 animations/svg-attribute-interpolation/svg-x1-x2-y1-y2-interpolation.html [ Crash Pass ] +crbug.com/591099 animations/svg-attribute-interpolation/svg-xChannelSelector-interpolation.html [ Crash Pass ] +crbug.com/591099 animations/svg-attribute-interpolation/svg-y-list-interpolation.html [ Crash Pass ] +crbug.com/591099 animations/svg-attribute-interpolation/svg-z-interpolation.html [ Crash Pass ] +crbug.com/591099 animations/svg-attribute-responsive/svg-d-responsive.html [ Crash Pass ] +crbug.com/591099 animations/svg-attribute-responsive/svg-points-responsive.html [ Crash Pass ] +crbug.com/591099 animations/svg-attribute-responsive/svg-tableValues-responsive.html [ Crash Pass ] +crbug.com/591099 animations/svg-attribute-responsive/svg-transform-responsive.html [ Crash Pass ] +crbug.com/591099 animations/svg-attribute-responsive/svg-x-list-responsive.html [ Crash Pass ] +crbug.com/591099 animations/svg-presentation-attribute-animation.html [ Crash Pass ] +crbug.com/591099 animations/svg-responsive-to-timing-updates.html [ Crash Pass ] crbug.com/591099 animations/timing-model.html [ Pass Timeout ] crbug.com/591099 battery-status/api-defined.html [ Failure ] crbug.com/591099 battery-status/detached-no-crash.html [ Failure ] @@ -517,14 +517,14 @@ crbug.com/591099 battery-status/multiple-windows-page-visibility.html [ Failure ] crbug.com/591099 battery-status/multiple-windows.html [ Failure ] crbug.com/591099 battery-status/no-gc-with-eventlisteners.html [ Failure ] -crbug.com/591099 battery-status/no-leak-on-detached-use.html [ Crash ] +crbug.com/591099 battery-status/no-leak-on-detached-use.html [ Crash Failure ] crbug.com/591099 battery-status/page-visibility.html [ Failure ] crbug.com/591099 battery-status/promise-with-eventlisteners.html [ Failure ] crbug.com/591099 battery-status/restricted-level-precision.html [ Failure ] crbug.com/591099 bindings/blink-in-js-asan-crash.html [ Failure ] -crbug.com/591099 bindings/location-lifetime.html [ Crash ] -crbug.com/591099 bluetooth/requestDevice/request-from-iframe.html [ Crash ] -crbug.com/591099 bluetooth/server/getPrimaryService/two-iframes-from-same-origin.html [ Crash ] +crbug.com/591099 bindings/location-lifetime.html [ Crash Pass ] +crbug.com/591099 bluetooth/requestDevice/request-from-iframe.html [ Crash Pass ] +crbug.com/591099 bluetooth/server/getPrimaryService/two-iframes-from-same-origin.html [ Crash Pass ] crbug.com/591099 compositing/absolute-inside-out-of-view-fixed.html [ Failure Pass ] crbug.com/591099 compositing/animation/busy-indicator.html [ Failure ] crbug.com/591099 compositing/animation/hidden-composited.html [ Failure ] @@ -562,7 +562,7 @@ crbug.com/591099 compositing/generated-content.html [ Failure Pass ] crbug.com/591099 compositing/geometry/abs-position-inside-opacity.html [ Failure ] crbug.com/591099 compositing/geometry/ancestor-overflow-change.html [ Failure ] -crbug.com/591099 compositing/geometry/assert-marquee-timer.html [ Crash ] +crbug.com/591099 compositing/geometry/assert-marquee-timer.html [ Crash Pass ] crbug.com/591099 compositing/geometry/bounds-clipped-composited-child.html [ Failure ] crbug.com/591099 compositing/geometry/bounds-ignores-hidden-composited-descendant.html [ Failure ] crbug.com/591099 compositing/geometry/bounds-ignores-hidden-dynamic-negzindex.html [ Failure ] @@ -614,10 +614,10 @@ crbug.com/591099 compositing/gestures/gesture-tapHighlight-2-iframe.html [ Failure ] crbug.com/591099 compositing/gestures/gesture-tapHighlight-img-and-text-2.html [ Failure ] crbug.com/591099 compositing/gestures/gesture-tapHighlight-img-transformed.html [ Failure ] -crbug.com/591099 compositing/gestures/gesture-tapHighlight-img.html [ Failure ] +crbug.com/591099 compositing/gestures/gesture-tapHighlight-img.html [ Failure Pass ] crbug.com/591099 compositing/gestures/gesture-tapHighlight-overflowing-text-crash.html [ Failure ] crbug.com/591099 compositing/gestures/gesture-tapHighlight-pixel-rotated-link.html [ Failure ] -crbug.com/591099 compositing/gestures/gesture-tapHighlight-shadow-tree.html [ Failure ] +crbug.com/591099 compositing/gestures/gesture-tapHighlight-shadow-tree.html [ Failure Pass ] crbug.com/591099 compositing/gestures/gesture-tapHighlight-with-box-shadow.html [ Failure ] crbug.com/591099 compositing/iframes/become-composited-nested-iframes.html [ Failure ] crbug.com/591099 compositing/iframes/become-overlapped-iframe.html [ Failure ] @@ -631,14 +631,14 @@ crbug.com/591099 compositing/iframes/enter-compositing-iframe.html [ Failure ] crbug.com/591099 compositing/iframes/floating-self-painting-frame-complex.html [ Failure ] crbug.com/591099 compositing/iframes/floating-self-painting-frame.html [ Failure ] -crbug.com/591099 compositing/iframes/iframe-composited-scrolling-hide-and-show.html [ Crash ] +crbug.com/591099 compositing/iframes/iframe-composited-scrolling-hide-and-show.html [ Crash Failure ] crbug.com/591099 compositing/iframes/iframe-content-flipping.html [ Failure ] crbug.com/591099 compositing/iframes/iframe-copy-on-scroll.html [ Failure ] crbug.com/591099 compositing/iframes/iframe-in-composited-layer.html [ Failure ] crbug.com/591099 compositing/iframes/iframe-resize.html [ Failure ] crbug.com/591099 compositing/iframes/iframe-size-from-zero.html [ Failure ] crbug.com/591099 compositing/iframes/invisible-iframe.html [ Failure ] -crbug.com/591099 compositing/iframes/invisible-nested-iframe-hide.html [ Crash ] +crbug.com/591099 compositing/iframes/invisible-nested-iframe-hide.html [ Crash Failure ] crbug.com/591099 compositing/iframes/invisible-nested-iframe-show.html [ Failure ] crbug.com/591099 compositing/iframes/invisible-nested-iframe.html [ Failure ] crbug.com/591099 compositing/iframes/layout-on-compositing-change.html [ Failure ] @@ -646,7 +646,7 @@ crbug.com/591099 compositing/iframes/overlapped-iframe-iframe.html [ Failure ] crbug.com/591099 compositing/iframes/overlapped-iframe.html [ Failure ] crbug.com/591099 compositing/iframes/overlapped-nested-iframes.html [ Failure ] -crbug.com/591099 compositing/iframes/remove-iframe-crash.html [ Crash ] +crbug.com/591099 compositing/iframes/remove-iframe-crash.html [ Crash Pass ] crbug.com/591099 compositing/iframes/resizer.html [ Failure ] crbug.com/591099 compositing/iframes/scrolling-iframe.html [ Failure ] crbug.com/591099 compositing/images/content-image.html [ Failure ] @@ -1678,16 +1678,16 @@ crbug.com/591099 css3/blending/effect-background-blend-mode-stacking.html [ Failure ] crbug.com/591099 css3/blending/effect-background-blend-mode-tiled.html [ Failure ] crbug.com/591099 css3/blending/effect-background-blend-mode.html [ Failure ] -crbug.com/591099 css3/blending/mix-blend-mode-2nd-stacking-context-composited.html [ Crash ] +crbug.com/591099 css3/blending/mix-blend-mode-2nd-stacking-context-composited.html [ Crash Failure ] crbug.com/591099 css3/blending/mix-blend-mode-composited-layers.html [ Failure Pass ] -crbug.com/591099 css3/blending/mix-blend-mode-composited-reason-children.html [ Crash ] +crbug.com/591099 css3/blending/mix-blend-mode-composited-reason-children.html [ Crash Failure ] crbug.com/591099 css3/blending/mix-blend-mode-has-ancestor-clipping-layer.html [ Failure ] crbug.com/591099 css3/blending/mix-blend-mode-isolated-group-1.html [ Failure ] crbug.com/591099 css3/blending/mix-blend-mode-isolated-group-2.html [ Failure ] crbug.com/591099 css3/blending/mix-blend-mode-isolated-group-3.html [ Failure ] -crbug.com/591099 css3/blending/mix-blend-mode-isolation-2-stacking-contexts.html [ Crash ] -crbug.com/591099 css3/blending/mix-blend-mode-isolation-layer.html [ Crash ] -crbug.com/591099 css3/blending/mix-blend-mode-isolation-remove.html [ Crash ] +crbug.com/591099 css3/blending/mix-blend-mode-isolation-2-stacking-contexts.html [ Crash Failure ] +crbug.com/591099 css3/blending/mix-blend-mode-isolation-layer.html [ Crash Failure ] +crbug.com/591099 css3/blending/mix-blend-mode-isolation-remove.html [ Crash Failure ] crbug.com/591099 css3/blending/mix-blend-mode-simple-text.html [ Failure ] crbug.com/591099 css3/blending/mix-blend-mode-simple.html [ Failure ] crbug.com/591099 css3/blending/mix-blend-mode-with-masking.html [ Failure Pass ] @@ -1709,7 +1709,7 @@ crbug.com/591099 css3/calc/lexer-regression-57581-3.html [ Failure ] crbug.com/591099 css3/calc/lexer-regression-57581.html [ Failure ] crbug.com/591099 css3/calc/line-height.html [ Failure ] -crbug.com/591099 css3/calc/margin.html [ Crash ] +crbug.com/591099 css3/calc/margin.html [ Crash Failure ] crbug.com/591099 css3/calc/padding.html [ Failure ] crbug.com/591099 css3/calc/reflection-computed-style.html [ Failure ] crbug.com/591099 css3/calc/regression-62276.html [ Failure ] @@ -1725,11 +1725,11 @@ crbug.com/591099 css3/css3-modsel-37.html [ Failure Pass ] crbug.com/591099 css3/escape-dom-api.html [ Failure ] crbug.com/591099 css3/filters/add-filter-rendering.html [ Failure ] -crbug.com/591099 css3/filters/adopt-inline-style.html [ Crash ] +crbug.com/591099 css3/filters/adopt-inline-style.html [ Crash Pass ] crbug.com/591099 css3/filters/blur-filter-page-scroll-parents.html [ Failure Pass ] crbug.com/591099 css3/filters/blur-filter-page-scroll-self.html [ Failure Pass ] crbug.com/591099 css3/filters/blur-filter-page-scroll.html [ Failure Pass ] -crbug.com/591099 css3/filters/composited-during-animation.html [ Crash ] +crbug.com/591099 css3/filters/composited-during-animation.html [ Crash Pass ] crbug.com/591099 css3/filters/composited-during-transition-layertree.html [ Failure ] crbug.com/591099 css3/filters/composited-layer-bounds-after-sw-blur-animation.html [ Failure Pass ] crbug.com/591099 css3/filters/composited-layer-bounds-with-composited-blur.html [ Failure Pass ] @@ -1759,7 +1759,7 @@ crbug.com/591099 css3/filters/effect-opacity.html [ Failure ] crbug.com/591099 css3/filters/effect-reference-add-hw.html [ Failure ] crbug.com/591099 css3/filters/effect-reference-delete-crash.html [ Failure ] -crbug.com/591099 css3/filters/effect-reference-delete.html [ Crash ] +crbug.com/591099 css3/filters/effect-reference-delete.html [ Crash Pass ] crbug.com/591099 css3/filters/effect-reference-reset-style-delete-crash.html [ Failure ] crbug.com/591099 css3/filters/effect-reference-source-alpha-hw.html [ Failure ] crbug.com/591099 css3/filters/effect-reference-subregion-hidpi-hw.html [ Failure ] @@ -1771,14 +1771,14 @@ crbug.com/591099 css3/filters/effect-saturate.html [ Failure ] crbug.com/591099 css3/filters/effect-sepia-hw.html [ Failure ] crbug.com/591099 css3/filters/effect-sepia.html [ Failure ] -crbug.com/591099 css3/filters/filter-animation-from-none-hw.html [ Crash ] -crbug.com/591099 css3/filters/filter-animation-from-none-multi-hw.html [ Crash ] -crbug.com/591099 css3/filters/filter-animation-from-none-multi.html [ Crash ] -crbug.com/591099 css3/filters/filter-animation-from-none.html [ Crash ] -crbug.com/591099 css3/filters/filter-animation-hw.html [ Crash ] -crbug.com/591099 css3/filters/filter-animation-multi-hw.html [ Crash ] -crbug.com/591099 css3/filters/filter-animation-multi.html [ Crash ] -crbug.com/591099 css3/filters/filter-animation.html [ Crash ] +crbug.com/591099 css3/filters/filter-animation-from-none-hw.html [ Crash Pass ] +crbug.com/591099 css3/filters/filter-animation-from-none-multi-hw.html [ Crash Pass ] +crbug.com/591099 css3/filters/filter-animation-from-none-multi.html [ Crash Pass ] +crbug.com/591099 css3/filters/filter-animation-from-none.html [ Crash Pass ] +crbug.com/591099 css3/filters/filter-animation-hw.html [ Crash Pass ] +crbug.com/591099 css3/filters/filter-animation-multi-hw.html [ Crash Pass ] +crbug.com/591099 css3/filters/filter-animation-multi.html [ Crash Pass ] +crbug.com/591099 css3/filters/filter-animation.html [ Crash Pass ] crbug.com/591099 css3/filters/filter-change-repaint-composited.html [ Failure ] crbug.com/591099 css3/filters/filter-repaint-shadow-clipped.html [ Failure ] crbug.com/591099 css3/filters/filter-repaint-shadow-rotated.html [ Failure ] @@ -1787,7 +1787,7 @@ crbug.com/591099 css3/filters/filtered-inline.html [ Failure ] crbug.com/591099 css3/filters/huge-region-composited.html [ Failure ] crbug.com/591099 css3/filters/huge-region.html [ Failure ] -crbug.com/591099 css3/filters/multiple-references-id-mutate-crash-2.html [ Crash ] +crbug.com/591099 css3/filters/multiple-references-id-mutate-crash-2.html [ Crash Pass ] crbug.com/591099 css3/filters/nested-filter.html [ Crash Failure ] crbug.com/591099 css3/filters/offscreen-filters-memory-usage.html [ Failure ] crbug.com/591099 css3/filters/regions-expanding.html [ Crash Failure ] @@ -1795,14 +1795,14 @@ crbug.com/591099 css3/filters/simple-filter-rendering.html [ Failure ] crbug.com/591099 css3/flexbox/alignContent-applies-with-flexWrap-wrap-with-single-line.html [ Failure ] crbug.com/591099 css3/flexbox/assert-generated-new-flexbox.html [ Failure ] -crbug.com/591099 css3/flexbox/box-orient-button.html [ Crash ] +crbug.com/591099 css3/flexbox/box-orient-button.html [ Crash Pass ] crbug.com/591099 css3/flexbox/bug527039.html [ Failure ] -crbug.com/591099 css3/flexbox/bug633212.html [ Crash ] +crbug.com/591099 css3/flexbox/bug633212.html [ Crash Pass ] crbug.com/591099 css3/flexbox/button.html [ Failure ] crbug.com/591099 css3/flexbox/child-overflow.html [ Failure Pass ] crbug.com/591099 css3/flexbox/crash-removing-out-of-flow-child.html [ Failure ] crbug.com/591099 css3/flexbox/css-properties.html [ Failure ] -crbug.com/591099 css3/flexbox/display-flexbox-set-get.html [ Crash ] +crbug.com/591099 css3/flexbox/display-flexbox-set-get.html [ Crash Pass ] crbug.com/591099 css3/flexbox/flex-algorithm-with-margins.html [ Failure ] crbug.com/591099 css3/flexbox/flex-algorithm.html [ Failure ] crbug.com/591099 css3/flexbox/flex-align-baseline.html [ Failure ] @@ -1816,7 +1816,7 @@ crbug.com/591099 css3/flexbox/flex-flow-margins.html [ Failure ] crbug.com/591099 css3/flexbox/flex-flow-padding.html [ Failure ] crbug.com/591099 css3/flexbox/flex-flow.html [ Failure ] -crbug.com/591099 css3/flexbox/flex-item-contains-strict.html [ Crash ] +crbug.com/591099 css3/flexbox/flex-item-contains-strict.html [ Crash Failure ] crbug.com/591099 css3/flexbox/flex-longhand-parsing.html [ Failure ] crbug.com/591099 css3/flexbox/flex-one-sets-flex-basis-to-zero-px.html [ Failure ] crbug.com/591099 css3/flexbox/flex-percentage-height-in-table-standards-mode.html [ Failure ] @@ -1827,25 +1827,25 @@ crbug.com/591099 css3/flexbox/flexbox-wordwrap.html [ Failure ] crbug.com/591099 css3/flexbox/floated-flexbox.html [ Failure ] crbug.com/591099 css3/flexbox/floated-flexitem.html [ Failure ] -crbug.com/591099 css3/flexbox/inline-flex-crash.html [ Crash ] -crbug.com/591099 css3/flexbox/inline-flex-crash2.html [ Crash ] -crbug.com/591099 css3/flexbox/inline-flex.html [ Crash ] -crbug.com/591099 css3/flexbox/intrinsic-min-width-applies-with-fixed-width.html [ Crash ] +crbug.com/591099 css3/flexbox/inline-flex-crash.html [ Crash Pass ] +crbug.com/591099 css3/flexbox/inline-flex-crash2.html [ Crash Pass ] +crbug.com/591099 css3/flexbox/inline-flex.html [ Crash Pass ] +crbug.com/591099 css3/flexbox/intrinsic-min-width-applies-with-fixed-width.html [ Crash Pass ] crbug.com/591099 css3/flexbox/intrinsic-width-orthogonal-writing-mode.html [ Failure ] crbug.com/591099 css3/flexbox/large-flex-shrink-assert.html [ Failure ] crbug.com/591099 css3/flexbox/line-wrapping.html [ Failure ] -crbug.com/591099 css3/flexbox/min-size-auto.html [ Crash ] +crbug.com/591099 css3/flexbox/min-size-auto.html [ Crash Pass ] crbug.com/591099 css3/flexbox/multiline-align-self.html [ Failure ] crbug.com/591099 css3/flexbox/multiline-reverse-wrap-baseline.html [ Failure ] crbug.com/591099 css3/flexbox/multiline-shrink-to-fit.html [ Failure ] crbug.com/591099 css3/flexbox/negative-flex-rounding-assert.html [ Failure ] crbug.com/591099 css3/flexbox/nested-stretch.html [ Failure ] crbug.com/591099 css3/flexbox/overflow-auto-dynamic-changes.html [ Failure ] -crbug.com/591099 css3/flexbox/overflow-auto-resizes-correctly.html [ Crash ] +crbug.com/591099 css3/flexbox/overflow-auto-resizes-correctly.html [ Crash Pass ] crbug.com/591099 css3/flexbox/percent-margins.html [ Failure ] -crbug.com/591099 css3/flexbox/percentage-height-replaced-element.html [ Crash ] +crbug.com/591099 css3/flexbox/percentage-height-replaced-element.html [ Crash Pass ] crbug.com/591099 css3/flexbox/percentage-heights.html [ Failure ] -crbug.com/591099 css3/flexbox/perpendicular-writing-modes-inside-flex-item.html [ Crash ] +crbug.com/591099 css3/flexbox/perpendicular-writing-modes-inside-flex-item.html [ Crash Pass ] crbug.com/591099 css3/flexbox/position-absolute-child-with-contenteditable.html [ Failure ] crbug.com/591099 css3/flexbox/preferred-widths.html [ Failure ] crbug.com/591099 css3/flexbox/relpos-with-scrollable-with-abspos-crash.html [ Failure ] @@ -1859,7 +1859,7 @@ crbug.com/591099 css3/font-weight-multiple-selectors.html [ Failure ] crbug.com/591099 css3/font-weight.html [ Failure ] crbug.com/591099 css3/khtml-background-size-0x0-bmp.html [ Failure ] -crbug.com/591099 css3/masking/clip-path-animation.html [ Crash ] +crbug.com/591099 css3/masking/clip-path-animation.html [ Crash Pass ] crbug.com/591099 css3/masking/clip-path-circle-filter.html [ Failure Pass ] crbug.com/591099 css3/masking/clip-path-circle-overflow-hidden.html [ Failure ] crbug.com/591099 css3/masking/clip-path-circle-overflow.html [ Failure Pass ] @@ -2652,32 +2652,32 @@ crbug.com/591099 css3/zoom-coords.xhtml [ Failure ] crbug.com/591099 cssom/ahem-ex-units.html [ Failure ] crbug.com/591099 cssom/cssvalue-comparison.html [ Failure ] -crbug.com/591099 custom-elements/constructor-context-dies-before-super.html [ Crash ] -crbug.com/591099 custom-elements/constructor-context-dies-cross-context-call.html [ Crash ] -crbug.com/591099 custom-elements/constructor-context-dies-retrieving-prototype.html [ Crash ] -crbug.com/591099 custom-elements/constructor-may-poach-upgrading-element.html [ Crash ] -crbug.com/591099 custom-elements/define-context-dies-retrieving-prototype.html [ Crash ] -crbug.com/591099 custom-elements/isolated-worlds.html [ Crash ] -crbug.com/591099 custom-elements/spec/adopt-node.html [ Crash ] -crbug.com/591099 custom-elements/spec/callback.html [ Crash ] -crbug.com/591099 custom-elements/spec/construct.html [ Crash ] -crbug.com/591099 custom-elements/spec/create-element-defined-asynchronous.html [ Crash ] -crbug.com/591099 custom-elements/spec/create-element-defined-synchronous.html [ Crash ] -crbug.com/591099 custom-elements/spec/create-element-inside-template.html [ Crash ] -crbug.com/591099 custom-elements/spec/create-element.html [ Crash ] -crbug.com/591099 custom-elements/spec/custom-elements-registry/when_defined.html [ Crash ] -crbug.com/591099 custom-elements/spec/define-builtin-element.html [ Crash ] -crbug.com/591099 custom-elements/spec/define-element.html [ Crash ] -crbug.com/591099 custom-elements/spec/doc-without-browsing-context.html [ Crash ] -crbug.com/591099 custom-elements/spec/insert-a-node-try-to-upgrade.html [ Crash ] -crbug.com/591099 custom-elements/spec/parsing.html [ Crash ] -crbug.com/591099 custom-elements/spec/remove-element.html [ Crash ] -crbug.com/591099 custom-elements/spec/report-the-exception.html [ Crash ] -crbug.com/591099 custom-elements/spec/selectors/pseudo-class-defined.html [ Crash ] -crbug.com/591099 custom-elements/spec/state-failed-create.html [ Crash ] -crbug.com/591099 custom-elements/spec/state-failed-upgrade.html [ Crash ] -crbug.com/591099 custom-elements/spec/upgrade-element.html [ Crash ] -crbug.com/591099 custom-elements/v0-v1-interop.html [ Crash ] +crbug.com/591099 custom-elements/constructor-context-dies-before-super.html [ Crash Pass ] +crbug.com/591099 custom-elements/constructor-context-dies-cross-context-call.html [ Crash Pass ] +crbug.com/591099 custom-elements/constructor-context-dies-retrieving-prototype.html [ Crash Pass ] +crbug.com/591099 custom-elements/constructor-may-poach-upgrading-element.html [ Crash Pass ] +crbug.com/591099 custom-elements/define-context-dies-retrieving-prototype.html [ Crash Pass ] +crbug.com/591099 custom-elements/isolated-worlds.html [ Crash Pass ] +crbug.com/591099 custom-elements/spec/adopt-node.html [ Crash Pass ] +crbug.com/591099 custom-elements/spec/callback.html [ Crash Pass ] +crbug.com/591099 custom-elements/spec/construct.html [ Crash Pass ] +crbug.com/591099 custom-elements/spec/create-element-defined-asynchronous.html [ Crash Pass ] +crbug.com/591099 custom-elements/spec/create-element-defined-synchronous.html [ Crash Pass ] +crbug.com/591099 custom-elements/spec/create-element-inside-template.html [ Crash Pass ] +crbug.com/591099 custom-elements/spec/create-element.html [ Crash Pass ] +crbug.com/591099 custom-elements/spec/custom-elements-registry/when_defined.html [ Crash Pass ] +crbug.com/591099 custom-elements/spec/define-builtin-element.html [ Crash Pass ] +crbug.com/591099 custom-elements/spec/define-element.html [ Crash Pass ] +crbug.com/591099 custom-elements/spec/doc-without-browsing-context.html [ Crash Pass ] +crbug.com/591099 custom-elements/spec/insert-a-node-try-to-upgrade.html [ Crash Pass ] +crbug.com/591099 custom-elements/spec/parsing.html [ Crash Pass ] +crbug.com/591099 custom-elements/spec/remove-element.html [ Crash Pass ] +crbug.com/591099 custom-elements/spec/report-the-exception.html [ Crash Pass ] +crbug.com/591099 custom-elements/spec/selectors/pseudo-class-defined.html [ Crash Pass ] +crbug.com/591099 custom-elements/spec/state-failed-create.html [ Crash Pass ] +crbug.com/591099 custom-elements/spec/state-failed-upgrade.html [ Crash Pass ] +crbug.com/591099 custom-elements/spec/upgrade-element.html [ Crash Pass ] +crbug.com/591099 custom-elements/v0-v1-interop.html [ Crash Pass ] crbug.com/591099 device_orientation/motion/add-during-dispatch.html [ Failure ] crbug.com/591099 device_orientation/motion/add-listener-from-callback.html [ Failure ] crbug.com/591099 device_orientation/motion/create-event.html [ Failure ] @@ -2705,7 +2705,7 @@ crbug.com/591099 dom/attr/set-attr-value-no-DOMSubtreeModified.html [ Failure ] crbug.com/591099 dom/attr/set-attribute-node-from-iframe.html [ Failure ] crbug.com/591099 dom/attr/update-attribute-node-no-crash.html [ Failure ] -crbug.com/591099 dom/document/adoptNode-reparenting-crash.html [ Crash ] +crbug.com/591099 dom/document/adoptNode-reparenting-crash.html [ Crash Pass ] crbug.com/591099 dom/domparsing/dom-parse-serialize-display.html [ Failure ] crbug.com/591099 dom/domparsing/dom-parse-serialize-xmldecl.html [ Failure ] crbug.com/591099 dom/domparsing/dom-parse-serialize.html [ Failure ] @@ -2719,7 +2719,7 @@ crbug.com/591099 dom/domparsing/xmlserializer-attribute-special-namespaces.html [ Failure ] crbug.com/591099 dom/domparsing/xmlserializer-doctype2.html [ Failure ] crbug.com/591099 dom/domparsing/xmlserializer-double-xmlns.html [ Failure ] -crbug.com/591099 dom/legacy_dom_conformance/html/level2/html/AppletsCollection.html [ Crash ] +crbug.com/591099 dom/legacy_dom_conformance/html/level2/html/AppletsCollection.html [ Crash Failure ] crbug.com/591099 dom/legacy_dom_conformance/html/level2/html/HTMLDocument01.html [ Crash Pass ] crbug.com/591099 dom/legacy_dom_conformance/html/level2/html/HTMLDocument02.html [ Crash Pass ] crbug.com/591099 dom/legacy_dom_conformance/html/level2/html/HTMLDocument03.html [ Crash Pass ] @@ -2740,152 +2740,152 @@ crbug.com/591099 dom/legacy_dom_conformance/html/level2/html/HTMLDocument19.html [ Crash Pass ] crbug.com/591099 dom/legacy_dom_conformance/html/level2/html/HTMLDocument20.html [ Crash Pass ] crbug.com/591099 dom/legacy_dom_conformance/html/level2/html/HTMLDocument21.html [ Crash Pass ] -crbug.com/591099 dom/legacy_dom_conformance/html/level2/html/HTMLElement01.html [ Crash ] -crbug.com/591099 dom/legacy_dom_conformance/html/level2/html/HTMLElement02.html [ Crash ] -crbug.com/591099 dom/legacy_dom_conformance/html/level2/html/HTMLElement03.html [ Crash ] -crbug.com/591099 dom/legacy_dom_conformance/html/level2/html/HTMLElement04.html [ Crash ] -crbug.com/591099 dom/legacy_dom_conformance/html/level2/html/HTMLElement05.html [ Crash ] -crbug.com/591099 dom/legacy_dom_conformance/html/level2/html/HTMLElement06.html [ Crash ] -crbug.com/591099 dom/legacy_dom_conformance/html/level2/html/HTMLElement07.html [ Crash ] -crbug.com/591099 dom/legacy_dom_conformance/html/level2/html/HTMLElement08.html [ Crash ] -crbug.com/591099 dom/legacy_dom_conformance/html/level2/html/HTMLElement09.html [ Crash ] -crbug.com/591099 dom/legacy_dom_conformance/html/level2/html/HTMLElement10.html [ Crash ] -crbug.com/591099 dom/legacy_dom_conformance/html/level2/html/HTMLElement100.html [ Crash ] -crbug.com/591099 dom/legacy_dom_conformance/html/level2/html/HTMLElement101.html [ Crash ] -crbug.com/591099 dom/legacy_dom_conformance/html/level2/html/HTMLElement102.html [ Crash ] -crbug.com/591099 dom/legacy_dom_conformance/html/level2/html/HTMLElement103.html [ Crash ] -crbug.com/591099 dom/legacy_dom_conformance/html/level2/html/HTMLElement104.html [ Crash ] -crbug.com/591099 dom/legacy_dom_conformance/html/level2/html/HTMLElement105.html [ Crash ] -crbug.com/591099 dom/legacy_dom_conformance/html/level2/html/HTMLElement106.html [ Crash ] -crbug.com/591099 dom/legacy_dom_conformance/html/level2/html/HTMLElement107.html [ Crash ] -crbug.com/591099 dom/legacy_dom_conformance/html/level2/html/HTMLElement108.html [ Crash ] -crbug.com/591099 dom/legacy_dom_conformance/html/level2/html/HTMLElement109.html [ Crash ] -crbug.com/591099 dom/legacy_dom_conformance/html/level2/html/HTMLElement11.html [ Crash ] -crbug.com/591099 dom/legacy_dom_conformance/html/level2/html/HTMLElement110.html [ Crash ] -crbug.com/591099 dom/legacy_dom_conformance/html/level2/html/HTMLElement111.html [ Crash ] -crbug.com/591099 dom/legacy_dom_conformance/html/level2/html/HTMLElement112.html [ Crash ] -crbug.com/591099 dom/legacy_dom_conformance/html/level2/html/HTMLElement113.html [ Crash ] -crbug.com/591099 dom/legacy_dom_conformance/html/level2/html/HTMLElement114.html [ Crash ] -crbug.com/591099 dom/legacy_dom_conformance/html/level2/html/HTMLElement115.html [ Crash ] -crbug.com/591099 dom/legacy_dom_conformance/html/level2/html/HTMLElement116.html [ Crash ] -crbug.com/591099 dom/legacy_dom_conformance/html/level2/html/HTMLElement117.html [ Crash ] -crbug.com/591099 dom/legacy_dom_conformance/html/level2/html/HTMLElement118.html [ Crash ] -crbug.com/591099 dom/legacy_dom_conformance/html/level2/html/HTMLElement119.html [ Crash ] -crbug.com/591099 dom/legacy_dom_conformance/html/level2/html/HTMLElement12.html [ Crash ] -crbug.com/591099 dom/legacy_dom_conformance/html/level2/html/HTMLElement120.html [ Crash ] -crbug.com/591099 dom/legacy_dom_conformance/html/level2/html/HTMLElement121.html [ Crash ] -crbug.com/591099 dom/legacy_dom_conformance/html/level2/html/HTMLElement122.html [ Crash ] -crbug.com/591099 dom/legacy_dom_conformance/html/level2/html/HTMLElement123.html [ Crash ] -crbug.com/591099 dom/legacy_dom_conformance/html/level2/html/HTMLElement124.html [ Crash ] -crbug.com/591099 dom/legacy_dom_conformance/html/level2/html/HTMLElement125.html [ Crash ] -crbug.com/591099 dom/legacy_dom_conformance/html/level2/html/HTMLElement126.html [ Crash ] -crbug.com/591099 dom/legacy_dom_conformance/html/level2/html/HTMLElement127.html [ Crash ] -crbug.com/591099 dom/legacy_dom_conformance/html/level2/html/HTMLElement128.html [ Crash ] -crbug.com/591099 dom/legacy_dom_conformance/html/level2/html/HTMLElement129.html [ Crash ] -crbug.com/591099 dom/legacy_dom_conformance/html/level2/html/HTMLElement13.html [ Crash ] -crbug.com/591099 dom/legacy_dom_conformance/html/level2/html/HTMLElement130.html [ Crash ] -crbug.com/591099 dom/legacy_dom_conformance/html/level2/html/HTMLElement131.html [ Crash ] -crbug.com/591099 dom/legacy_dom_conformance/html/level2/html/HTMLElement132.html [ Crash ] -crbug.com/591099 dom/legacy_dom_conformance/html/level2/html/HTMLElement133.html [ Crash ] -crbug.com/591099 dom/legacy_dom_conformance/html/level2/html/HTMLElement134.html [ Crash ] -crbug.com/591099 dom/legacy_dom_conformance/html/level2/html/HTMLElement135.html [ Crash ] -crbug.com/591099 dom/legacy_dom_conformance/html/level2/html/HTMLElement136.html [ Crash ] -crbug.com/591099 dom/legacy_dom_conformance/html/level2/html/HTMLElement137.html [ Crash ] -crbug.com/591099 dom/legacy_dom_conformance/html/level2/html/HTMLElement138.html [ Crash ] -crbug.com/591099 dom/legacy_dom_conformance/html/level2/html/HTMLElement139.html [ Crash ] -crbug.com/591099 dom/legacy_dom_conformance/html/level2/html/HTMLElement14.html [ Crash ] -crbug.com/591099 dom/legacy_dom_conformance/html/level2/html/HTMLElement140.html [ Crash ] -crbug.com/591099 dom/legacy_dom_conformance/html/level2/html/HTMLElement141.html [ Crash ] -crbug.com/591099 dom/legacy_dom_conformance/html/level2/html/HTMLElement142.html [ Crash ] -crbug.com/591099 dom/legacy_dom_conformance/html/level2/html/HTMLElement143.html [ Crash ] -crbug.com/591099 dom/legacy_dom_conformance/html/level2/html/HTMLElement144.html [ Crash ] -crbug.com/591099 dom/legacy_dom_conformance/html/level2/html/HTMLElement145.html [ Crash ] -crbug.com/591099 dom/legacy_dom_conformance/html/level2/html/HTMLElement15.html [ Crash ] -crbug.com/591099 dom/legacy_dom_conformance/html/level2/html/HTMLElement16.html [ Crash ] -crbug.com/591099 dom/legacy_dom_conformance/html/level2/html/HTMLElement17.html [ Crash ] -crbug.com/591099 dom/legacy_dom_conformance/html/level2/html/HTMLElement18.html [ Crash ] -crbug.com/591099 dom/legacy_dom_conformance/html/level2/html/HTMLElement19.html [ Crash ] -crbug.com/591099 dom/legacy_dom_conformance/html/level2/html/HTMLElement20.html [ Crash ] -crbug.com/591099 dom/legacy_dom_conformance/html/level2/html/HTMLElement21.html [ Crash ] -crbug.com/591099 dom/legacy_dom_conformance/html/level2/html/HTMLElement22.html [ Crash ] -crbug.com/591099 dom/legacy_dom_conformance/html/level2/html/HTMLElement23.html [ Crash ] -crbug.com/591099 dom/legacy_dom_conformance/html/level2/html/HTMLElement24.html [ Crash ] -crbug.com/591099 dom/legacy_dom_conformance/html/level2/html/HTMLElement25.html [ Crash ] -crbug.com/591099 dom/legacy_dom_conformance/html/level2/html/HTMLElement26.html [ Crash ] -crbug.com/591099 dom/legacy_dom_conformance/html/level2/html/HTMLElement27.html [ Crash ] -crbug.com/591099 dom/legacy_dom_conformance/html/level2/html/HTMLElement28.html [ Crash ] -crbug.com/591099 dom/legacy_dom_conformance/html/level2/html/HTMLElement29.html [ Crash ] -crbug.com/591099 dom/legacy_dom_conformance/html/level2/html/HTMLElement30.html [ Crash ] -crbug.com/591099 dom/legacy_dom_conformance/html/level2/html/HTMLElement31.html [ Crash ] -crbug.com/591099 dom/legacy_dom_conformance/html/level2/html/HTMLElement32.html [ Crash ] -crbug.com/591099 dom/legacy_dom_conformance/html/level2/html/HTMLElement33.html [ Crash ] -crbug.com/591099 dom/legacy_dom_conformance/html/level2/html/HTMLElement34.html [ Crash ] -crbug.com/591099 dom/legacy_dom_conformance/html/level2/html/HTMLElement35.html [ Crash ] -crbug.com/591099 dom/legacy_dom_conformance/html/level2/html/HTMLElement36.html [ Crash ] -crbug.com/591099 dom/legacy_dom_conformance/html/level2/html/HTMLElement37.html [ Crash ] -crbug.com/591099 dom/legacy_dom_conformance/html/level2/html/HTMLElement38.html [ Crash ] -crbug.com/591099 dom/legacy_dom_conformance/html/level2/html/HTMLElement39.html [ Crash ] -crbug.com/591099 dom/legacy_dom_conformance/html/level2/html/HTMLElement40.html [ Crash ] -crbug.com/591099 dom/legacy_dom_conformance/html/level2/html/HTMLElement41.html [ Crash ] -crbug.com/591099 dom/legacy_dom_conformance/html/level2/html/HTMLElement42.html [ Crash ] -crbug.com/591099 dom/legacy_dom_conformance/html/level2/html/HTMLElement43.html [ Crash ] -crbug.com/591099 dom/legacy_dom_conformance/html/level2/html/HTMLElement44.html [ Crash ] -crbug.com/591099 dom/legacy_dom_conformance/html/level2/html/HTMLElement45.html [ Crash ] -crbug.com/591099 dom/legacy_dom_conformance/html/level2/html/HTMLElement46.html [ Crash ] -crbug.com/591099 dom/legacy_dom_conformance/html/level2/html/HTMLElement47.html [ Crash ] -crbug.com/591099 dom/legacy_dom_conformance/html/level2/html/HTMLElement48.html [ Crash ] -crbug.com/591099 dom/legacy_dom_conformance/html/level2/html/HTMLElement49.html [ Crash ] -crbug.com/591099 dom/legacy_dom_conformance/html/level2/html/HTMLElement50.html [ Crash ] -crbug.com/591099 dom/legacy_dom_conformance/html/level2/html/HTMLElement51.html [ Crash ] -crbug.com/591099 dom/legacy_dom_conformance/html/level2/html/HTMLElement52.html [ Crash ] -crbug.com/591099 dom/legacy_dom_conformance/html/level2/html/HTMLElement53.html [ Crash ] -crbug.com/591099 dom/legacy_dom_conformance/html/level2/html/HTMLElement54.html [ Crash ] -crbug.com/591099 dom/legacy_dom_conformance/html/level2/html/HTMLElement55.html [ Crash ] -crbug.com/591099 dom/legacy_dom_conformance/html/level2/html/HTMLElement56.html [ Crash ] -crbug.com/591099 dom/legacy_dom_conformance/html/level2/html/HTMLElement57.html [ Crash ] -crbug.com/591099 dom/legacy_dom_conformance/html/level2/html/HTMLElement58.html [ Crash ] -crbug.com/591099 dom/legacy_dom_conformance/html/level2/html/HTMLElement59.html [ Crash ] -crbug.com/591099 dom/legacy_dom_conformance/html/level2/html/HTMLElement60.html [ Crash ] -crbug.com/591099 dom/legacy_dom_conformance/html/level2/html/HTMLElement61.html [ Crash ] -crbug.com/591099 dom/legacy_dom_conformance/html/level2/html/HTMLElement62.html [ Crash ] -crbug.com/591099 dom/legacy_dom_conformance/html/level2/html/HTMLElement63.html [ Crash ] -crbug.com/591099 dom/legacy_dom_conformance/html/level2/html/HTMLElement64.html [ Crash ] -crbug.com/591099 dom/legacy_dom_conformance/html/level2/html/HTMLElement65.html [ Crash ] -crbug.com/591099 dom/legacy_dom_conformance/html/level2/html/HTMLElement66.html [ Crash ] -crbug.com/591099 dom/legacy_dom_conformance/html/level2/html/HTMLElement67.html [ Crash ] -crbug.com/591099 dom/legacy_dom_conformance/html/level2/html/HTMLElement68.html [ Crash ] -crbug.com/591099 dom/legacy_dom_conformance/html/level2/html/HTMLElement69.html [ Crash ] -crbug.com/591099 dom/legacy_dom_conformance/html/level2/html/HTMLElement70.html [ Crash ] -crbug.com/591099 dom/legacy_dom_conformance/html/level2/html/HTMLElement71.html [ Crash ] -crbug.com/591099 dom/legacy_dom_conformance/html/level2/html/HTMLElement72.html [ Crash ] -crbug.com/591099 dom/legacy_dom_conformance/html/level2/html/HTMLElement73.html [ Crash ] -crbug.com/591099 dom/legacy_dom_conformance/html/level2/html/HTMLElement74.html [ Crash ] -crbug.com/591099 dom/legacy_dom_conformance/html/level2/html/HTMLElement75.html [ Crash ] -crbug.com/591099 dom/legacy_dom_conformance/html/level2/html/HTMLElement76.html [ Crash ] -crbug.com/591099 dom/legacy_dom_conformance/html/level2/html/HTMLElement77.html [ Crash ] -crbug.com/591099 dom/legacy_dom_conformance/html/level2/html/HTMLElement78.html [ Crash ] -crbug.com/591099 dom/legacy_dom_conformance/html/level2/html/HTMLElement79.html [ Crash ] -crbug.com/591099 dom/legacy_dom_conformance/html/level2/html/HTMLElement80.html [ Crash ] -crbug.com/591099 dom/legacy_dom_conformance/html/level2/html/HTMLElement81.html [ Crash ] -crbug.com/591099 dom/legacy_dom_conformance/html/level2/html/HTMLElement82.html [ Crash ] -crbug.com/591099 dom/legacy_dom_conformance/html/level2/html/HTMLElement83.html [ Crash ] -crbug.com/591099 dom/legacy_dom_conformance/html/level2/html/HTMLElement84.html [ Crash ] -crbug.com/591099 dom/legacy_dom_conformance/html/level2/html/HTMLElement85.html [ Crash ] -crbug.com/591099 dom/legacy_dom_conformance/html/level2/html/HTMLElement86.html [ Crash ] -crbug.com/591099 dom/legacy_dom_conformance/html/level2/html/HTMLElement87.html [ Crash ] -crbug.com/591099 dom/legacy_dom_conformance/html/level2/html/HTMLElement88.html [ Crash ] -crbug.com/591099 dom/legacy_dom_conformance/html/level2/html/HTMLElement89.html [ Crash ] -crbug.com/591099 dom/legacy_dom_conformance/html/level2/html/HTMLElement90.html [ Crash ] -crbug.com/591099 dom/legacy_dom_conformance/html/level2/html/HTMLElement91.html [ Crash ] -crbug.com/591099 dom/legacy_dom_conformance/html/level2/html/HTMLElement92.html [ Crash ] -crbug.com/591099 dom/legacy_dom_conformance/html/level2/html/HTMLElement93.html [ Crash ] -crbug.com/591099 dom/legacy_dom_conformance/html/level2/html/HTMLElement94.html [ Crash ] -crbug.com/591099 dom/legacy_dom_conformance/html/level2/html/HTMLElement95.html [ Crash ] -crbug.com/591099 dom/legacy_dom_conformance/html/level2/html/HTMLElement96.html [ Crash ] -crbug.com/591099 dom/legacy_dom_conformance/html/level2/html/HTMLElement97.html [ Crash ] -crbug.com/591099 dom/legacy_dom_conformance/html/level2/html/HTMLElement98.html [ Crash ] -crbug.com/591099 dom/legacy_dom_conformance/html/level2/html/HTMLElement99.html [ Crash ] -crbug.com/591099 dom/legacy_dom_conformance/html/level2/html/HTMLFormElement10.html [ Crash ] +crbug.com/591099 dom/legacy_dom_conformance/html/level2/html/HTMLElement01.html [ Crash Pass ] +crbug.com/591099 dom/legacy_dom_conformance/html/level2/html/HTMLElement02.html [ Crash Pass ] +crbug.com/591099 dom/legacy_dom_conformance/html/level2/html/HTMLElement03.html [ Crash Pass ] +crbug.com/591099 dom/legacy_dom_conformance/html/level2/html/HTMLElement04.html [ Crash Pass ] +crbug.com/591099 dom/legacy_dom_conformance/html/level2/html/HTMLElement05.html [ Crash Pass ] +crbug.com/591099 dom/legacy_dom_conformance/html/level2/html/HTMLElement06.html [ Crash Pass ] +crbug.com/591099 dom/legacy_dom_conformance/html/level2/html/HTMLElement07.html [ Crash Pass ] +crbug.com/591099 dom/legacy_dom_conformance/html/level2/html/HTMLElement08.html [ Crash Pass ] +crbug.com/591099 dom/legacy_dom_conformance/html/level2/html/HTMLElement09.html [ Crash Pass ] +crbug.com/591099 dom/legacy_dom_conformance/html/level2/html/HTMLElement10.html [ Crash Pass ] +crbug.com/591099 dom/legacy_dom_conformance/html/level2/html/HTMLElement100.html [ Crash Pass ] +crbug.com/591099 dom/legacy_dom_conformance/html/level2/html/HTMLElement101.html [ Crash Pass ] +crbug.com/591099 dom/legacy_dom_conformance/html/level2/html/HTMLElement102.html [ Crash Pass ] +crbug.com/591099 dom/legacy_dom_conformance/html/level2/html/HTMLElement103.html [ Crash Pass ] +crbug.com/591099 dom/legacy_dom_conformance/html/level2/html/HTMLElement104.html [ Crash Pass ] +crbug.com/591099 dom/legacy_dom_conformance/html/level2/html/HTMLElement105.html [ Crash Pass ] +crbug.com/591099 dom/legacy_dom_conformance/html/level2/html/HTMLElement106.html [ Crash Pass ] +crbug.com/591099 dom/legacy_dom_conformance/html/level2/html/HTMLElement107.html [ Crash Pass ] +crbug.com/591099 dom/legacy_dom_conformance/html/level2/html/HTMLElement108.html [ Crash Pass ] +crbug.com/591099 dom/legacy_dom_conformance/html/level2/html/HTMLElement109.html [ Crash Pass ] +crbug.com/591099 dom/legacy_dom_conformance/html/level2/html/HTMLElement11.html [ Crash Pass ] +crbug.com/591099 dom/legacy_dom_conformance/html/level2/html/HTMLElement110.html [ Crash Pass ] +crbug.com/591099 dom/legacy_dom_conformance/html/level2/html/HTMLElement111.html [ Crash Pass ] +crbug.com/591099 dom/legacy_dom_conformance/html/level2/html/HTMLElement112.html [ Crash Pass ] +crbug.com/591099 dom/legacy_dom_conformance/html/level2/html/HTMLElement113.html [ Crash Pass ] +crbug.com/591099 dom/legacy_dom_conformance/html/level2/html/HTMLElement114.html [ Crash Pass ] +crbug.com/591099 dom/legacy_dom_conformance/html/level2/html/HTMLElement115.html [ Crash Pass ] +crbug.com/591099 dom/legacy_dom_conformance/html/level2/html/HTMLElement116.html [ Crash Pass ] +crbug.com/591099 dom/legacy_dom_conformance/html/level2/html/HTMLElement117.html [ Crash Pass ] +crbug.com/591099 dom/legacy_dom_conformance/html/level2/html/HTMLElement118.html [ Crash Pass ] +crbug.com/591099 dom/legacy_dom_conformance/html/level2/html/HTMLElement119.html [ Crash Pass ] +crbug.com/591099 dom/legacy_dom_conformance/html/level2/html/HTMLElement12.html [ Crash Pass ] +crbug.com/591099 dom/legacy_dom_conformance/html/level2/html/HTMLElement120.html [ Crash Pass ] +crbug.com/591099 dom/legacy_dom_conformance/html/level2/html/HTMLElement121.html [ Crash Pass ] +crbug.com/591099 dom/legacy_dom_conformance/html/level2/html/HTMLElement122.html [ Crash Pass ] +crbug.com/591099 dom/legacy_dom_conformance/html/level2/html/HTMLElement123.html [ Crash Pass ] +crbug.com/591099 dom/legacy_dom_conformance/html/level2/html/HTMLElement124.html [ Crash Pass ] +crbug.com/591099 dom/legacy_dom_conformance/html/level2/html/HTMLElement125.html [ Crash Pass ] +crbug.com/591099 dom/legacy_dom_conformance/html/level2/html/HTMLElement126.html [ Crash Pass ] +crbug.com/591099 dom/legacy_dom_conformance/html/level2/html/HTMLElement127.html [ Crash Pass ] +crbug.com/591099 dom/legacy_dom_conformance/html/level2/html/HTMLElement128.html [ Crash Pass ] +crbug.com/591099 dom/legacy_dom_conformance/html/level2/html/HTMLElement129.html [ Crash Pass ] +crbug.com/591099 dom/legacy_dom_conformance/html/level2/html/HTMLElement13.html [ Crash Pass ] +crbug.com/591099 dom/legacy_dom_conformance/html/level2/html/HTMLElement130.html [ Crash Pass ] +crbug.com/591099 dom/legacy_dom_conformance/html/level2/html/HTMLElement131.html [ Crash Pass ] +crbug.com/591099 dom/legacy_dom_conformance/html/level2/html/HTMLElement132.html [ Crash Pass ] +crbug.com/591099 dom/legacy_dom_conformance/html/level2/html/HTMLElement133.html [ Crash Pass ] +crbug.com/591099 dom/legacy_dom_conformance/html/level2/html/HTMLElement134.html [ Crash Pass ] +crbug.com/591099 dom/legacy_dom_conformance/html/level2/html/HTMLElement135.html [ Crash Pass ] +crbug.com/591099 dom/legacy_dom_conformance/html/level2/html/HTMLElement136.html [ Crash Pass ] +crbug.com/591099 dom/legacy_dom_conformance/html/level2/html/HTMLElement137.html [ Crash Pass ] +crbug.com/591099 dom/legacy_dom_conformance/html/level2/html/HTMLElement138.html [ Crash Pass ] +crbug.com/591099 dom/legacy_dom_conformance/html/level2/html/HTMLElement139.html [ Crash Pass ] +crbug.com/591099 dom/legacy_dom_conformance/html/level2/html/HTMLElement14.html [ Crash Pass ] +crbug.com/591099 dom/legacy_dom_conformance/html/level2/html/HTMLElement140.html [ Crash Pass ] +crbug.com/591099 dom/legacy_dom_conformance/html/level2/html/HTMLElement141.html [ Crash Pass ] +crbug.com/591099 dom/legacy_dom_conformance/html/level2/html/HTMLElement142.html [ Crash Pass ] +crbug.com/591099 dom/legacy_dom_conformance/html/level2/html/HTMLElement143.html [ Crash Pass ] +crbug.com/591099 dom/legacy_dom_conformance/html/level2/html/HTMLElement144.html [ Crash Pass ] +crbug.com/591099 dom/legacy_dom_conformance/html/level2/html/HTMLElement145.html [ Crash Pass ] +crbug.com/591099 dom/legacy_dom_conformance/html/level2/html/HTMLElement15.html [ Crash Pass ] +crbug.com/591099 dom/legacy_dom_conformance/html/level2/html/HTMLElement16.html [ Crash Pass ] +crbug.com/591099 dom/legacy_dom_conformance/html/level2/html/HTMLElement17.html [ Crash Pass ] +crbug.com/591099 dom/legacy_dom_conformance/html/level2/html/HTMLElement18.html [ Crash Pass ] +crbug.com/591099 dom/legacy_dom_conformance/html/level2/html/HTMLElement19.html [ Crash Pass ] +crbug.com/591099 dom/legacy_dom_conformance/html/level2/html/HTMLElement20.html [ Crash Pass ] +crbug.com/591099 dom/legacy_dom_conformance/html/level2/html/HTMLElement21.html [ Crash Pass ] +crbug.com/591099 dom/legacy_dom_conformance/html/level2/html/HTMLElement22.html [ Crash Pass ] +crbug.com/591099 dom/legacy_dom_conformance/html/level2/html/HTMLElement23.html [ Crash Pass ] +crbug.com/591099 dom/legacy_dom_conformance/html/level2/html/HTMLElement24.html [ Crash Pass ] +crbug.com/591099 dom/legacy_dom_conformance/html/level2/html/HTMLElement25.html [ Crash Pass ] +crbug.com/591099 dom/legacy_dom_conformance/html/level2/html/HTMLElement26.html [ Crash Pass ] +crbug.com/591099 dom/legacy_dom_conformance/html/level2/html/HTMLElement27.html [ Crash Pass ] +crbug.com/591099 dom/legacy_dom_conformance/html/level2/html/HTMLElement28.html [ Crash Pass ] +crbug.com/591099 dom/legacy_dom_conformance/html/level2/html/HTMLElement29.html [ Crash Pass ] +crbug.com/591099 dom/legacy_dom_conformance/html/level2/html/HTMLElement30.html [ Crash Pass ] +crbug.com/591099 dom/legacy_dom_conformance/html/level2/html/HTMLElement31.html [ Crash Pass ] +crbug.com/591099 dom/legacy_dom_conformance/html/level2/html/HTMLElement32.html [ Crash Pass ] +crbug.com/591099 dom/legacy_dom_conformance/html/level2/html/HTMLElement33.html [ Crash Pass ] +crbug.com/591099 dom/legacy_dom_conformance/html/level2/html/HTMLElement34.html [ Crash Pass ] +crbug.com/591099 dom/legacy_dom_conformance/html/level2/html/HTMLElement35.html [ Crash Pass ] +crbug.com/591099 dom/legacy_dom_conformance/html/level2/html/HTMLElement36.html [ Crash Pass ] +crbug.com/591099 dom/legacy_dom_conformance/html/level2/html/HTMLElement37.html [ Crash Pass ] +crbug.com/591099 dom/legacy_dom_conformance/html/level2/html/HTMLElement38.html [ Crash Pass ] +crbug.com/591099 dom/legacy_dom_conformance/html/level2/html/HTMLElement39.html [ Crash Pass ] +crbug.com/591099 dom/legacy_dom_conformance/html/level2/html/HTMLElement40.html [ Crash Pass ] +crbug.com/591099 dom/legacy_dom_conformance/html/level2/html/HTMLElement41.html [ Crash Pass ] +crbug.com/591099 dom/legacy_dom_conformance/html/level2/html/HTMLElement42.html [ Crash Pass ] +crbug.com/591099 dom/legacy_dom_conformance/html/level2/html/HTMLElement43.html [ Crash Pass ] +crbug.com/591099 dom/legacy_dom_conformance/html/level2/html/HTMLElement44.html [ Crash Pass ] +crbug.com/591099 dom/legacy_dom_conformance/html/level2/html/HTMLElement45.html [ Crash Pass ] +crbug.com/591099 dom/legacy_dom_conformance/html/level2/html/HTMLElement46.html [ Crash Pass ] +crbug.com/591099 dom/legacy_dom_conformance/html/level2/html/HTMLElement47.html [ Crash Pass ] +crbug.com/591099 dom/legacy_dom_conformance/html/level2/html/HTMLElement48.html [ Crash Pass ] +crbug.com/591099 dom/legacy_dom_conformance/html/level2/html/HTMLElement49.html [ Crash Pass ] +crbug.com/591099 dom/legacy_dom_conformance/html/level2/html/HTMLElement50.html [ Crash Pass ] +crbug.com/591099 dom/legacy_dom_conformance/html/level2/html/HTMLElement51.html [ Crash Pass ] +crbug.com/591099 dom/legacy_dom_conformance/html/level2/html/HTMLElement52.html [ Crash Pass ] +crbug.com/591099 dom/legacy_dom_conformance/html/level2/html/HTMLElement53.html [ Crash Pass ] +crbug.com/591099 dom/legacy_dom_conformance/html/level2/html/HTMLElement54.html [ Crash Pass ] +crbug.com/591099 dom/legacy_dom_conformance/html/level2/html/HTMLElement55.html [ Crash Pass ] +crbug.com/591099 dom/legacy_dom_conformance/html/level2/html/HTMLElement56.html [ Crash Pass ] +crbug.com/591099 dom/legacy_dom_conformance/html/level2/html/HTMLElement57.html [ Crash Pass ] +crbug.com/591099 dom/legacy_dom_conformance/html/level2/html/HTMLElement58.html [ Crash Pass ] +crbug.com/591099 dom/legacy_dom_conformance/html/level2/html/HTMLElement59.html [ Crash Pass ] +crbug.com/591099 dom/legacy_dom_conformance/html/level2/html/HTMLElement60.html [ Crash Pass ] +crbug.com/591099 dom/legacy_dom_conformance/html/level2/html/HTMLElement61.html [ Crash Pass ] +crbug.com/591099 dom/legacy_dom_conformance/html/level2/html/HTMLElement62.html [ Crash Pass ] +crbug.com/591099 dom/legacy_dom_conformance/html/level2/html/HTMLElement63.html [ Crash Pass ] +crbug.com/591099 dom/legacy_dom_conformance/html/level2/html/HTMLElement64.html [ Crash Pass ] +crbug.com/591099 dom/legacy_dom_conformance/html/level2/html/HTMLElement65.html [ Crash Pass ] +crbug.com/591099 dom/legacy_dom_conformance/html/level2/html/HTMLElement66.html [ Crash Pass ] +crbug.com/591099 dom/legacy_dom_conformance/html/level2/html/HTMLElement67.html [ Crash Pass ] +crbug.com/591099 dom/legacy_dom_conformance/html/level2/html/HTMLElement68.html [ Crash Pass ] +crbug.com/591099 dom/legacy_dom_conformance/html/level2/html/HTMLElement69.html [ Crash Pass ] +crbug.com/591099 dom/legacy_dom_conformance/html/level2/html/HTMLElement70.html [ Crash Pass ] +crbug.com/591099 dom/legacy_dom_conformance/html/level2/html/HTMLElement71.html [ Crash Pass ] +crbug.com/591099 dom/legacy_dom_conformance/html/level2/html/HTMLElement72.html [ Crash Pass ] +crbug.com/591099 dom/legacy_dom_conformance/html/level2/html/HTMLElement73.html [ Crash Pass ] +crbug.com/591099 dom/legacy_dom_conformance/html/level2/html/HTMLElement74.html [ Crash Pass ] +crbug.com/591099 dom/legacy_dom_conformance/html/level2/html/HTMLElement75.html [ Crash Pass ] +crbug.com/591099 dom/legacy_dom_conformance/html/level2/html/HTMLElement76.html [ Crash Pass ] +crbug.com/591099 dom/legacy_dom_conformance/html/level2/html/HTMLElement77.html [ Crash Pass ] +crbug.com/591099 dom/legacy_dom_conformance/html/level2/html/HTMLElement78.html [ Crash Pass ] +crbug.com/591099 dom/legacy_dom_conformance/html/level2/html/HTMLElement79.html [ Crash Pass ] +crbug.com/591099 dom/legacy_dom_conformance/html/level2/html/HTMLElement80.html [ Crash Pass ] +crbug.com/591099 dom/legacy_dom_conformance/html/level2/html/HTMLElement81.html [ Crash Pass ] +crbug.com/591099 dom/legacy_dom_conformance/html/level2/html/HTMLElement82.html [ Crash Pass ] +crbug.com/591099 dom/legacy_dom_conformance/html/level2/html/HTMLElement83.html [ Crash Pass ] +crbug.com/591099 dom/legacy_dom_conformance/html/level2/html/HTMLElement84.html [ Crash Pass ] +crbug.com/591099 dom/legacy_dom_conformance/html/level2/html/HTMLElement85.html [ Crash Pass ] +crbug.com/591099 dom/legacy_dom_conformance/html/level2/html/HTMLElement86.html [ Crash Pass ] +crbug.com/591099 dom/legacy_dom_conformance/html/level2/html/HTMLElement87.html [ Crash Pass ] +crbug.com/591099 dom/legacy_dom_conformance/html/level2/html/HTMLElement88.html [ Crash Pass ] +crbug.com/591099 dom/legacy_dom_conformance/html/level2/html/HTMLElement89.html [ Crash Pass ] +crbug.com/591099 dom/legacy_dom_conformance/html/level2/html/HTMLElement90.html [ Crash Pass ] +crbug.com/591099 dom/legacy_dom_conformance/html/level2/html/HTMLElement91.html [ Crash Pass ] +crbug.com/591099 dom/legacy_dom_conformance/html/level2/html/HTMLElement92.html [ Crash Pass ] +crbug.com/591099 dom/legacy_dom_conformance/html/level2/html/HTMLElement93.html [ Crash Pass ] +crbug.com/591099 dom/legacy_dom_conformance/html/level2/html/HTMLElement94.html [ Crash Pass ] +crbug.com/591099 dom/legacy_dom_conformance/html/level2/html/HTMLElement95.html [ Crash Pass ] +crbug.com/591099 dom/legacy_dom_conformance/html/level2/html/HTMLElement96.html [ Crash Pass ] +crbug.com/591099 dom/legacy_dom_conformance/html/level2/html/HTMLElement97.html [ Crash Pass ] +crbug.com/591099 dom/legacy_dom_conformance/html/level2/html/HTMLElement98.html [ Crash Pass ] +crbug.com/591099 dom/legacy_dom_conformance/html/level2/html/HTMLElement99.html [ Crash Pass ] +crbug.com/591099 dom/legacy_dom_conformance/html/level2/html/HTMLFormElement10.html [ Crash Pass ] crbug.com/591099 dom/legacy_dom_conformance/html/level2/html/HTMLIFrameElement01.html [ Crash Pass ] crbug.com/591099 dom/legacy_dom_conformance/html/level2/html/HTMLIFrameElement02.html [ Crash Pass ] crbug.com/591099 dom/legacy_dom_conformance/html/level2/html/HTMLIFrameElement03.html [ Crash Pass ] @@ -2895,50 +2895,50 @@ crbug.com/591099 dom/legacy_dom_conformance/html/level2/html/HTMLIFrameElement07.html [ Crash Pass ] crbug.com/591099 dom/legacy_dom_conformance/html/level2/html/HTMLIFrameElement09.html [ Crash Pass ] crbug.com/591099 dom/legacy_dom_conformance/html/level2/html/HTMLIFrameElement10.html [ Crash Pass ] -crbug.com/591099 dom/legacy_dom_conformance/html/level2/html/HTMLIFrameElement11.html [ Crash ] -crbug.com/591099 dom/legacy_dom_conformance/html/level2/html/HTMLImageElement05.html [ Crash ] -crbug.com/591099 dom/legacy_dom_conformance/html/level2/html/HTMLImageElement12.html [ Crash ] -crbug.com/591099 dom/legacy_dom_conformance/html/level2/html/HTMLObjectElement01.html [ Crash ] -crbug.com/591099 dom/legacy_dom_conformance/html/level2/html/HTMLObjectElement02.html [ Crash ] -crbug.com/591099 dom/legacy_dom_conformance/html/level2/html/HTMLObjectElement03.html [ Crash ] -crbug.com/591099 dom/legacy_dom_conformance/html/level2/html/HTMLObjectElement04.html [ Crash ] -crbug.com/591099 dom/legacy_dom_conformance/html/level2/html/HTMLObjectElement05.html [ Crash ] -crbug.com/591099 dom/legacy_dom_conformance/html/level2/html/HTMLObjectElement06.html [ Crash ] -crbug.com/591099 dom/legacy_dom_conformance/html/level2/html/HTMLObjectElement07.html [ Crash ] -crbug.com/591099 dom/legacy_dom_conformance/html/level2/html/HTMLObjectElement08.html [ Crash ] -crbug.com/591099 dom/legacy_dom_conformance/html/level2/html/HTMLObjectElement09.html [ Crash ] -crbug.com/591099 dom/legacy_dom_conformance/html/level2/html/HTMLObjectElement10.html [ Crash ] -crbug.com/591099 dom/legacy_dom_conformance/html/level2/html/HTMLObjectElement11.html [ Crash ] -crbug.com/591099 dom/legacy_dom_conformance/html/level2/html/HTMLObjectElement12.html [ Crash ] -crbug.com/591099 dom/legacy_dom_conformance/html/level2/html/HTMLObjectElement13.html [ Crash ] -crbug.com/591099 dom/legacy_dom_conformance/html/level2/html/HTMLObjectElement14.html [ Crash ] -crbug.com/591099 dom/legacy_dom_conformance/html/level2/html/HTMLObjectElement15.html [ Crash ] -crbug.com/591099 dom/legacy_dom_conformance/html/level2/html/HTMLObjectElement16.html [ Crash ] -crbug.com/591099 dom/legacy_dom_conformance/html/level2/html/HTMLObjectElement17.html [ Crash ] -crbug.com/591099 dom/legacy_dom_conformance/html/level2/html/HTMLObjectElement18.html [ Crash ] -crbug.com/591099 dom/legacy_dom_conformance/html/level2/html/HTMLObjectElement19.html [ Crash ] -crbug.com/591099 dom/legacy_dom_conformance/html/level2/html/HTMLObjectElement20.html [ Crash ] -crbug.com/591099 dom/legacy_dom_conformance/html/level2/html/HTMLParamElement01.html [ Crash ] -crbug.com/591099 dom/legacy_dom_conformance/html/level2/html/HTMLParamElement02.html [ Crash ] -crbug.com/591099 dom/legacy_dom_conformance/html/level2/html/HTMLParamElement03.html [ Crash ] -crbug.com/591099 dom/legacy_dom_conformance/html/level2/html/HTMLParamElement04.html [ Crash ] -crbug.com/591099 dom/legacy_dom_conformance/html/level2/html/HTMLSelectElement14.html [ Crash ] -crbug.com/591099 dom/legacy_dom_conformance/html/level2/html/HTMLTextAreaElement14.html [ Crash ] -crbug.com/591099 dom/legacy_dom_conformance/html/level2/html/HTMLTextAreaElement15.html [ Crash ] -crbug.com/591099 dom/legacy_dom_conformance/html/level2/html/object01.html [ Crash ] -crbug.com/591099 dom/legacy_dom_conformance/html/level2/html/object02.html [ Crash ] -crbug.com/591099 dom/legacy_dom_conformance/html/level2/html/object03.html [ Crash ] -crbug.com/591099 dom/legacy_dom_conformance/html/level2/html/object04.html [ Crash ] -crbug.com/591099 dom/legacy_dom_conformance/html/level2/html/object05.html [ Crash ] -crbug.com/591099 dom/legacy_dom_conformance/html/level2/html/object07.html [ Crash ] -crbug.com/591099 dom/legacy_dom_conformance/html/level2/html/object08.html [ Crash ] -crbug.com/591099 dom/legacy_dom_conformance/html/level2/html/object09.html [ Crash ] -crbug.com/591099 dom/legacy_dom_conformance/html/level2/html/object10.html [ Crash ] -crbug.com/591099 dom/legacy_dom_conformance/html/level2/html/object11.html [ Crash ] -crbug.com/591099 dom/legacy_dom_conformance/html/level2/html/object12.html [ Crash ] -crbug.com/591099 dom/legacy_dom_conformance/html/level2/html/object13.html [ Crash ] -crbug.com/591099 dom/legacy_dom_conformance/html/level2/html/object14.html [ Crash ] -crbug.com/591099 dom/legacy_dom_conformance/html/level2/html/object15.html [ Crash ] +crbug.com/591099 dom/legacy_dom_conformance/html/level2/html/HTMLIFrameElement11.html [ Crash Pass ] +crbug.com/591099 dom/legacy_dom_conformance/html/level2/html/HTMLImageElement05.html [ Crash Pass ] +crbug.com/591099 dom/legacy_dom_conformance/html/level2/html/HTMLImageElement12.html [ Crash Pass ] +crbug.com/591099 dom/legacy_dom_conformance/html/level2/html/HTMLObjectElement01.html [ Crash Pass ] +crbug.com/591099 dom/legacy_dom_conformance/html/level2/html/HTMLObjectElement02.html [ Crash Pass ] +crbug.com/591099 dom/legacy_dom_conformance/html/level2/html/HTMLObjectElement03.html [ Crash Pass ] +crbug.com/591099 dom/legacy_dom_conformance/html/level2/html/HTMLObjectElement04.html [ Crash Pass ] +crbug.com/591099 dom/legacy_dom_conformance/html/level2/html/HTMLObjectElement05.html [ Crash Pass ] +crbug.com/591099 dom/legacy_dom_conformance/html/level2/html/HTMLObjectElement06.html [ Crash Pass ] +crbug.com/591099 dom/legacy_dom_conformance/html/level2/html/HTMLObjectElement07.html [ Crash Pass ] +crbug.com/591099 dom/legacy_dom_conformance/html/level2/html/HTMLObjectElement08.html [ Crash Pass ] +crbug.com/591099 dom/legacy_dom_conformance/html/level2/html/HTMLObjectElement09.html [ Crash Pass ] +crbug.com/591099 dom/legacy_dom_conformance/html/level2/html/HTMLObjectElement10.html [ Crash Pass ] +crbug.com/591099 dom/legacy_dom_conformance/html/level2/html/HTMLObjectElement11.html [ Crash Pass ] +crbug.com/591099 dom/legacy_dom_conformance/html/level2/html/HTMLObjectElement12.html [ Crash Pass ] +crbug.com/591099 dom/legacy_dom_conformance/html/level2/html/HTMLObjectElement13.html [ Crash Pass ] +crbug.com/591099 dom/legacy_dom_conformance/html/level2/html/HTMLObjectElement14.html [ Crash Pass ] +crbug.com/591099 dom/legacy_dom_conformance/html/level2/html/HTMLObjectElement15.html [ Crash Pass ] +crbug.com/591099 dom/legacy_dom_conformance/html/level2/html/HTMLObjectElement16.html [ Crash Pass ] +crbug.com/591099 dom/legacy_dom_conformance/html/level2/html/HTMLObjectElement17.html [ Crash Pass ] +crbug.com/591099 dom/legacy_dom_conformance/html/level2/html/HTMLObjectElement18.html [ Crash Pass ] +crbug.com/591099 dom/legacy_dom_conformance/html/level2/html/HTMLObjectElement19.html [ Crash Pass ] +crbug.com/591099 dom/legacy_dom_conformance/html/level2/html/HTMLObjectElement20.html [ Crash Pass ] +crbug.com/591099 dom/legacy_dom_conformance/html/level2/html/HTMLParamElement01.html [ Crash Pass ] +crbug.com/591099 dom/legacy_dom_conformance/html/level2/html/HTMLParamElement02.html [ Crash Pass ] +crbug.com/591099 dom/legacy_dom_conformance/html/level2/html/HTMLParamElement03.html [ Crash Pass ] +crbug.com/591099 dom/legacy_dom_conformance/html/level2/html/HTMLParamElement04.html [ Crash Pass ] +crbug.com/591099 dom/legacy_dom_conformance/html/level2/html/HTMLSelectElement14.html [ Crash Pass ] +crbug.com/591099 dom/legacy_dom_conformance/html/level2/html/HTMLTextAreaElement14.html [ Crash Pass ] +crbug.com/591099 dom/legacy_dom_conformance/html/level2/html/HTMLTextAreaElement15.html [ Crash Pass ] +crbug.com/591099 dom/legacy_dom_conformance/html/level2/html/object01.html [ Crash Pass ] +crbug.com/591099 dom/legacy_dom_conformance/html/level2/html/object02.html [ Crash Pass ] +crbug.com/591099 dom/legacy_dom_conformance/html/level2/html/object03.html [ Crash Pass ] +crbug.com/591099 dom/legacy_dom_conformance/html/level2/html/object04.html [ Crash Pass ] +crbug.com/591099 dom/legacy_dom_conformance/html/level2/html/object05.html [ Crash Pass ] +crbug.com/591099 dom/legacy_dom_conformance/html/level2/html/object07.html [ Crash Pass ] +crbug.com/591099 dom/legacy_dom_conformance/html/level2/html/object08.html [ Crash Pass ] +crbug.com/591099 dom/legacy_dom_conformance/html/level2/html/object09.html [ Crash Pass ] +crbug.com/591099 dom/legacy_dom_conformance/html/level2/html/object10.html [ Crash Pass ] +crbug.com/591099 dom/legacy_dom_conformance/html/level2/html/object11.html [ Crash Pass ] +crbug.com/591099 dom/legacy_dom_conformance/html/level2/html/object12.html [ Crash Pass ] +crbug.com/591099 dom/legacy_dom_conformance/html/level2/html/object13.html [ Crash Pass ] +crbug.com/591099 dom/legacy_dom_conformance/html/level2/html/object14.html [ Crash Pass ] +crbug.com/591099 dom/legacy_dom_conformance/html/level2/html/object15.html [ Crash Pass ] crbug.com/591099 dom/legacy_dom_conformance/xhtml/level2/html/HTMLDocument01.xhtml [ Crash Pass ] crbug.com/591099 dom/legacy_dom_conformance/xhtml/level2/html/HTMLDocument02.xhtml [ Crash Pass ] crbug.com/591099 dom/legacy_dom_conformance/xhtml/level2/html/HTMLDocument03.xhtml [ Crash Pass ] @@ -2954,151 +2954,151 @@ crbug.com/591099 dom/legacy_dom_conformance/xhtml/level2/html/HTMLDocument14.xhtml [ Crash Pass ] crbug.com/591099 dom/legacy_dom_conformance/xhtml/level2/html/HTMLDocument15.xhtml [ Crash Pass ] crbug.com/591099 dom/legacy_dom_conformance/xhtml/level2/html/HTMLDocument16.xhtml [ Crash Pass ] -crbug.com/591099 dom/legacy_dom_conformance/xhtml/level2/html/HTMLElement01.xhtml [ Crash ] -crbug.com/591099 dom/legacy_dom_conformance/xhtml/level2/html/HTMLElement02.xhtml [ Crash ] -crbug.com/591099 dom/legacy_dom_conformance/xhtml/level2/html/HTMLElement03.xhtml [ Crash ] -crbug.com/591099 dom/legacy_dom_conformance/xhtml/level2/html/HTMLElement04.xhtml [ Crash ] -crbug.com/591099 dom/legacy_dom_conformance/xhtml/level2/html/HTMLElement05.xhtml [ Crash ] -crbug.com/591099 dom/legacy_dom_conformance/xhtml/level2/html/HTMLElement06.xhtml [ Crash ] -crbug.com/591099 dom/legacy_dom_conformance/xhtml/level2/html/HTMLElement07.xhtml [ Crash ] -crbug.com/591099 dom/legacy_dom_conformance/xhtml/level2/html/HTMLElement08.xhtml [ Crash ] -crbug.com/591099 dom/legacy_dom_conformance/xhtml/level2/html/HTMLElement09.xhtml [ Crash ] -crbug.com/591099 dom/legacy_dom_conformance/xhtml/level2/html/HTMLElement10.xhtml [ Crash ] -crbug.com/591099 dom/legacy_dom_conformance/xhtml/level2/html/HTMLElement100.xhtml [ Crash ] -crbug.com/591099 dom/legacy_dom_conformance/xhtml/level2/html/HTMLElement101.xhtml [ Crash ] -crbug.com/591099 dom/legacy_dom_conformance/xhtml/level2/html/HTMLElement102.xhtml [ Crash ] -crbug.com/591099 dom/legacy_dom_conformance/xhtml/level2/html/HTMLElement103.xhtml [ Crash ] -crbug.com/591099 dom/legacy_dom_conformance/xhtml/level2/html/HTMLElement104.xhtml [ Crash ] -crbug.com/591099 dom/legacy_dom_conformance/xhtml/level2/html/HTMLElement105.xhtml [ Crash ] -crbug.com/591099 dom/legacy_dom_conformance/xhtml/level2/html/HTMLElement106.xhtml [ Crash ] -crbug.com/591099 dom/legacy_dom_conformance/xhtml/level2/html/HTMLElement107.xhtml [ Crash ] -crbug.com/591099 dom/legacy_dom_conformance/xhtml/level2/html/HTMLElement108.xhtml [ Crash ] -crbug.com/591099 dom/legacy_dom_conformance/xhtml/level2/html/HTMLElement109.xhtml [ Crash ] -crbug.com/591099 dom/legacy_dom_conformance/xhtml/level2/html/HTMLElement11.xhtml [ Crash ] -crbug.com/591099 dom/legacy_dom_conformance/xhtml/level2/html/HTMLElement110.xhtml [ Crash ] -crbug.com/591099 dom/legacy_dom_conformance/xhtml/level2/html/HTMLElement111.xhtml [ Crash ] -crbug.com/591099 dom/legacy_dom_conformance/xhtml/level2/html/HTMLElement112.xhtml [ Crash ] -crbug.com/591099 dom/legacy_dom_conformance/xhtml/level2/html/HTMLElement113.xhtml [ Crash ] -crbug.com/591099 dom/legacy_dom_conformance/xhtml/level2/html/HTMLElement114.xhtml [ Crash ] -crbug.com/591099 dom/legacy_dom_conformance/xhtml/level2/html/HTMLElement115.xhtml [ Crash ] -crbug.com/591099 dom/legacy_dom_conformance/xhtml/level2/html/HTMLElement116.xhtml [ Crash ] -crbug.com/591099 dom/legacy_dom_conformance/xhtml/level2/html/HTMLElement117.xhtml [ Crash ] -crbug.com/591099 dom/legacy_dom_conformance/xhtml/level2/html/HTMLElement118.xhtml [ Crash ] -crbug.com/591099 dom/legacy_dom_conformance/xhtml/level2/html/HTMLElement119.xhtml [ Crash ] -crbug.com/591099 dom/legacy_dom_conformance/xhtml/level2/html/HTMLElement12.xhtml [ Crash ] -crbug.com/591099 dom/legacy_dom_conformance/xhtml/level2/html/HTMLElement120.xhtml [ Crash ] -crbug.com/591099 dom/legacy_dom_conformance/xhtml/level2/html/HTMLElement121.xhtml [ Crash ] -crbug.com/591099 dom/legacy_dom_conformance/xhtml/level2/html/HTMLElement122.xhtml [ Crash ] -crbug.com/591099 dom/legacy_dom_conformance/xhtml/level2/html/HTMLElement123.xhtml [ Crash ] -crbug.com/591099 dom/legacy_dom_conformance/xhtml/level2/html/HTMLElement124.xhtml [ Crash ] -crbug.com/591099 dom/legacy_dom_conformance/xhtml/level2/html/HTMLElement125.xhtml [ Crash ] -crbug.com/591099 dom/legacy_dom_conformance/xhtml/level2/html/HTMLElement126.xhtml [ Crash ] -crbug.com/591099 dom/legacy_dom_conformance/xhtml/level2/html/HTMLElement127.xhtml [ Crash ] -crbug.com/591099 dom/legacy_dom_conformance/xhtml/level2/html/HTMLElement128.xhtml [ Crash ] -crbug.com/591099 dom/legacy_dom_conformance/xhtml/level2/html/HTMLElement129.xhtml [ Crash ] -crbug.com/591099 dom/legacy_dom_conformance/xhtml/level2/html/HTMLElement13.xhtml [ Crash ] -crbug.com/591099 dom/legacy_dom_conformance/xhtml/level2/html/HTMLElement130.xhtml [ Crash ] -crbug.com/591099 dom/legacy_dom_conformance/xhtml/level2/html/HTMLElement131.xhtml [ Crash ] -crbug.com/591099 dom/legacy_dom_conformance/xhtml/level2/html/HTMLElement132.xhtml [ Crash ] -crbug.com/591099 dom/legacy_dom_conformance/xhtml/level2/html/HTMLElement133.xhtml [ Crash ] -crbug.com/591099 dom/legacy_dom_conformance/xhtml/level2/html/HTMLElement134.xhtml [ Crash ] -crbug.com/591099 dom/legacy_dom_conformance/xhtml/level2/html/HTMLElement135.xhtml [ Crash ] -crbug.com/591099 dom/legacy_dom_conformance/xhtml/level2/html/HTMLElement136.xhtml [ Crash ] -crbug.com/591099 dom/legacy_dom_conformance/xhtml/level2/html/HTMLElement137.xhtml [ Crash ] -crbug.com/591099 dom/legacy_dom_conformance/xhtml/level2/html/HTMLElement138.xhtml [ Crash ] -crbug.com/591099 dom/legacy_dom_conformance/xhtml/level2/html/HTMLElement139.xhtml [ Crash ] -crbug.com/591099 dom/legacy_dom_conformance/xhtml/level2/html/HTMLElement14.xhtml [ Crash ] -crbug.com/591099 dom/legacy_dom_conformance/xhtml/level2/html/HTMLElement140.xhtml [ Crash ] -crbug.com/591099 dom/legacy_dom_conformance/xhtml/level2/html/HTMLElement141.xhtml [ Crash ] -crbug.com/591099 dom/legacy_dom_conformance/xhtml/level2/html/HTMLElement142.xhtml [ Crash ] -crbug.com/591099 dom/legacy_dom_conformance/xhtml/level2/html/HTMLElement143.xhtml [ Crash ] -crbug.com/591099 dom/legacy_dom_conformance/xhtml/level2/html/HTMLElement144.xhtml [ Crash ] -crbug.com/591099 dom/legacy_dom_conformance/xhtml/level2/html/HTMLElement145.xhtml [ Crash ] -crbug.com/591099 dom/legacy_dom_conformance/xhtml/level2/html/HTMLElement15.xhtml [ Crash ] -crbug.com/591099 dom/legacy_dom_conformance/xhtml/level2/html/HTMLElement16.xhtml [ Crash ] -crbug.com/591099 dom/legacy_dom_conformance/xhtml/level2/html/HTMLElement17.xhtml [ Crash ] -crbug.com/591099 dom/legacy_dom_conformance/xhtml/level2/html/HTMLElement18.xhtml [ Crash ] -crbug.com/591099 dom/legacy_dom_conformance/xhtml/level2/html/HTMLElement19.xhtml [ Crash ] -crbug.com/591099 dom/legacy_dom_conformance/xhtml/level2/html/HTMLElement20.xhtml [ Crash ] -crbug.com/591099 dom/legacy_dom_conformance/xhtml/level2/html/HTMLElement21.xhtml [ Crash ] -crbug.com/591099 dom/legacy_dom_conformance/xhtml/level2/html/HTMLElement22.xhtml [ Crash ] -crbug.com/591099 dom/legacy_dom_conformance/xhtml/level2/html/HTMLElement23.xhtml [ Crash ] -crbug.com/591099 dom/legacy_dom_conformance/xhtml/level2/html/HTMLElement24.xhtml [ Crash ] -crbug.com/591099 dom/legacy_dom_conformance/xhtml/level2/html/HTMLElement25.xhtml [ Crash ] -crbug.com/591099 dom/legacy_dom_conformance/xhtml/level2/html/HTMLElement26.xhtml [ Crash ] -crbug.com/591099 dom/legacy_dom_conformance/xhtml/level2/html/HTMLElement27.xhtml [ Crash ] -crbug.com/591099 dom/legacy_dom_conformance/xhtml/level2/html/HTMLElement28.xhtml [ Crash ] -crbug.com/591099 dom/legacy_dom_conformance/xhtml/level2/html/HTMLElement29.xhtml [ Crash ] -crbug.com/591099 dom/legacy_dom_conformance/xhtml/level2/html/HTMLElement30.xhtml [ Crash ] -crbug.com/591099 dom/legacy_dom_conformance/xhtml/level2/html/HTMLElement31.xhtml [ Crash ] -crbug.com/591099 dom/legacy_dom_conformance/xhtml/level2/html/HTMLElement32.xhtml [ Crash ] -crbug.com/591099 dom/legacy_dom_conformance/xhtml/level2/html/HTMLElement33.xhtml [ Crash ] -crbug.com/591099 dom/legacy_dom_conformance/xhtml/level2/html/HTMLElement34.xhtml [ Crash ] -crbug.com/591099 dom/legacy_dom_conformance/xhtml/level2/html/HTMLElement35.xhtml [ Crash ] -crbug.com/591099 dom/legacy_dom_conformance/xhtml/level2/html/HTMLElement36.xhtml [ Crash ] -crbug.com/591099 dom/legacy_dom_conformance/xhtml/level2/html/HTMLElement37.xhtml [ Crash ] -crbug.com/591099 dom/legacy_dom_conformance/xhtml/level2/html/HTMLElement38.xhtml [ Crash ] -crbug.com/591099 dom/legacy_dom_conformance/xhtml/level2/html/HTMLElement39.xhtml [ Crash ] -crbug.com/591099 dom/legacy_dom_conformance/xhtml/level2/html/HTMLElement40.xhtml [ Crash ] -crbug.com/591099 dom/legacy_dom_conformance/xhtml/level2/html/HTMLElement41.xhtml [ Crash ] -crbug.com/591099 dom/legacy_dom_conformance/xhtml/level2/html/HTMLElement42.xhtml [ Crash ] -crbug.com/591099 dom/legacy_dom_conformance/xhtml/level2/html/HTMLElement43.xhtml [ Crash ] -crbug.com/591099 dom/legacy_dom_conformance/xhtml/level2/html/HTMLElement44.xhtml [ Crash ] -crbug.com/591099 dom/legacy_dom_conformance/xhtml/level2/html/HTMLElement45.xhtml [ Crash ] -crbug.com/591099 dom/legacy_dom_conformance/xhtml/level2/html/HTMLElement46.xhtml [ Crash ] -crbug.com/591099 dom/legacy_dom_conformance/xhtml/level2/html/HTMLElement47.xhtml [ Crash ] -crbug.com/591099 dom/legacy_dom_conformance/xhtml/level2/html/HTMLElement48.xhtml [ Crash ] -crbug.com/591099 dom/legacy_dom_conformance/xhtml/level2/html/HTMLElement49.xhtml [ Crash ] -crbug.com/591099 dom/legacy_dom_conformance/xhtml/level2/html/HTMLElement50.xhtml [ Crash ] -crbug.com/591099 dom/legacy_dom_conformance/xhtml/level2/html/HTMLElement51.xhtml [ Crash ] -crbug.com/591099 dom/legacy_dom_conformance/xhtml/level2/html/HTMLElement52.xhtml [ Crash ] -crbug.com/591099 dom/legacy_dom_conformance/xhtml/level2/html/HTMLElement53.xhtml [ Crash ] -crbug.com/591099 dom/legacy_dom_conformance/xhtml/level2/html/HTMLElement54.xhtml [ Crash ] -crbug.com/591099 dom/legacy_dom_conformance/xhtml/level2/html/HTMLElement55.xhtml [ Crash ] -crbug.com/591099 dom/legacy_dom_conformance/xhtml/level2/html/HTMLElement56.xhtml [ Crash ] -crbug.com/591099 dom/legacy_dom_conformance/xhtml/level2/html/HTMLElement57.xhtml [ Crash ] -crbug.com/591099 dom/legacy_dom_conformance/xhtml/level2/html/HTMLElement58.xhtml [ Crash ] -crbug.com/591099 dom/legacy_dom_conformance/xhtml/level2/html/HTMLElement59.xhtml [ Crash ] -crbug.com/591099 dom/legacy_dom_conformance/xhtml/level2/html/HTMLElement60.xhtml [ Crash ] -crbug.com/591099 dom/legacy_dom_conformance/xhtml/level2/html/HTMLElement61.xhtml [ Crash ] -crbug.com/591099 dom/legacy_dom_conformance/xhtml/level2/html/HTMLElement62.xhtml [ Crash ] -crbug.com/591099 dom/legacy_dom_conformance/xhtml/level2/html/HTMLElement63.xhtml [ Crash ] -crbug.com/591099 dom/legacy_dom_conformance/xhtml/level2/html/HTMLElement64.xhtml [ Crash ] -crbug.com/591099 dom/legacy_dom_conformance/xhtml/level2/html/HTMLElement65.xhtml [ Crash ] -crbug.com/591099 dom/legacy_dom_conformance/xhtml/level2/html/HTMLElement66.xhtml [ Crash ] -crbug.com/591099 dom/legacy_dom_conformance/xhtml/level2/html/HTMLElement67.xhtml [ Crash ] -crbug.com/591099 dom/legacy_dom_conformance/xhtml/level2/html/HTMLElement68.xhtml [ Crash ] -crbug.com/591099 dom/legacy_dom_conformance/xhtml/level2/html/HTMLElement69.xhtml [ Crash ] -crbug.com/591099 dom/legacy_dom_conformance/xhtml/level2/html/HTMLElement70.xhtml [ Crash ] -crbug.com/591099 dom/legacy_dom_conformance/xhtml/level2/html/HTMLElement71.xhtml [ Crash ] -crbug.com/591099 dom/legacy_dom_conformance/xhtml/level2/html/HTMLElement72.xhtml [ Crash ] -crbug.com/591099 dom/legacy_dom_conformance/xhtml/level2/html/HTMLElement73.xhtml [ Crash ] -crbug.com/591099 dom/legacy_dom_conformance/xhtml/level2/html/HTMLElement74.xhtml [ Crash ] -crbug.com/591099 dom/legacy_dom_conformance/xhtml/level2/html/HTMLElement75.xhtml [ Crash ] -crbug.com/591099 dom/legacy_dom_conformance/xhtml/level2/html/HTMLElement76.xhtml [ Crash ] -crbug.com/591099 dom/legacy_dom_conformance/xhtml/level2/html/HTMLElement77.xhtml [ Crash ] -crbug.com/591099 dom/legacy_dom_conformance/xhtml/level2/html/HTMLElement78.xhtml [ Crash ] -crbug.com/591099 dom/legacy_dom_conformance/xhtml/level2/html/HTMLElement79.xhtml [ Crash ] -crbug.com/591099 dom/legacy_dom_conformance/xhtml/level2/html/HTMLElement80.xhtml [ Crash ] -crbug.com/591099 dom/legacy_dom_conformance/xhtml/level2/html/HTMLElement81.xhtml [ Crash ] -crbug.com/591099 dom/legacy_dom_conformance/xhtml/level2/html/HTMLElement82.xhtml [ Crash ] -crbug.com/591099 dom/legacy_dom_conformance/xhtml/level2/html/HTMLElement83.xhtml [ Crash ] -crbug.com/591099 dom/legacy_dom_conformance/xhtml/level2/html/HTMLElement84.xhtml [ Crash ] -crbug.com/591099 dom/legacy_dom_conformance/xhtml/level2/html/HTMLElement85.xhtml [ Crash ] -crbug.com/591099 dom/legacy_dom_conformance/xhtml/level2/html/HTMLElement86.xhtml [ Crash ] -crbug.com/591099 dom/legacy_dom_conformance/xhtml/level2/html/HTMLElement87.xhtml [ Crash ] -crbug.com/591099 dom/legacy_dom_conformance/xhtml/level2/html/HTMLElement88.xhtml [ Crash ] -crbug.com/591099 dom/legacy_dom_conformance/xhtml/level2/html/HTMLElement89.xhtml [ Crash ] -crbug.com/591099 dom/legacy_dom_conformance/xhtml/level2/html/HTMLElement90.xhtml [ Crash ] -crbug.com/591099 dom/legacy_dom_conformance/xhtml/level2/html/HTMLElement91.xhtml [ Crash ] -crbug.com/591099 dom/legacy_dom_conformance/xhtml/level2/html/HTMLElement92.xhtml [ Crash ] -crbug.com/591099 dom/legacy_dom_conformance/xhtml/level2/html/HTMLElement93.xhtml [ Crash ] -crbug.com/591099 dom/legacy_dom_conformance/xhtml/level2/html/HTMLElement94.xhtml [ Crash ] -crbug.com/591099 dom/legacy_dom_conformance/xhtml/level2/html/HTMLElement95.xhtml [ Crash ] -crbug.com/591099 dom/legacy_dom_conformance/xhtml/level2/html/HTMLElement96.xhtml [ Crash ] -crbug.com/591099 dom/legacy_dom_conformance/xhtml/level2/html/HTMLElement97.xhtml [ Crash ] -crbug.com/591099 dom/legacy_dom_conformance/xhtml/level2/html/HTMLElement98.xhtml [ Crash ] -crbug.com/591099 dom/legacy_dom_conformance/xhtml/level2/html/HTMLElement99.xhtml [ Crash ] +crbug.com/591099 dom/legacy_dom_conformance/xhtml/level2/html/HTMLElement01.xhtml [ Crash Pass ] +crbug.com/591099 dom/legacy_dom_conformance/xhtml/level2/html/HTMLElement02.xhtml [ Crash Pass ] +crbug.com/591099 dom/legacy_dom_conformance/xhtml/level2/html/HTMLElement03.xhtml [ Crash Pass ] +crbug.com/591099 dom/legacy_dom_conformance/xhtml/level2/html/HTMLElement04.xhtml [ Crash Pass ] +crbug.com/591099 dom/legacy_dom_conformance/xhtml/level2/html/HTMLElement05.xhtml [ Crash Pass ] +crbug.com/591099 dom/legacy_dom_conformance/xhtml/level2/html/HTMLElement06.xhtml [ Crash Pass ] +crbug.com/591099 dom/legacy_dom_conformance/xhtml/level2/html/HTMLElement07.xhtml [ Crash Pass ] +crbug.com/591099 dom/legacy_dom_conformance/xhtml/level2/html/HTMLElement08.xhtml [ Crash Pass ] +crbug.com/591099 dom/legacy_dom_conformance/xhtml/level2/html/HTMLElement09.xhtml [ Crash Pass ] +crbug.com/591099 dom/legacy_dom_conformance/xhtml/level2/html/HTMLElement10.xhtml [ Crash Pass ] +crbug.com/591099 dom/legacy_dom_conformance/xhtml/level2/html/HTMLElement100.xhtml [ Crash Pass ] +crbug.com/591099 dom/legacy_dom_conformance/xhtml/level2/html/HTMLElement101.xhtml [ Crash Pass ] +crbug.com/591099 dom/legacy_dom_conformance/xhtml/level2/html/HTMLElement102.xhtml [ Crash Pass ] +crbug.com/591099 dom/legacy_dom_conformance/xhtml/level2/html/HTMLElement103.xhtml [ Crash Pass ] +crbug.com/591099 dom/legacy_dom_conformance/xhtml/level2/html/HTMLElement104.xhtml [ Crash Pass ] +crbug.com/591099 dom/legacy_dom_conformance/xhtml/level2/html/HTMLElement105.xhtml [ Crash Pass ] +crbug.com/591099 dom/legacy_dom_conformance/xhtml/level2/html/HTMLElement106.xhtml [ Crash Pass ] +crbug.com/591099 dom/legacy_dom_conformance/xhtml/level2/html/HTMLElement107.xhtml [ Crash Pass ] +crbug.com/591099 dom/legacy_dom_conformance/xhtml/level2/html/HTMLElement108.xhtml [ Crash Pass ] +crbug.com/591099 dom/legacy_dom_conformance/xhtml/level2/html/HTMLElement109.xhtml [ Crash Pass ] +crbug.com/591099 dom/legacy_dom_conformance/xhtml/level2/html/HTMLElement11.xhtml [ Crash Pass ] +crbug.com/591099 dom/legacy_dom_conformance/xhtml/level2/html/HTMLElement110.xhtml [ Crash Pass ] +crbug.com/591099 dom/legacy_dom_conformance/xhtml/level2/html/HTMLElement111.xhtml [ Crash Pass ] +crbug.com/591099 dom/legacy_dom_conformance/xhtml/level2/html/HTMLElement112.xhtml [ Crash Pass ] +crbug.com/591099 dom/legacy_dom_conformance/xhtml/level2/html/HTMLElement113.xhtml [ Crash Pass ] +crbug.com/591099 dom/legacy_dom_conformance/xhtml/level2/html/HTMLElement114.xhtml [ Crash Pass ] +crbug.com/591099 dom/legacy_dom_conformance/xhtml/level2/html/HTMLElement115.xhtml [ Crash Pass ] +crbug.com/591099 dom/legacy_dom_conformance/xhtml/level2/html/HTMLElement116.xhtml [ Crash Pass ] +crbug.com/591099 dom/legacy_dom_conformance/xhtml/level2/html/HTMLElement117.xhtml [ Crash Pass ] +crbug.com/591099 dom/legacy_dom_conformance/xhtml/level2/html/HTMLElement118.xhtml [ Crash Pass ] +crbug.com/591099 dom/legacy_dom_conformance/xhtml/level2/html/HTMLElement119.xhtml [ Crash Pass ] +crbug.com/591099 dom/legacy_dom_conformance/xhtml/level2/html/HTMLElement12.xhtml [ Crash Pass ] +crbug.com/591099 dom/legacy_dom_conformance/xhtml/level2/html/HTMLElement120.xhtml [ Crash Pass ] +crbug.com/591099 dom/legacy_dom_conformance/xhtml/level2/html/HTMLElement121.xhtml [ Crash Pass ] +crbug.com/591099 dom/legacy_dom_conformance/xhtml/level2/html/HTMLElement122.xhtml [ Crash Pass ] +crbug.com/591099 dom/legacy_dom_conformance/xhtml/level2/html/HTMLElement123.xhtml [ Crash Pass ] +crbug.com/591099 dom/legacy_dom_conformance/xhtml/level2/html/HTMLElement124.xhtml [ Crash Pass ] +crbug.com/591099 dom/legacy_dom_conformance/xhtml/level2/html/HTMLElement125.xhtml [ Crash Pass ] +crbug.com/591099 dom/legacy_dom_conformance/xhtml/level2/html/HTMLElement126.xhtml [ Crash Pass ] +crbug.com/591099 dom/legacy_dom_conformance/xhtml/level2/html/HTMLElement127.xhtml [ Crash Pass ] +crbug.com/591099 dom/legacy_dom_conformance/xhtml/level2/html/HTMLElement128.xhtml [ Crash Pass ] +crbug.com/591099 dom/legacy_dom_conformance/xhtml/level2/html/HTMLElement129.xhtml [ Crash Pass ] +crbug.com/591099 dom/legacy_dom_conformance/xhtml/level2/html/HTMLElement13.xhtml [ Crash Pass ] +crbug.com/591099 dom/legacy_dom_conformance/xhtml/level2/html/HTMLElement130.xhtml [ Crash Pass ] +crbug.com/591099 dom/legacy_dom_conformance/xhtml/level2/html/HTMLElement131.xhtml [ Crash Pass ] +crbug.com/591099 dom/legacy_dom_conformance/xhtml/level2/html/HTMLElement132.xhtml [ Crash Pass ] +crbug.com/591099 dom/legacy_dom_conformance/xhtml/level2/html/HTMLElement133.xhtml [ Crash Pass ] +crbug.com/591099 dom/legacy_dom_conformance/xhtml/level2/html/HTMLElement134.xhtml [ Crash Pass ] +crbug.com/591099 dom/legacy_dom_conformance/xhtml/level2/html/HTMLElement135.xhtml [ Crash Pass ] +crbug.com/591099 dom/legacy_dom_conformance/xhtml/level2/html/HTMLElement136.xhtml [ Crash Pass ] +crbug.com/591099 dom/legacy_dom_conformance/xhtml/level2/html/HTMLElement137.xhtml [ Crash Pass ] +crbug.com/591099 dom/legacy_dom_conformance/xhtml/level2/html/HTMLElement138.xhtml [ Crash Pass ] +crbug.com/591099 dom/legacy_dom_conformance/xhtml/level2/html/HTMLElement139.xhtml [ Crash Pass ] +crbug.com/591099 dom/legacy_dom_conformance/xhtml/level2/html/HTMLElement14.xhtml [ Crash Pass ] +crbug.com/591099 dom/legacy_dom_conformance/xhtml/level2/html/HTMLElement140.xhtml [ Crash Pass ] +crbug.com/591099 dom/legacy_dom_conformance/xhtml/level2/html/HTMLElement141.xhtml [ Crash Pass ] +crbug.com/591099 dom/legacy_dom_conformance/xhtml/level2/html/HTMLElement142.xhtml [ Crash Pass ] +crbug.com/591099 dom/legacy_dom_conformance/xhtml/level2/html/HTMLElement143.xhtml [ Crash Pass ] +crbug.com/591099 dom/legacy_dom_conformance/xhtml/level2/html/HTMLElement144.xhtml [ Crash Pass ] +crbug.com/591099 dom/legacy_dom_conformance/xhtml/level2/html/HTMLElement145.xhtml [ Crash Pass ] +crbug.com/591099 dom/legacy_dom_conformance/xhtml/level2/html/HTMLElement15.xhtml [ Crash Pass ] +crbug.com/591099 dom/legacy_dom_conformance/xhtml/level2/html/HTMLElement16.xhtml [ Crash Pass ] +crbug.com/591099 dom/legacy_dom_conformance/xhtml/level2/html/HTMLElement17.xhtml [ Crash Pass ] +crbug.com/591099 dom/legacy_dom_conformance/xhtml/level2/html/HTMLElement18.xhtml [ Crash Pass ] +crbug.com/591099 dom/legacy_dom_conformance/xhtml/level2/html/HTMLElement19.xhtml [ Crash Pass ] +crbug.com/591099 dom/legacy_dom_conformance/xhtml/level2/html/HTMLElement20.xhtml [ Crash Pass ] +crbug.com/591099 dom/legacy_dom_conformance/xhtml/level2/html/HTMLElement21.xhtml [ Crash Pass ] +crbug.com/591099 dom/legacy_dom_conformance/xhtml/level2/html/HTMLElement22.xhtml [ Crash Pass ] +crbug.com/591099 dom/legacy_dom_conformance/xhtml/level2/html/HTMLElement23.xhtml [ Crash Pass ] +crbug.com/591099 dom/legacy_dom_conformance/xhtml/level2/html/HTMLElement24.xhtml [ Crash Pass ] +crbug.com/591099 dom/legacy_dom_conformance/xhtml/level2/html/HTMLElement25.xhtml [ Crash Pass ] +crbug.com/591099 dom/legacy_dom_conformance/xhtml/level2/html/HTMLElement26.xhtml [ Crash Pass ] +crbug.com/591099 dom/legacy_dom_conformance/xhtml/level2/html/HTMLElement27.xhtml [ Crash Pass ] +crbug.com/591099 dom/legacy_dom_conformance/xhtml/level2/html/HTMLElement28.xhtml [ Crash Pass ] +crbug.com/591099 dom/legacy_dom_conformance/xhtml/level2/html/HTMLElement29.xhtml [ Crash Pass ] +crbug.com/591099 dom/legacy_dom_conformance/xhtml/level2/html/HTMLElement30.xhtml [ Crash Pass ] +crbug.com/591099 dom/legacy_dom_conformance/xhtml/level2/html/HTMLElement31.xhtml [ Crash Pass ] +crbug.com/591099 dom/legacy_dom_conformance/xhtml/level2/html/HTMLElement32.xhtml [ Crash Pass ] +crbug.com/591099 dom/legacy_dom_conformance/xhtml/level2/html/HTMLElement33.xhtml [ Crash Pass ] +crbug.com/591099 dom/legacy_dom_conformance/xhtml/level2/html/HTMLElement34.xhtml [ Crash Pass ] +crbug.com/591099 dom/legacy_dom_conformance/xhtml/level2/html/HTMLElement35.xhtml [ Crash Pass ] +crbug.com/591099 dom/legacy_dom_conformance/xhtml/level2/html/HTMLElement36.xhtml [ Crash Pass ] +crbug.com/591099 dom/legacy_dom_conformance/xhtml/level2/html/HTMLElement37.xhtml [ Crash Pass ] +crbug.com/591099 dom/legacy_dom_conformance/xhtml/level2/html/HTMLElement38.xhtml [ Crash Pass ] +crbug.com/591099 dom/legacy_dom_conformance/xhtml/level2/html/HTMLElement39.xhtml [ Crash Pass ] +crbug.com/591099 dom/legacy_dom_conformance/xhtml/level2/html/HTMLElement40.xhtml [ Crash Pass ] +crbug.com/591099 dom/legacy_dom_conformance/xhtml/level2/html/HTMLElement41.xhtml [ Crash Pass ] +crbug.com/591099 dom/legacy_dom_conformance/xhtml/level2/html/HTMLElement42.xhtml [ Crash Pass ] +crbug.com/591099 dom/legacy_dom_conformance/xhtml/level2/html/HTMLElement43.xhtml [ Crash Pass ] +crbug.com/591099 dom/legacy_dom_conformance/xhtml/level2/html/HTMLElement44.xhtml [ Crash Pass ] +crbug.com/591099 dom/legacy_dom_conformance/xhtml/level2/html/HTMLElement45.xhtml [ Crash Pass ] +crbug.com/591099 dom/legacy_dom_conformance/xhtml/level2/html/HTMLElement46.xhtml [ Crash Pass ] +crbug.com/591099 dom/legacy_dom_conformance/xhtml/level2/html/HTMLElement47.xhtml [ Crash Pass ] +crbug.com/591099 dom/legacy_dom_conformance/xhtml/level2/html/HTMLElement48.xhtml [ Crash Pass ] +crbug.com/591099 dom/legacy_dom_conformance/xhtml/level2/html/HTMLElement49.xhtml [ Crash Pass ] +crbug.com/591099 dom/legacy_dom_conformance/xhtml/level2/html/HTMLElement50.xhtml [ Crash Pass ] +crbug.com/591099 dom/legacy_dom_conformance/xhtml/level2/html/HTMLElement51.xhtml [ Crash Pass ] +crbug.com/591099 dom/legacy_dom_conformance/xhtml/level2/html/HTMLElement52.xhtml [ Crash Pass ] +crbug.com/591099 dom/legacy_dom_conformance/xhtml/level2/html/HTMLElement53.xhtml [ Crash Pass ] +crbug.com/591099 dom/legacy_dom_conformance/xhtml/level2/html/HTMLElement54.xhtml [ Crash Pass ] +crbug.com/591099 dom/legacy_dom_conformance/xhtml/level2/html/HTMLElement55.xhtml [ Crash Pass ] +crbug.com/591099 dom/legacy_dom_conformance/xhtml/level2/html/HTMLElement56.xhtml [ Crash Pass ] +crbug.com/591099 dom/legacy_dom_conformance/xhtml/level2/html/HTMLElement57.xhtml [ Crash Pass ] +crbug.com/591099 dom/legacy_dom_conformance/xhtml/level2/html/HTMLElement58.xhtml [ Crash Pass ] +crbug.com/591099 dom/legacy_dom_conformance/xhtml/level2/html/HTMLElement59.xhtml [ Crash Pass ] +crbug.com/591099 dom/legacy_dom_conformance/xhtml/level2/html/HTMLElement60.xhtml [ Crash Pass ] +crbug.com/591099 dom/legacy_dom_conformance/xhtml/level2/html/HTMLElement61.xhtml [ Crash Pass ] +crbug.com/591099 dom/legacy_dom_conformance/xhtml/level2/html/HTMLElement62.xhtml [ Crash Pass ] +crbug.com/591099 dom/legacy_dom_conformance/xhtml/level2/html/HTMLElement63.xhtml [ Crash Pass ] +crbug.com/591099 dom/legacy_dom_conformance/xhtml/level2/html/HTMLElement64.xhtml [ Crash Pass ] +crbug.com/591099 dom/legacy_dom_conformance/xhtml/level2/html/HTMLElement65.xhtml [ Crash Pass ] +crbug.com/591099 dom/legacy_dom_conformance/xhtml/level2/html/HTMLElement66.xhtml [ Crash Pass ] +crbug.com/591099 dom/legacy_dom_conformance/xhtml/level2/html/HTMLElement67.xhtml [ Crash Pass ] +crbug.com/591099 dom/legacy_dom_conformance/xhtml/level2/html/HTMLElement68.xhtml [ Crash Pass ] +crbug.com/591099 dom/legacy_dom_conformance/xhtml/level2/html/HTMLElement69.xhtml [ Crash Pass ] +crbug.com/591099 dom/legacy_dom_conformance/xhtml/level2/html/HTMLElement70.xhtml [ Crash Pass ] +crbug.com/591099 dom/legacy_dom_conformance/xhtml/level2/html/HTMLElement71.xhtml [ Crash Pass ] +crbug.com/591099 dom/legacy_dom_conformance/xhtml/level2/html/HTMLElement72.xhtml [ Crash Pass ] +crbug.com/591099 dom/legacy_dom_conformance/xhtml/level2/html/HTMLElement73.xhtml [ Crash Pass ] +crbug.com/591099 dom/legacy_dom_conformance/xhtml/level2/html/HTMLElement74.xhtml [ Crash Pass ] +crbug.com/591099 dom/legacy_dom_conformance/xhtml/level2/html/HTMLElement75.xhtml [ Crash Pass ] +crbug.com/591099 dom/legacy_dom_conformance/xhtml/level2/html/HTMLElement76.xhtml [ Crash Pass ] +crbug.com/591099 dom/legacy_dom_conformance/xhtml/level2/html/HTMLElement77.xhtml [ Crash Pass ] +crbug.com/591099 dom/legacy_dom_conformance/xhtml/level2/html/HTMLElement78.xhtml [ Crash Pass ] +crbug.com/591099 dom/legacy_dom_conformance/xhtml/level2/html/HTMLElement79.xhtml [ Crash Pass ] +crbug.com/591099 dom/legacy_dom_conformance/xhtml/level2/html/HTMLElement80.xhtml [ Crash Pass ] +crbug.com/591099 dom/legacy_dom_conformance/xhtml/level2/html/HTMLElement81.xhtml [ Crash Pass ] +crbug.com/591099 dom/legacy_dom_conformance/xhtml/level2/html/HTMLElement82.xhtml [ Crash Pass ] +crbug.com/591099 dom/legacy_dom_conformance/xhtml/level2/html/HTMLElement83.xhtml [ Crash Pass ] +crbug.com/591099 dom/legacy_dom_conformance/xhtml/level2/html/HTMLElement84.xhtml [ Crash Pass ] +crbug.com/591099 dom/legacy_dom_conformance/xhtml/level2/html/HTMLElement85.xhtml [ Crash Pass ] +crbug.com/591099 dom/legacy_dom_conformance/xhtml/level2/html/HTMLElement86.xhtml [ Crash Pass ] +crbug.com/591099 dom/legacy_dom_conformance/xhtml/level2/html/HTMLElement87.xhtml [ Crash Pass ] +crbug.com/591099 dom/legacy_dom_conformance/xhtml/level2/html/HTMLElement88.xhtml [ Crash Pass ] +crbug.com/591099 dom/legacy_dom_conformance/xhtml/level2/html/HTMLElement89.xhtml [ Crash Pass ] +crbug.com/591099 dom/legacy_dom_conformance/xhtml/level2/html/HTMLElement90.xhtml [ Crash Pass ] +crbug.com/591099 dom/legacy_dom_conformance/xhtml/level2/html/HTMLElement91.xhtml [ Crash Pass ] +crbug.com/591099 dom/legacy_dom_conformance/xhtml/level2/html/HTMLElement92.xhtml [ Crash Pass ] +crbug.com/591099 dom/legacy_dom_conformance/xhtml/level2/html/HTMLElement93.xhtml [ Crash Pass ] +crbug.com/591099 dom/legacy_dom_conformance/xhtml/level2/html/HTMLElement94.xhtml [ Crash Pass ] +crbug.com/591099 dom/legacy_dom_conformance/xhtml/level2/html/HTMLElement95.xhtml [ Crash Pass ] +crbug.com/591099 dom/legacy_dom_conformance/xhtml/level2/html/HTMLElement96.xhtml [ Crash Pass ] +crbug.com/591099 dom/legacy_dom_conformance/xhtml/level2/html/HTMLElement97.xhtml [ Crash Pass ] +crbug.com/591099 dom/legacy_dom_conformance/xhtml/level2/html/HTMLElement98.xhtml [ Crash Pass ] +crbug.com/591099 dom/legacy_dom_conformance/xhtml/level2/html/HTMLElement99.xhtml [ Crash Pass ] crbug.com/591099 dom/legacy_dom_conformance/xhtml/level2/html/HTMLIFrameElement01.xhtml [ Crash Pass ] crbug.com/591099 dom/legacy_dom_conformance/xhtml/level2/html/HTMLIFrameElement02.xhtml [ Crash Pass ] crbug.com/591099 dom/legacy_dom_conformance/xhtml/level2/html/HTMLIFrameElement03.xhtml [ Crash Pass ] @@ -3109,57 +3109,57 @@ crbug.com/591099 dom/legacy_dom_conformance/xhtml/level2/html/HTMLIFrameElement08.xhtml [ Crash Pass ] crbug.com/591099 dom/legacy_dom_conformance/xhtml/level2/html/HTMLIFrameElement09.xhtml [ Crash Pass ] crbug.com/591099 dom/legacy_dom_conformance/xhtml/level2/html/HTMLIFrameElement10.xhtml [ Crash Pass ] -crbug.com/591099 dom/legacy_dom_conformance/xhtml/level2/html/HTMLIFrameElement11.xhtml [ Crash ] +crbug.com/591099 dom/legacy_dom_conformance/xhtml/level2/html/HTMLIFrameElement11.xhtml [ Crash Pass ] crbug.com/591099 dom/legacy_dom_conformance/xhtml/level2/html/HTMLImageElement03.xhtml [ Crash Pass ] crbug.com/591099 dom/legacy_dom_conformance/xhtml/level2/html/HTMLImageElement04.xhtml [ Crash Pass ] -crbug.com/591099 dom/legacy_dom_conformance/xhtml/level2/html/HTMLImageElement05.xhtml [ Crash ] +crbug.com/591099 dom/legacy_dom_conformance/xhtml/level2/html/HTMLImageElement05.xhtml [ Crash Pass ] crbug.com/591099 dom/legacy_dom_conformance/xhtml/level2/html/HTMLImageElement07.xhtml [ Crash Pass ] crbug.com/591099 dom/legacy_dom_conformance/xhtml/level2/html/HTMLImageElement09.xhtml [ Crash Pass ] -crbug.com/591099 dom/legacy_dom_conformance/xhtml/level2/html/HTMLImageElement12.xhtml [ Crash ] -crbug.com/591099 dom/legacy_dom_conformance/xhtml/level2/html/HTMLObjectElement01.xhtml [ Crash ] -crbug.com/591099 dom/legacy_dom_conformance/xhtml/level2/html/HTMLObjectElement02.xhtml [ Crash ] -crbug.com/591099 dom/legacy_dom_conformance/xhtml/level2/html/HTMLObjectElement03.xhtml [ Crash ] -crbug.com/591099 dom/legacy_dom_conformance/xhtml/level2/html/HTMLObjectElement04.xhtml [ Crash ] -crbug.com/591099 dom/legacy_dom_conformance/xhtml/level2/html/HTMLObjectElement05.xhtml [ Crash ] -crbug.com/591099 dom/legacy_dom_conformance/xhtml/level2/html/HTMLObjectElement06.xhtml [ Crash ] -crbug.com/591099 dom/legacy_dom_conformance/xhtml/level2/html/HTMLObjectElement07.xhtml [ Crash ] -crbug.com/591099 dom/legacy_dom_conformance/xhtml/level2/html/HTMLObjectElement08.xhtml [ Crash ] -crbug.com/591099 dom/legacy_dom_conformance/xhtml/level2/html/HTMLObjectElement09.xhtml [ Crash ] -crbug.com/591099 dom/legacy_dom_conformance/xhtml/level2/html/HTMLObjectElement10.xhtml [ Crash ] -crbug.com/591099 dom/legacy_dom_conformance/xhtml/level2/html/HTMLObjectElement11.xhtml [ Crash ] -crbug.com/591099 dom/legacy_dom_conformance/xhtml/level2/html/HTMLObjectElement12.xhtml [ Crash ] -crbug.com/591099 dom/legacy_dom_conformance/xhtml/level2/html/HTMLObjectElement13.xhtml [ Crash ] -crbug.com/591099 dom/legacy_dom_conformance/xhtml/level2/html/HTMLObjectElement14.xhtml [ Crash ] -crbug.com/591099 dom/legacy_dom_conformance/xhtml/level2/html/HTMLObjectElement15.xhtml [ Crash ] -crbug.com/591099 dom/legacy_dom_conformance/xhtml/level2/html/HTMLObjectElement16.xhtml [ Crash ] -crbug.com/591099 dom/legacy_dom_conformance/xhtml/level2/html/HTMLObjectElement17.xhtml [ Crash ] -crbug.com/591099 dom/legacy_dom_conformance/xhtml/level2/html/HTMLObjectElement18.xhtml [ Crash ] -crbug.com/591099 dom/legacy_dom_conformance/xhtml/level2/html/HTMLObjectElement19.xhtml [ Crash ] -crbug.com/591099 dom/legacy_dom_conformance/xhtml/level2/html/HTMLObjectElement20.xhtml [ Crash ] -crbug.com/591099 dom/legacy_dom_conformance/xhtml/level2/html/HTMLParamElement01.xhtml [ Crash ] -crbug.com/591099 dom/legacy_dom_conformance/xhtml/level2/html/HTMLParamElement02.xhtml [ Crash ] -crbug.com/591099 dom/legacy_dom_conformance/xhtml/level2/html/HTMLParamElement03.xhtml [ Crash ] -crbug.com/591099 dom/legacy_dom_conformance/xhtml/level2/html/HTMLParamElement04.xhtml [ Crash ] -crbug.com/591099 dom/legacy_dom_conformance/xhtml/level2/html/HTMLSelectElement14.xhtml [ Crash ] -crbug.com/591099 dom/legacy_dom_conformance/xhtml/level2/html/HTMLTextAreaElement14.xhtml [ Crash ] -crbug.com/591099 dom/legacy_dom_conformance/xhtml/level2/html/HTMLTextAreaElement15.xhtml [ Crash ] -crbug.com/591099 dom/legacy_dom_conformance/xhtml/level2/html/object01.xhtml [ Crash ] -crbug.com/591099 dom/legacy_dom_conformance/xhtml/level2/html/object02.xhtml [ Crash ] -crbug.com/591099 dom/legacy_dom_conformance/xhtml/level2/html/object03.xhtml [ Crash ] -crbug.com/591099 dom/legacy_dom_conformance/xhtml/level2/html/object04.xhtml [ Crash ] -crbug.com/591099 dom/legacy_dom_conformance/xhtml/level2/html/object05.xhtml [ Crash ] -crbug.com/591099 dom/legacy_dom_conformance/xhtml/level2/html/object07.xhtml [ Crash ] -crbug.com/591099 dom/legacy_dom_conformance/xhtml/level2/html/object08.xhtml [ Crash ] -crbug.com/591099 dom/legacy_dom_conformance/xhtml/level2/html/object09.xhtml [ Crash ] -crbug.com/591099 dom/legacy_dom_conformance/xhtml/level2/html/object10.xhtml [ Crash ] -crbug.com/591099 dom/legacy_dom_conformance/xhtml/level2/html/object11.xhtml [ Crash ] -crbug.com/591099 dom/legacy_dom_conformance/xhtml/level2/html/object12.xhtml [ Crash ] -crbug.com/591099 dom/legacy_dom_conformance/xhtml/level2/html/object13.xhtml [ Crash ] -crbug.com/591099 dom/legacy_dom_conformance/xhtml/level2/html/object14.xhtml [ Crash ] -crbug.com/591099 dom/legacy_dom_conformance/xhtml/level2/html/object15.xhtml [ Crash ] +crbug.com/591099 dom/legacy_dom_conformance/xhtml/level2/html/HTMLImageElement12.xhtml [ Crash Pass ] +crbug.com/591099 dom/legacy_dom_conformance/xhtml/level2/html/HTMLObjectElement01.xhtml [ Crash Pass ] +crbug.com/591099 dom/legacy_dom_conformance/xhtml/level2/html/HTMLObjectElement02.xhtml [ Crash Pass ] +crbug.com/591099 dom/legacy_dom_conformance/xhtml/level2/html/HTMLObjectElement03.xhtml [ Crash Pass ] +crbug.com/591099 dom/legacy_dom_conformance/xhtml/level2/html/HTMLObjectElement04.xhtml [ Crash Pass ] +crbug.com/591099 dom/legacy_dom_conformance/xhtml/level2/html/HTMLObjectElement05.xhtml [ Crash Pass ] +crbug.com/591099 dom/legacy_dom_conformance/xhtml/level2/html/HTMLObjectElement06.xhtml [ Crash Pass ] +crbug.com/591099 dom/legacy_dom_conformance/xhtml/level2/html/HTMLObjectElement07.xhtml [ Crash Pass ] +crbug.com/591099 dom/legacy_dom_conformance/xhtml/level2/html/HTMLObjectElement08.xhtml [ Crash Pass ] +crbug.com/591099 dom/legacy_dom_conformance/xhtml/level2/html/HTMLObjectElement09.xhtml [ Crash Pass ] +crbug.com/591099 dom/legacy_dom_conformance/xhtml/level2/html/HTMLObjectElement10.xhtml [ Crash Pass ] +crbug.com/591099 dom/legacy_dom_conformance/xhtml/level2/html/HTMLObjectElement11.xhtml [ Crash Pass ] +crbug.com/591099 dom/legacy_dom_conformance/xhtml/level2/html/HTMLObjectElement12.xhtml [ Crash Pass ] +crbug.com/591099 dom/legacy_dom_conformance/xhtml/level2/html/HTMLObjectElement13.xhtml [ Crash Pass ] +crbug.com/591099 dom/legacy_dom_conformance/xhtml/level2/html/HTMLObjectElement14.xhtml [ Crash Pass ] +crbug.com/591099 dom/legacy_dom_conformance/xhtml/level2/html/HTMLObjectElement15.xhtml [ Crash Pass ] +crbug.com/591099 dom/legacy_dom_conformance/xhtml/level2/html/HTMLObjectElement16.xhtml [ Crash Pass ] +crbug.com/591099 dom/legacy_dom_conformance/xhtml/level2/html/HTMLObjectElement17.xhtml [ Crash Pass ] +crbug.com/591099 dom/legacy_dom_conformance/xhtml/level2/html/HTMLObjectElement18.xhtml [ Crash Pass ] +crbug.com/591099 dom/legacy_dom_conformance/xhtml/level2/html/HTMLObjectElement19.xhtml [ Crash Pass ] +crbug.com/591099 dom/legacy_dom_conformance/xhtml/level2/html/HTMLObjectElement20.xhtml [ Crash Pass ] +crbug.com/591099 dom/legacy_dom_conformance/xhtml/level2/html/HTMLParamElement01.xhtml [ Crash Pass ] +crbug.com/591099 dom/legacy_dom_conformance/xhtml/level2/html/HTMLParamElement02.xhtml [ Crash Pass ] +crbug.com/591099 dom/legacy_dom_conformance/xhtml/level2/html/HTMLParamElement03.xhtml [ Crash Pass ] +crbug.com/591099 dom/legacy_dom_conformance/xhtml/level2/html/HTMLParamElement04.xhtml [ Crash Pass ] +crbug.com/591099 dom/legacy_dom_conformance/xhtml/level2/html/HTMLSelectElement14.xhtml [ Crash Pass ] +crbug.com/591099 dom/legacy_dom_conformance/xhtml/level2/html/HTMLTextAreaElement14.xhtml [ Crash Pass ] +crbug.com/591099 dom/legacy_dom_conformance/xhtml/level2/html/HTMLTextAreaElement15.xhtml [ Crash Pass ] +crbug.com/591099 dom/legacy_dom_conformance/xhtml/level2/html/object01.xhtml [ Crash Pass ] +crbug.com/591099 dom/legacy_dom_conformance/xhtml/level2/html/object02.xhtml [ Crash Pass ] +crbug.com/591099 dom/legacy_dom_conformance/xhtml/level2/html/object03.xhtml [ Crash Pass ] +crbug.com/591099 dom/legacy_dom_conformance/xhtml/level2/html/object04.xhtml [ Crash Pass ] +crbug.com/591099 dom/legacy_dom_conformance/xhtml/level2/html/object05.xhtml [ Crash Pass ] +crbug.com/591099 dom/legacy_dom_conformance/xhtml/level2/html/object07.xhtml [ Crash Pass ] +crbug.com/591099 dom/legacy_dom_conformance/xhtml/level2/html/object08.xhtml [ Crash Pass ] +crbug.com/591099 dom/legacy_dom_conformance/xhtml/level2/html/object09.xhtml [ Crash Pass ] +crbug.com/591099 dom/legacy_dom_conformance/xhtml/level2/html/object10.xhtml [ Crash Pass ] +crbug.com/591099 dom/legacy_dom_conformance/xhtml/level2/html/object11.xhtml [ Crash Pass ] +crbug.com/591099 dom/legacy_dom_conformance/xhtml/level2/html/object12.xhtml [ Crash Pass ] +crbug.com/591099 dom/legacy_dom_conformance/xhtml/level2/html/object13.xhtml [ Crash Pass ] +crbug.com/591099 dom/legacy_dom_conformance/xhtml/level2/html/object14.xhtml [ Crash Pass ] +crbug.com/591099 dom/legacy_dom_conformance/xhtml/level2/html/object15.xhtml [ Crash Pass ] crbug.com/591099 editing/active-suggestion-marker-basic.html [ Failure ] crbug.com/591099 editing/active-suggestion-marker-split.html [ Failure ] -crbug.com/591099 editing/assert_selection.html [ Crash ] +crbug.com/591099 editing/assert_selection.html [ Crash Failure ] crbug.com/591099 editing/caret/caret-color-001.html [ Failure ] crbug.com/591099 editing/caret/caret-color-002.html [ Failure ] crbug.com/591099 editing/caret/caret-color-003.html [ Failure ] @@ -3178,7 +3178,7 @@ crbug.com/591099 editing/caret/selection-with-caret-type-progress.html [ Failure ] crbug.com/591099 editing/composition-marker-basic.html [ Failure ] crbug.com/591099 editing/composition-marker-split.html [ Failure ] -crbug.com/591099 editing/deleting/4866671.html [ Crash ] +crbug.com/591099 editing/deleting/4866671.html [ Crash Failure ] crbug.com/591099 editing/deleting/4875189.html [ Crash Failure ] crbug.com/591099 editing/deleting/4916235-1.html [ Failure ] crbug.com/591099 editing/deleting/4922367.html [ Failure ] @@ -3195,24 +3195,24 @@ crbug.com/591099 editing/deleting/5433862-2.html [ Failure ] crbug.com/591099 editing/deleting/5483370.html [ Failure ] crbug.com/591099 editing/deleting/5729680.html [ Failure ] -crbug.com/591099 editing/deleting/delete-3608430-fix.html [ Crash ] +crbug.com/591099 editing/deleting/delete-3608430-fix.html [ Crash Failure ] crbug.com/591099 editing/deleting/delete-3865854-fix.html [ Failure ] -crbug.com/591099 editing/deleting/delete-all-text-in-text-field-assertion.html [ Crash ] +crbug.com/591099 editing/deleting/delete-all-text-in-text-field-assertion.html [ Crash Pass ] crbug.com/591099 editing/deleting/delete-and-cleanup.html [ Failure ] crbug.com/591099 editing/deleting/delete-at-paragraph-boundaries-011.html [ Failure ] crbug.com/591099 editing/deleting/delete-block-merge-contents-025.html [ Failure ] crbug.com/591099 editing/deleting/delete-block-table.html [ Crash Failure ] crbug.com/591099 editing/deleting/delete-blockquote-large-offsets.html [ Failure ] crbug.com/591099 editing/deleting/delete-br-013.html [ Failure ] -crbug.com/591099 editing/deleting/delete-br-after-image.html [ Crash ] +crbug.com/591099 editing/deleting/delete-br-after-image.html [ Crash Pass ] crbug.com/591099 editing/deleting/delete-button-background-image-none.html [ Failure ] -crbug.com/591099 editing/deleting/delete-character-002.html [ Crash ] +crbug.com/591099 editing/deleting/delete-character-002.html [ Crash Pass ] crbug.com/591099 editing/deleting/delete-contiguous-ws-001.html [ Crash Failure ] crbug.com/591099 editing/deleting/delete-empty-table.html [ Failure ] -crbug.com/591099 editing/deleting/delete-inline-br.html [ Crash ] +crbug.com/591099 editing/deleting/delete-inline-br.html [ Crash Pass ] crbug.com/591099 editing/deleting/delete-last-char-in-table.html [ Crash Failure ] crbug.com/591099 editing/deleting/delete-leading-ws-001.html [ Failure ] -crbug.com/591099 editing/deleting/delete-ligature-001.html [ Crash ] +crbug.com/591099 editing/deleting/delete-ligature-001.html [ Crash Pass ] crbug.com/591099 editing/deleting/delete-line-001.html [ Failure ] crbug.com/591099 editing/deleting/delete-line-002.html [ Failure ] crbug.com/591099 editing/deleting/delete-line-004.html [ Failure ] @@ -3230,15 +3230,15 @@ crbug.com/591099 editing/deleting/delete-node-after-DOMNodeRemoved.html [ Failure ] crbug.com/591099 editing/deleting/delete-selection-001.html [ Failure ] crbug.com/591099 editing/deleting/delete-surrogatepair.html [ Failure ] -crbug.com/591099 editing/deleting/delete-svg-001.html [ Crash ] +crbug.com/591099 editing/deleting/delete-svg-001.html [ Crash Pass ] crbug.com/591099 editing/deleting/delete_after_span_ws.html [ Failure ] -crbug.com/591099 editing/deleting/delete_block_merge_contents_1.html [ Crash ] -crbug.com/591099 editing/deleting/delete_block_merge_whitespace.html [ Crash ] -crbug.com/591099 editing/deleting/delete_image.html [ Crash ] +crbug.com/591099 editing/deleting/delete_block_merge_contents_1.html [ Crash Failure ] +crbug.com/591099 editing/deleting/delete_block_merge_whitespace.html [ Crash Failure ] +crbug.com/591099 editing/deleting/delete_image.html [ Crash Pass ] crbug.com/591099 editing/deleting/delete_line_end_ws.html [ Failure ] crbug.com/591099 editing/deleting/delete_map_area.html [ Failure ] -crbug.com/591099 editing/deleting/delete_trailing_ws.html [ Crash ] -crbug.com/591099 editing/deleting/delete_ws_fixup.html [ Crash ] +crbug.com/591099 editing/deleting/delete_trailing_ws.html [ Crash Failure ] +crbug.com/591099 editing/deleting/delete_ws_fixup.html [ Crash Failure ] crbug.com/591099 editing/deleting/forward-delete-key.html [ Failure ] crbug.com/591099 editing/deleting/merge-at-end-of-document.html [ Failure ] crbug.com/591099 editing/deleting/merge-different-styles.html [ Failure ] @@ -3249,10 +3249,10 @@ crbug.com/591099 editing/deleting/merge-paragraph-into-blockquote.html [ Failure ] crbug.com/591099 editing/deleting/merge-paragraph-into-pre.html [ Failure ] crbug.com/591099 editing/deleting/merge-whitespace-pre.html [ Failure ] -crbug.com/591099 editing/deleting/merge_paragraph_into_h1.html [ Crash ] +crbug.com/591099 editing/deleting/merge_paragraph_into_h1.html [ Crash Failure ] crbug.com/591099 editing/deleting/move-nodes-001.html [ Failure ] crbug.com/591099 editing/deleting/non-smart-delete.html [ Failure ] -crbug.com/591099 editing/deleting/password-delete-contents.html [ Crash ] +crbug.com/591099 editing/deleting/password-delete-contents.html [ Crash Failure ] crbug.com/591099 editing/deleting/paste-with-transparent-background-color.html [ Failure ] crbug.com/591099 editing/deleting/removeNodeCommand-assert.html [ Failure ] crbug.com/591099 editing/deleting/table-cells.html [ Failure ] @@ -3275,8 +3275,8 @@ crbug.com/591099 editing/execCommand/4920742-2.html [ Crash Failure ] crbug.com/591099 editing/execCommand/4928635.html [ Crash Failure ] crbug.com/591099 editing/execCommand/4976800.html [ Failure ] -crbug.com/591099 editing/execCommand/5080333-1.html [ Crash ] -crbug.com/591099 editing/execCommand/5080333-2.html [ Crash ] +crbug.com/591099 editing/execCommand/5080333-1.html [ Crash Pass ] +crbug.com/591099 editing/execCommand/5080333-2.html [ Crash Pass ] crbug.com/591099 editing/execCommand/5119244.html [ Failure ] crbug.com/591099 editing/execCommand/5120591.html [ Failure ] crbug.com/591099 editing/execCommand/5136770.html [ Crash Failure ] @@ -3301,11 +3301,11 @@ crbug.com/591099 editing/execCommand/5700414-1.html [ Failure ] crbug.com/591099 editing/execCommand/5700414-2.html [ Failure ] crbug.com/591099 editing/execCommand/align-in-span.html [ Failure ] -crbug.com/591099 editing/execCommand/apply-inline-style-to-element-with-no-renderer-crash.html [ Crash ] -crbug.com/591099 editing/execCommand/apply-style-command-crash.html [ Crash ] -crbug.com/591099 editing/execCommand/apply-style-empty-paragraph-start-crash.html [ Crash ] +crbug.com/591099 editing/execCommand/apply-inline-style-to-element-with-no-renderer-crash.html [ Crash Pass ] +crbug.com/591099 editing/execCommand/apply-style-command-crash.html [ Crash Pass ] +crbug.com/591099 editing/execCommand/apply-style-empty-paragraph-start-crash.html [ Crash Pass ] crbug.com/591099 editing/execCommand/apply-style-text-decoration-crash.html [ Failure ] -crbug.com/591099 editing/execCommand/applyblockelement-visiblepositionforindex-crash.html [ Crash ] +crbug.com/591099 editing/execCommand/applyblockelement-visiblepositionforindex-crash.html [ Crash Pass ] crbug.com/591099 editing/execCommand/arguments-combinations.html [ Failure ] crbug.com/591099 editing/execCommand/backcolor-crash.html [ Crash Failure ] crbug.com/591099 editing/execCommand/boldSelection.html [ Failure ] @@ -3313,12 +3313,12 @@ crbug.com/591099 editing/execCommand/clipboard-access-with-userGesture.html [ Failure ] crbug.com/591099 editing/execCommand/clipboard-access.html [ Failure ] crbug.com/591099 editing/execCommand/convert-style-elements-to-spans.html [ Failure ] -crbug.com/591099 editing/execCommand/crash-line-break-after-outdent.html [ Crash ] -crbug.com/591099 editing/execCommand/crash-object-cloning.html [ Crash ] +crbug.com/591099 editing/execCommand/crash-line-break-after-outdent.html [ Crash Failure ] +crbug.com/591099 editing/execCommand/crash-object-cloning.html [ Crash Pass ] crbug.com/591099 editing/execCommand/default-paragraph-separator.html [ Failure ] crbug.com/591099 editing/execCommand/default-parameters.html [ Failure ] crbug.com/591099 editing/execCommand/delete-selection-has-style.html [ Failure ] -crbug.com/591099 editing/execCommand/editing-nontext-node-crash.xhtml [ Crash ] +crbug.com/591099 editing/execCommand/editing-nontext-node-crash.xhtml [ Crash Failure ] crbug.com/591099 editing/execCommand/empty-span-removal.html [ Failure ] crbug.com/591099 editing/execCommand/enabling-and-selection-2.html [ Failure Timeout ] crbug.com/591099 editing/execCommand/enabling-and-selection.html [ Failure ] @@ -3327,53 +3327,53 @@ crbug.com/591099 editing/execCommand/findString-diacriticals.html [ Failure ] crbug.com/591099 editing/execCommand/findString.html [ Failure ] crbug.com/591099 editing/execCommand/format-block-contenteditable-false.html [ Failure ] -crbug.com/591099 editing/execCommand/format-block-crash.html [ Crash ] +crbug.com/591099 editing/execCommand/format-block-crash.html [ Crash Failure ] crbug.com/591099 editing/execCommand/format-block-from-range-selection.html [ Failure ] -crbug.com/591099 editing/execCommand/format-block-multiple-paragraphs-in-pre.html [ Crash ] -crbug.com/591099 editing/execCommand/format-block-multiple-paragraphs.html [ Crash ] +crbug.com/591099 editing/execCommand/format-block-multiple-paragraphs-in-pre.html [ Crash Failure ] +crbug.com/591099 editing/execCommand/format-block-multiple-paragraphs.html [ Crash Failure ] crbug.com/591099 editing/execCommand/format-block-with-trailing-br.html [ Failure ] crbug.com/591099 editing/execCommand/format_block/no-visible-content.html [ Failure ] -crbug.com/591099 editing/execCommand/format_block/unrooted-selection-start-crash.html [ Crash ] +crbug.com/591099 editing/execCommand/format_block/unrooted-selection-start-crash.html [ Crash Pass ] crbug.com/591099 editing/execCommand/forward-delete-no-scroll.html [ Failure ] -crbug.com/591099 editing/execCommand/indent-crash-by-top-load-event.html [ Crash ] +crbug.com/591099 editing/execCommand/indent-crash-by-top-load-event.html [ Crash Pass ] crbug.com/591099 editing/execCommand/indent-div-inside-list.html [ Failure ] crbug.com/591099 editing/execCommand/indent-empty-root.html [ Failure ] crbug.com/591099 editing/execCommand/indent-empty-table-cell.html [ Failure ] -crbug.com/591099 editing/execCommand/indent-images-2.html [ Crash ] -crbug.com/591099 editing/execCommand/indent-images-3.html [ Crash ] -crbug.com/591099 editing/execCommand/indent-images.html [ Crash ] +crbug.com/591099 editing/execCommand/indent-images-2.html [ Crash Pass ] +crbug.com/591099 editing/execCommand/indent-images-3.html [ Crash Pass ] +crbug.com/591099 editing/execCommand/indent-images.html [ Crash Pass ] crbug.com/591099 editing/execCommand/indent-inline-box-crash.html [ Crash Pass ] crbug.com/591099 editing/execCommand/indent-nested-blockquotes-crash.html [ Crash Pass ] crbug.com/591099 editing/execCommand/indent-nested-blockquotes.html [ Failure ] crbug.com/591099 editing/execCommand/indent-nested-div.html [ Failure ] -crbug.com/591099 editing/execCommand/indent-paragraphs.html [ Crash ] +crbug.com/591099 editing/execCommand/indent-paragraphs.html [ Crash Pass ] crbug.com/591099 editing/execCommand/indent-partial-table.html [ Failure ] crbug.com/591099 editing/execCommand/indent-right-after-table.html [ Failure ] crbug.com/591099 editing/execCommand/indent-second-paragraph-in-blockquote.html [ Failure ] -crbug.com/591099 editing/execCommand/infinite-recursion-computeRectForRepaint.html [ Crash ] +crbug.com/591099 editing/execCommand/infinite-recursion-computeRectForRepaint.html [ Crash Failure ] crbug.com/591099 editing/execCommand/inline-style-after-indentoutdent.html [ Crash Failure ] -crbug.com/591099 editing/execCommand/insert-image-changing-visibility-crash.html [ Crash ] +crbug.com/591099 editing/execCommand/insert-image-changing-visibility-crash.html [ Crash Failure ] crbug.com/591099 editing/execCommand/insert-image-on-top-of-directional-text.html [ Failure ] -crbug.com/591099 editing/execCommand/insert-image-with-selecting-document.html [ Crash ] +crbug.com/591099 editing/execCommand/insert-image-with-selecting-document.html [ Crash Pass ] crbug.com/591099 editing/execCommand/insert-line-break-no-scroll.html [ Failure ] -crbug.com/591099 editing/execCommand/insert-list-br-with-child-crash.html [ Crash ] +crbug.com/591099 editing/execCommand/insert-list-br-with-child-crash.html [ Crash Failure ] crbug.com/591099 editing/execCommand/insert-list-empty-div.html [ Failure ] crbug.com/591099 editing/execCommand/insert-list-in-noneditable-list-parent.html [ Failure ] -crbug.com/591099 editing/execCommand/insert-list-with-progress-crash.html [ Crash ] +crbug.com/591099 editing/execCommand/insert-list-with-progress-crash.html [ Crash Pass ] crbug.com/591099 editing/execCommand/insert-lists-inside-another-list.html [ Crash Failure ] -crbug.com/591099 editing/execCommand/insert-ordered-list-crash.html [ Crash ] -crbug.com/591099 editing/execCommand/insert-ordered-list.html [ Crash ] -crbug.com/591099 editing/execCommand/insert-paragraph-into-table.html [ Crash ] +crbug.com/591099 editing/execCommand/insert-ordered-list-crash.html [ Crash Failure ] +crbug.com/591099 editing/execCommand/insert-ordered-list.html [ Crash Pass ] +crbug.com/591099 editing/execCommand/insert-paragraph-into-table.html [ Crash Pass ] crbug.com/591099 editing/execCommand/insert-remove-block-list-inside-presentational-inline.html [ Crash Failure ] crbug.com/591099 editing/execCommand/insert-text-not-inheriting-block-properties.html [ Failure ] -crbug.com/591099 editing/execCommand/insertHTML-aborted.html [ Crash ] +crbug.com/591099 editing/execCommand/insertHTML-aborted.html [ Crash Pass ] crbug.com/591099 editing/execCommand/insertHTML.html [ Failure ] crbug.com/591099 editing/execCommand/insertImage-src.html [ Failure ] crbug.com/591099 editing/execCommand/insertImage.html [ Failure ] -crbug.com/591099 editing/execCommand/inserting-ordered-list-crash.html [ Crash ] -crbug.com/591099 editing/execCommand/italic-crash-by-iframe-load.html [ Crash ] +crbug.com/591099 editing/execCommand/inserting-ordered-list-crash.html [ Crash Failure ] +crbug.com/591099 editing/execCommand/italic-crash-by-iframe-load.html [ Crash Pass ] crbug.com/591099 editing/execCommand/italicizeByCharacter.html [ Crash Failure ] -crbug.com/591099 editing/execCommand/justify-right-crash.html [ Crash ] +crbug.com/591099 editing/execCommand/justify-right-crash.html [ Crash Pass ] crbug.com/591099 editing/execCommand/justify.html [ Failure Timeout ] crbug.com/591099 editing/execCommand/merge-text-decoration-with-typing-style.html [ Failure ] crbug.com/591099 editing/execCommand/modifyForeColorByCharacter.html [ Crash Failure ] @@ -3381,42 +3381,42 @@ crbug.com/591099 editing/execCommand/move-selection-back-line-strict.html [ Failure ] crbug.com/591099 editing/execCommand/move-selection-back-line.html [ Failure ] crbug.com/591099 editing/execCommand/non-html-document.html [ Failure ] -crbug.com/591099 editing/execCommand/outdent-break-with-style.html [ Crash ] -crbug.com/591099 editing/execCommand/outdent-collapse-table-crash.html [ Crash ] +crbug.com/591099 editing/execCommand/outdent-break-with-style.html [ Crash Pass ] +crbug.com/591099 editing/execCommand/outdent-collapse-table-crash.html [ Crash Pass ] crbug.com/591099 editing/execCommand/outdent-inline-list.html [ Crash Failure ] crbug.com/591099 editing/execCommand/outdent-multiparagraph-list.html [ Crash Failure ] crbug.com/591099 editing/execCommand/outdent-regular-blockquote.html [ Crash Failure ] crbug.com/591099 editing/execCommand/outdent-selection.html [ Crash Failure ] crbug.com/591099 editing/execCommand/overtype-support.html [ Failure ] -crbug.com/591099 editing/execCommand/paste-1.html [ Crash ] -crbug.com/591099 editing/execCommand/paste-2.html [ Crash ] +crbug.com/591099 editing/execCommand/paste-1.html [ Crash Pass ] +crbug.com/591099 editing/execCommand/paste-2.html [ Crash Pass ] crbug.com/591099 editing/execCommand/query-command-state.html [ Timeout ] crbug.com/591099 editing/execCommand/query-command-value-background-color.html [ Failure ] crbug.com/591099 editing/execCommand/query-font-size-with-typing-style.html [ Failure ] -crbug.com/591099 editing/execCommand/query-format-block.html [ Crash ] +crbug.com/591099 editing/execCommand/query-format-block.html [ Crash Timeout ] crbug.com/591099 editing/execCommand/query-text-alignment.html [ Failure Timeout ] crbug.com/591099 editing/execCommand/query-text-decoration-with-typing-style.html [ Failure ] crbug.com/591099 editing/execCommand/queryCommandState-02.html [ Crash Failure ] -crbug.com/591099 editing/execCommand/queryCommandState-03.html [ Crash ] +crbug.com/591099 editing/execCommand/queryCommandState-03.html [ Crash Pass ] crbug.com/591099 editing/execCommand/queryCommandValue-unsupported-commands.html [ Failure ] crbug.com/591099 editing/execCommand/remove-format-background-color.html [ Failure ] -crbug.com/591099 editing/execCommand/remove-format-elements.html [ Crash ] -crbug.com/591099 editing/execCommand/remove-format-iframe-in-button.html [ Crash ] -crbug.com/591099 editing/execCommand/remove-format-image.html [ Crash ] +crbug.com/591099 editing/execCommand/remove-format-elements.html [ Crash Pass ] +crbug.com/591099 editing/execCommand/remove-format-iframe-in-button.html [ Crash Pass ] +crbug.com/591099 editing/execCommand/remove-format-image.html [ Crash Pass ] crbug.com/591099 editing/execCommand/remove-format-multiple-elements-mac.html [ Failure ] crbug.com/591099 editing/execCommand/remove-format-multiple-elements-win.html [ Failure Timeout ] -crbug.com/591099 editing/execCommand/remove-format-textdecoration-in-iframe.html [ Crash ] +crbug.com/591099 editing/execCommand/remove-format-textdecoration-in-iframe.html [ Crash Pass ] crbug.com/591099 editing/execCommand/remove-list-from-range-selection.html [ Crash Failure ] crbug.com/591099 editing/execCommand/remove_format_and_extract_contents.html [ Failure ] -crbug.com/591099 editing/execCommand/replace-crossing-mailblockquote-crash.html [ Crash ] -crbug.com/591099 editing/execCommand/replaceSelectorCommand-crash.html [ Crash ] -crbug.com/591099 editing/execCommand/selectAll-including-marquee-crash.html [ Crash ] +crbug.com/591099 editing/execCommand/replace-crossing-mailblockquote-crash.html [ Crash Pass ] +crbug.com/591099 editing/execCommand/replaceSelectorCommand-crash.html [ Crash Failure ] +crbug.com/591099 editing/execCommand/selectAll-including-marquee-crash.html [ Crash Pass ] crbug.com/591099 editing/execCommand/selection-after-insert-list.html [ Crash Failure ] crbug.com/591099 editing/execCommand/strikethrough-uses-strike-tag.html [ Failure ] crbug.com/591099 editing/execCommand/strikethroughSelection.html [ Crash Failure ] crbug.com/591099 editing/execCommand/style-with-css.html [ Failure ] -crbug.com/591099 editing/execCommand/switch-multiple-list-items-crash.html [ Crash ] -crbug.com/591099 editing/execCommand/toggle-compound-styles.html [ Crash ] +crbug.com/591099 editing/execCommand/switch-multiple-list-items-crash.html [ Crash Pass ] +crbug.com/591099 editing/execCommand/toggle-compound-styles.html [ Crash Timeout ] crbug.com/591099 editing/execCommand/toggle-link-mac.html [ Failure ] crbug.com/591099 editing/execCommand/toggle-link-win.html [ Failure ] crbug.com/591099 editing/execCommand/toggle-style-2.html [ Failure ] @@ -3425,20 +3425,20 @@ crbug.com/591099 editing/execCommand/toggle-text-decorations.html [ Failure ] crbug.com/591099 editing/execCommand/toggle-unlink-mac.html [ Failure ] crbug.com/591099 editing/execCommand/toggle-unlink-win.html [ Failure ] -crbug.com/591099 editing/execCommand/unlink.html [ Crash ] +crbug.com/591099 editing/execCommand/unlink.html [ Crash Pass ] crbug.com/591099 editing/execCommand/use-css.html [ Failure ] -crbug.com/591099 editing/execCommand/window-open-insert-list-crash.html [ Crash ] +crbug.com/591099 editing/execCommand/window-open-insert-list-crash.html [ Crash Failure ] crbug.com/591099 editing/input/caret-at-the-edge-of-contenteditable.html [ Failure ] crbug.com/591099 editing/input/caret-at-the-edge-of-input.html [ Crash Failure ] crbug.com/591099 editing/input/caret-read-only-after-editable.html [ Failure ] crbug.com/591099 editing/input/change-style-with-key-binding.html [ Failure ] -crbug.com/591099 editing/input/div-first-child-rule-input.html [ Crash ] -crbug.com/591099 editing/input/div-first-child-rule-textarea.html [ Crash ] -crbug.com/591099 editing/input/drag_in_unselectable.html [ Crash ] +crbug.com/591099 editing/input/div-first-child-rule-input.html [ Crash Failure ] +crbug.com/591099 editing/input/div-first-child-rule-textarea.html [ Crash Failure ] +crbug.com/591099 editing/input/drag_in_unselectable.html [ Crash Pass ] crbug.com/591099 editing/input/editable-container-with-word-wrap-normal.html [ Failure ] crbug.com/591099 editing/input/ime-composition-clearpreedit.html [ Crash Failure ] -crbug.com/591099 editing/input/insert-wrapping-space-in-textarea.html [ Crash ] -crbug.com/591099 editing/input/keyboard-ctrl-enter-no-newline.html [ Crash ] +crbug.com/591099 editing/input/insert-wrapping-space-in-textarea.html [ Crash Failure ] +crbug.com/591099 editing/input/keyboard-ctrl-enter-no-newline.html [ Crash Pass ] crbug.com/591099 editing/input/linux_ltr_composition_underline.html [ Crash Failure ] crbug.com/591099 editing/input/linux_rtl_composition_underline.html [ Crash Failure ] crbug.com/591099 editing/input/option-page-up-down.html [ Failure ] @@ -3447,10 +3447,10 @@ crbug.com/591099 editing/input/password-echo-passnode3.html [ Crash Failure ] crbug.com/591099 editing/input/password-echo-textnode.html [ Crash Failure ] crbug.com/591099 editing/input/paste-linebreak-into-initially-hidden-textarea.html [ Crash Failure ] -crbug.com/591099 editing/input/paste-text-ending-with-interchange-newline.html [ Crash ] +crbug.com/591099 editing/input/paste-text-ending-with-interchange-newline.html [ Crash Pass ] crbug.com/591099 editing/input/reveal-caret-of-multiline-contenteditable.html [ Failure ] crbug.com/591099 editing/input/reveal-caret-of-multiline-input.html [ Crash Failure ] -crbug.com/591099 editing/input/reveal-caret-of-transformed-input-scrollable-parent.html [ Crash ] +crbug.com/591099 editing/input/reveal-caret-of-transformed-input-scrollable-parent.html [ Crash Pass ] crbug.com/591099 editing/input/reveal-password.html [ Crash Failure ] crbug.com/591099 editing/input/scroll-viewport-page-up-down.html [ Failure ] crbug.com/591099 editing/input/search-field-crash-in-designmode.html [ Failure ] @@ -3458,8 +3458,8 @@ crbug.com/591099 editing/input/set-value-on-input-and-forward-delete.html [ Crash Failure ] crbug.com/591099 editing/input/set-value-on-input-and-type-input.html [ Crash Failure ] crbug.com/591099 editing/input/set-value-on-input-and-type-textarea.html [ Crash Failure ] -crbug.com/591099 editing/input/setting-input-value-cancel-ime-composition.html [ Crash ] -crbug.com/591099 editing/input/textcontrol-doubleclick-at-end.html [ Crash Failure ] +crbug.com/591099 editing/input/setting-input-value-cancel-ime-composition.html [ Crash Failure ] +crbug.com/591099 editing/input/textcontrol-doubleclick-at-end.html [ Crash Failure Pass ] crbug.com/591099 editing/inserting/4278698.html [ Failure ] crbug.com/591099 editing/inserting/4840662.html [ Failure ] crbug.com/591099 editing/inserting/4875189-1.html [ Crash Failure ] @@ -3478,10 +3478,10 @@ crbug.com/591099 editing/inserting/5549929-2.html [ Failure ] crbug.com/591099 editing/inserting/5549929-3.html [ Failure ] crbug.com/591099 editing/inserting/5607069-1.html [ Failure ] -crbug.com/591099 editing/inserting/5607069-2.html [ Crash ] -crbug.com/591099 editing/inserting/5607069-3.html [ Crash ] +crbug.com/591099 editing/inserting/5607069-2.html [ Crash Pass ] +crbug.com/591099 editing/inserting/5607069-3.html [ Crash Pass ] crbug.com/591099 editing/inserting/5685601-3.html [ Failure ] -crbug.com/591099 editing/inserting/5994480-2.html [ Crash ] +crbug.com/591099 editing/inserting/5994480-2.html [ Crash Pass ] crbug.com/591099 editing/inserting/6609479-1.html [ Failure ] crbug.com/591099 editing/inserting/6609479.html [ Failure ] crbug.com/591099 editing/inserting/6703873.html [ Failure ] @@ -3490,7 +3490,7 @@ crbug.com/591099 editing/inserting/delete-insignificant-text-crash.html [ Failure ] crbug.com/591099 editing/inserting/editable-inline-element.html [ Failure ] crbug.com/591099 editing/inserting/edited-whitespace-1.html [ Failure ] -crbug.com/591099 editing/inserting/editing-empty-divs.html [ Crash ] +crbug.com/591099 editing/inserting/editing-empty-divs.html [ Crash Failure ] crbug.com/591099 editing/inserting/insert-3659587-fix.html [ Crash Failure ] crbug.com/591099 editing/inserting/insert-3800346-fix.html [ Failure ] crbug.com/591099 editing/inserting/insert-after-delete-001.html [ Failure ] @@ -3502,47 +3502,47 @@ crbug.com/591099 editing/inserting/insert-br-quoted-006.html [ Failure ] crbug.com/591099 editing/inserting/insert-composition-whitespace.html [ Failure ] crbug.com/591099 editing/inserting/insert-empty-html.html [ Failure ] -crbug.com/591099 editing/inserting/insert-html-to-textarea-crash.html [ Crash ] -crbug.com/591099 editing/inserting/insert-images-in-pre-x-crash.html [ Crash Failure ] -crbug.com/591099 editing/inserting/insert-paragraph-after-non-editable-node-before-text.html [ Crash ] -crbug.com/591099 editing/inserting/insert-paragraph-empty-textarea.html [ Crash ] -crbug.com/591099 editing/inserting/insert-paragraph-selection-outside-contenteditable.html [ Crash ] -crbug.com/591099 editing/inserting/insert-paragraph-separator-crash2.html [ Crash ] +crbug.com/591099 editing/inserting/insert-html-to-textarea-crash.html [ Crash Pass ] +crbug.com/591099 editing/inserting/insert-images-in-pre-x-crash.html [ Crash Failure Pass ] +crbug.com/591099 editing/inserting/insert-paragraph-after-non-editable-node-before-text.html [ Crash Pass ] +crbug.com/591099 editing/inserting/insert-paragraph-empty-textarea.html [ Crash Pass ] +crbug.com/591099 editing/inserting/insert-paragraph-selection-outside-contenteditable.html [ Crash Pass ] +crbug.com/591099 editing/inserting/insert-paragraph-separator-crash2.html [ Crash Pass ] crbug.com/591099 editing/inserting/insert-paragraph-separator-tab-span.html [ Failure ] crbug.com/591099 editing/inserting/insert-paste-bidi-control.html [ Crash Failure ] -crbug.com/591099 editing/inserting/insert-space-at-start-of-wrapped-line.html [ Crash ] +crbug.com/591099 editing/inserting/insert-space-at-start-of-wrapped-line.html [ Crash Failure ] crbug.com/591099 editing/inserting/insert-space-in-empty-doc.html [ Failure ] crbug.com/591099 editing/inserting/insert-table-in-paragraph-crash.html [ Failure ] crbug.com/591099 editing/inserting/insert-text-at-tabspan-001.html [ Failure ] crbug.com/591099 editing/inserting/insert-text-at-tabspan-003.html [ Failure ] crbug.com/591099 editing/inserting/insert-text-into-font.html [ Failure ] -crbug.com/591099 editing/inserting/insert-text-with-newlines.html [ Crash ] +crbug.com/591099 editing/inserting/insert-text-with-newlines.html [ Crash Failure ] crbug.com/591099 editing/inserting/insert-thai-characters-001.html [ Failure ] -crbug.com/591099 editing/inserting/insert-without-inheriting-style.html [ Crash ] +crbug.com/591099 editing/inserting/insert-without-inheriting-style.html [ Crash Pass ] crbug.com/591099 editing/inserting/insert_after_delete.html [ Failure ] crbug.com/591099 editing/inserting/insert_div_with_style.html [ Failure ] -crbug.com/591099 editing/inserting/insert_html_as_plain_text.html [ Crash ] +crbug.com/591099 editing/inserting/insert_html_as_plain_text.html [ Crash Failure ] crbug.com/591099 editing/inserting/insert_interchange_newline.html [ Failure ] crbug.com/591099 editing/inserting/line-break.html [ Failure ] crbug.com/591099 editing/inserting/page-zoom-font-size.html [ Failure ] crbug.com/591099 editing/inserting/paragraph-outside-nested-divs.html [ Failure ] crbug.com/591099 editing/inserting/paragraph-separator-in-table-1.html [ Failure ] crbug.com/591099 editing/inserting/paragraph-separator-in-table-2.html [ Failure ] -crbug.com/591099 editing/inserting/redo_insert_text.html [ Crash ] -crbug.com/591099 editing/inserting/replace-at-visible-boundary.html [ Crash ] +crbug.com/591099 editing/inserting/redo_insert_text.html [ Crash Failure ] +crbug.com/591099 editing/inserting/replace-at-visible-boundary.html [ Crash Pass ] crbug.com/591099 editing/inserting/replace-in-heading-001.html [ Failure ] crbug.com/591099 editing/inserting/replace-in-paragraph-001.html [ Failure ] -crbug.com/591099 editing/inserting/replace_text_with_br.html [ Crash ] -crbug.com/591099 editing/inserting/return-key-in-hidden-field.html [ Crash ] +crbug.com/591099 editing/inserting/replace_text_with_br.html [ Crash Failure ] +crbug.com/591099 editing/inserting/return-key-in-hidden-field.html [ Crash Pass ] crbug.com/591099 editing/inserting/return-key-middle-of-span.html [ Failure ] crbug.com/591099 editing/inserting/return-with-object-element.html [ Failure Pass ] -crbug.com/591099 editing/inserting/typing.html [ Crash ] +crbug.com/591099 editing/inserting/typing.html [ Crash Failure ] crbug.com/591099 editing/pasteboard/4242293.html [ Failure ] crbug.com/591099 editing/pasteboard/4631972.html [ Failure ] crbug.com/591099 editing/pasteboard/4744008.html [ Failure ] -crbug.com/591099 editing/pasteboard/4806874.html [ Crash ] +crbug.com/591099 editing/pasteboard/4806874.html [ Crash Failure ] crbug.com/591099 editing/pasteboard/4944770-1.html [ Failure ] -crbug.com/591099 editing/pasteboard/4944770-2.html [ Crash ] +crbug.com/591099 editing/pasteboard/4944770-2.html [ Crash Pass ] crbug.com/591099 editing/pasteboard/4947130.html [ Failure ] crbug.com/591099 editing/pasteboard/5006779.html [ Failure ] crbug.com/591099 editing/pasteboard/5032095.html [ Failure ] @@ -3554,7 +3554,7 @@ crbug.com/591099 editing/pasteboard/5478250.html [ Failure ] crbug.com/591099 editing/pasteboard/5521237.html [ Failure ] crbug.com/591099 editing/pasteboard/5601583-1.html [ Failure ] -crbug.com/591099 editing/pasteboard/5665299.html [ Crash ] +crbug.com/591099 editing/pasteboard/5665299.html [ Crash Pass ] crbug.com/591099 editing/pasteboard/5761530-1.html [ Failure ] crbug.com/591099 editing/pasteboard/5780697-2.html [ Failure ] crbug.com/591099 editing/pasteboard/6018653.html [ Failure ] @@ -3566,27 +3566,27 @@ crbug.com/591099 editing/pasteboard/clipboard-customData.html [ Failure ] crbug.com/591099 editing/pasteboard/copy-backslash-with-euc.html [ Crash Failure ] crbug.com/591099 editing/pasteboard/copy-crash.html [ Crash Timeout ] -crbug.com/591099 editing/pasteboard/copy-cut-paste-keyevent.html [ Crash ] +crbug.com/591099 editing/pasteboard/copy-cut-paste-keyevent.html [ Crash Pass ] crbug.com/591099 editing/pasteboard/copy-display-none.html [ Failure ] crbug.com/591099 editing/pasteboard/copy-element-with-conflicting-background-color-from-rule.html [ Failure ] -crbug.com/591099 editing/pasteboard/copy-image-with-alt-text.html [ Crash ] +crbug.com/591099 editing/pasteboard/copy-image-with-alt-text.html [ Crash Failure ] crbug.com/591099 editing/pasteboard/copy-in-password-field.html [ Crash Failure ] -crbug.com/591099 editing/pasteboard/copy-null-characters.html [ Crash ] +crbug.com/591099 editing/pasteboard/copy-null-characters.html [ Crash Failure ] crbug.com/591099 editing/pasteboard/copy-paste-bidi.html [ Crash Failure ] crbug.com/591099 editing/pasteboard/copy-paste-float.html [ Crash Failure ] crbug.com/591099 editing/pasteboard/copy-paste-pre-line-content.html [ Failure ] -crbug.com/591099 editing/pasteboard/copy-paste-ruby-text-with-block.html [ Crash ] -crbug.com/591099 editing/pasteboard/copy-paste-ruby-text.html [ Crash ] +crbug.com/591099 editing/pasteboard/copy-paste-ruby-text-with-block.html [ Crash Failure ] +crbug.com/591099 editing/pasteboard/copy-paste-ruby-text.html [ Crash Failure ] crbug.com/591099 editing/pasteboard/copy-paste-white-space.html [ Failure ] crbug.com/591099 editing/pasteboard/copy-resolves-urls.html [ Crash Failure ] -crbug.com/591099 editing/pasteboard/copy-standalone-image-crash.html [ Crash ] +crbug.com/591099 editing/pasteboard/copy-standalone-image-crash.html [ Crash Pass ] crbug.com/591099 editing/pasteboard/copy-standalone-image-escaping.html [ Timeout ] crbug.com/591099 editing/pasteboard/copy-standalone-image.html [ Failure ] crbug.com/591099 editing/pasteboard/copy-without-common-block-crash.html [ Failure ] crbug.com/591099 editing/pasteboard/copy_image_and_select.html [ Failure ] crbug.com/591099 editing/pasteboard/crash-accessing-clipboardData-types.html [ Failure ] crbug.com/591099 editing/pasteboard/data-transfer-items-drag-drop-string.html [ Crash Failure ] -crbug.com/591099 editing/pasteboard/data-transfer-items-image-png-details.html [ Crash ] +crbug.com/591099 editing/pasteboard/data-transfer-items-image-png-details.html [ Crash Pass ] crbug.com/591099 editing/pasteboard/data-transfer-items.html [ Failure ] crbug.com/591099 editing/pasteboard/dataTransfer-setData-getData.html [ Failure ] crbug.com/591099 editing/pasteboard/drag-and-drop-image-contenteditable.html [ Timeout ] @@ -3594,15 +3594,15 @@ crbug.com/591099 editing/pasteboard/drag-and-drop-objectimage-contenteditable.html [ Timeout ] crbug.com/591099 editing/pasteboard/drag-drop-copy-text.html [ Crash Failure ] crbug.com/591099 editing/pasteboard/drag-drop-dead-frame.html [ Timeout ] -crbug.com/591099 editing/pasteboard/drag-drop-iframe-refresh-crash.html [ Crash ] -crbug.com/591099 editing/pasteboard/drag-drop-input-in-svg.svg [ Crash ] +crbug.com/591099 editing/pasteboard/drag-drop-iframe-refresh-crash.html [ Crash Failure ] +crbug.com/591099 editing/pasteboard/drag-drop-input-in-svg.svg [ Crash Pass ] crbug.com/591099 editing/pasteboard/drag-drop-input-textarea.html [ Crash Failure ] crbug.com/591099 editing/pasteboard/drag-drop-list.html [ Failure ] crbug.com/591099 editing/pasteboard/drag-drop-modifies-page.html [ Failure ] crbug.com/591099 editing/pasteboard/drag-drop-url-text.html [ Crash Failure ] crbug.com/591099 editing/pasteboard/drag-drop-url-with-style.html [ Failure ] crbug.com/591099 editing/pasteboard/drag-files-to-editable-element.html [ Failure ] -crbug.com/591099 editing/pasteboard/drag-image-in-about-blank-frame.html [ Crash ] +crbug.com/591099 editing/pasteboard/drag-image-in-about-blank-frame.html [ Crash Failure ] crbug.com/591099 editing/pasteboard/drag-image-to-contenteditable-in-iframe.html [ Crash Failure ] crbug.com/591099 editing/pasteboard/drag-list-item.html [ Crash Failure ] crbug.com/591099 editing/pasteboard/drag-prioritizes-draggable-container-over-image.html [ Failure ] @@ -3615,7 +3615,7 @@ crbug.com/591099 editing/pasteboard/drop-text-events.html [ Crash Failure ] crbug.com/591099 editing/pasteboard/drop-text-without-selection.html [ Failure ] crbug.com/591099 editing/pasteboard/file-drag-to-editable.html [ Failure ] -crbug.com/591099 editing/pasteboard/file-input-files-access.html [ Crash ] +crbug.com/591099 editing/pasteboard/file-input-files-access.html [ Crash Failure ] crbug.com/591099 editing/pasteboard/files-during-page-drags.html [ Failure ] crbug.com/591099 editing/pasteboard/get-data-text-plain-drop.html [ Failure ] crbug.com/591099 editing/pasteboard/get-data-text-plain-paste.html [ Failure ] @@ -3626,7 +3626,7 @@ crbug.com/591099 editing/pasteboard/insert-font-weight.html [ Failure ] crbug.com/591099 editing/pasteboard/merge-start-blockquote.html [ Failure ] crbug.com/591099 editing/pasteboard/merge-start-list.html [ Failure ] -crbug.com/591099 editing/pasteboard/mixed_editability.html [ Crash ] +crbug.com/591099 editing/pasteboard/mixed_editability.html [ Crash Failure ] crbug.com/591099 editing/pasteboard/onpaste-text-html.html [ Failure ] crbug.com/591099 editing/pasteboard/paste-after-inline-style-element.html [ Failure ] crbug.com/591099 editing/pasteboard/paste-and-sanitize.html [ Failure ] @@ -3664,12 +3664,12 @@ crbug.com/591099 editing/pasteboard/paste-wrapped-blockquote-into-nonblockquote.html [ Failure ] crbug.com/591099 editing/pasteboard/paste_match_style.html [ Failure ] crbug.com/591099 editing/pasteboard/paste_with_spaces.html [ Failure ] -crbug.com/591099 editing/pasteboard/pasteboard_with_unfocused_selection.html [ Crash ] +crbug.com/591099 editing/pasteboard/pasteboard_with_unfocused_selection.html [ Crash Failure ] crbug.com/591099 editing/pasteboard/pasting-empty-html-falls-back-to-text.html [ Failure ] crbug.com/591099 editing/pasteboard/pasting-tabs.html [ Crash Failure ] crbug.com/591099 editing/pasteboard/quirks-mode-br-1.html [ Crash Failure ] -crbug.com/591099 editing/pasteboard/restore-collapsed-space-for-copy.html [ Crash ] -crbug.com/591099 editing/pasteboard/select-element-1.html [ Crash ] +crbug.com/591099 editing/pasteboard/restore-collapsed-space-for-copy.html [ Crash Failure ] +crbug.com/591099 editing/pasteboard/select-element-1.html [ Crash Failure ] crbug.com/591099 editing/pasteboard/selection-paste-crash.html [ Failure ] crbug.com/591099 editing/pasteboard/set_data_typeof_return.html [ Failure ] crbug.com/591099 editing/pasteboard/smart-drag-drop.html [ Failure ] @@ -3678,7 +3678,7 @@ crbug.com/591099 editing/pasteboard/smart-paste-in-text-control.html [ Failure ] crbug.com/591099 editing/pasteboard/smart_paste.html [ Failure ] crbug.com/591099 editing/pasteboard/styled-element-markup.html [ Failure ] -crbug.com/591099 editing/pasteboard/subframe-dragndrop-1.html [ Crash ] +crbug.com/591099 editing/pasteboard/subframe-dragndrop-1.html [ Crash Failure ] crbug.com/591099 editing/selection/4402375.html [ Failure ] crbug.com/591099 editing/selection/4776665.html [ Failure ] crbug.com/591099 editing/selection/4960116.html [ Failure ] @@ -3696,7 +3696,7 @@ crbug.com/591099 editing/selection/5232159.html [ Failure ] crbug.com/591099 editing/selection/5241148.html [ Failure ] crbug.com/591099 editing/selection/5354455-2.html [ Failure ] -crbug.com/591099 editing/selection/5794920-1.html [ Crash ] +crbug.com/591099 editing/selection/5794920-1.html [ Crash Pass ] crbug.com/591099 editing/selection/6476.html [ Failure ] crbug.com/591099 editing/selection/DOMSelection-DocumentType.html [ Failure ] crbug.com/591099 editing/selection/DOMSelection-crossing-document.html [ Failure ] @@ -3729,9 +3729,9 @@ crbug.com/591099 editing/selection/caret-rtl-right.html [ Failure ] crbug.com/591099 editing/selection/caret-rtl.html [ Failure ] crbug.com/591099 editing/selection/character-data-mutation-crash.html [ Failure ] -crbug.com/591099 editing/selection/clear-selection-crash.html [ Crash ] +crbug.com/591099 editing/selection/clear-selection-crash.html [ Crash Pass ] crbug.com/591099 editing/selection/clear-selection.html [ Failure ] -crbug.com/591099 editing/selection/cleared-by-relayout.html [ Crash ] +crbug.com/591099 editing/selection/cleared-by-relayout.html [ Crash Failure ] crbug.com/591099 editing/selection/click-after-nested-block.html [ Failure ] crbug.com/591099 editing/selection/click-in-focusable-link-should-not-clear-selection.html [ Failure ] crbug.com/591099 editing/selection/click-in-margins-inside-editable-div.html [ Failure ] @@ -3741,10 +3741,10 @@ crbug.com/591099 editing/selection/click-start-of-line.html [ Failure ] crbug.com/591099 editing/selection/collapse-null.html [ Failure ] crbug.com/591099 editing/selection/collapse-selection-in-bidi.html [ Failure ] -crbug.com/591099 editing/selection/collapse/collapse_before_select.html [ Crash ] -crbug.com/591099 editing/selection/collapse/table-caret-3.html [ Crash ] -crbug.com/591099 editing/selection/collapseto_in_text_fields.html [ Crash ] -crbug.com/591099 editing/selection/commit-pending-selection-crash.html [ Crash ] +crbug.com/591099 editing/selection/collapse/collapse_before_select.html [ Crash Pass ] +crbug.com/591099 editing/selection/collapse/table-caret-3.html [ Crash Pass ] +crbug.com/591099 editing/selection/collapseto_in_text_fields.html [ Crash Pass ] +crbug.com/591099 editing/selection/commit-pending-selection-crash.html [ Crash Pass ] crbug.com/591099 editing/selection/contains-boundaries.html [ Failure ] crbug.com/591099 editing/selection/contenteditable-click-inside.html [ Failure ] crbug.com/591099 editing/selection/context-menu-on-text.html [ Failure ] @@ -3754,8 +3754,8 @@ crbug.com/591099 editing/selection/css-pseudo-element-hang.html [ Failure ] crbug.com/591099 editing/selection/css-pseudo-element.html [ Failure ] crbug.com/591099 editing/selection/delete-word-granularity-text-control.html [ Crash Failure ] -crbug.com/591099 editing/selection/deleteFromDocument-scoped-dispatch-event-crash.html [ Crash ] -crbug.com/591099 editing/selection/deletefromdocument-shadow-leak.html [ Crash ] +crbug.com/591099 editing/selection/deleteFromDocument-scoped-dispatch-event-crash.html [ Crash Failure ] +crbug.com/591099 editing/selection/deletefromdocument-shadow-leak.html [ Crash Pass ] crbug.com/591099 editing/selection/designmode-no-caret.html [ Failure ] crbug.com/591099 editing/selection/directionality-after-undo-replace.html [ Crash Failure ] crbug.com/591099 editing/selection/display-table-text.html [ Failure ] @@ -3766,7 +3766,7 @@ crbug.com/591099 editing/selection/double_click_and_modify.html [ Failure ] crbug.com/591099 editing/selection/doubleclick-beside-cr-span.html [ Failure Timeout ] crbug.com/591099 editing/selection/doubleclick-inline-first-last-contenteditable.html [ Failure ] -crbug.com/591099 editing/selection/doubleclick-whitespace-img-crash.html [ Crash ] +crbug.com/591099 editing/selection/doubleclick-whitespace-img-crash.html [ Crash Pass ] crbug.com/591099 editing/selection/doubleclick-whitespace.html [ Crash Failure ] crbug.com/591099 editing/selection/doubleclick-with-split-text.html [ Crash Failure ] crbug.com/591099 editing/selection/drag-drop-events.html [ Crash Failure ] @@ -3779,9 +3779,9 @@ crbug.com/591099 editing/selection/drag-start-event-client-x-y.html [ Failure ] crbug.com/591099 editing/selection/drag-text-delay.html [ Crash Failure ] crbug.com/591099 editing/selection/drag-to-contenteditable-iframe.html [ Crash Failure ] -crbug.com/591099 editing/selection/drag_with_unfocused_selection.html [ Crash ] -crbug.com/591099 editing/selection/dump-as-markup-form-text.html [ Crash ] -crbug.com/591099 editing/selection/dump-as-markup.html [ Crash ] +crbug.com/591099 editing/selection/drag_with_unfocused_selection.html [ Crash Failure ] +crbug.com/591099 editing/selection/dump-as-markup-form-text.html [ Crash Pass ] +crbug.com/591099 editing/selection/dump-as-markup.html [ Crash Pass ] crbug.com/591099 editing/selection/editable-div-clear-on-keydown.html [ Failure ] crbug.com/591099 editing/selection/editable-links.html [ Failure ] crbug.com/591099 editing/selection/expanding-selections.html [ Failure ] @@ -3793,7 +3793,7 @@ crbug.com/591099 editing/selection/extend-forward-after-set-base-and-extent.html [ Failure ] crbug.com/591099 editing/selection/extend-inside-transforms-backward.html [ Failure ] crbug.com/591099 editing/selection/extend-inside-transforms-forward.html [ Failure ] -crbug.com/591099 editing/selection/extend-over-file-input-by-drag-crash.html [ Crash ] +crbug.com/591099 editing/selection/extend-over-file-input-by-drag-crash.html [ Crash Failure ] crbug.com/591099 editing/selection/extend-selection-after-double-click.html [ Failure ] crbug.com/591099 editing/selection/extend-selection-bidi.html [ Failure ] crbug.com/591099 editing/selection/extend-selection-character.html [ Timeout ] @@ -3801,24 +3801,24 @@ crbug.com/591099 editing/selection/extend-selection-word.html [ Timeout ] crbug.com/591099 editing/selection/extend-to-trailing-spaces.html [ Failure ] crbug.com/591099 editing/selection/find-in-text-control.html [ Crash Failure ] -crbug.com/591099 editing/selection/first-letter-selection-crash.html [ Crash ] +crbug.com/591099 editing/selection/first-letter-selection-crash.html [ Crash Pass ] crbug.com/591099 editing/selection/firstRect-crash.html [ Failure ] -crbug.com/591099 editing/selection/focus-and-display-none-and-redisplay.html [ Crash ] -crbug.com/591099 editing/selection/focus-and-display-none.html [ Crash ] +crbug.com/591099 editing/selection/focus-and-display-none-and-redisplay.html [ Crash Failure ] +crbug.com/591099 editing/selection/focus-and-display-none.html [ Crash Pass ] crbug.com/591099 editing/selection/focus-body.html [ Failure ] -crbug.com/591099 editing/selection/focus-contenteditable-iframe.html [ Crash ] -crbug.com/591099 editing/selection/focus-crash.html [ Crash ] +crbug.com/591099 editing/selection/focus-contenteditable-iframe.html [ Crash Pass ] +crbug.com/591099 editing/selection/focus-crash.html [ Crash Pass ] crbug.com/591099 editing/selection/focus-iframe-removal-crash.html [ Failure ] crbug.com/591099 editing/selection/focus_editable_html_element.html [ Timeout ] crbug.com/591099 editing/selection/hit-test-anonymous.html [ Failure ] crbug.com/591099 editing/selection/hit-test-on-text-with-line-height.html [ Failure ] crbug.com/591099 editing/selection/home-end.html [ Timeout ] -crbug.com/591099 editing/selection/iframe-select-animation.html [ Crash ] +crbug.com/591099 editing/selection/iframe-select-animation.html [ Crash Pass ] crbug.com/591099 editing/selection/inactive-selection.html [ Crash Failure ] crbug.com/591099 editing/selection/inline-closest-leaf-child.html [ Failure ] crbug.com/591099 editing/selection/internal-caret-rect.html [ Failure ] crbug.com/591099 editing/selection/keep-selection-after-set-focus.html [ Failure ] -crbug.com/591099 editing/selection/keydown-without-selection-crash.html [ Crash ] +crbug.com/591099 editing/selection/keydown-without-selection-crash.html [ Crash Pass ] crbug.com/591099 editing/selection/leave-requested-block.html [ Failure ] crbug.com/591099 editing/selection/legal-positions.html [ Crash Failure ] crbug.com/591099 editing/selection/line-wrap-1.html [ Failure ] @@ -3838,34 +3838,34 @@ crbug.com/591099 editing/selection/mixed-editability-inline-height.html [ Failure ] crbug.com/591099 editing/selection/modify-by-lineboundary-in-inline-editable-contexts.html [ Failure ] crbug.com/591099 editing/selection/modify-up-on-rtl-wrapping-text.html [ Failure ] -crbug.com/591099 editing/selection/modify_extend/extend_by_character.html [ Crash ] -crbug.com/591099 editing/selection/modify_extend/extend_selection_enclosing_block.html [ Crash ] +crbug.com/591099 editing/selection/modify_extend/extend_by_character.html [ Crash Failure ] +crbug.com/591099 editing/selection/modify_extend/extend_selection_enclosing_block.html [ Crash Failure ] crbug.com/591099 editing/selection/modify_move/move-by-character-001.html [ Failure ] -crbug.com/591099 editing/selection/modify_move/move-by-character-002.html [ Crash ] +crbug.com/591099 editing/selection/modify_move/move-by-character-002.html [ Crash Failure ] crbug.com/591099 editing/selection/modify_move/move-by-character-003.html [ Failure Pass ] -crbug.com/591099 editing/selection/modify_move/move-by-character-004.html [ Crash ] -crbug.com/591099 editing/selection/modify_move/move-by-character-crash-test-textarea.html [ Crash ] -crbug.com/591099 editing/selection/modify_move/move-by-word-visually-crash-test-1.html [ Crash ] -crbug.com/591099 editing/selection/modify_move/move-by-word-visually-crash-test-3.html [ Crash ] -crbug.com/591099 editing/selection/modify_move/move-by-word-visually-crash-test-css-generated-content.html [ Crash ] -crbug.com/591099 editing/selection/modify_move/move-by-word-visually-inline-block-positioned-element.html [ Crash ] +crbug.com/591099 editing/selection/modify_move/move-by-character-004.html [ Crash Failure ] +crbug.com/591099 editing/selection/modify_move/move-by-character-crash-test-textarea.html [ Crash Pass ] +crbug.com/591099 editing/selection/modify_move/move-by-word-visually-crash-test-1.html [ Crash Pass ] +crbug.com/591099 editing/selection/modify_move/move-by-word-visually-crash-test-3.html [ Crash Pass ] +crbug.com/591099 editing/selection/modify_move/move-by-word-visually-crash-test-css-generated-content.html [ Crash Pass ] +crbug.com/591099 editing/selection/modify_move/move-by-word-visually-inline-block-positioned-element.html [ Crash Pass ] crbug.com/591099 editing/selection/modify_move/move-by-word-visually-multi-line.html [ Crash Failure ] crbug.com/591099 editing/selection/modify_move/move-by-word-visually-multi-space.html [ Failure ] -crbug.com/591099 editing/selection/modify_move/move-by-word-visually-single-space-one-element.html [ Crash ] -crbug.com/591099 editing/selection/modify_move/move-by-word-visually-textarea.html [ Crash ] +crbug.com/591099 editing/selection/modify_move/move-by-word-visually-single-space-one-element.html [ Crash Pass ] +crbug.com/591099 editing/selection/modify_move/move-by-word-visually-textarea.html [ Crash Pass ] crbug.com/591099 editing/selection/modify_move/move-by-word-visually-wrong-left-right.html [ Failure ] -crbug.com/591099 editing/selection/modify_move/move_by_sentence_boundary.html [ Crash ] -crbug.com/591099 editing/selection/modify_move/move_character_across_iframe.html [ Crash ] -crbug.com/591099 editing/selection/modify_move/move_character_inline_table.html [ Crash ] -crbug.com/591099 editing/selection/modify_move/move_forward_character_button.html [ Crash ] +crbug.com/591099 editing/selection/modify_move/move_by_sentence_boundary.html [ Crash Failure ] +crbug.com/591099 editing/selection/modify_move/move_character_across_iframe.html [ Crash Failure ] +crbug.com/591099 editing/selection/modify_move/move_character_inline_table.html [ Crash Pass ] +crbug.com/591099 editing/selection/modify_move/move_forward_character_button.html [ Crash Pass ] crbug.com/591099 editing/selection/modify_move/move_forward_line_br.html [ Failure ] crbug.com/591099 editing/selection/modify_move/move_forward_line_range.html [ Failure Pass ] crbug.com/591099 editing/selection/modify_move/move_left_right_character_in_mixed_bidi.html [ Failure ] crbug.com/591099 editing/selection/mouse/click-left-of-rtl-wrapping-text.html [ Failure ] crbug.com/591099 editing/selection/mouse/click-user-select-all-contenteditable.html [ Failure ] -crbug.com/591099 editing/selection/mouse/click-user-select-all-textarea.html [ Crash ] +crbug.com/591099 editing/selection/mouse/click-user-select-all-textarea.html [ Crash Failure ] crbug.com/591099 editing/selection/mouse/drag-user-select-all-contenteditable.html [ Failure ] -crbug.com/591099 editing/selection/mouse/drag-user-select-all-textarea.html [ Crash ] +crbug.com/591099 editing/selection/mouse/drag-user-select-all-textarea.html [ Crash Failure ] crbug.com/591099 editing/selection/move-3875618-fix.html [ Failure ] crbug.com/591099 editing/selection/move-3875641-fix.html [ Failure ] crbug.com/591099 editing/selection/move-backwords-by-word-001.html [ Failure ] @@ -3908,7 +3908,7 @@ crbug.com/591099 editing/selection/select-bidi-run.html [ Failure Timeout ] crbug.com/591099 editing/selection/select-box.html [ Failure ] crbug.com/591099 editing/selection/select-element-paragraph-boundary.html [ Failure ] -crbug.com/591099 editing/selection/select-from-textfield-outwards.html [ Crash ] +crbug.com/591099 editing/selection/select-from-textfield-outwards.html [ Crash Pass ] crbug.com/591099 editing/selection/select-line-break-with-opposite-directionality.html [ Crash Failure ] crbug.com/591099 editing/selection/select-line.html [ Failure ] crbug.com/591099 editing/selection/select-missing-image.html [ Crash Failure ] @@ -3923,26 +3923,26 @@ crbug.com/591099 editing/selection/selectNode.html [ Crash Failure ] crbug.com/591099 editing/selection/selectNodeContents.html [ Crash Failure ] crbug.com/591099 editing/selection/select_all/select_all_contenteditable.html [ Failure ] -crbug.com/591099 editing/selection/select_all/select_all_iframe.html [ Crash ] -crbug.com/591099 editing/selection/select_all/select_all_iframe_crash.html [ Crash ] -crbug.com/591099 editing/selection/select_all/select_all_input.html [ Crash ] +crbug.com/591099 editing/selection/select_all/select_all_iframe.html [ Crash Pass ] +crbug.com/591099 editing/selection/select_all/select_all_iframe_crash.html [ Crash Pass ] +crbug.com/591099 editing/selection/select_all/select_all_input.html [ Crash Pass ] crbug.com/591099 editing/selection/select_all/select_all_overflow_hidden.html [ Failure ] crbug.com/591099 editing/selection/select_all/select_all_overflow_hidden_br.html [ Failure ] crbug.com/591099 editing/selection/select_all/select_all_overflow_hidden_table.html [ Failure ] -crbug.com/591099 editing/selection/select_all/select_all_readonly_textarea.html [ Crash ] -crbug.com/591099 editing/selection/select_all/select_all_textarea.html [ Crash ] +crbug.com/591099 editing/selection/select_all/select_all_readonly_textarea.html [ Crash Pass ] +crbug.com/591099 editing/selection/select_all/select_all_textarea.html [ Crash Pass ] crbug.com/591099 editing/selection/select_all/select_all_user_select_none.html [ Failure ] crbug.com/591099 editing/selection/selection-3748164-fix.html [ Failure ] crbug.com/591099 editing/selection/selection-background.html [ Failure ] crbug.com/591099 editing/selection/selection-button-text.html [ Failure ] -crbug.com/591099 editing/selection/selection-crash.html [ Crash ] +crbug.com/591099 editing/selection/selection-crash.html [ Crash Pass ] crbug.com/591099 editing/selection/selection-empty-documentElement.html [ Failure ] crbug.com/591099 editing/selection/selection-exceptions.html [ Failure ] crbug.com/591099 editing/selection/selection-extend-should-not-move-across-caret-on-mac.html [ Failure ] -crbug.com/591099 editing/selection/selection-forces-unrooted-repaint.html [ Crash ] +crbug.com/591099 editing/selection/selection-forces-unrooted-repaint.html [ Crash Pass ] crbug.com/591099 editing/selection/selection-invalid-offset.html [ Failure Pass ] -crbug.com/591099 editing/selection/selection-plugin-clear-crash.html [ Crash ] -crbug.com/591099 editing/selection/selectstart_detaches_frame.html [ Crash ] +crbug.com/591099 editing/selection/selection-plugin-clear-crash.html [ Crash Pass ] +crbug.com/591099 editing/selection/selectstart_detaches_frame.html [ Crash Pass ] crbug.com/591099 editing/selection/shift-click.html [ Crash Failure ] crbug.com/591099 editing/selection/shrink-selection-after-shift-pagedown.html [ Crash Failure ] crbug.com/591099 editing/selection/skip-non-editable-1.html [ Crash Failure ] @@ -3957,16 +3957,16 @@ crbug.com/591099 editing/selection/toString.html [ Crash Failure ] crbug.com/591099 editing/selection/transformed-selection-rects.html [ Failure ] crbug.com/591099 editing/selection/triple-click-in-pre.html [ Failure ] -crbug.com/591099 editing/selection/undo-crash.html [ Crash ] +crbug.com/591099 editing/selection/undo-crash.html [ Crash Pass ] crbug.com/591099 editing/selection/user-select-all-parsing.html [ Failure ] -crbug.com/591099 editing/selection/user-select-all-with-shift.html [ Crash ] -crbug.com/591099 editing/selection/user-select/user-select-all.html [ Crash ] +crbug.com/591099 editing/selection/user-select-all-with-shift.html [ Crash Failure ] +crbug.com/591099 editing/selection/user-select/user-select-all.html [ Crash Failure ] crbug.com/591099 editing/selection/vertical-lr-ltr-extend-line-backward-br.html [ Failure Pass ] crbug.com/591099 editing/selection/vertical-lr-ltr-extend-line-forward-br.html [ Failure Pass ] crbug.com/591099 editing/selection/vertical-rl-ltr-extend-line-backward-br.html [ Failure Pass ] -crbug.com/591099 editing/selection/vertical-rl-ltr-extend-line-backward-wrap.html [ Crash ] +crbug.com/591099 editing/selection/vertical-rl-ltr-extend-line-backward-wrap.html [ Crash Failure ] crbug.com/591099 editing/selection/vertical-rl-ltr-extend-line-forward-br.html [ Failure Pass ] -crbug.com/591099 editing/selection/vertical-rl-ltr-extend-line-forward-wrap.html [ Crash ] +crbug.com/591099 editing/selection/vertical-rl-ltr-extend-line-forward-wrap.html [ Crash Failure ] crbug.com/591099 editing/selection/vertical-rl-rtl-extend-line-backward-br.html [ Failure Pass ] crbug.com/591099 editing/selection/vertical-rl-rtl-extend-line-backward-p.html [ Failure ] crbug.com/591099 editing/selection/vertical-rl-rtl-extend-line-forward-br.html [ Failure Pass ] @@ -3998,17 +3998,17 @@ crbug.com/591099 editing/spelling/context_click_select_misspelling.html [ Crash Failure ] crbug.com/591099 editing/spelling/grammar-paste.html [ Failure ] crbug.com/591099 editing/spelling/mixed_paste.html [ Failure ] -crbug.com/591099 editing/spelling/no_marker_in_blurred_input.html [ Crash ] +crbug.com/591099 editing/spelling/no_marker_in_blurred_input.html [ Crash Pass ] crbug.com/591099 editing/spelling/spellcheck-async-mutation.html [ Failure ] -crbug.com/591099 editing/spelling/spellcheck-async-remove-frame.html [ Crash ] +crbug.com/591099 editing/spelling/spellcheck-async-remove-frame.html [ Crash Pass ] crbug.com/591099 editing/spelling/spellcheck-disable-enable.html [ Failure ] -crbug.com/591099 editing/spelling/spellcheck-editable-on-focus.html [ Crash ] +crbug.com/591099 editing/spelling/spellcheck-editable-on-focus.html [ Crash Pass ] crbug.com/591099 editing/spelling/spellcheck-input-search-crash.html [ Failure ] crbug.com/591099 editing/spelling/spellcheck-paste-disabled.html [ Failure ] crbug.com/591099 editing/spelling/spellcheck-paste.html [ Failure ] crbug.com/591099 editing/spelling/spellcheck-queue.html [ Failure ] -crbug.com/591099 editing/spelling/spellcheck-remove-markers.html [ Crash ] -crbug.com/591099 editing/spelling/spellcheck-sequencenum.html [ Crash ] +crbug.com/591099 editing/spelling/spellcheck-remove-markers.html [ Crash Pass ] +crbug.com/591099 editing/spelling/spellcheck-sequencenum.html [ Crash Failure ] crbug.com/591099 editing/spelling/spellcheck_test.html [ Crash Failure ] crbug.com/591099 editing/spelling/spelling-backward.html [ Failure ] crbug.com/591099 editing/spelling/spelling-changed-text.html [ Failure ] @@ -4018,12 +4018,12 @@ crbug.com/591099 editing/style/5065910.html [ Failure ] crbug.com/591099 editing/style/5084241.html [ Failure ] crbug.com/591099 editing/style/5228141.html [ Failure ] -crbug.com/591099 editing/style/5279521.html [ Crash ] +crbug.com/591099 editing/style/5279521.html [ Crash Failure ] crbug.com/591099 editing/style/apply-font-size-to-multiple-nodes.html [ Failure ] -crbug.com/591099 editing/style/apply-style-atomic.html [ Crash ] -crbug.com/591099 editing/style/apply-style-crash.html [ Crash ] -crbug.com/591099 editing/style/apply-style-crash2.html [ Crash ] -crbug.com/591099 editing/style/apply-style-crash3.html [ Crash ] +crbug.com/591099 editing/style/apply-style-atomic.html [ Crash Pass ] +crbug.com/591099 editing/style/apply-style-crash.html [ Crash Pass ] +crbug.com/591099 editing/style/apply-style-crash2.html [ Crash Pass ] +crbug.com/591099 editing/style/apply-style-crash3.html [ Crash Failure ] crbug.com/591099 editing/style/apply-through-end-of-document.html [ Failure ] crbug.com/591099 editing/style/background-color-retained.html [ Failure ] crbug.com/591099 editing/style/block-style-001.html [ Failure ] @@ -4031,7 +4031,7 @@ crbug.com/591099 editing/style/block-style-003.html [ Failure ] crbug.com/591099 editing/style/block-styles-007.html [ Failure ] crbug.com/591099 editing/style/designmode.html [ Failure ] -crbug.com/591099 editing/style/fix-range-from-root-editable-crash.html [ Crash ] +crbug.com/591099 editing/style/fix-range-from-root-editable-crash.html [ Crash Pass ] crbug.com/591099 editing/style/font-face-unquote.html [ Failure ] crbug.com/591099 editing/style/font-family-with-space.html [ Failure ] crbug.com/591099 editing/style/fontsize-1.html [ Crash Failure ] @@ -4060,32 +4060,32 @@ crbug.com/591099 editing/style/text-decoration-state.html [ Failure ] crbug.com/591099 editing/style/textdecoration-outside-of-rooteditable.html [ Crash Failure ] crbug.com/591099 editing/style/textdecoration-outside-of-unsplittable-element.html [ Crash Failure ] -crbug.com/591099 editing/style/typing_style.html [ Crash ] -crbug.com/591099 editing/style/unbold-in-bold.html [ Crash ] +crbug.com/591099 editing/style/typing_style.html [ Crash Failure ] +crbug.com/591099 editing/style/unbold-in-bold.html [ Crash Failure ] crbug.com/591099 editing/surrounding-text/surrounding-text-detached-no-crash.html [ Failure ] -crbug.com/591099 editing/surrounding-text/surrounding-text.html [ Crash ] +crbug.com/591099 editing/surrounding-text/surrounding-text.html [ Crash Failure ] crbug.com/591099 editing/text-iterator/basic-iteration-shadowdom.html [ Failure ] crbug.com/591099 editing/text-iterator/basic-iteration.html [ Crash Failure ] crbug.com/591099 editing/text-iterator/findString-shadow-roots.html [ Failure ] crbug.com/591099 editing/text-iterator/findString-start-search-after-selection.html [ Failure Pass ] crbug.com/591099 editing/text-iterator/findString.html [ Crash Timeout ] crbug.com/591099 editing/text-iterator/first-letter-rtl-crash.html [ Failure Pass ] -crbug.com/591099 editing/text-iterator/first-letter-word-boundary.html [ Crash ] +crbug.com/591099 editing/text-iterator/first-letter-word-boundary.html [ Crash Failure ] crbug.com/591099 editing/text-iterator/range-to-from-location-and-length.html [ Failure ] -crbug.com/591099 editing/text-iterator/selection-to-string-with-auto-fill.html [ Crash ] +crbug.com/591099 editing/text-iterator/selection-to-string-with-auto-fill.html [ Crash Pass ] crbug.com/591099 editing/text-iterator/thai-cursor-movement.html [ Crash Failure ] crbug.com/591099 editing/undo/5658727.html [ Failure ] crbug.com/591099 editing/undo/5738768.html [ Failure ] -crbug.com/591099 editing/undo/audio-in-undo-stack-crash.html [ Crash ] +crbug.com/591099 editing/undo/audio-in-undo-stack-crash.html [ Crash Pass ] crbug.com/591099 editing/undo/crash-redo-with-iframes.html [ Failure ] -crbug.com/591099 editing/undo/orphaned-selection-crash-bug32823-2.html [ Crash ] -crbug.com/591099 editing/undo/orphaned-selection-crash-bug32823-4.html [ Crash ] +crbug.com/591099 editing/undo/orphaned-selection-crash-bug32823-2.html [ Crash Pass ] +crbug.com/591099 editing/undo/orphaned-selection-crash-bug32823-4.html [ Crash Pass ] crbug.com/591099 editing/undo/paste_with_mutation_event_undo_order.html [ Failure ] -crbug.com/591099 editing/undo/redo_correct_selection.html [ Crash ] -crbug.com/591099 editing/undo/undo-after-removing-iframe.html [ Crash ] +crbug.com/591099 editing/undo/redo_correct_selection.html [ Crash Pass ] +crbug.com/591099 editing/undo/undo-after-removing-iframe.html [ Crash Pass ] crbug.com/591099 editing/undo/undo-after-setting-value.html [ Crash Failure ] crbug.com/591099 editing/undo/undo-deleteWord.html [ Failure Pass ] -crbug.com/591099 editing/undo/undo-iframe-location-change.html [ Crash ] +crbug.com/591099 editing/undo/undo-iframe-location-change.html [ Crash Pass ] crbug.com/591099 editing/undo/undo-set-selection-crash.html [ Failure ] crbug.com/591099 editing/undo/undo-smart-delete-reversed-selection.html [ Failure Pass ] crbug.com/591099 editing/unsupported-content/list-delete-001.html [ Crash Failure ] @@ -4097,23 +4097,23 @@ crbug.com/591099 editing/unsupported-content/table-delete-003.html [ Failure ] crbug.com/591099 editing/unsupported-content/table-type-after.html [ Failure ] crbug.com/591099 editing/unsupported-content/table-type-before.html [ Failure ] -crbug.com/591099 external/wpt/2dcontext/drawing-images-to-the-canvas/2d.drawImage.incomplete.emptysrc.html [ Crash ] +crbug.com/591099 external/wpt/2dcontext/drawing-images-to-the-canvas/2d.drawImage.incomplete.emptysrc.html [ Crash Pass ] crbug.com/591099 external/wpt/2dcontext/drawing-images-to-the-canvas/2d.drawImage.incomplete.removedsrc.html [ Crash Pass ] crbug.com/591099 external/wpt/2dcontext/drawing-images-to-the-canvas/2d.drawImage.zerosource.image.html [ Crash Pass ] -crbug.com/591099 external/wpt/2dcontext/drawing-paths-to-the-canvas/canvas_focus_drawCustomFocusRing_001.html [ Crash ] -crbug.com/591099 external/wpt/2dcontext/drawing-paths-to-the-canvas/drawFocusIfNeeded_001.html [ Crash ] -crbug.com/591099 external/wpt/2dcontext/drawing-paths-to-the-canvas/drawFocusIfNeeded_002.html [ Crash ] -crbug.com/591099 external/wpt/2dcontext/drawing-paths-to-the-canvas/drawFocusIfNeeded_003.html [ Crash ] -crbug.com/591099 external/wpt/2dcontext/drawing-paths-to-the-canvas/drawFocusIfNeeded_004.html [ Crash ] -crbug.com/591099 external/wpt/2dcontext/drawing-paths-to-the-canvas/drawFocusIfNeeded_005.html [ Crash ] +crbug.com/591099 external/wpt/2dcontext/drawing-paths-to-the-canvas/canvas_focus_drawCustomFocusRing_001.html [ Crash Pass ] +crbug.com/591099 external/wpt/2dcontext/drawing-paths-to-the-canvas/drawFocusIfNeeded_001.html [ Crash Pass ] +crbug.com/591099 external/wpt/2dcontext/drawing-paths-to-the-canvas/drawFocusIfNeeded_002.html [ Crash Pass ] +crbug.com/591099 external/wpt/2dcontext/drawing-paths-to-the-canvas/drawFocusIfNeeded_003.html [ Crash Pass ] +crbug.com/591099 external/wpt/2dcontext/drawing-paths-to-the-canvas/drawFocusIfNeeded_004.html [ Crash Pass ] +crbug.com/591099 external/wpt/2dcontext/drawing-paths-to-the-canvas/drawFocusIfNeeded_005.html [ Crash Pass ] crbug.com/591099 external/wpt/2dcontext/fill-and-stroke-styles/2d.pattern.image.incomplete.emptysrc.html [ Crash Pass ] -crbug.com/591099 external/wpt/2dcontext/fill-and-stroke-styles/2d.pattern.image.incomplete.removedsrc.html [ Crash ] -crbug.com/591099 external/wpt/2dcontext/hit-regions/hitregions-members-exist.html [ Crash ] -crbug.com/591099 external/wpt/2dcontext/line-styles/setLineDash.html [ Crash ] -crbug.com/591099 external/wpt/FileAPI/idlharness.html [ Crash ] -crbug.com/591099 external/wpt/FileAPI/url/blob-url-in-sandboxed-iframe.html [ Crash ] -crbug.com/591099 external/wpt/FileAPI/url/multi-global-origin-serialization.sub.html [ Crash ] -crbug.com/591099 external/wpt/FileAPI/url/origin.sub.html [ Crash ] +crbug.com/591099 external/wpt/2dcontext/fill-and-stroke-styles/2d.pattern.image.incomplete.removedsrc.html [ Crash Pass ] +crbug.com/591099 external/wpt/2dcontext/hit-regions/hitregions-members-exist.html [ Crash Pass ] +crbug.com/591099 external/wpt/2dcontext/line-styles/setLineDash.html [ Crash Pass ] +crbug.com/591099 external/wpt/FileAPI/idlharness.html [ Crash Pass ] +crbug.com/591099 external/wpt/FileAPI/url/blob-url-in-sandboxed-iframe.html [ Crash Pass ] +crbug.com/591099 external/wpt/FileAPI/url/multi-global-origin-serialization.sub.html [ Crash Pass ] +crbug.com/591099 external/wpt/FileAPI/url/origin.sub.html [ Crash Pass ] crbug.com/591099 external/wpt/WebCryptoAPI/derive_bits_keys/test_hkdf.https.html [ Pass Timeout ] crbug.com/591099 external/wpt/WebCryptoAPI/derive_bits_keys/test_pbkdf2_empty_empty.https.html [ Pass Timeout ] crbug.com/591099 external/wpt/WebCryptoAPI/derive_bits_keys/test_pbkdf2_empty_long.https.html [ Pass Timeout ] @@ -4131,61 +4131,61 @@ crbug.com/591099 external/wpt/WebCryptoAPI/import_export/test_rsa_importKey.https.html [ Pass Timeout ] crbug.com/591099 external/wpt/WebCryptoAPI/import_export/test_symmetric_importKey.https.html [ Pass Timeout ] crbug.com/591099 external/wpt/WebIDL/ecmascript-binding/has-instance.html [ Crash Pass ] -crbug.com/591099 external/wpt/WebIDL/ecmascript-binding/sequence-conversion.html [ Crash ] -crbug.com/591099 external/wpt/XMLHttpRequest/open-url-multi-window-2.htm [ Crash ] -crbug.com/591099 external/wpt/XMLHttpRequest/open-url-multi-window-3.htm [ Crash ] -crbug.com/591099 external/wpt/XMLHttpRequest/open-url-multi-window-4.htm [ Crash ] +crbug.com/591099 external/wpt/WebIDL/ecmascript-binding/sequence-conversion.html [ Crash Pass ] +crbug.com/591099 external/wpt/XMLHttpRequest/open-url-multi-window-2.htm [ Crash Pass ] +crbug.com/591099 external/wpt/XMLHttpRequest/open-url-multi-window-3.htm [ Crash Pass ] +crbug.com/591099 external/wpt/XMLHttpRequest/open-url-multi-window-4.htm [ Crash Pass ] crbug.com/591099 external/wpt/XMLHttpRequest/send-authentication-prompt-2-manual.htm [ Crash Failure ] -crbug.com/591099 external/wpt/XMLHttpRequest/xmlhttprequest-sync-block-defer-scripts.html [ Crash ] -crbug.com/591099 external/wpt/XMLHttpRequest/xmlhttprequest-sync-not-hang-scriptloader.html [ Crash ] -crbug.com/591099 external/wpt/clear-site-data/navigation-insecure.html [ Crash ] -crbug.com/591099 external/wpt/clear-site-data/navigation.https.html [ Crash ] -crbug.com/591099 external/wpt/content-security-policy/child-src/child-src-about-blank-allowed-by-default.sub.html [ Crash ] -crbug.com/591099 external/wpt/content-security-policy/child-src/child-src-about-blank-allowed-by-scheme.sub.html [ Crash ] -crbug.com/591099 external/wpt/content-security-policy/child-src/child-src-allowed.sub.html [ Crash ] -crbug.com/591099 external/wpt/content-security-policy/child-src/child-src-blocked.sub.html [ Crash ] -crbug.com/591099 external/wpt/content-security-policy/child-src/child-src-conflicting-frame-src.sub.html [ Crash ] -crbug.com/591099 external/wpt/content-security-policy/child-src/child-src-cross-origin-load.sub.html [ Crash ] -crbug.com/591099 external/wpt/content-security-policy/child-src/child-src-redirect-blocked.sub.html [ Crash ] -crbug.com/591099 external/wpt/content-security-policy/embedded-enforcement/allow_csp_from-header.html [ Crash ] -crbug.com/591099 external/wpt/content-security-policy/embedded-enforcement/required_csp-header.html [ Crash ] -crbug.com/591099 external/wpt/content-security-policy/embedded-enforcement/subsumption_algorithm-general.html [ Crash ] -crbug.com/591099 external/wpt/content-security-policy/embedded-enforcement/subsumption_algorithm-hashes.html [ Crash ] -crbug.com/591099 external/wpt/content-security-policy/embedded-enforcement/subsumption_algorithm-host_sources-hosts.html [ Crash ] -crbug.com/591099 external/wpt/content-security-policy/embedded-enforcement/subsumption_algorithm-host_sources-paths.html [ Crash ] -crbug.com/591099 external/wpt/content-security-policy/embedded-enforcement/subsumption_algorithm-host_sources-ports.html [ Crash ] -crbug.com/591099 external/wpt/content-security-policy/embedded-enforcement/subsumption_algorithm-host_sources-protocols.html [ Crash ] -crbug.com/591099 external/wpt/content-security-policy/embedded-enforcement/subsumption_algorithm-nonces.html [ Crash ] -crbug.com/591099 external/wpt/content-security-policy/embedded-enforcement/subsumption_algorithm-none.html [ Crash ] -crbug.com/591099 external/wpt/content-security-policy/embedded-enforcement/subsumption_algorithm-self.html [ Crash ] -crbug.com/591099 external/wpt/content-security-policy/embedded-enforcement/subsumption_algorithm-strict_dynamic.html [ Crash ] -crbug.com/591099 external/wpt/content-security-policy/embedded-enforcement/subsumption_algorithm-unsafe_eval.html [ Crash ] -crbug.com/591099 external/wpt/content-security-policy/embedded-enforcement/subsumption_algorithm-unsafe_hashed_attributes.html [ Crash ] -crbug.com/591099 external/wpt/content-security-policy/embedded-enforcement/subsumption_algorithm-unsafe_inline.html [ Crash ] -crbug.com/591099 external/wpt/content-security-policy/frame-ancestors/frame-ancestors-overrides-xfo.html [ Crash ] -crbug.com/591099 external/wpt/content-security-policy/frame-src/frame-src-redirect.html [ Crash ] -crbug.com/591099 external/wpt/content-security-policy/generic/no-default-src.sub.html [ Crash ] -crbug.com/591099 external/wpt/content-security-policy/img-src/img-src-full-host-wildcard-blocked.sub.html [ Crash ] -crbug.com/591099 external/wpt/content-security-policy/img-src/img-src-host-partial-wildcard-allowed.sub.html [ Crash ] -crbug.com/591099 external/wpt/content-security-policy/img-src/img-src-none-blocks.html [ Crash ] -crbug.com/591099 external/wpt/content-security-policy/img-src/img-src-port-wildcard-allowed.sub.html [ Crash ] -crbug.com/591099 external/wpt/content-security-policy/img-src/img-src-wildcard-allowed.html [ Crash ] -crbug.com/591099 external/wpt/content-security-policy/meta/meta-img-src.html [ Crash ] -crbug.com/591099 external/wpt/content-security-policy/meta/meta-modified.html [ Crash ] -crbug.com/591099 external/wpt/content-security-policy/navigation/to-javascript-url-frame-src.html [ Crash ] -crbug.com/591099 external/wpt/content-security-policy/navigation/to-javascript-url-script-src.html [ Crash ] -crbug.com/591099 external/wpt/content-security-policy/nonce-hiding/svgscript-nonces-hidden-meta.tentative.html [ Crash ] -crbug.com/591099 external/wpt/content-security-policy/nonce-hiding/svgscript-nonces-hidden.tentative.html [ Crash ] +crbug.com/591099 external/wpt/XMLHttpRequest/xmlhttprequest-sync-block-defer-scripts.html [ Crash Pass ] +crbug.com/591099 external/wpt/XMLHttpRequest/xmlhttprequest-sync-not-hang-scriptloader.html [ Crash Pass ] +crbug.com/591099 external/wpt/clear-site-data/navigation-insecure.html [ Crash Pass ] +crbug.com/591099 external/wpt/clear-site-data/navigation.https.html [ Crash Pass ] +crbug.com/591099 external/wpt/content-security-policy/child-src/child-src-about-blank-allowed-by-default.sub.html [ Crash Pass ] +crbug.com/591099 external/wpt/content-security-policy/child-src/child-src-about-blank-allowed-by-scheme.sub.html [ Crash Pass ] +crbug.com/591099 external/wpt/content-security-policy/child-src/child-src-allowed.sub.html [ Crash Pass ] +crbug.com/591099 external/wpt/content-security-policy/child-src/child-src-blocked.sub.html [ Crash Pass ] +crbug.com/591099 external/wpt/content-security-policy/child-src/child-src-conflicting-frame-src.sub.html [ Crash Pass ] +crbug.com/591099 external/wpt/content-security-policy/child-src/child-src-cross-origin-load.sub.html [ Crash Pass ] +crbug.com/591099 external/wpt/content-security-policy/child-src/child-src-redirect-blocked.sub.html [ Crash Pass ] +crbug.com/591099 external/wpt/content-security-policy/embedded-enforcement/allow_csp_from-header.html [ Crash Pass ] +crbug.com/591099 external/wpt/content-security-policy/embedded-enforcement/required_csp-header.html [ Crash Pass ] +crbug.com/591099 external/wpt/content-security-policy/embedded-enforcement/subsumption_algorithm-general.html [ Crash Pass ] +crbug.com/591099 external/wpt/content-security-policy/embedded-enforcement/subsumption_algorithm-hashes.html [ Crash Pass ] +crbug.com/591099 external/wpt/content-security-policy/embedded-enforcement/subsumption_algorithm-host_sources-hosts.html [ Crash Pass ] +crbug.com/591099 external/wpt/content-security-policy/embedded-enforcement/subsumption_algorithm-host_sources-paths.html [ Crash Pass ] +crbug.com/591099 external/wpt/content-security-policy/embedded-enforcement/subsumption_algorithm-host_sources-ports.html [ Crash Pass ] +crbug.com/591099 external/wpt/content-security-policy/embedded-enforcement/subsumption_algorithm-host_sources-protocols.html [ Crash Pass ] +crbug.com/591099 external/wpt/content-security-policy/embedded-enforcement/subsumption_algorithm-nonces.html [ Crash Pass ] +crbug.com/591099 external/wpt/content-security-policy/embedded-enforcement/subsumption_algorithm-none.html [ Crash Pass ] +crbug.com/591099 external/wpt/content-security-policy/embedded-enforcement/subsumption_algorithm-self.html [ Crash Pass ] +crbug.com/591099 external/wpt/content-security-policy/embedded-enforcement/subsumption_algorithm-strict_dynamic.html [ Crash Pass ] +crbug.com/591099 external/wpt/content-security-policy/embedded-enforcement/subsumption_algorithm-unsafe_eval.html [ Crash Pass ] +crbug.com/591099 external/wpt/content-security-policy/embedded-enforcement/subsumption_algorithm-unsafe_hashed_attributes.html [ Crash Pass ] +crbug.com/591099 external/wpt/content-security-policy/embedded-enforcement/subsumption_algorithm-unsafe_inline.html [ Crash Pass ] +crbug.com/591099 external/wpt/content-security-policy/frame-ancestors/frame-ancestors-overrides-xfo.html [ Crash Pass ] +crbug.com/591099 external/wpt/content-security-policy/frame-src/frame-src-redirect.html [ Crash Pass ] +crbug.com/591099 external/wpt/content-security-policy/generic/no-default-src.sub.html [ Crash Pass ] +crbug.com/591099 external/wpt/content-security-policy/img-src/img-src-full-host-wildcard-blocked.sub.html [ Crash Pass ] +crbug.com/591099 external/wpt/content-security-policy/img-src/img-src-host-partial-wildcard-allowed.sub.html [ Crash Pass ] +crbug.com/591099 external/wpt/content-security-policy/img-src/img-src-none-blocks.html [ Crash Pass ] +crbug.com/591099 external/wpt/content-security-policy/img-src/img-src-port-wildcard-allowed.sub.html [ Crash Pass ] +crbug.com/591099 external/wpt/content-security-policy/img-src/img-src-wildcard-allowed.html [ Crash Pass ] +crbug.com/591099 external/wpt/content-security-policy/meta/meta-img-src.html [ Crash Pass ] +crbug.com/591099 external/wpt/content-security-policy/meta/meta-modified.html [ Crash Pass ] +crbug.com/591099 external/wpt/content-security-policy/navigation/to-javascript-url-frame-src.html [ Crash Pass ] +crbug.com/591099 external/wpt/content-security-policy/navigation/to-javascript-url-script-src.html [ Crash Pass ] +crbug.com/591099 external/wpt/content-security-policy/nonce-hiding/svgscript-nonces-hidden-meta.tentative.html [ Crash Pass ] +crbug.com/591099 external/wpt/content-security-policy/nonce-hiding/svgscript-nonces-hidden.tentative.html [ Crash Pass ] crbug.com/591099 external/wpt/content-security-policy/script-src/script-src-1_2.html [ Crash Pass ] -crbug.com/591099 external/wpt/content-security-policy/securitypolicyviolation/img-src-redirect-upgrade-reporting.https.html [ Crash ] -crbug.com/591099 external/wpt/content-security-policy/securitypolicyviolation/script-sample-no-opt-in.html [ Crash ] -crbug.com/591099 external/wpt/content-security-policy/securitypolicyviolation/script-sample.html [ Crash ] -crbug.com/591099 external/wpt/content-security-policy/securitypolicyviolation/upgrade-insecure-requests-reporting.https.html [ Crash ] -crbug.com/591099 external/wpt/content-security-policy/svg/object-in-svg-foreignobject.sub.html [ Crash ] -crbug.com/591099 external/wpt/content-security-policy/svg/svg-from-guid.html [ Crash ] -crbug.com/591099 external/wpt/content-security-policy/svg/svg-policy-resource-doc-includes.html [ Crash ] -crbug.com/591099 external/wpt/content-security-policy/svg/svg-policy-with-resource.html [ Crash ] -crbug.com/591099 external/wpt/cors/remote-origin.htm [ Crash ] +crbug.com/591099 external/wpt/content-security-policy/securitypolicyviolation/img-src-redirect-upgrade-reporting.https.html [ Crash Pass ] +crbug.com/591099 external/wpt/content-security-policy/securitypolicyviolation/script-sample-no-opt-in.html [ Crash Pass ] +crbug.com/591099 external/wpt/content-security-policy/securitypolicyviolation/script-sample.html [ Crash Pass ] +crbug.com/591099 external/wpt/content-security-policy/securitypolicyviolation/upgrade-insecure-requests-reporting.https.html [ Crash Pass ] +crbug.com/591099 external/wpt/content-security-policy/svg/object-in-svg-foreignobject.sub.html [ Crash Pass ] +crbug.com/591099 external/wpt/content-security-policy/svg/svg-from-guid.html [ Crash Pass ] +crbug.com/591099 external/wpt/content-security-policy/svg/svg-policy-resource-doc-includes.html [ Crash Pass ] +crbug.com/591099 external/wpt/content-security-policy/svg/svg-policy-with-resource.html [ Crash Pass ] +crbug.com/591099 external/wpt/cors/remote-origin.htm [ Crash Pass ] crbug.com/591099 external/wpt/css-paint-api/geometry-background-image-001.html [ Failure Pass ] crbug.com/591099 external/wpt/css-paint-api/geometry-background-image-002.html [ Failure Pass ] crbug.com/591099 external/wpt/css-paint-api/geometry-background-image-003.html [ Failure Pass ] @@ -4392,7 +4392,7 @@ crbug.com/591099 external/wpt/css/css-display-3/display-contents-dynamic-list-001-none.html [ Failure ] crbug.com/591099 external/wpt/css/css-display-3/display-contents-dynamic-multicol-001-inline.html [ Failure ] crbug.com/591099 external/wpt/css/css-display-3/display-contents-dynamic-multicol-001-none.html [ Failure ] -crbug.com/591099 external/wpt/css/css-display-3/display-contents-dynamic-table-001-inline.html [ Crash ] +crbug.com/591099 external/wpt/css/css-display-3/display-contents-dynamic-table-001-inline.html [ Crash Failure ] crbug.com/591099 external/wpt/css/css-display-3/display-contents-list-001.html [ Failure ] crbug.com/591099 external/wpt/css/css-display-3/display-contents-multicol-001.html [ Failure ] crbug.com/591099 external/wpt/css/css-display-3/display-flow-root-001.html [ Failure ] @@ -4601,54 +4601,54 @@ crbug.com/591099 external/wpt/css/css-grid-1/abspos/positioned-grid-items-015.html [ Failure ] crbug.com/591099 external/wpt/css/css-grid-1/abspos/positioned-grid-items-016.html [ Failure ] crbug.com/591099 external/wpt/css/css-grid-1/abspos/positioned-grid-items-017.html [ Failure ] -crbug.com/591099 external/wpt/css/css-grid-1/alignment/grid-self-alignment-stretch-001.html [ Crash ] -crbug.com/591099 external/wpt/css/css-grid-1/alignment/grid-self-alignment-stretch-002.html [ Crash ] -crbug.com/591099 external/wpt/css/css-grid-1/alignment/grid-self-alignment-stretch-003.html [ Crash ] -crbug.com/591099 external/wpt/css/css-grid-1/alignment/grid-self-alignment-stretch-004.html [ Crash ] -crbug.com/591099 external/wpt/css/css-grid-1/alignment/grid-self-alignment-stretch-005.html [ Crash ] -crbug.com/591099 external/wpt/css/css-grid-1/alignment/grid-self-alignment-stretch-006.html [ Crash ] -crbug.com/591099 external/wpt/css/css-grid-1/alignment/grid-self-alignment-stretch-007.html [ Crash ] -crbug.com/591099 external/wpt/css/css-grid-1/alignment/grid-self-alignment-stretch-008.html [ Crash ] -crbug.com/591099 external/wpt/css/css-grid-1/alignment/grid-self-alignment-stretch-009.html [ Crash ] -crbug.com/591099 external/wpt/css/css-grid-1/alignment/grid-self-alignment-stretch-010.html [ Crash ] -crbug.com/591099 external/wpt/css/css-grid-1/alignment/grid-self-alignment-stretch-011.html [ Crash ] -crbug.com/591099 external/wpt/css/css-grid-1/alignment/grid-self-alignment-stretch-012.html [ Crash ] -crbug.com/591099 external/wpt/css/css-grid-1/alignment/grid-self-alignment-stretch-013.html [ Crash ] -crbug.com/591099 external/wpt/css/css-grid-1/alignment/grid-self-alignment-stretch-014.html [ Crash ] -crbug.com/591099 external/wpt/css/css-grid-1/alignment/grid-self-alignment-stretch-015.html [ Crash ] -crbug.com/591099 external/wpt/css/css-grid-1/alignment/grid-self-alignment-stretch-016.html [ Crash ] -crbug.com/591099 external/wpt/css/css-grid-1/alignment/grid-self-alignment-stretch-vertical-lr-001.html [ Crash ] -crbug.com/591099 external/wpt/css/css-grid-1/alignment/grid-self-alignment-stretch-vertical-lr-002.html [ Crash ] -crbug.com/591099 external/wpt/css/css-grid-1/alignment/grid-self-alignment-stretch-vertical-lr-003.html [ Crash ] -crbug.com/591099 external/wpt/css/css-grid-1/alignment/grid-self-alignment-stretch-vertical-lr-004.html [ Crash ] -crbug.com/591099 external/wpt/css/css-grid-1/alignment/grid-self-alignment-stretch-vertical-lr-005.html [ Crash ] -crbug.com/591099 external/wpt/css/css-grid-1/alignment/grid-self-alignment-stretch-vertical-lr-006.html [ Crash ] -crbug.com/591099 external/wpt/css/css-grid-1/alignment/grid-self-alignment-stretch-vertical-lr-007.html [ Crash ] -crbug.com/591099 external/wpt/css/css-grid-1/alignment/grid-self-alignment-stretch-vertical-lr-008.html [ Crash ] -crbug.com/591099 external/wpt/css/css-grid-1/alignment/grid-self-alignment-stretch-vertical-lr-009.html [ Crash ] -crbug.com/591099 external/wpt/css/css-grid-1/alignment/grid-self-alignment-stretch-vertical-lr-010.html [ Crash ] -crbug.com/591099 external/wpt/css/css-grid-1/alignment/grid-self-alignment-stretch-vertical-lr-011.html [ Crash ] -crbug.com/591099 external/wpt/css/css-grid-1/alignment/grid-self-alignment-stretch-vertical-lr-012.html [ Crash ] -crbug.com/591099 external/wpt/css/css-grid-1/alignment/grid-self-alignment-stretch-vertical-lr-013.html [ Crash ] -crbug.com/591099 external/wpt/css/css-grid-1/alignment/grid-self-alignment-stretch-vertical-lr-014.html [ Crash ] -crbug.com/591099 external/wpt/css/css-grid-1/alignment/grid-self-alignment-stretch-vertical-lr-015.html [ Crash ] -crbug.com/591099 external/wpt/css/css-grid-1/alignment/grid-self-alignment-stretch-vertical-lr-016.html [ Crash ] -crbug.com/591099 external/wpt/css/css-grid-1/alignment/grid-self-alignment-stretch-vertical-rl-001.html [ Crash ] -crbug.com/591099 external/wpt/css/css-grid-1/alignment/grid-self-alignment-stretch-vertical-rl-002.html [ Crash ] -crbug.com/591099 external/wpt/css/css-grid-1/alignment/grid-self-alignment-stretch-vertical-rl-003.html [ Crash ] -crbug.com/591099 external/wpt/css/css-grid-1/alignment/grid-self-alignment-stretch-vertical-rl-004.html [ Crash ] -crbug.com/591099 external/wpt/css/css-grid-1/alignment/grid-self-alignment-stretch-vertical-rl-005.html [ Crash ] -crbug.com/591099 external/wpt/css/css-grid-1/alignment/grid-self-alignment-stretch-vertical-rl-006.html [ Crash ] -crbug.com/591099 external/wpt/css/css-grid-1/alignment/grid-self-alignment-stretch-vertical-rl-007.html [ Crash ] -crbug.com/591099 external/wpt/css/css-grid-1/alignment/grid-self-alignment-stretch-vertical-rl-008.html [ Crash ] -crbug.com/591099 external/wpt/css/css-grid-1/alignment/grid-self-alignment-stretch-vertical-rl-009.html [ Crash ] -crbug.com/591099 external/wpt/css/css-grid-1/alignment/grid-self-alignment-stretch-vertical-rl-010.html [ Crash ] -crbug.com/591099 external/wpt/css/css-grid-1/alignment/grid-self-alignment-stretch-vertical-rl-011.html [ Crash ] -crbug.com/591099 external/wpt/css/css-grid-1/alignment/grid-self-alignment-stretch-vertical-rl-012.html [ Crash ] -crbug.com/591099 external/wpt/css/css-grid-1/alignment/grid-self-alignment-stretch-vertical-rl-013.html [ Crash ] -crbug.com/591099 external/wpt/css/css-grid-1/alignment/grid-self-alignment-stretch-vertical-rl-014.html [ Crash ] -crbug.com/591099 external/wpt/css/css-grid-1/alignment/grid-self-alignment-stretch-vertical-rl-015.html [ Crash ] -crbug.com/591099 external/wpt/css/css-grid-1/alignment/grid-self-alignment-stretch-vertical-rl-016.html [ Crash ] +crbug.com/591099 external/wpt/css/css-grid-1/alignment/grid-self-alignment-stretch-001.html [ Crash Failure ] +crbug.com/591099 external/wpt/css/css-grid-1/alignment/grid-self-alignment-stretch-002.html [ Crash Failure ] +crbug.com/591099 external/wpt/css/css-grid-1/alignment/grid-self-alignment-stretch-003.html [ Crash Failure ] +crbug.com/591099 external/wpt/css/css-grid-1/alignment/grid-self-alignment-stretch-004.html [ Crash Failure ] +crbug.com/591099 external/wpt/css/css-grid-1/alignment/grid-self-alignment-stretch-005.html [ Crash Failure ] +crbug.com/591099 external/wpt/css/css-grid-1/alignment/grid-self-alignment-stretch-006.html [ Crash Failure ] +crbug.com/591099 external/wpt/css/css-grid-1/alignment/grid-self-alignment-stretch-007.html [ Crash Failure ] +crbug.com/591099 external/wpt/css/css-grid-1/alignment/grid-self-alignment-stretch-008.html [ Crash Failure ] +crbug.com/591099 external/wpt/css/css-grid-1/alignment/grid-self-alignment-stretch-009.html [ Crash Pass ] +crbug.com/591099 external/wpt/css/css-grid-1/alignment/grid-self-alignment-stretch-010.html [ Crash Failure ] +crbug.com/591099 external/wpt/css/css-grid-1/alignment/grid-self-alignment-stretch-011.html [ Crash Pass ] +crbug.com/591099 external/wpt/css/css-grid-1/alignment/grid-self-alignment-stretch-012.html [ Crash Pass ] +crbug.com/591099 external/wpt/css/css-grid-1/alignment/grid-self-alignment-stretch-013.html [ Crash Failure ] +crbug.com/591099 external/wpt/css/css-grid-1/alignment/grid-self-alignment-stretch-014.html [ Crash Failure ] +crbug.com/591099 external/wpt/css/css-grid-1/alignment/grid-self-alignment-stretch-015.html [ Crash Failure ] +crbug.com/591099 external/wpt/css/css-grid-1/alignment/grid-self-alignment-stretch-016.html [ Crash Failure ] +crbug.com/591099 external/wpt/css/css-grid-1/alignment/grid-self-alignment-stretch-vertical-lr-001.html [ Crash Failure ] +crbug.com/591099 external/wpt/css/css-grid-1/alignment/grid-self-alignment-stretch-vertical-lr-002.html [ Crash Failure ] +crbug.com/591099 external/wpt/css/css-grid-1/alignment/grid-self-alignment-stretch-vertical-lr-003.html [ Crash Failure ] +crbug.com/591099 external/wpt/css/css-grid-1/alignment/grid-self-alignment-stretch-vertical-lr-004.html [ Crash Failure ] +crbug.com/591099 external/wpt/css/css-grid-1/alignment/grid-self-alignment-stretch-vertical-lr-005.html [ Crash Pass ] +crbug.com/591099 external/wpt/css/css-grid-1/alignment/grid-self-alignment-stretch-vertical-lr-006.html [ Crash Failure ] +crbug.com/591099 external/wpt/css/css-grid-1/alignment/grid-self-alignment-stretch-vertical-lr-007.html [ Crash Pass ] +crbug.com/591099 external/wpt/css/css-grid-1/alignment/grid-self-alignment-stretch-vertical-lr-008.html [ Crash Pass ] +crbug.com/591099 external/wpt/css/css-grid-1/alignment/grid-self-alignment-stretch-vertical-lr-009.html [ Crash Failure ] +crbug.com/591099 external/wpt/css/css-grid-1/alignment/grid-self-alignment-stretch-vertical-lr-010.html [ Crash Failure ] +crbug.com/591099 external/wpt/css/css-grid-1/alignment/grid-self-alignment-stretch-vertical-lr-011.html [ Crash Failure ] +crbug.com/591099 external/wpt/css/css-grid-1/alignment/grid-self-alignment-stretch-vertical-lr-012.html [ Crash Failure ] +crbug.com/591099 external/wpt/css/css-grid-1/alignment/grid-self-alignment-stretch-vertical-lr-013.html [ Crash Pass ] +crbug.com/591099 external/wpt/css/css-grid-1/alignment/grid-self-alignment-stretch-vertical-lr-014.html [ Crash Failure ] +crbug.com/591099 external/wpt/css/css-grid-1/alignment/grid-self-alignment-stretch-vertical-lr-015.html [ Crash Pass ] +crbug.com/591099 external/wpt/css/css-grid-1/alignment/grid-self-alignment-stretch-vertical-lr-016.html [ Crash Pass ] +crbug.com/591099 external/wpt/css/css-grid-1/alignment/grid-self-alignment-stretch-vertical-rl-001.html [ Crash Failure ] +crbug.com/591099 external/wpt/css/css-grid-1/alignment/grid-self-alignment-stretch-vertical-rl-002.html [ Crash Failure ] +crbug.com/591099 external/wpt/css/css-grid-1/alignment/grid-self-alignment-stretch-vertical-rl-003.html [ Crash Failure ] +crbug.com/591099 external/wpt/css/css-grid-1/alignment/grid-self-alignment-stretch-vertical-rl-004.html [ Crash Failure ] +crbug.com/591099 external/wpt/css/css-grid-1/alignment/grid-self-alignment-stretch-vertical-rl-005.html [ Crash Pass ] +crbug.com/591099 external/wpt/css/css-grid-1/alignment/grid-self-alignment-stretch-vertical-rl-006.html [ Crash Failure ] +crbug.com/591099 external/wpt/css/css-grid-1/alignment/grid-self-alignment-stretch-vertical-rl-007.html [ Crash Pass ] +crbug.com/591099 external/wpt/css/css-grid-1/alignment/grid-self-alignment-stretch-vertical-rl-008.html [ Crash Pass ] +crbug.com/591099 external/wpt/css/css-grid-1/alignment/grid-self-alignment-stretch-vertical-rl-009.html [ Crash Failure ] +crbug.com/591099 external/wpt/css/css-grid-1/alignment/grid-self-alignment-stretch-vertical-rl-010.html [ Crash Failure ] +crbug.com/591099 external/wpt/css/css-grid-1/alignment/grid-self-alignment-stretch-vertical-rl-011.html [ Crash Failure ] +crbug.com/591099 external/wpt/css/css-grid-1/alignment/grid-self-alignment-stretch-vertical-rl-012.html [ Crash Failure ] +crbug.com/591099 external/wpt/css/css-grid-1/alignment/grid-self-alignment-stretch-vertical-rl-013.html [ Crash Pass ] +crbug.com/591099 external/wpt/css/css-grid-1/alignment/grid-self-alignment-stretch-vertical-rl-014.html [ Crash Failure ] +crbug.com/591099 external/wpt/css/css-grid-1/alignment/grid-self-alignment-stretch-vertical-rl-015.html [ Crash Pass ] +crbug.com/591099 external/wpt/css/css-grid-1/alignment/grid-self-alignment-stretch-vertical-rl-016.html [ Crash Pass ] crbug.com/591099 external/wpt/css/css-grid-1/grid-definition/fr-unit-with-percentage.html [ Failure ] crbug.com/591099 external/wpt/css/css-grid-1/grid-definition/fr-unit.html [ Failure ] crbug.com/591099 external/wpt/css/css-grid-1/grid-items/grid-inline-z-axis-ordering-overlapped-items-006.html [ Failure ] @@ -4659,7 +4659,7 @@ crbug.com/591099 external/wpt/css/css-grid-1/grid-items/grid-z-axis-ordering-overlapped-items-006.html [ Failure ] crbug.com/591099 external/wpt/css/css-grid-1/grid-model/grid-inline-margins-no-collapse-001.html [ Failure ] crbug.com/591099 external/wpt/css/css-grid-1/grid-model/grid-margins-no-collapse-001.html [ Failure ] -crbug.com/591099 external/wpt/css/css-grid-1/grid-model/grid-support-display-001.html [ Crash ] +crbug.com/591099 external/wpt/css/css-grid-1/grid-model/grid-support-display-001.html [ Crash Pass ] crbug.com/591099 external/wpt/css/css-position-3/position-sticky-table-th-left.html [ Failure Pass ] crbug.com/591099 external/wpt/css/css-position-3/position-sticky-table-th-right.html [ Failure Pass ] crbug.com/591099 external/wpt/css/css-rhythm-1/line-height-step-basic-001.html [ Failure ] @@ -4790,11 +4790,11 @@ crbug.com/591099 external/wpt/css/css-ui-3/box-sizing-009.html [ Failure ] crbug.com/591099 external/wpt/css/css-ui-3/box-sizing-010.html [ Failure Pass ] crbug.com/591099 external/wpt/css/css-ui-3/box-sizing-020.html [ Failure Pass ] -crbug.com/591099 external/wpt/css/css-ui-3/caret-color-013.html [ Crash ] -crbug.com/591099 external/wpt/css/css-ui-3/caret-color-018.html [ Crash ] -crbug.com/591099 external/wpt/css/css-ui-3/caret-color-019.html [ Crash ] -crbug.com/591099 external/wpt/css/css-ui-3/caret-color-020.html [ Crash ] -crbug.com/591099 external/wpt/css/css-ui-3/caret-color-021.html [ Crash ] +crbug.com/591099 external/wpt/css/css-ui-3/caret-color-013.html [ Crash Pass ] +crbug.com/591099 external/wpt/css/css-ui-3/caret-color-018.html [ Crash Pass ] +crbug.com/591099 external/wpt/css/css-ui-3/caret-color-019.html [ Crash Pass ] +crbug.com/591099 external/wpt/css/css-ui-3/caret-color-020.html [ Crash Pass ] +crbug.com/591099 external/wpt/css/css-ui-3/caret-color-021.html [ Crash Pass ] crbug.com/591099 external/wpt/css/css-ui-3/outline-004.html [ Failure Pass ] crbug.com/591099 external/wpt/css/css-ui-3/outline-011.html [ Failure ] crbug.com/591099 external/wpt/css/css-ui-3/outline-019.html [ Failure ] @@ -5077,14 +5077,14 @@ crbug.com/591099 external/wpt/css/css-writing-modes-3/normal-flow-overconstrained-vrl-004.xht [ Failure ] crbug.com/591099 external/wpt/css/css-writing-modes-3/ortho-htb-alongside-vrl-floats-002.xht [ Failure ] crbug.com/591099 external/wpt/css/css-writing-modes-3/ortho-htb-alongside-vrl-floats-010.xht [ Failure ] -crbug.com/591099 external/wpt/css/css-writing-modes-3/orthogonal-parent-shrink-to-fit-001a.html [ Crash ] -crbug.com/591099 external/wpt/css/css-writing-modes-3/orthogonal-parent-shrink-to-fit-001b.html [ Crash ] -crbug.com/591099 external/wpt/css/css-writing-modes-3/orthogonal-parent-shrink-to-fit-001c.html [ Crash ] -crbug.com/591099 external/wpt/css/css-writing-modes-3/orthogonal-parent-shrink-to-fit-001d.html [ Crash ] -crbug.com/591099 external/wpt/css/css-writing-modes-3/orthogonal-parent-shrink-to-fit-001e.html [ Crash ] -crbug.com/591099 external/wpt/css/css-writing-modes-3/orthogonal-parent-shrink-to-fit-001f.html [ Crash ] -crbug.com/591099 external/wpt/css/css-writing-modes-3/orthogonal-parent-shrink-to-fit-001g.html [ Crash ] -crbug.com/591099 external/wpt/css/css-writing-modes-3/orthogonal-parent-shrink-to-fit-001h.html [ Crash ] +crbug.com/591099 external/wpt/css/css-writing-modes-3/orthogonal-parent-shrink-to-fit-001a.html [ Crash Failure ] +crbug.com/591099 external/wpt/css/css-writing-modes-3/orthogonal-parent-shrink-to-fit-001b.html [ Crash Pass ] +crbug.com/591099 external/wpt/css/css-writing-modes-3/orthogonal-parent-shrink-to-fit-001c.html [ Crash Failure ] +crbug.com/591099 external/wpt/css/css-writing-modes-3/orthogonal-parent-shrink-to-fit-001d.html [ Crash Failure ] +crbug.com/591099 external/wpt/css/css-writing-modes-3/orthogonal-parent-shrink-to-fit-001e.html [ Crash Failure ] +crbug.com/591099 external/wpt/css/css-writing-modes-3/orthogonal-parent-shrink-to-fit-001f.html [ Crash Pass ] +crbug.com/591099 external/wpt/css/css-writing-modes-3/orthogonal-parent-shrink-to-fit-001g.html [ Crash Failure ] +crbug.com/591099 external/wpt/css/css-writing-modes-3/orthogonal-parent-shrink-to-fit-001h.html [ Crash Failure ] crbug.com/591099 external/wpt/css/css-writing-modes-3/orthogonal-parent-shrink-to-fit-001i.html [ Failure ] crbug.com/591099 external/wpt/css/css-writing-modes-3/orthogonal-parent-shrink-to-fit-001k.html [ Failure ] crbug.com/591099 external/wpt/css/css-writing-modes-3/orthogonal-parent-shrink-to-fit-001l.html [ Crash Failure ] @@ -5199,9 +5199,9 @@ crbug.com/591099 external/wpt/css/css-writing-modes-3/writing-mode-vertical-rl-002.xht [ Failure ] crbug.com/591099 external/wpt/css/css-writing-modes-3/writing-mode-vertical-rl-003.htm [ Failure ] crbug.com/591099 external/wpt/css/geometry-1/interfaces.html [ Timeout ] -crbug.com/591099 external/wpt/css/selectors4/focus-display-none-001.html [ Crash ] -crbug.com/591099 external/wpt/css/selectors4/focus-within-009.html [ Crash ] -crbug.com/591099 external/wpt/css/selectors4/focus-within-display-none-001.html [ Crash ] +crbug.com/591099 external/wpt/css/selectors4/focus-display-none-001.html [ Crash Pass ] +crbug.com/591099 external/wpt/css/selectors4/focus-within-009.html [ Crash Pass ] +crbug.com/591099 external/wpt/css/selectors4/focus-within-display-none-001.html [ Crash Pass ] crbug.com/591099 external/wpt/css/vendor-imports/mozilla/mozilla-central-reftests/flexbox/flexbox-align-content-vert-001a.xhtml [ Crash Failure ] crbug.com/591099 external/wpt/css/vendor-imports/mozilla/mozilla-central-reftests/flexbox/flexbox-align-self-baseline-horiz-002.xhtml [ Failure Pass ] crbug.com/591099 external/wpt/css/vendor-imports/mozilla/mozilla-central-reftests/flexbox/flexbox-align-self-baseline-horiz-003.xhtml [ Failure Pass ] @@ -5253,49 +5253,49 @@ crbug.com/591099 external/wpt/css/vendor-imports/mozilla/mozilla-central-reftests/writing-modes-3/text-combine-upright-compression-006.html [ Crash Failure ] crbug.com/591099 external/wpt/css/vendor-imports/mozilla/mozilla-central-reftests/writing-modes-3/text-combine-upright-compression-007.html [ Crash Failure Pass ] crbug.com/591099 external/wpt/cssom-view/cssom-getClientRects-002.html [ Failure ] -crbug.com/591099 external/wpt/cssom-view/elementFromPoint.html [ Crash ] -crbug.com/591099 external/wpt/cssom-view/elementsFromPoint.html [ Crash ] -crbug.com/591099 external/wpt/cssom-view/scrolling-quirks-vs-nonquirks.html [ Crash ] -crbug.com/591099 external/wpt/cssom-view/scrollingElement.html [ Crash ] -crbug.com/591099 external/wpt/cssom-view/ttwf-js-cssomview-getclientrects-length.html [ Crash ] +crbug.com/591099 external/wpt/cssom-view/elementFromPoint.html [ Crash Failure ] +crbug.com/591099 external/wpt/cssom-view/elementsFromPoint.html [ Crash Failure ] +crbug.com/591099 external/wpt/cssom-view/scrolling-quirks-vs-nonquirks.html [ Crash Pass ] +crbug.com/591099 external/wpt/cssom-view/scrollingElement.html [ Crash Pass ] +crbug.com/591099 external/wpt/cssom-view/ttwf-js-cssomview-getclientrects-length.html [ Crash Pass ] crbug.com/591099 external/wpt/cssom/serialize-values.html [ Pass Timeout ] -crbug.com/591099 external/wpt/custom-elements/custom-element-reaction-queue.html [ Crash ] -crbug.com/591099 external/wpt/custom-elements/custom-element-registry/per-global.html [ Crash ] -crbug.com/591099 external/wpt/custom-elements/htmlconstructor/newtarget.html [ Crash ] -crbug.com/591099 external/wpt/custom-elements/reactions/Document.html [ Crash ] -crbug.com/591099 external/wpt/custom-elements/reactions/HTMLAnchorElement.html [ Crash ] -crbug.com/591099 external/wpt/custom-elements/reactions/HTMLOptionElement.html [ Crash ] -crbug.com/591099 external/wpt/custom-elements/reactions/HTMLOptionsCollection.html [ Crash ] -crbug.com/591099 external/wpt/custom-elements/reactions/HTMLOutputElement.html [ Crash ] -crbug.com/591099 external/wpt/custom-elements/reactions/HTMLSelectElement.html [ Crash ] -crbug.com/591099 external/wpt/custom-elements/reactions/HTMLTableElement.html [ Crash ] -crbug.com/591099 external/wpt/custom-elements/reactions/HTMLTableRowElement.html [ Crash ] -crbug.com/591099 external/wpt/custom-elements/reactions/HTMLTableSectionElement.html [ Crash ] -crbug.com/591099 external/wpt/custom-elements/reactions/HTMLTitleElement.html [ Crash ] -crbug.com/591099 external/wpt/custom-elements/reactions/ShadowRoot.html [ Crash ] -crbug.com/591099 external/wpt/custom-elements/upgrading/Node-cloneNode.html [ Crash ] -crbug.com/591099 external/wpt/custom-elements/upgrading/upgrading-enqueue-reactions.html [ Crash ] -crbug.com/591099 external/wpt/dom/events/EventListener-incumbent-global-1.sub.html [ Crash ] -crbug.com/591099 external/wpt/dom/events/EventListener-incumbent-global-2.sub.html [ Crash ] +crbug.com/591099 external/wpt/custom-elements/custom-element-reaction-queue.html [ Crash Pass ] +crbug.com/591099 external/wpt/custom-elements/custom-element-registry/per-global.html [ Crash Pass ] +crbug.com/591099 external/wpt/custom-elements/htmlconstructor/newtarget.html [ Crash Pass ] +crbug.com/591099 external/wpt/custom-elements/reactions/Document.html [ Crash Failure ] +crbug.com/591099 external/wpt/custom-elements/reactions/HTMLAnchorElement.html [ Crash Pass ] +crbug.com/591099 external/wpt/custom-elements/reactions/HTMLOptionElement.html [ Crash Pass ] +crbug.com/591099 external/wpt/custom-elements/reactions/HTMLOptionsCollection.html [ Crash Pass ] +crbug.com/591099 external/wpt/custom-elements/reactions/HTMLOutputElement.html [ Crash Pass ] +crbug.com/591099 external/wpt/custom-elements/reactions/HTMLSelectElement.html [ Crash Pass ] +crbug.com/591099 external/wpt/custom-elements/reactions/HTMLTableElement.html [ Crash Pass ] +crbug.com/591099 external/wpt/custom-elements/reactions/HTMLTableRowElement.html [ Crash Pass ] +crbug.com/591099 external/wpt/custom-elements/reactions/HTMLTableSectionElement.html [ Crash Pass ] +crbug.com/591099 external/wpt/custom-elements/reactions/HTMLTitleElement.html [ Crash Pass ] +crbug.com/591099 external/wpt/custom-elements/reactions/ShadowRoot.html [ Crash Pass ] +crbug.com/591099 external/wpt/custom-elements/upgrading/Node-cloneNode.html [ Crash Pass ] +crbug.com/591099 external/wpt/custom-elements/upgrading/upgrading-enqueue-reactions.html [ Crash Pass ] +crbug.com/591099 external/wpt/dom/events/EventListener-incumbent-global-1.sub.html [ Crash Pass ] +crbug.com/591099 external/wpt/dom/events/EventListener-incumbent-global-2.sub.html [ Crash Pass ] crbug.com/591099 external/wpt/dom/interfaces.html [ Pass Timeout ] crbug.com/591099 external/wpt/dom/nodes/DOMImplementation-createDocument.html [ Pass Timeout ] -crbug.com/591099 external/wpt/dom/nodes/Document-URL.sub.html [ Crash ] -crbug.com/591099 external/wpt/dom/nodes/Document-createElement-namespace.html [ Crash ] +crbug.com/591099 external/wpt/dom/nodes/Document-URL.sub.html [ Crash Pass ] +crbug.com/591099 external/wpt/dom/nodes/Document-createElement-namespace.html [ Crash Pass ] crbug.com/591099 external/wpt/dom/nodes/Document-createElementNS.html [ Pass Timeout ] -crbug.com/591099 external/wpt/dom/nodes/Element-children.html [ Crash ] +crbug.com/591099 external/wpt/dom/nodes/Element-children.html [ Crash Pass ] crbug.com/591099 external/wpt/dom/nodes/Element-classlist.html [ Pass Timeout ] -crbug.com/591099 external/wpt/dom/nodes/Element-getElementsByTagName-change-document-HTMLNess.html [ Crash ] -crbug.com/591099 external/wpt/dom/nodes/Element-hasAttributes.html [ Crash ] +crbug.com/591099 external/wpt/dom/nodes/Element-getElementsByTagName-change-document-HTMLNess.html [ Crash Pass ] +crbug.com/591099 external/wpt/dom/nodes/Element-hasAttributes.html [ Crash Pass ] crbug.com/591099 external/wpt/dom/nodes/Element-matches.html [ Crash Failure Pass Timeout ] crbug.com/591099 external/wpt/dom/nodes/Element-webkitMatchesSelector.html [ Crash Failure Pass Timeout ] crbug.com/591099 external/wpt/dom/nodes/Node-compareDocumentPosition.html [ Pass Timeout ] -crbug.com/591099 external/wpt/dom/nodes/Node-contains-xml.xml [ Crash ] +crbug.com/591099 external/wpt/dom/nodes/Node-contains-xml.xml [ Crash Pass ] crbug.com/591099 external/wpt/dom/nodes/Node-contains.html [ Pass Timeout ] -crbug.com/591099 external/wpt/dom/nodes/Node-parentNode.html [ Crash ] +crbug.com/591099 external/wpt/dom/nodes/Node-parentNode.html [ Crash Pass ] crbug.com/591099 external/wpt/dom/nodes/Node-properties.html [ Pass Timeout ] crbug.com/591099 external/wpt/dom/nodes/ParentNode-querySelector-All-xht.xht [ Crash Pass Timeout ] crbug.com/591099 external/wpt/dom/nodes/ParentNode-querySelector-All.html [ Crash Pass Timeout ] -crbug.com/591099 external/wpt/dom/nodes/getElementsByClassName-30.htm [ Crash ] +crbug.com/591099 external/wpt/dom/nodes/getElementsByClassName-30.htm [ Crash Pass ] crbug.com/591099 external/wpt/dom/ranges/Range-compareBoundaryPoints.html [ Timeout ] crbug.com/591099 external/wpt/dom/ranges/Range-comparePoint.html [ Pass Timeout ] crbug.com/591099 external/wpt/dom/ranges/Range-insertNode.html [ Pass Timeout ] @@ -5308,21 +5308,21 @@ crbug.com/591099 external/wpt/dom/traversal/NodeIterator.html [ Pass Timeout ] crbug.com/591099 external/wpt/dom/traversal/TreeWalker.html [ Pass Timeout ] crbug.com/591099 external/wpt/domxpath/xml_xpath_runner.html [ Pass Timeout ] -crbug.com/591099 external/wpt/editing/event.html [ Crash ] -crbug.com/591099 external/wpt/editing/other/extra-text-nodes.html [ Crash ] -crbug.com/591099 external/wpt/editing/other/restoration.html [ Crash ] +crbug.com/591099 external/wpt/editing/event.html [ Crash Pass ] +crbug.com/591099 external/wpt/editing/other/extra-text-nodes.html [ Crash Pass ] +crbug.com/591099 external/wpt/editing/other/restoration.html [ Crash Pass ] crbug.com/591099 external/wpt/editing/run/backcolor.html [ Pass Timeout ] crbug.com/591099 external/wpt/editing/run/bold.html [ Pass Timeout ] crbug.com/591099 external/wpt/editing/run/fontname.html [ Pass Timeout ] crbug.com/591099 external/wpt/editing/run/fontsize.html [ Pass Timeout ] crbug.com/591099 external/wpt/editing/run/forecolor.html [ Pass Timeout ] crbug.com/591099 external/wpt/editing/run/formatblock.html [ Crash Failure Timeout ] -crbug.com/591099 external/wpt/editing/run/forwarddelete.html [ Crash ] +crbug.com/591099 external/wpt/editing/run/forwarddelete.html [ Crash Timeout ] crbug.com/591099 external/wpt/editing/run/hilitecolor.html [ Pass Timeout ] crbug.com/591099 external/wpt/editing/run/indent.html [ Crash Timeout ] -crbug.com/591099 external/wpt/editing/run/inserthorizontalrule.html [ Crash ] +crbug.com/591099 external/wpt/editing/run/inserthorizontalrule.html [ Crash Timeout ] crbug.com/591099 external/wpt/editing/run/inserthtml.html [ Crash Failure Timeout ] -crbug.com/591099 external/wpt/editing/run/insertimage.html [ Crash ] +crbug.com/591099 external/wpt/editing/run/insertimage.html [ Crash Timeout ] crbug.com/591099 external/wpt/editing/run/insertlinebreak.html [ Crash Failure Timeout ] crbug.com/591099 external/wpt/editing/run/insertorderedlist.html [ Crash Timeout ] crbug.com/591099 external/wpt/editing/run/insertparagraph.html [ Crash Failure Timeout ] @@ -5332,9 +5332,9 @@ crbug.com/591099 external/wpt/editing/run/justifyfull.html [ Pass Timeout ] crbug.com/591099 external/wpt/editing/run/justifyleft.html [ Pass Timeout ] crbug.com/591099 external/wpt/editing/run/justifyright.html [ Pass Timeout ] -crbug.com/591099 external/wpt/editing/run/multitest.html [ Crash ] +crbug.com/591099 external/wpt/editing/run/multitest.html [ Crash Timeout ] crbug.com/591099 external/wpt/editing/run/outdent.html [ Crash Timeout ] -crbug.com/591099 external/wpt/editing/run/removeformat.html [ Crash ] +crbug.com/591099 external/wpt/editing/run/removeformat.html [ Crash Timeout ] crbug.com/591099 external/wpt/editing/run/strikethrough.html [ Pass Timeout ] crbug.com/591099 external/wpt/editing/run/subscript.html [ Pass Timeout ] crbug.com/591099 external/wpt/editing/run/superscript.html [ Pass Timeout ] @@ -5410,90 +5410,90 @@ crbug.com/591099 external/wpt/encoding/legacy-mb-tchinese/big5/big5-encode-href-errors-misc.html [ Timeout ] crbug.com/591099 external/wpt/encoding/legacy-mb-tchinese/big5/big5-encode-href.html [ Timeout ] crbug.com/591099 external/wpt/encoding/textdecoder-fatal-single-byte.html [ Timeout ] -crbug.com/591099 external/wpt/eventsource/eventsource-onmessage-realm.htm [ Crash ] -crbug.com/591099 external/wpt/fetch/api/request/multi-globals/url-parsing.html [ Crash ] -crbug.com/591099 external/wpt/fetch/api/response/multi-globals/url-parsing.html [ Crash ] -crbug.com/591099 external/wpt/fetch/security/dangling-markup-mitigation.tentative.html [ Crash ] -crbug.com/591099 external/wpt/fetch/security/embedded-credentials.tentative.sub.html [ Crash ] -crbug.com/591099 external/wpt/fullscreen/api/element-request-fullscreen-and-remove-iframe-manual.html [ Crash ] -crbug.com/591099 external/wpt/fullscreen/model/move-to-iframe-manual.html [ Crash ] +crbug.com/591099 external/wpt/eventsource/eventsource-onmessage-realm.htm [ Crash Pass ] +crbug.com/591099 external/wpt/fetch/api/request/multi-globals/url-parsing.html [ Crash Pass ] +crbug.com/591099 external/wpt/fetch/api/response/multi-globals/url-parsing.html [ Crash Pass ] +crbug.com/591099 external/wpt/fetch/security/dangling-markup-mitigation.tentative.html [ Crash Pass ] +crbug.com/591099 external/wpt/fetch/security/embedded-credentials.tentative.sub.html [ Crash Pass ] +crbug.com/591099 external/wpt/fullscreen/api/element-request-fullscreen-and-remove-iframe-manual.html [ Crash Pass ] +crbug.com/591099 external/wpt/fullscreen/model/move-to-iframe-manual.html [ Crash Pass ] crbug.com/591099 external/wpt/html-media-capture/capture_audio_cancel-manual.html [ Crash Failure ] crbug.com/591099 external/wpt/html-media-capture/capture_image_cancel-manual.html [ Crash Failure ] crbug.com/591099 external/wpt/html-media-capture/capture_video_cancel-manual.html [ Crash Failure ] -crbug.com/591099 external/wpt/html/browsers/browsing-the-web/history-traversal/persisted-user-state-restoration/scroll-restoration-fragment-scrolling-cross-origin.html [ Crash ] -crbug.com/591099 external/wpt/html/browsers/browsing-the-web/history-traversal/persisted-user-state-restoration/scroll-restoration-navigation-cross-origin.html [ Crash ] -crbug.com/591099 external/wpt/html/browsers/browsing-the-web/navigating-across-documents/003.html [ Crash ] -crbug.com/591099 external/wpt/html/browsers/browsing-the-web/navigating-across-documents/004.html [ Crash ] -crbug.com/591099 external/wpt/html/browsers/browsing-the-web/navigating-across-documents/006.html [ Crash ] -crbug.com/591099 external/wpt/html/browsers/browsing-the-web/navigating-across-documents/014.html [ Crash ] -crbug.com/591099 external/wpt/html/browsers/browsing-the-web/navigating-across-documents/empty_fragment.html [ Crash ] -crbug.com/591099 external/wpt/html/browsers/browsing-the-web/navigating-across-documents/javascript-url-query-fragment-components.html [ Crash ] -crbug.com/591099 external/wpt/html/browsers/browsing-the-web/navigating-across-documents/javascript-url-return-value-handling.html [ Crash ] -crbug.com/591099 external/wpt/html/browsers/browsing-the-web/navigating-across-documents/navigation-unload-form-submit.html [ Crash ] -crbug.com/591099 external/wpt/html/browsers/browsing-the-web/navigating-across-documents/navigation-unload-same-origin-fragment.html [ Crash ] -crbug.com/591099 external/wpt/html/browsers/browsing-the-web/unloading-documents/002.html [ Crash ] -crbug.com/591099 external/wpt/html/browsers/browsing-the-web/unloading-documents/003.html [ Crash ] -crbug.com/591099 external/wpt/html/browsers/browsing-the-web/unloading-documents/004.html [ Crash ] -crbug.com/591099 external/wpt/html/browsers/browsing-the-web/unloading-documents/005.html [ Crash ] -crbug.com/591099 external/wpt/html/browsers/history/joint-session-history/joint-session-history-only-fully-active.html [ Crash ] -crbug.com/591099 external/wpt/html/browsers/history/the-location-interface/location-prototype-setting-cross-origin-domain.sub.html [ Crash ] -crbug.com/591099 external/wpt/html/browsers/history/the-location-interface/location-prototype-setting-cross-origin.sub.html [ Crash ] -crbug.com/591099 external/wpt/html/browsers/history/the-location-interface/location-prototype-setting-goes-cross-origin-domain.sub.html [ Crash ] -crbug.com/591099 external/wpt/html/browsers/history/the-location-interface/location-prototype-setting-same-origin-domain.sub.html [ Crash ] -crbug.com/591099 external/wpt/html/browsers/origin/origin-of-data-document.html [ Crash ] -crbug.com/591099 external/wpt/html/browsers/origin/relaxing-the-same-origin-restriction/document_domain_setter.html [ Crash ] -crbug.com/591099 external/wpt/html/browsers/origin/relaxing-the-same-origin-restriction/document_domain_setter_null.tentative.html [ Crash ] -crbug.com/591099 external/wpt/html/browsers/origin/relaxing-the-same-origin-restriction/document_domain_setter_srcdoc.html [ Crash ] -crbug.com/591099 external/wpt/html/browsers/the-window-object/garbage-collection-and-browsing-contexts/discard_iframe_history_3.html [ Crash ] -crbug.com/591099 external/wpt/html/browsers/the-window-object/garbage-collection-and-browsing-contexts/discard_iframe_history_4.html [ Crash ] -crbug.com/591099 external/wpt/html/browsers/the-windowproxy-exotic-object/windowproxy-prototype-setting-cross-origin-domain.sub.html [ Crash ] -crbug.com/591099 external/wpt/html/browsers/the-windowproxy-exotic-object/windowproxy-prototype-setting-cross-origin.sub.html [ Crash ] -crbug.com/591099 external/wpt/html/browsers/the-windowproxy-exotic-object/windowproxy-prototype-setting-goes-cross-origin-domain.sub.html [ Crash ] -crbug.com/591099 external/wpt/html/browsers/the-windowproxy-exotic-object/windowproxy-prototype-setting-same-origin-domain.sub.html [ Crash ] -crbug.com/591099 external/wpt/html/browsers/windows/noreferrer-window-name.html [ Crash ] -crbug.com/591099 external/wpt/html/dom/documents/dom-tree-accessors/document.forms.html [ Crash ] -crbug.com/591099 external/wpt/html/dom/documents/dom-tree-accessors/document.getElementsByName/document.getElementsByName-namespace.html [ Crash ] -crbug.com/591099 external/wpt/html/dom/documents/dom-tree-accessors/document.getElementsByName/document.getElementsByName-newelements-xhtml.xhtml [ Crash ] -crbug.com/591099 external/wpt/html/dom/documents/dom-tree-accessors/document.getElementsByName/document.getElementsByName-newelements.html [ Crash ] -crbug.com/591099 external/wpt/html/dom/documents/dom-tree-accessors/document.getElementsByName/document.getElementsByName-param-xhtml.xhtml [ Crash ] -crbug.com/591099 external/wpt/html/dom/documents/dom-tree-accessors/document.getElementsByName/document.getElementsByName-param.html [ Crash ] -crbug.com/591099 external/wpt/html/dom/documents/dom-tree-accessors/document.images.html [ Crash ] -crbug.com/591099 external/wpt/html/dom/documents/dom-tree-accessors/nameditem-01.html [ Crash ] -crbug.com/591099 external/wpt/html/dom/documents/dom-tree-accessors/nameditem-02.html [ Crash ] -crbug.com/591099 external/wpt/html/dom/documents/dom-tree-accessors/nameditem-06.html [ Crash ] -crbug.com/591099 external/wpt/html/dom/documents/dom-tree-accessors/nameditem-07.html [ Crash ] -crbug.com/591099 external/wpt/html/dom/documents/dom-tree-accessors/nameditem-08.html [ Crash ] -crbug.com/591099 external/wpt/html/dom/dynamic-markup-insertion/document-write/034.html [ Crash ] -crbug.com/591099 external/wpt/html/dom/dynamic-markup-insertion/document-write/035.html [ Crash ] -crbug.com/591099 external/wpt/html/dom/dynamic-markup-insertion/document-write/036.html [ Crash ] -crbug.com/591099 external/wpt/html/dom/dynamic-markup-insertion/document-write/044.html [ Crash ] -crbug.com/591099 external/wpt/html/dom/dynamic-markup-insertion/document-write/045.html [ Crash ] -crbug.com/591099 external/wpt/html/dom/dynamic-markup-insertion/document-write/046.html [ Crash ] -crbug.com/591099 external/wpt/html/dom/dynamic-markup-insertion/document-write/iframe_001.html [ Crash ] -crbug.com/591099 external/wpt/html/dom/dynamic-markup-insertion/document-write/iframe_002.html [ Crash ] -crbug.com/591099 external/wpt/html/dom/dynamic-markup-insertion/document-write/iframe_003.html [ Crash ] -crbug.com/591099 external/wpt/html/dom/dynamic-markup-insertion/document-write/iframe_004.html [ Crash ] -crbug.com/591099 external/wpt/html/dom/dynamic-markup-insertion/document-write/iframe_005.html [ Crash ] -crbug.com/591099 external/wpt/html/dom/dynamic-markup-insertion/document-write/iframe_006.html [ Crash ] -crbug.com/591099 external/wpt/html/dom/dynamic-markup-insertion/document-write/iframe_007.html [ Crash ] -crbug.com/591099 external/wpt/html/dom/dynamic-markup-insertion/document-write/iframe_008.html [ Crash ] -crbug.com/591099 external/wpt/html/dom/dynamic-markup-insertion/document-write/iframe_009.html [ Crash ] -crbug.com/591099 external/wpt/html/dom/dynamic-markup-insertion/document-write/iframe_010.html [ Crash ] -crbug.com/591099 external/wpt/html/dom/dynamic-markup-insertion/document-write/script_013.html [ Crash ] +crbug.com/591099 external/wpt/html/browsers/browsing-the-web/history-traversal/persisted-user-state-restoration/scroll-restoration-fragment-scrolling-cross-origin.html [ Crash Pass ] +crbug.com/591099 external/wpt/html/browsers/browsing-the-web/history-traversal/persisted-user-state-restoration/scroll-restoration-navigation-cross-origin.html [ Crash Pass ] +crbug.com/591099 external/wpt/html/browsers/browsing-the-web/navigating-across-documents/003.html [ Crash Pass ] +crbug.com/591099 external/wpt/html/browsers/browsing-the-web/navigating-across-documents/004.html [ Crash Pass ] +crbug.com/591099 external/wpt/html/browsers/browsing-the-web/navigating-across-documents/006.html [ Crash Pass ] +crbug.com/591099 external/wpt/html/browsers/browsing-the-web/navigating-across-documents/014.html [ Crash Pass ] +crbug.com/591099 external/wpt/html/browsers/browsing-the-web/navigating-across-documents/empty_fragment.html [ Crash Pass ] +crbug.com/591099 external/wpt/html/browsers/browsing-the-web/navigating-across-documents/javascript-url-query-fragment-components.html [ Crash Pass ] +crbug.com/591099 external/wpt/html/browsers/browsing-the-web/navigating-across-documents/javascript-url-return-value-handling.html [ Crash Pass ] +crbug.com/591099 external/wpt/html/browsers/browsing-the-web/navigating-across-documents/navigation-unload-form-submit.html [ Crash Pass ] +crbug.com/591099 external/wpt/html/browsers/browsing-the-web/navigating-across-documents/navigation-unload-same-origin-fragment.html [ Crash Pass ] +crbug.com/591099 external/wpt/html/browsers/browsing-the-web/unloading-documents/002.html [ Crash Pass ] +crbug.com/591099 external/wpt/html/browsers/browsing-the-web/unloading-documents/003.html [ Crash Pass ] +crbug.com/591099 external/wpt/html/browsers/browsing-the-web/unloading-documents/004.html [ Crash Pass ] +crbug.com/591099 external/wpt/html/browsers/browsing-the-web/unloading-documents/005.html [ Crash Pass ] +crbug.com/591099 external/wpt/html/browsers/history/joint-session-history/joint-session-history-only-fully-active.html [ Crash Pass ] +crbug.com/591099 external/wpt/html/browsers/history/the-location-interface/location-prototype-setting-cross-origin-domain.sub.html [ Crash Pass ] +crbug.com/591099 external/wpt/html/browsers/history/the-location-interface/location-prototype-setting-cross-origin.sub.html [ Crash Pass ] +crbug.com/591099 external/wpt/html/browsers/history/the-location-interface/location-prototype-setting-goes-cross-origin-domain.sub.html [ Crash Pass ] +crbug.com/591099 external/wpt/html/browsers/history/the-location-interface/location-prototype-setting-same-origin-domain.sub.html [ Crash Pass ] +crbug.com/591099 external/wpt/html/browsers/origin/origin-of-data-document.html [ Crash Pass ] +crbug.com/591099 external/wpt/html/browsers/origin/relaxing-the-same-origin-restriction/document_domain_setter.html [ Crash Pass ] +crbug.com/591099 external/wpt/html/browsers/origin/relaxing-the-same-origin-restriction/document_domain_setter_null.tentative.html [ Crash Pass ] +crbug.com/591099 external/wpt/html/browsers/origin/relaxing-the-same-origin-restriction/document_domain_setter_srcdoc.html [ Crash Pass ] +crbug.com/591099 external/wpt/html/browsers/the-window-object/garbage-collection-and-browsing-contexts/discard_iframe_history_3.html [ Crash Pass ] +crbug.com/591099 external/wpt/html/browsers/the-window-object/garbage-collection-and-browsing-contexts/discard_iframe_history_4.html [ Crash Pass ] +crbug.com/591099 external/wpt/html/browsers/the-windowproxy-exotic-object/windowproxy-prototype-setting-cross-origin-domain.sub.html [ Crash Pass ] +crbug.com/591099 external/wpt/html/browsers/the-windowproxy-exotic-object/windowproxy-prototype-setting-cross-origin.sub.html [ Crash Pass ] +crbug.com/591099 external/wpt/html/browsers/the-windowproxy-exotic-object/windowproxy-prototype-setting-goes-cross-origin-domain.sub.html [ Crash Pass ] +crbug.com/591099 external/wpt/html/browsers/the-windowproxy-exotic-object/windowproxy-prototype-setting-same-origin-domain.sub.html [ Crash Pass ] +crbug.com/591099 external/wpt/html/browsers/windows/noreferrer-window-name.html [ Crash Timeout ] +crbug.com/591099 external/wpt/html/dom/documents/dom-tree-accessors/document.forms.html [ Crash Pass ] +crbug.com/591099 external/wpt/html/dom/documents/dom-tree-accessors/document.getElementsByName/document.getElementsByName-namespace.html [ Crash Pass ] +crbug.com/591099 external/wpt/html/dom/documents/dom-tree-accessors/document.getElementsByName/document.getElementsByName-newelements-xhtml.xhtml [ Crash Pass ] +crbug.com/591099 external/wpt/html/dom/documents/dom-tree-accessors/document.getElementsByName/document.getElementsByName-newelements.html [ Crash Pass ] +crbug.com/591099 external/wpt/html/dom/documents/dom-tree-accessors/document.getElementsByName/document.getElementsByName-param-xhtml.xhtml [ Crash Pass ] +crbug.com/591099 external/wpt/html/dom/documents/dom-tree-accessors/document.getElementsByName/document.getElementsByName-param.html [ Crash Pass ] +crbug.com/591099 external/wpt/html/dom/documents/dom-tree-accessors/document.images.html [ Crash Pass ] +crbug.com/591099 external/wpt/html/dom/documents/dom-tree-accessors/nameditem-01.html [ Crash Pass ] +crbug.com/591099 external/wpt/html/dom/documents/dom-tree-accessors/nameditem-02.html [ Crash Pass ] +crbug.com/591099 external/wpt/html/dom/documents/dom-tree-accessors/nameditem-06.html [ Crash Pass ] +crbug.com/591099 external/wpt/html/dom/documents/dom-tree-accessors/nameditem-07.html [ Crash Pass ] +crbug.com/591099 external/wpt/html/dom/documents/dom-tree-accessors/nameditem-08.html [ Crash Pass ] +crbug.com/591099 external/wpt/html/dom/dynamic-markup-insertion/document-write/034.html [ Crash Pass ] +crbug.com/591099 external/wpt/html/dom/dynamic-markup-insertion/document-write/035.html [ Crash Pass ] +crbug.com/591099 external/wpt/html/dom/dynamic-markup-insertion/document-write/036.html [ Crash Pass ] +crbug.com/591099 external/wpt/html/dom/dynamic-markup-insertion/document-write/044.html [ Crash Pass ] +crbug.com/591099 external/wpt/html/dom/dynamic-markup-insertion/document-write/045.html [ Crash Pass ] +crbug.com/591099 external/wpt/html/dom/dynamic-markup-insertion/document-write/046.html [ Crash Pass ] +crbug.com/591099 external/wpt/html/dom/dynamic-markup-insertion/document-write/iframe_001.html [ Crash Pass ] +crbug.com/591099 external/wpt/html/dom/dynamic-markup-insertion/document-write/iframe_002.html [ Crash Pass ] +crbug.com/591099 external/wpt/html/dom/dynamic-markup-insertion/document-write/iframe_003.html [ Crash Pass ] +crbug.com/591099 external/wpt/html/dom/dynamic-markup-insertion/document-write/iframe_004.html [ Crash Pass ] +crbug.com/591099 external/wpt/html/dom/dynamic-markup-insertion/document-write/iframe_005.html [ Crash Pass ] +crbug.com/591099 external/wpt/html/dom/dynamic-markup-insertion/document-write/iframe_006.html [ Crash Pass ] +crbug.com/591099 external/wpt/html/dom/dynamic-markup-insertion/document-write/iframe_007.html [ Crash Pass ] +crbug.com/591099 external/wpt/html/dom/dynamic-markup-insertion/document-write/iframe_008.html [ Crash Pass ] +crbug.com/591099 external/wpt/html/dom/dynamic-markup-insertion/document-write/iframe_009.html [ Crash Pass ] +crbug.com/591099 external/wpt/html/dom/dynamic-markup-insertion/document-write/iframe_010.html [ Crash Pass ] +crbug.com/591099 external/wpt/html/dom/dynamic-markup-insertion/document-write/script_013.html [ Crash Pass ] crbug.com/591099 external/wpt/html/dom/interfaces.html [ Timeout ] -crbug.com/591099 external/wpt/html/editing/focus/focus-management/focus-event-targets-simple.html [ Crash ] -crbug.com/591099 external/wpt/html/editing/focus/processing-model/focus-fixup-rule-one-no-dialogs.html [ Crash ] -crbug.com/591099 external/wpt/html/editing/focus/sequential-focus-navigation-and-the-tabindex-attribute/focus-tabindex-default-value.html [ Crash ] -crbug.com/591099 external/wpt/html/infrastructure/common-dom-interfaces/collections/htmlallcollection.html [ Crash ] -crbug.com/591099 external/wpt/html/infrastructure/common-dom-interfaces/collections/htmlformcontrolscollection.html [ Crash ] -crbug.com/591099 external/wpt/html/infrastructure/common-dom-interfaces/collections/htmloptionscollection.html [ Crash ] -crbug.com/591099 external/wpt/html/infrastructure/common-dom-interfaces/collections/radionodelist.html [ Crash ] -crbug.com/591099 external/wpt/html/infrastructure/terminology/plugins/text-plain.html [ Crash ] -crbug.com/591099 external/wpt/html/infrastructure/urls/resolving-urls/query-encoding/utf-16be.html [ Crash ] -crbug.com/591099 external/wpt/html/infrastructure/urls/resolving-urls/query-encoding/utf-16le.html [ Crash ] -crbug.com/591099 external/wpt/html/infrastructure/urls/resolving-urls/query-encoding/utf-8.html [ Crash ] -crbug.com/591099 external/wpt/html/infrastructure/urls/resolving-urls/query-encoding/windows-1251.html [ Crash ] -crbug.com/591099 external/wpt/html/infrastructure/urls/resolving-urls/query-encoding/windows-1252.html [ Crash ] +crbug.com/591099 external/wpt/html/editing/focus/focus-management/focus-event-targets-simple.html [ Crash Pass ] +crbug.com/591099 external/wpt/html/editing/focus/processing-model/focus-fixup-rule-one-no-dialogs.html [ Crash Pass ] +crbug.com/591099 external/wpt/html/editing/focus/sequential-focus-navigation-and-the-tabindex-attribute/focus-tabindex-default-value.html [ Crash Pass ] +crbug.com/591099 external/wpt/html/infrastructure/common-dom-interfaces/collections/htmlallcollection.html [ Crash Pass ] +crbug.com/591099 external/wpt/html/infrastructure/common-dom-interfaces/collections/htmlformcontrolscollection.html [ Crash Pass ] +crbug.com/591099 external/wpt/html/infrastructure/common-dom-interfaces/collections/htmloptionscollection.html [ Crash Pass ] +crbug.com/591099 external/wpt/html/infrastructure/common-dom-interfaces/collections/radionodelist.html [ Crash Pass ] +crbug.com/591099 external/wpt/html/infrastructure/terminology/plugins/text-plain.html [ Crash Pass ] +crbug.com/591099 external/wpt/html/infrastructure/urls/resolving-urls/query-encoding/utf-16be.html [ Crash Timeout ] +crbug.com/591099 external/wpt/html/infrastructure/urls/resolving-urls/query-encoding/utf-16le.html [ Crash Timeout ] +crbug.com/591099 external/wpt/html/infrastructure/urls/resolving-urls/query-encoding/utf-8.html [ Crash Timeout ] +crbug.com/591099 external/wpt/html/infrastructure/urls/resolving-urls/query-encoding/windows-1251.html [ Crash Timeout ] +crbug.com/591099 external/wpt/html/infrastructure/urls/resolving-urls/query-encoding/windows-1252.html [ Crash Timeout ] crbug.com/591099 external/wpt/html/rendering/non-replaced-elements/flow-content-0/dialog.html [ Failure ] crbug.com/591099 external/wpt/html/rendering/non-replaced-elements/flow-content-0/div-align.html [ Failure ] crbug.com/591099 external/wpt/html/rendering/non-replaced-elements/tables/table-cell-width-s.html [ Failure ] @@ -5501,85 +5501,85 @@ crbug.com/591099 external/wpt/html/rendering/non-replaced-elements/the-fieldset-element-0/legend-block-formatting-context.html [ Crash Failure ] crbug.com/591099 external/wpt/html/rendering/non-replaced-elements/the-hr-element-0/align.html [ Failure ] crbug.com/591099 external/wpt/html/rendering/non-replaced-elements/the-hr-element-0/setting-overflow-visible.html [ Failure ] -crbug.com/591099 external/wpt/html/rendering/non-replaced-elements/the-page/iframe-body-margin-attributes.html [ Crash ] -crbug.com/591099 external/wpt/html/rendering/non-replaced-elements/the-page/iframe-marginwidth-marginheight.html [ Crash ] +crbug.com/591099 external/wpt/html/rendering/non-replaced-elements/the-page/iframe-body-margin-attributes.html [ Crash Pass ] +crbug.com/591099 external/wpt/html/rendering/non-replaced-elements/the-page/iframe-marginwidth-marginheight.html [ Crash Pass ] crbug.com/591099 external/wpt/html/rendering/replaced-elements/svg-embedded-sizing/svg-in-img-auto.html [ Failure ] crbug.com/591099 external/wpt/html/rendering/replaced-elements/svg-embedded-sizing/svg-in-img-percentage.html [ Failure ] crbug.com/591099 external/wpt/html/rendering/replaced-elements/svg-inline-sizing/svg-inline.html [ Failure Timeout ] -crbug.com/591099 external/wpt/html/semantics/disabled-elements/disabledElement.html [ Crash ] -crbug.com/591099 external/wpt/html/semantics/document-metadata/the-base-element/base_about_blank.html [ Crash ] -crbug.com/591099 external/wpt/html/semantics/document-metadata/the-base-element/base_srcdoc.html [ Crash ] -crbug.com/591099 external/wpt/html/semantics/embedded-content/media-elements/loading-the-media-resource/resource-selection-invoke-remove-from-document-networkState.html [ Crash ] -crbug.com/591099 external/wpt/html/semantics/embedded-content/media-elements/networkState_initial.html [ Crash ] -crbug.com/591099 external/wpt/html/semantics/embedded-content/media-elements/preload_reflects_none_autoplay.html [ Crash ] -crbug.com/591099 external/wpt/html/semantics/embedded-content/media-elements/readyState_initial.html [ Crash ] -crbug.com/591099 external/wpt/html/semantics/embedded-content/media-elements/src_reflects_attribute_not_source_elements.html [ Crash ] -crbug.com/591099 external/wpt/html/semantics/embedded-content/the-area-element/area-coords.html [ Crash ] -crbug.com/591099 external/wpt/html/semantics/embedded-content/the-area-element/area-download-click.html [ Crash ] -crbug.com/591099 external/wpt/html/semantics/embedded-content/the-area-element/area-processing.html [ Crash ] -crbug.com/591099 external/wpt/html/semantics/embedded-content/the-area-element/area-shape.html [ Crash ] -crbug.com/591099 external/wpt/html/semantics/embedded-content/the-embed-element/embed-document.html [ Crash ] -crbug.com/591099 external/wpt/html/semantics/embedded-content/the-embed-element/embed-ignored-in-media-element.html [ Crash ] -crbug.com/591099 external/wpt/html/semantics/embedded-content/the-embed-element/embed-in-object-fallback.html [ Crash ] -crbug.com/591099 external/wpt/html/semantics/embedded-content/the-iframe-element/change_parentage.html [ Crash ] -crbug.com/591099 external/wpt/html/semantics/embedded-content/the-iframe-element/content_document_changes_only_after_load_matures.html [ Crash ] -crbug.com/591099 external/wpt/html/semantics/embedded-content/the-iframe-element/iframe-load-event.html [ Crash ] -crbug.com/591099 external/wpt/html/semantics/embedded-content/the-iframe-element/iframe-synchronously-discard.html [ Crash ] -crbug.com/591099 external/wpt/html/semantics/embedded-content/the-iframe-element/iframe_sandbox_allow_top_navigation-2.html [ Crash ] -crbug.com/591099 external/wpt/html/semantics/embedded-content/the-iframe-element/iframe_sandbox_navigate_ancestor-1.html [ Crash ] -crbug.com/591099 external/wpt/html/semantics/embedded-content/the-iframe-element/iframe_sandbox_navigate_ancestor-2.html [ Crash ] -crbug.com/591099 external/wpt/html/semantics/embedded-content/the-iframe-element/iframe_sandbox_navigate_descendants.html [ Crash ] -crbug.com/591099 external/wpt/html/semantics/embedded-content/the-iframe-element/iframe_sandbox_navigate_itself.html [ Crash ] -crbug.com/591099 external/wpt/html/semantics/embedded-content/the-iframe-element/same_origin_parentage.html [ Crash ] -crbug.com/591099 external/wpt/html/semantics/embedded-content/the-img-element/current-pixel-density/error.html [ Crash ] -crbug.com/591099 external/wpt/html/semantics/embedded-content/the-img-element/delay-load-event.html [ Crash ] -crbug.com/591099 external/wpt/html/semantics/embedded-content/the-img-element/img.complete.html [ Crash ] -crbug.com/591099 external/wpt/html/semantics/embedded-content/the-img-element/nonexistent-image.html [ Crash ] +crbug.com/591099 external/wpt/html/semantics/disabled-elements/disabledElement.html [ Crash Pass ] +crbug.com/591099 external/wpt/html/semantics/document-metadata/the-base-element/base_about_blank.html [ Crash Pass ] +crbug.com/591099 external/wpt/html/semantics/document-metadata/the-base-element/base_srcdoc.html [ Crash Pass ] +crbug.com/591099 external/wpt/html/semantics/embedded-content/media-elements/loading-the-media-resource/resource-selection-invoke-remove-from-document-networkState.html [ Crash Pass ] +crbug.com/591099 external/wpt/html/semantics/embedded-content/media-elements/networkState_initial.html [ Crash Pass ] +crbug.com/591099 external/wpt/html/semantics/embedded-content/media-elements/preload_reflects_none_autoplay.html [ Crash Pass ] +crbug.com/591099 external/wpt/html/semantics/embedded-content/media-elements/readyState_initial.html [ Crash Pass ] +crbug.com/591099 external/wpt/html/semantics/embedded-content/media-elements/src_reflects_attribute_not_source_elements.html [ Crash Pass ] +crbug.com/591099 external/wpt/html/semantics/embedded-content/the-area-element/area-coords.html [ Crash Failure ] +crbug.com/591099 external/wpt/html/semantics/embedded-content/the-area-element/area-download-click.html [ Crash Pass ] +crbug.com/591099 external/wpt/html/semantics/embedded-content/the-area-element/area-processing.html [ Crash Failure ] +crbug.com/591099 external/wpt/html/semantics/embedded-content/the-area-element/area-shape.html [ Crash Failure ] +crbug.com/591099 external/wpt/html/semantics/embedded-content/the-embed-element/embed-document.html [ Crash Pass ] +crbug.com/591099 external/wpt/html/semantics/embedded-content/the-embed-element/embed-ignored-in-media-element.html [ Crash Pass ] +crbug.com/591099 external/wpt/html/semantics/embedded-content/the-embed-element/embed-in-object-fallback.html [ Crash Pass ] +crbug.com/591099 external/wpt/html/semantics/embedded-content/the-iframe-element/change_parentage.html [ Crash Pass ] +crbug.com/591099 external/wpt/html/semantics/embedded-content/the-iframe-element/content_document_changes_only_after_load_matures.html [ Crash Pass ] +crbug.com/591099 external/wpt/html/semantics/embedded-content/the-iframe-element/iframe-load-event.html [ Crash Pass ] +crbug.com/591099 external/wpt/html/semantics/embedded-content/the-iframe-element/iframe-synchronously-discard.html [ Crash Pass ] +crbug.com/591099 external/wpt/html/semantics/embedded-content/the-iframe-element/iframe_sandbox_allow_top_navigation-2.html [ Crash Pass ] +crbug.com/591099 external/wpt/html/semantics/embedded-content/the-iframe-element/iframe_sandbox_navigate_ancestor-1.html [ Crash Pass ] +crbug.com/591099 external/wpt/html/semantics/embedded-content/the-iframe-element/iframe_sandbox_navigate_ancestor-2.html [ Crash Pass ] +crbug.com/591099 external/wpt/html/semantics/embedded-content/the-iframe-element/iframe_sandbox_navigate_descendants.html [ Crash Pass ] +crbug.com/591099 external/wpt/html/semantics/embedded-content/the-iframe-element/iframe_sandbox_navigate_itself.html [ Crash Pass ] +crbug.com/591099 external/wpt/html/semantics/embedded-content/the-iframe-element/same_origin_parentage.html [ Crash Pass ] +crbug.com/591099 external/wpt/html/semantics/embedded-content/the-img-element/current-pixel-density/error.html [ Crash Pass ] +crbug.com/591099 external/wpt/html/semantics/embedded-content/the-img-element/delay-load-event.html [ Crash Pass ] +crbug.com/591099 external/wpt/html/semantics/embedded-content/the-img-element/img.complete.html [ Crash Pass ] +crbug.com/591099 external/wpt/html/semantics/embedded-content/the-img-element/nonexistent-image.html [ Crash Pass ] crbug.com/591099 external/wpt/html/semantics/embedded-content/the-img-element/srcset/parse-a-srcset-attribute.html [ Crash Pass ] crbug.com/591099 external/wpt/html/semantics/embedded-content/the-img-element/srcset/select-an-image-source.html [ Crash Pass ] -crbug.com/591099 external/wpt/html/semantics/embedded-content/the-img-element/update-the-source-set.html [ Crash ] +crbug.com/591099 external/wpt/html/semantics/embedded-content/the-img-element/update-the-source-set.html [ Crash Pass ] crbug.com/591099 external/wpt/html/semantics/embedded-content/the-img-element/usemap-casing.html [ Failure ] -crbug.com/591099 external/wpt/html/semantics/embedded-content/the-object-element/object-attributes.html [ Crash ] -crbug.com/591099 external/wpt/html/semantics/embedded-content/the-object-element/object-ignored-in-media-element.html [ Crash ] +crbug.com/591099 external/wpt/html/semantics/embedded-content/the-object-element/object-attributes.html [ Crash Pass ] +crbug.com/591099 external/wpt/html/semantics/embedded-content/the-object-element/object-ignored-in-media-element.html [ Crash Pass ] crbug.com/591099 external/wpt/html/semantics/embedded-content/the-object-element/usemap-casing.html [ Failure ] -crbug.com/591099 external/wpt/html/semantics/embedded-content/the-video-element/video-tabindex.html [ Crash ] -crbug.com/591099 external/wpt/html/semantics/forms/attributes-common-to-form-controls/dirname-ltr.html [ Crash ] -crbug.com/591099 external/wpt/html/semantics/forms/constraints/form-validation-willValidate.html [ Crash ] -crbug.com/591099 external/wpt/html/semantics/forms/form-control-infrastructure/form.html [ Crash ] -crbug.com/591099 external/wpt/html/semantics/forms/form-control-infrastructure/form_attribute.html [ Crash ] -crbug.com/591099 external/wpt/html/semantics/forms/form-submission-0/form-data-set-usv.html [ Crash ] -crbug.com/591099 external/wpt/html/semantics/forms/form-submission-0/getactionurl.html [ Crash ] -crbug.com/591099 external/wpt/html/semantics/forms/form-submission-0/submit-entity-body.html [ Crash ] -crbug.com/591099 external/wpt/html/semantics/forms/resetting-a-form/reset-form-event-realm.html [ Crash ] -crbug.com/591099 external/wpt/html/semantics/forms/textfieldselection/selection-after-content-change.html [ Crash ] -crbug.com/591099 external/wpt/html/semantics/forms/textfieldselection/selection-start-end.html [ Crash ] -crbug.com/591099 external/wpt/html/semantics/forms/textfieldselection/textfieldselection-setSelectionRange.html [ Crash ] -crbug.com/591099 external/wpt/html/semantics/forms/the-button-element/button-activate.html [ Crash ] -crbug.com/591099 external/wpt/html/semantics/forms/the-button-element/button-menu-historical.html [ Crash ] -crbug.com/591099 external/wpt/html/semantics/forms/the-fieldset-element/disabled-001.html [ Crash ] -crbug.com/591099 external/wpt/html/semantics/forms/the-form-element/form-action-submission-with-base-url.html [ Crash ] -crbug.com/591099 external/wpt/html/semantics/forms/the-form-element/form-action-submission.html [ Crash ] -crbug.com/591099 external/wpt/html/semantics/forms/the-form-element/form-autocomplete.html [ Crash ] -crbug.com/591099 external/wpt/html/semantics/forms/the-form-element/form-elements-filter.html [ Crash ] -crbug.com/591099 external/wpt/html/semantics/forms/the-form-element/form-elements-matches.html [ Crash ] -crbug.com/591099 external/wpt/html/semantics/forms/the-form-element/form-elements-nameditem-01.html [ Crash ] -crbug.com/591099 external/wpt/html/semantics/forms/the-form-element/form-elements-sameobject.html [ Crash ] -crbug.com/591099 external/wpt/html/semantics/forms/the-form-element/form-indexed-element.html [ Crash ] -crbug.com/591099 external/wpt/html/semantics/forms/the-form-element/form-nameditem.html [ Crash ] -crbug.com/591099 external/wpt/html/semantics/forms/the-input-element/button.html [ Crash ] -crbug.com/591099 external/wpt/html/semantics/forms/the-input-element/checkbox-click-events.html [ Crash ] -crbug.com/591099 external/wpt/html/semantics/forms/the-input-element/email.html [ Crash ] -crbug.com/591099 external/wpt/html/semantics/forms/the-input-element/input-type-button.html [ Crash ] -crbug.com/591099 external/wpt/html/semantics/forms/the-input-element/radio-input-cancel.html [ Crash ] -crbug.com/591099 external/wpt/html/semantics/forms/the-input-element/reset.html [ Crash ] -crbug.com/591099 external/wpt/html/semantics/forms/the-input-element/telephone.html [ Crash ] +crbug.com/591099 external/wpt/html/semantics/embedded-content/the-video-element/video-tabindex.html [ Crash Pass ] +crbug.com/591099 external/wpt/html/semantics/forms/attributes-common-to-form-controls/dirname-ltr.html [ Crash Pass ] +crbug.com/591099 external/wpt/html/semantics/forms/constraints/form-validation-willValidate.html [ Crash Pass ] +crbug.com/591099 external/wpt/html/semantics/forms/form-control-infrastructure/form.html [ Crash Pass ] +crbug.com/591099 external/wpt/html/semantics/forms/form-control-infrastructure/form_attribute.html [ Crash Pass ] +crbug.com/591099 external/wpt/html/semantics/forms/form-submission-0/form-data-set-usv.html [ Crash Pass ] +crbug.com/591099 external/wpt/html/semantics/forms/form-submission-0/getactionurl.html [ Crash Pass ] +crbug.com/591099 external/wpt/html/semantics/forms/form-submission-0/submit-entity-body.html [ Crash Pass ] +crbug.com/591099 external/wpt/html/semantics/forms/resetting-a-form/reset-form-event-realm.html [ Crash Pass ] +crbug.com/591099 external/wpt/html/semantics/forms/textfieldselection/selection-after-content-change.html [ Crash Pass ] +crbug.com/591099 external/wpt/html/semantics/forms/textfieldselection/selection-start-end.html [ Crash Pass ] +crbug.com/591099 external/wpt/html/semantics/forms/textfieldselection/textfieldselection-setSelectionRange.html [ Crash Pass ] +crbug.com/591099 external/wpt/html/semantics/forms/the-button-element/button-activate.html [ Crash Pass ] +crbug.com/591099 external/wpt/html/semantics/forms/the-button-element/button-menu-historical.html [ Crash Pass ] +crbug.com/591099 external/wpt/html/semantics/forms/the-fieldset-element/disabled-001.html [ Crash Pass ] +crbug.com/591099 external/wpt/html/semantics/forms/the-form-element/form-action-submission-with-base-url.html [ Crash Pass ] +crbug.com/591099 external/wpt/html/semantics/forms/the-form-element/form-action-submission.html [ Crash Pass ] +crbug.com/591099 external/wpt/html/semantics/forms/the-form-element/form-autocomplete.html [ Crash Pass ] +crbug.com/591099 external/wpt/html/semantics/forms/the-form-element/form-elements-filter.html [ Crash Pass ] +crbug.com/591099 external/wpt/html/semantics/forms/the-form-element/form-elements-matches.html [ Crash Pass ] +crbug.com/591099 external/wpt/html/semantics/forms/the-form-element/form-elements-nameditem-01.html [ Crash Pass ] +crbug.com/591099 external/wpt/html/semantics/forms/the-form-element/form-elements-sameobject.html [ Crash Pass ] +crbug.com/591099 external/wpt/html/semantics/forms/the-form-element/form-indexed-element.html [ Crash Pass ] +crbug.com/591099 external/wpt/html/semantics/forms/the-form-element/form-nameditem.html [ Crash Pass ] +crbug.com/591099 external/wpt/html/semantics/forms/the-input-element/button.html [ Crash Pass ] +crbug.com/591099 external/wpt/html/semantics/forms/the-input-element/checkbox-click-events.html [ Crash Pass ] +crbug.com/591099 external/wpt/html/semantics/forms/the-input-element/email.html [ Crash Pass ] +crbug.com/591099 external/wpt/html/semantics/forms/the-input-element/input-type-button.html [ Crash Pass ] +crbug.com/591099 external/wpt/html/semantics/forms/the-input-element/radio-input-cancel.html [ Crash Pass ] +crbug.com/591099 external/wpt/html/semantics/forms/the-input-element/reset.html [ Crash Pass ] +crbug.com/591099 external/wpt/html/semantics/forms/the-input-element/telephone.html [ Crash Pass ] crbug.com/591099 external/wpt/html/semantics/forms/the-input-element/type-change-state.html [ Pass Timeout ] -crbug.com/591099 external/wpt/html/semantics/forms/the-label-element/proxy-click-to-associated-element.html [ Crash ] -crbug.com/591099 external/wpt/html/semantics/forms/the-option-element/option-form.html [ Crash ] -crbug.com/591099 external/wpt/html/semantics/forms/the-option-element/option-index.html [ Crash ] -crbug.com/591099 external/wpt/html/semantics/forms/the-select-element/select-multiple.html [ Crash ] -crbug.com/591099 external/wpt/html/semantics/forms/the-select-element/selected-index.html [ Crash ] -crbug.com/591099 external/wpt/html/semantics/forms/the-textarea-element/textarea-type.html [ Crash ] +crbug.com/591099 external/wpt/html/semantics/forms/the-label-element/proxy-click-to-associated-element.html [ Crash Pass ] +crbug.com/591099 external/wpt/html/semantics/forms/the-option-element/option-form.html [ Crash Pass ] +crbug.com/591099 external/wpt/html/semantics/forms/the-option-element/option-index.html [ Crash Pass ] +crbug.com/591099 external/wpt/html/semantics/forms/the-select-element/select-multiple.html [ Crash Pass ] +crbug.com/591099 external/wpt/html/semantics/forms/the-select-element/selected-index.html [ Crash Pass ] +crbug.com/591099 external/wpt/html/semantics/forms/the-textarea-element/textarea-type.html [ Crash Pass ] crbug.com/591099 external/wpt/html/semantics/grouping-content/the-li-element/grouping-li-reftest-002.html [ Failure ] crbug.com/591099 external/wpt/html/semantics/grouping-content/the-li-element/grouping-li-reftest-list-owner-menu.html [ Crash Failure ] crbug.com/591099 external/wpt/html/semantics/grouping-content/the-li-element/grouping-li-reftest-list-owner-mixed.html [ Crash Failure Pass ] @@ -5588,857 +5588,865 @@ crbug.com/591099 external/wpt/html/semantics/grouping-content/the-li-element/grouping-li-reftest-list-owner-parent.html [ Crash Failure Pass ] crbug.com/591099 external/wpt/html/semantics/grouping-content/the-li-element/grouping-li-reftest-list-owner-skip-no-boxes.html [ Crash Failure ] crbug.com/591099 external/wpt/html/semantics/grouping-content/the-li-element/grouping-li-reftest-list-owner-ul.html [ Crash Failure Pass ] -crbug.com/591099 external/wpt/html/semantics/grouping-content/the-li-element/grouping-li.html [ Crash ] +crbug.com/591099 external/wpt/html/semantics/grouping-content/the-li-element/grouping-li.html [ Crash Pass ] crbug.com/591099 external/wpt/html/semantics/grouping-content/the-ol-element/grouping-ol-rev-reftest-001.html [ Failure ] crbug.com/591099 external/wpt/html/semantics/grouping-content/the-ol-element/grouping-ol-start-reftest-001.html [ Failure ] crbug.com/591099 external/wpt/html/semantics/grouping-content/the-ol-element/grouping-ol-start-reftest-002.html [ Failure ] crbug.com/591099 external/wpt/html/semantics/grouping-content/the-ol-element/grouping-ol-type-reftest-001.html [ Failure ] crbug.com/591099 external/wpt/html/semantics/grouping-content/the-ol-element/grouping-ol-type-reftest-002.html [ Failure ] crbug.com/591099 external/wpt/html/semantics/grouping-content/the-ol-element/grouping-ol-type-reftest-003.html [ Failure ] -crbug.com/591099 external/wpt/html/semantics/grouping-content/the-ol-element/grouping-ol.html [ Crash ] +crbug.com/591099 external/wpt/html/semantics/grouping-content/the-ol-element/grouping-ol.html [ Crash Pass ] crbug.com/591099 external/wpt/html/semantics/interactive-elements/the-dialog-element/centering.html [ Failure ] -crbug.com/591099 external/wpt/html/semantics/interactive-elements/the-dialog-element/dialog-showModal.html [ Crash ] -crbug.com/591099 external/wpt/html/semantics/links/links-created-by-a-and-area-elements/htmlanchorelement_noopener.html [ Crash ] -crbug.com/591099 external/wpt/html/semantics/scripting-1/the-script-element/script-noembed-noframes-iframe.xhtml [ Crash ] -crbug.com/591099 external/wpt/html/semantics/scripting-1/the-script-element/script-not-executed-after-shutdown.html [ Crash ] -crbug.com/591099 external/wpt/html/semantics/scripting-1/the-script-element/script-onerror-insertion-point-1.html [ Crash ] -crbug.com/591099 external/wpt/html/semantics/scripting-1/the-script-element/script-onerror-insertion-point-2.html [ Crash ] -crbug.com/591099 external/wpt/html/semantics/scripting-1/the-script-element/script-onload-insertion-point.html [ Crash ] -crbug.com/591099 external/wpt/html/semantics/scripting-1/the-template-element/additions-to-parsing-xhtml-documents/node-document.html [ Crash ] -crbug.com/591099 external/wpt/html/semantics/scripting-1/the-template-element/additions-to-parsing-xhtml-documents/template-child-nodes.html [ Crash ] -crbug.com/591099 external/wpt/html/semantics/scripting-1/the-template-element/additions-to-the-steps-to-clone-a-node/templates-copy-document-owner.html [ Crash ] -crbug.com/591099 external/wpt/html/semantics/scripting-1/the-template-element/definitions/template-contents-owner-document-type.html [ Crash ] -crbug.com/591099 external/wpt/html/semantics/scripting-1/the-template-element/definitions/template-contents-owner-test-002.html [ Crash ] -crbug.com/591099 external/wpt/html/semantics/scripting-1/the-template-element/definitions/template-contents.html [ Crash ] -crbug.com/591099 external/wpt/html/semantics/scripting-1/the-template-element/innerhtml-on-templates/innerhtml.html [ Crash ] -crbug.com/591099 external/wpt/html/semantics/scripting-1/the-template-element/template-element/content-attribute.html [ Crash ] -crbug.com/591099 external/wpt/html/semantics/scripting-1/the-template-element/template-element/node-document-changes.html [ Crash ] -crbug.com/591099 external/wpt/html/semantics/scripting-1/the-template-element/template-element/template-content-node-document.html [ Crash ] -crbug.com/591099 external/wpt/html/semantics/scripting-1/the-template-element/template-element/template-descendant-body.html [ Crash ] -crbug.com/591099 external/wpt/html/semantics/scripting-1/the-template-element/template-element/template-descendant-frameset.html [ Crash ] -crbug.com/591099 external/wpt/html/semantics/scripting-1/the-template-element/template-element/template-descendant-head.html [ Crash ] -crbug.com/591099 external/wpt/html/semantics/selectors/pseudo-classes/checked.html [ Crash ] -crbug.com/591099 external/wpt/html/semantics/selectors/pseudo-classes/default.html [ Crash ] -crbug.com/591099 external/wpt/html/semantics/selectors/pseudo-classes/disabled.html [ Crash ] -crbug.com/591099 external/wpt/html/semantics/selectors/pseudo-classes/enabled.html [ Crash ] -crbug.com/591099 external/wpt/html/semantics/selectors/pseudo-classes/focus-autofocus.html [ Crash ] -crbug.com/591099 external/wpt/html/semantics/selectors/pseudo-classes/focus.html [ Crash ] -crbug.com/591099 external/wpt/html/semantics/selectors/pseudo-classes/indeterminate-radio.html [ Crash ] -crbug.com/591099 external/wpt/html/semantics/selectors/pseudo-classes/readwrite-readonly.html [ Crash ] -crbug.com/591099 external/wpt/html/semantics/selectors/pseudo-classes/valid-invalid.html [ Crash ] -crbug.com/591099 external/wpt/html/semantics/text-level-semantics/the-a-element/a-download-click-404.html [ Crash ] +crbug.com/591099 external/wpt/html/semantics/interactive-elements/the-dialog-element/dialog-showModal.html [ Crash Pass ] +crbug.com/591099 external/wpt/html/semantics/links/links-created-by-a-and-area-elements/htmlanchorelement_noopener.html [ Crash Pass ] +crbug.com/591099 external/wpt/html/semantics/scripting-1/the-script-element/script-noembed-noframes-iframe.xhtml [ Crash Pass ] +crbug.com/591099 external/wpt/html/semantics/scripting-1/the-script-element/script-not-executed-after-shutdown.html [ Crash Pass ] +crbug.com/591099 external/wpt/html/semantics/scripting-1/the-script-element/script-onerror-insertion-point-1.html [ Crash Pass ] +crbug.com/591099 external/wpt/html/semantics/scripting-1/the-script-element/script-onerror-insertion-point-2.html [ Crash Pass ] +crbug.com/591099 external/wpt/html/semantics/scripting-1/the-script-element/script-onload-insertion-point.html [ Crash Pass ] +crbug.com/591099 external/wpt/html/semantics/scripting-1/the-template-element/additions-to-parsing-xhtml-documents/node-document.html [ Crash Pass ] +crbug.com/591099 external/wpt/html/semantics/scripting-1/the-template-element/additions-to-parsing-xhtml-documents/template-child-nodes.html [ Crash Pass ] +crbug.com/591099 external/wpt/html/semantics/scripting-1/the-template-element/additions-to-the-steps-to-clone-a-node/templates-copy-document-owner.html [ Crash Pass ] +crbug.com/591099 external/wpt/html/semantics/scripting-1/the-template-element/definitions/template-contents-owner-document-type.html [ Crash Pass ] +crbug.com/591099 external/wpt/html/semantics/scripting-1/the-template-element/definitions/template-contents-owner-test-002.html [ Crash Pass ] +crbug.com/591099 external/wpt/html/semantics/scripting-1/the-template-element/definitions/template-contents.html [ Crash Pass ] +crbug.com/591099 external/wpt/html/semantics/scripting-1/the-template-element/innerhtml-on-templates/innerhtml.html [ Crash Pass ] +crbug.com/591099 external/wpt/html/semantics/scripting-1/the-template-element/template-element/content-attribute.html [ Crash Pass ] +crbug.com/591099 external/wpt/html/semantics/scripting-1/the-template-element/template-element/node-document-changes.html [ Crash Pass ] +crbug.com/591099 external/wpt/html/semantics/scripting-1/the-template-element/template-element/template-content-node-document.html [ Crash Pass ] +crbug.com/591099 external/wpt/html/semantics/scripting-1/the-template-element/template-element/template-descendant-body.html [ Crash Pass ] +crbug.com/591099 external/wpt/html/semantics/scripting-1/the-template-element/template-element/template-descendant-frameset.html [ Crash Pass ] +crbug.com/591099 external/wpt/html/semantics/scripting-1/the-template-element/template-element/template-descendant-head.html [ Crash Pass ] +crbug.com/591099 external/wpt/html/semantics/selectors/pseudo-classes/checked.html [ Crash Pass ] +crbug.com/591099 external/wpt/html/semantics/selectors/pseudo-classes/default.html [ Crash Pass ] +crbug.com/591099 external/wpt/html/semantics/selectors/pseudo-classes/disabled.html [ Crash Pass ] +crbug.com/591099 external/wpt/html/semantics/selectors/pseudo-classes/enabled.html [ Crash Pass ] +crbug.com/591099 external/wpt/html/semantics/selectors/pseudo-classes/focus-autofocus.html [ Crash Pass ] +crbug.com/591099 external/wpt/html/semantics/selectors/pseudo-classes/focus.html [ Crash Pass ] +crbug.com/591099 external/wpt/html/semantics/selectors/pseudo-classes/indeterminate-radio.html [ Crash Pass ] +crbug.com/591099 external/wpt/html/semantics/selectors/pseudo-classes/readwrite-readonly.html [ Crash Pass ] +crbug.com/591099 external/wpt/html/semantics/selectors/pseudo-classes/valid-invalid.html [ Crash Pass ] +crbug.com/591099 external/wpt/html/semantics/text-level-semantics/the-a-element/a-download-click-404.html [ Crash Pass ] crbug.com/591099 external/wpt/html/semantics/text-level-semantics/the-br-element/br-bidi-in-inline-ancestors.html [ Failure ] crbug.com/591099 external/wpt/html/semantics/text-level-semantics/the-wbr-element/wbr-element.html [ Failure ] -crbug.com/591099 external/wpt/html/syntax/parsing/Document.getElementsByTagName-foreign-01.html [ Crash ] -crbug.com/591099 external/wpt/html/syntax/parsing/Document.getElementsByTagName-foreign-02.html [ Crash ] -crbug.com/591099 external/wpt/html/syntax/parsing/Element.getElementsByTagName-foreign-01.html [ Crash ] -crbug.com/591099 external/wpt/html/syntax/parsing/Element.getElementsByTagName-foreign-02.html [ Crash ] -crbug.com/591099 external/wpt/html/syntax/parsing/math-parse03.html [ Crash ] +crbug.com/591099 external/wpt/html/syntax/parsing/Document.getElementsByTagName-foreign-01.html [ Crash Pass ] +crbug.com/591099 external/wpt/html/syntax/parsing/Document.getElementsByTagName-foreign-02.html [ Crash Pass ] +crbug.com/591099 external/wpt/html/syntax/parsing/Element.getElementsByTagName-foreign-01.html [ Crash Pass ] +crbug.com/591099 external/wpt/html/syntax/parsing/Element.getElementsByTagName-foreign-02.html [ Crash Pass ] +crbug.com/591099 external/wpt/html/syntax/parsing/math-parse03.html [ Crash Pass ] crbug.com/591099 external/wpt/html/syntax/parsing/named-character-references.html [ Pass Timeout ] -crbug.com/591099 external/wpt/html/syntax/parsing/template/additions-to-the-in-body-insertion-mode/generating-of-implied-end-tags.html [ Crash ] -crbug.com/591099 external/wpt/html/syntax/parsing/template/additions-to-the-in-body-insertion-mode/ignore-body-token.html [ Crash ] -crbug.com/591099 external/wpt/html/syntax/parsing/template/additions-to-the-in-body-insertion-mode/ignore-frameset-token.html [ Crash ] -crbug.com/591099 external/wpt/html/syntax/parsing/template/additions-to-the-in-body-insertion-mode/ignore-head-token.html [ Crash ] -crbug.com/591099 external/wpt/html/syntax/parsing/template/additions-to-the-in-body-insertion-mode/ignore-html-token.html [ Crash ] -crbug.com/591099 external/wpt/html/syntax/parsing/template/additions-to-the-in-body-insertion-mode/start-tag-html.html [ Crash ] -crbug.com/591099 external/wpt/html/syntax/parsing/template/additions-to-the-in-body-insertion-mode/template-end-tag-without-start-one.html [ Crash ] -crbug.com/591099 external/wpt/html/syntax/parsing/template/additions-to-the-in-frameset-insertion-mode/end-tag-frameset.html [ Crash ] -crbug.com/591099 external/wpt/html/syntax/parsing/template/additions-to-the-in-head-insertion-mode/generating-of-implied-end-tags.html [ Crash ] -crbug.com/591099 external/wpt/html/syntax/parsing/template/additions-to-the-in-head-insertion-mode/template-end-tag-without-start-one.html [ Crash ] -crbug.com/591099 external/wpt/html/syntax/parsing/template/appending-to-a-template/template-child-nodes.html [ Crash ] -crbug.com/591099 external/wpt/html/syntax/parsing/template/creating-an-element-for-the-token/template-owner-document.html [ Crash ] -crbug.com/591099 external/wpt/html/syntax/serializing-html-fragments/initial-linefeed-pre.html [ Crash ] -crbug.com/591099 external/wpt/html/the-xhtml-syntax/parsing-xhtml-documents/xhtml-mathml-dtd-entity-10.htm [ Crash ] -crbug.com/591099 external/wpt/html/the-xhtml-syntax/parsing-xhtml-documents/xhtml-mathml-dtd-entity-8.htm [ Crash ] -crbug.com/591099 external/wpt/html/webappapis/dynamic-markup-insertion/opening-the-input-stream/origin-check-in-document-open-same-origin-domain.sub.html [ Crash ] -crbug.com/591099 external/wpt/html/webappapis/scripting/events/onerroreventhandler.html [ Crash ] -crbug.com/591099 external/wpt/html/webappapis/scripting/processing-model-2/window-onerror-with-cross-frame-event-listeners-1.html [ Crash ] -crbug.com/591099 external/wpt/html/webappapis/scripting/processing-model-2/window-onerror-with-cross-frame-event-listeners-2.html [ Crash ] -crbug.com/591099 external/wpt/html/webappapis/scripting/processing-model-2/window-onerror-with-cross-frame-event-listeners-3.html [ Crash ] -crbug.com/591099 external/wpt/html/webappapis/scripting/processing-model-2/window-onerror-with-cross-frame-event-listeners-4.html [ Crash ] +crbug.com/591099 external/wpt/html/syntax/parsing/template/additions-to-the-in-body-insertion-mode/generating-of-implied-end-tags.html [ Crash Pass ] +crbug.com/591099 external/wpt/html/syntax/parsing/template/additions-to-the-in-body-insertion-mode/ignore-body-token.html [ Crash Pass ] +crbug.com/591099 external/wpt/html/syntax/parsing/template/additions-to-the-in-body-insertion-mode/ignore-frameset-token.html [ Crash Pass ] +crbug.com/591099 external/wpt/html/syntax/parsing/template/additions-to-the-in-body-insertion-mode/ignore-head-token.html [ Crash Pass ] +crbug.com/591099 external/wpt/html/syntax/parsing/template/additions-to-the-in-body-insertion-mode/ignore-html-token.html [ Crash Pass ] +crbug.com/591099 external/wpt/html/syntax/parsing/template/additions-to-the-in-body-insertion-mode/start-tag-html.html [ Crash Pass ] +crbug.com/591099 external/wpt/html/syntax/parsing/template/additions-to-the-in-body-insertion-mode/template-end-tag-without-start-one.html [ Crash Pass ] +crbug.com/591099 external/wpt/html/syntax/parsing/template/additions-to-the-in-frameset-insertion-mode/end-tag-frameset.html [ Crash Pass ] +crbug.com/591099 external/wpt/html/syntax/parsing/template/additions-to-the-in-head-insertion-mode/generating-of-implied-end-tags.html [ Crash Pass ] +crbug.com/591099 external/wpt/html/syntax/parsing/template/additions-to-the-in-head-insertion-mode/template-end-tag-without-start-one.html [ Crash Pass ] +crbug.com/591099 external/wpt/html/syntax/parsing/template/appending-to-a-template/template-child-nodes.html [ Crash Pass ] +crbug.com/591099 external/wpt/html/syntax/parsing/template/creating-an-element-for-the-token/template-owner-document.html [ Crash Pass ] +crbug.com/591099 external/wpt/html/syntax/serializing-html-fragments/initial-linefeed-pre.html [ Crash Pass ] +crbug.com/591099 external/wpt/html/the-xhtml-syntax/parsing-xhtml-documents/xhtml-mathml-dtd-entity-1.htm [ Timeout ] +crbug.com/591099 external/wpt/html/the-xhtml-syntax/parsing-xhtml-documents/xhtml-mathml-dtd-entity-10.htm [ Crash Timeout ] +crbug.com/591099 external/wpt/html/the-xhtml-syntax/parsing-xhtml-documents/xhtml-mathml-dtd-entity-2.htm [ Timeout ] +crbug.com/591099 external/wpt/html/the-xhtml-syntax/parsing-xhtml-documents/xhtml-mathml-dtd-entity-3.htm [ Timeout ] +crbug.com/591099 external/wpt/html/the-xhtml-syntax/parsing-xhtml-documents/xhtml-mathml-dtd-entity-4.htm [ Timeout ] +crbug.com/591099 external/wpt/html/the-xhtml-syntax/parsing-xhtml-documents/xhtml-mathml-dtd-entity-5.htm [ Timeout ] +crbug.com/591099 external/wpt/html/the-xhtml-syntax/parsing-xhtml-documents/xhtml-mathml-dtd-entity-6.htm [ Timeout ] +crbug.com/591099 external/wpt/html/the-xhtml-syntax/parsing-xhtml-documents/xhtml-mathml-dtd-entity-7.htm [ Timeout ] +crbug.com/591099 external/wpt/html/the-xhtml-syntax/parsing-xhtml-documents/xhtml-mathml-dtd-entity-8.htm [ Crash Timeout ] +crbug.com/591099 external/wpt/html/the-xhtml-syntax/parsing-xhtml-documents/xhtml-mathml-dtd-entity-9.htm [ Timeout ] +crbug.com/591099 external/wpt/html/webappapis/dynamic-markup-insertion/opening-the-input-stream/origin-check-in-document-open-same-origin-domain.sub.html [ Crash Pass ] +crbug.com/591099 external/wpt/html/webappapis/scripting/events/onerroreventhandler.html [ Crash Pass ] +crbug.com/591099 external/wpt/html/webappapis/scripting/processing-model-2/window-onerror-with-cross-frame-event-listeners-1.html [ Crash Pass ] +crbug.com/591099 external/wpt/html/webappapis/scripting/processing-model-2/window-onerror-with-cross-frame-event-listeners-2.html [ Crash Pass ] +crbug.com/591099 external/wpt/html/webappapis/scripting/processing-model-2/window-onerror-with-cross-frame-event-listeners-3.html [ Crash Pass ] +crbug.com/591099 external/wpt/html/webappapis/scripting/processing-model-2/window-onerror-with-cross-frame-event-listeners-4.html [ Crash Pass ] crbug.com/591099 external/wpt/http/basic-auth-cache-test.html [ Crash Timeout ] -crbug.com/591099 external/wpt/innerText/getter.html [ Crash ] -crbug.com/591099 external/wpt/input-events/input-events-typing-data-manual.html [ Crash ] -crbug.com/591099 external/wpt/intersection-observer/client-rect.html [ Crash ] -crbug.com/591099 external/wpt/intersection-observer/cross-origin-iframe.html [ Crash ] +crbug.com/591099 external/wpt/innerText/getter.html [ Crash Failure ] +crbug.com/591099 external/wpt/input-events/input-events-typing-data-manual.html [ Crash Pass ] +crbug.com/591099 external/wpt/intersection-observer/client-rect.html [ Crash Pass ] +crbug.com/591099 external/wpt/intersection-observer/cross-origin-iframe.html [ Crash Pass ] crbug.com/591099 external/wpt/intersection-observer/edge-inclusive-intersection.html [ Failure ] -crbug.com/591099 external/wpt/intersection-observer/iframe-no-root.html [ Crash ] +crbug.com/591099 external/wpt/intersection-observer/iframe-no-root.html [ Crash Pass ] crbug.com/591099 external/wpt/intersection-observer/remove-element.html [ Failure ] -crbug.com/591099 external/wpt/intersection-observer/root-margin.html [ Crash ] -crbug.com/591099 external/wpt/intersection-observer/same-document-root.html [ Crash ] -crbug.com/591099 external/wpt/media-source/mediasource-activesourcebuffers.html [ Crash ] -crbug.com/591099 external/wpt/media-source/mediasource-addsourcebuffer-mode.html [ Crash ] -crbug.com/591099 external/wpt/media-source/mediasource-addsourcebuffer.html [ Crash ] -crbug.com/591099 external/wpt/media-source/mediasource-append-buffer.html [ Crash ] -crbug.com/591099 external/wpt/media-source/mediasource-appendwindow.html [ Crash ] -crbug.com/591099 external/wpt/media-source/mediasource-buffered.html [ Crash ] -crbug.com/591099 external/wpt/media-source/mediasource-closed.html [ Crash ] -crbug.com/591099 external/wpt/media-source/mediasource-config-change-mp4-a-bitrate.html [ Crash ] -crbug.com/591099 external/wpt/media-source/mediasource-config-change-mp4-av-audio-bitrate.html [ Crash ] -crbug.com/591099 external/wpt/media-source/mediasource-config-change-mp4-av-framesize.html [ Crash ] -crbug.com/591099 external/wpt/media-source/mediasource-config-change-mp4-av-video-bitrate.html [ Crash ] -crbug.com/591099 external/wpt/media-source/mediasource-config-change-mp4-v-bitrate.html [ Crash ] -crbug.com/591099 external/wpt/media-source/mediasource-config-change-mp4-v-framerate.html [ Crash ] -crbug.com/591099 external/wpt/media-source/mediasource-config-change-mp4-v-framesize.html [ Crash ] -crbug.com/591099 external/wpt/media-source/mediasource-config-change-webm-a-bitrate.html [ Crash ] -crbug.com/591099 external/wpt/media-source/mediasource-config-change-webm-av-audio-bitrate.html [ Crash ] -crbug.com/591099 external/wpt/media-source/mediasource-config-change-webm-av-framesize.html [ Crash ] -crbug.com/591099 external/wpt/media-source/mediasource-config-change-webm-av-video-bitrate.html [ Crash ] -crbug.com/591099 external/wpt/media-source/mediasource-config-change-webm-v-bitrate.html [ Crash ] -crbug.com/591099 external/wpt/media-source/mediasource-config-change-webm-v-framerate.html [ Crash ] -crbug.com/591099 external/wpt/media-source/mediasource-config-change-webm-v-framesize.html [ Crash ] -crbug.com/591099 external/wpt/media-source/mediasource-detach.html [ Crash ] -crbug.com/591099 external/wpt/media-source/mediasource-duration-boundaryconditions.html [ Crash ] -crbug.com/591099 external/wpt/media-source/mediasource-duration.html [ Crash ] -crbug.com/591099 external/wpt/media-source/mediasource-endofstream-invaliderror.html [ Crash ] -crbug.com/591099 external/wpt/media-source/mediasource-endofstream.html [ Crash ] -crbug.com/591099 external/wpt/media-source/mediasource-errors.html [ Crash ] -crbug.com/591099 external/wpt/media-source/mediasource-getvideoplaybackquality.html [ Crash ] -crbug.com/591099 external/wpt/media-source/mediasource-liveseekable.html [ Crash ] -crbug.com/591099 external/wpt/media-source/mediasource-multiple-attach.html [ Crash ] -crbug.com/591099 external/wpt/media-source/mediasource-play-then-seek-back.html [ Crash ] -crbug.com/591099 external/wpt/media-source/mediasource-play.html [ Crash ] -crbug.com/591099 external/wpt/media-source/mediasource-preload.html [ Crash ] -crbug.com/591099 external/wpt/media-source/mediasource-redundant-seek.html [ Crash ] -crbug.com/591099 external/wpt/media-source/mediasource-remove.html [ Crash ] -crbug.com/591099 external/wpt/media-source/mediasource-removesourcebuffer.html [ Crash ] -crbug.com/591099 external/wpt/media-source/mediasource-seek-beyond-duration.html [ Crash ] -crbug.com/591099 external/wpt/media-source/mediasource-seek-during-pending-seek.html [ Crash ] -crbug.com/591099 external/wpt/media-source/mediasource-seekable.html [ Crash ] -crbug.com/591099 external/wpt/media-source/mediasource-sequencemode-append-buffer.html [ Crash ] -crbug.com/591099 external/wpt/media-source/mediasource-sourcebuffer-mode.html [ Crash ] -crbug.com/591099 external/wpt/media-source/mediasource-sourcebuffer-trackdefaults.html [ Crash ] -crbug.com/591099 external/wpt/media-source/mediasource-sourcebufferlist.html [ Crash ] -crbug.com/591099 external/wpt/media-source/mediasource-timestamp-offset.html [ Crash ] -crbug.com/591099 external/wpt/mediacapture-fromelement/idlharness.html [ Crash ] -crbug.com/591099 external/wpt/mediacapture-streams/MediaStream-MediaElement-srcObject.https.html [ Crash ] -crbug.com/591099 external/wpt/mediacapture-streams/MediaStreamTrack-MediaElement-disabled-video-is-black.https.html [ Crash ] -crbug.com/591099 external/wpt/mixed-content/imageset.https.sub.html [ Crash ] -crbug.com/591099 external/wpt/navigation-timing/nav2_test_frame_removed.html [ Crash ] -crbug.com/591099 external/wpt/navigation-timing/test_performance_attributes_exist_in_object.html [ Crash ] -crbug.com/591099 external/wpt/page-visibility/test_child_document.html [ Crash ] -crbug.com/591099 external/wpt/payment-request/allowpaymentrequest/active-document-cross-origin.https.sub.html [ Crash ] -crbug.com/591099 external/wpt/payment-request/allowpaymentrequest/active-document-same-origin.https.html [ Crash ] -crbug.com/591099 external/wpt/payment-request/allowpaymentrequest/basic.https.html [ Crash ] -crbug.com/591099 external/wpt/payment-request/payment-allowed-by-feature-policy-attribute-redirect-on-load.https.sub.html [ Crash ] -crbug.com/591099 external/wpt/payment-request/payment-allowed-by-feature-policy-attribute.https.sub.html [ Crash ] -crbug.com/591099 external/wpt/payment-request/payment-allowed-by-feature-policy.https.sub.html [ Crash ] -crbug.com/591099 external/wpt/payment-request/payment-default-feature-policy.https.sub.html [ Crash ] -crbug.com/591099 external/wpt/payment-request/payment-disabled-by-feature-policy.https.sub.html [ Crash ] -crbug.com/591099 external/wpt/payment-request/payment-request-id.https.html [ Crash ] -crbug.com/591099 external/wpt/payment-request/payment-request-in-iframe.html [ Crash ] +crbug.com/591099 external/wpt/intersection-observer/root-margin.html [ Crash Pass ] +crbug.com/591099 external/wpt/intersection-observer/same-document-root.html [ Crash Failure ] +crbug.com/591099 external/wpt/media-source/mediasource-activesourcebuffers.html [ Crash Pass ] +crbug.com/591099 external/wpt/media-source/mediasource-addsourcebuffer-mode.html [ Crash Pass ] +crbug.com/591099 external/wpt/media-source/mediasource-addsourcebuffer.html [ Crash Pass ] +crbug.com/591099 external/wpt/media-source/mediasource-append-buffer.html [ Crash Pass ] +crbug.com/591099 external/wpt/media-source/mediasource-appendwindow.html [ Crash Pass ] +crbug.com/591099 external/wpt/media-source/mediasource-buffered.html [ Crash Pass ] +crbug.com/591099 external/wpt/media-source/mediasource-closed.html [ Crash Pass ] +crbug.com/591099 external/wpt/media-source/mediasource-config-change-mp4-a-bitrate.html [ Crash Pass ] +crbug.com/591099 external/wpt/media-source/mediasource-config-change-mp4-av-audio-bitrate.html [ Crash Pass ] +crbug.com/591099 external/wpt/media-source/mediasource-config-change-mp4-av-framesize.html [ Crash Pass ] +crbug.com/591099 external/wpt/media-source/mediasource-config-change-mp4-av-video-bitrate.html [ Crash Pass ] +crbug.com/591099 external/wpt/media-source/mediasource-config-change-mp4-v-bitrate.html [ Crash Pass ] +crbug.com/591099 external/wpt/media-source/mediasource-config-change-mp4-v-framerate.html [ Crash Pass ] +crbug.com/591099 external/wpt/media-source/mediasource-config-change-mp4-v-framesize.html [ Crash Pass ] +crbug.com/591099 external/wpt/media-source/mediasource-config-change-webm-a-bitrate.html [ Crash Pass ] +crbug.com/591099 external/wpt/media-source/mediasource-config-change-webm-av-audio-bitrate.html [ Crash Pass ] +crbug.com/591099 external/wpt/media-source/mediasource-config-change-webm-av-framesize.html [ Crash Pass ] +crbug.com/591099 external/wpt/media-source/mediasource-config-change-webm-av-video-bitrate.html [ Crash Pass ] +crbug.com/591099 external/wpt/media-source/mediasource-config-change-webm-v-bitrate.html [ Crash Pass ] +crbug.com/591099 external/wpt/media-source/mediasource-config-change-webm-v-framerate.html [ Crash Pass ] +crbug.com/591099 external/wpt/media-source/mediasource-config-change-webm-v-framesize.html [ Crash Pass ] +crbug.com/591099 external/wpt/media-source/mediasource-detach.html [ Crash Pass ] +crbug.com/591099 external/wpt/media-source/mediasource-duration-boundaryconditions.html [ Crash Pass ] +crbug.com/591099 external/wpt/media-source/mediasource-duration.html [ Crash Pass ] +crbug.com/591099 external/wpt/media-source/mediasource-endofstream-invaliderror.html [ Crash Pass ] +crbug.com/591099 external/wpt/media-source/mediasource-endofstream.html [ Crash Pass ] +crbug.com/591099 external/wpt/media-source/mediasource-errors.html [ Crash Pass ] +crbug.com/591099 external/wpt/media-source/mediasource-getvideoplaybackquality.html [ Crash Timeout ] +crbug.com/591099 external/wpt/media-source/mediasource-liveseekable.html [ Crash Pass ] +crbug.com/591099 external/wpt/media-source/mediasource-multiple-attach.html [ Crash Pass ] +crbug.com/591099 external/wpt/media-source/mediasource-play-then-seek-back.html [ Crash Pass ] +crbug.com/591099 external/wpt/media-source/mediasource-play.html [ Crash Pass ] +crbug.com/591099 external/wpt/media-source/mediasource-preload.html [ Crash Pass ] +crbug.com/591099 external/wpt/media-source/mediasource-redundant-seek.html [ Crash Pass ] +crbug.com/591099 external/wpt/media-source/mediasource-remove.html [ Crash Pass ] +crbug.com/591099 external/wpt/media-source/mediasource-removesourcebuffer.html [ Crash Pass ] +crbug.com/591099 external/wpt/media-source/mediasource-seek-beyond-duration.html [ Crash Pass ] +crbug.com/591099 external/wpt/media-source/mediasource-seek-during-pending-seek.html [ Crash Pass ] +crbug.com/591099 external/wpt/media-source/mediasource-seekable.html [ Crash Pass ] +crbug.com/591099 external/wpt/media-source/mediasource-sequencemode-append-buffer.html [ Crash Pass ] +crbug.com/591099 external/wpt/media-source/mediasource-sourcebuffer-mode.html [ Crash Pass ] +crbug.com/591099 external/wpt/media-source/mediasource-sourcebuffer-trackdefaults.html [ Crash Pass ] +crbug.com/591099 external/wpt/media-source/mediasource-sourcebufferlist.html [ Crash Pass ] +crbug.com/591099 external/wpt/media-source/mediasource-timestamp-offset.html [ Crash Pass ] +crbug.com/591099 external/wpt/mediacapture-fromelement/idlharness.html [ Crash Pass ] +crbug.com/591099 external/wpt/mediacapture-streams/MediaStream-MediaElement-srcObject.https.html [ Crash Pass ] +crbug.com/591099 external/wpt/mediacapture-streams/MediaStreamTrack-MediaElement-disabled-video-is-black.https.html [ Crash Pass ] +crbug.com/591099 external/wpt/mixed-content/imageset.https.sub.html [ Crash Pass ] +crbug.com/591099 external/wpt/navigation-timing/nav2_test_frame_removed.html [ Crash Pass ] +crbug.com/591099 external/wpt/navigation-timing/test_performance_attributes_exist_in_object.html [ Crash Pass ] +crbug.com/591099 external/wpt/page-visibility/test_child_document.html [ Crash Pass ] +crbug.com/591099 external/wpt/payment-request/allowpaymentrequest/active-document-cross-origin.https.sub.html [ Crash Pass ] +crbug.com/591099 external/wpt/payment-request/allowpaymentrequest/active-document-same-origin.https.html [ Crash Pass ] +crbug.com/591099 external/wpt/payment-request/allowpaymentrequest/basic.https.html [ Crash Pass ] +crbug.com/591099 external/wpt/payment-request/payment-allowed-by-feature-policy-attribute-redirect-on-load.https.sub.html [ Crash Pass ] +crbug.com/591099 external/wpt/payment-request/payment-allowed-by-feature-policy-attribute.https.sub.html [ Crash Pass ] +crbug.com/591099 external/wpt/payment-request/payment-allowed-by-feature-policy.https.sub.html [ Crash Failure ] +crbug.com/591099 external/wpt/payment-request/payment-default-feature-policy.https.sub.html [ Crash Pass ] +crbug.com/591099 external/wpt/payment-request/payment-disabled-by-feature-policy.https.sub.html [ Crash Failure ] +crbug.com/591099 external/wpt/payment-request/payment-request-id.https.html [ Crash Pass ] +crbug.com/591099 external/wpt/payment-request/payment-request-in-iframe.html [ Crash Pass ] crbug.com/591099 external/wpt/pointerevents/pointerevent_attributes_hoverable_pointers-manual.html [ Crash Pass Timeout ] crbug.com/591099 external/wpt/pointerevents/pointerevent_attributes_nohover_pointers-manual.html [ Crash Pass Timeout ] -crbug.com/591099 external/wpt/pointerevents/pointerevent_capture_mouse-manual.html [ Crash Timeout ] -crbug.com/591099 external/wpt/pointerevents/pointerevent_capture_suppressing_mouse-manual.html [ Crash Timeout ] +crbug.com/591099 external/wpt/pointerevents/pointerevent_capture_mouse-manual.html [ Crash Pass Timeout ] +crbug.com/591099 external/wpt/pointerevents/pointerevent_capture_suppressing_mouse-manual.html [ Crash Pass Timeout ] crbug.com/591099 external/wpt/pointerevents/pointerevent_click_during_capture-manual.html [ Crash Timeout ] crbug.com/591099 external/wpt/pointerevents/pointerevent_disabled_form_control-manual.html [ Timeout ] crbug.com/591099 external/wpt/pointerevents/pointerevent_lostpointercapture_for_disconnected_node-manual.html [ Crash Timeout ] -crbug.com/591099 external/wpt/pointerevents/pointerevent_lostpointercapture_is_first-manual.html [ Crash Timeout ] +crbug.com/591099 external/wpt/pointerevents/pointerevent_lostpointercapture_is_first-manual.html [ Crash Pass Timeout ] crbug.com/591099 external/wpt/pointerevents/pointerevent_pointerleave_pen-manual.html [ Failure Timeout ] -crbug.com/591099 external/wpt/pointerevents/pointerevent_releasepointercapture_onpointerup_mouse-manual.html [ Crash ] -crbug.com/591099 external/wpt/pointerevents/pointerevent_setpointercapture_relatedtarget-manual.html [ Crash Timeout ] -crbug.com/591099 external/wpt/pointerevents/pointerevent_touch-action-button-test_touch-manual.html [ Crash Timeout ] -crbug.com/591099 external/wpt/pointerevents/pointerevent_touch-action-inherit_child-auto-child-none_touch-manual.html [ Crash Timeout ] -crbug.com/591099 external/wpt/pointerevents/pointerevent_touch-action-inherit_child-none_touch-manual.html [ Crash Timeout ] -crbug.com/591099 external/wpt/pointerevents/pointerevent_touch-action-inherit_child-pan-x-child-pan-x_touch-manual.html [ Crash Timeout ] -crbug.com/591099 external/wpt/pointerevents/pointerevent_touch-action-inherit_child-pan-x-child-pan-y_touch-manual.html [ Crash Timeout ] -crbug.com/591099 external/wpt/pointerevents/pointerevent_touch-action-inherit_parent-none_touch-manual.html [ Crash Timeout ] -crbug.com/591099 external/wpt/pointerevents/pointerevent_touch-action-none-css_touch-manual.html [ Crash Timeout ] -crbug.com/591099 external/wpt/pointerevents/pointerevent_touch-action-pan-down-css_touch-manual.html [ Crash Timeout ] -crbug.com/591099 external/wpt/pointerevents/pointerevent_touch-action-pan-left-css_touch-manual.html [ Crash Timeout ] -crbug.com/591099 external/wpt/pointerevents/pointerevent_touch-action-pan-right-css_touch-manual.html [ Crash Timeout ] -crbug.com/591099 external/wpt/pointerevents/pointerevent_touch-action-pan-up-css_touch-manual.html [ Crash Timeout ] -crbug.com/591099 external/wpt/pointerevents/pointerevent_touch-action-pan-x-css_touch-manual.html [ Crash Timeout ] -crbug.com/591099 external/wpt/pointerevents/pointerevent_touch-action-pan-x-pan-y-pan-y_touch-manual.html [ Crash Timeout ] -crbug.com/591099 external/wpt/pointerevents/pointerevent_touch-action-pan-y-css_touch-manual.html [ Crash Timeout ] +crbug.com/591099 external/wpt/pointerevents/pointerevent_releasepointercapture_onpointerup_mouse-manual.html [ Crash Pass ] +crbug.com/591099 external/wpt/pointerevents/pointerevent_setpointercapture_relatedtarget-manual.html [ Crash Pass Timeout ] +crbug.com/591099 external/wpt/pointerevents/pointerevent_touch-action-button-test_touch-manual.html [ Crash Failure Timeout ] +crbug.com/591099 external/wpt/pointerevents/pointerevent_touch-action-inherit_child-auto-child-none_touch-manual.html [ Crash Pass Timeout ] +crbug.com/591099 external/wpt/pointerevents/pointerevent_touch-action-inherit_child-none_touch-manual.html [ Crash Pass Timeout ] +crbug.com/591099 external/wpt/pointerevents/pointerevent_touch-action-inherit_child-pan-x-child-pan-x_touch-manual.html [ Crash Pass Timeout ] +crbug.com/591099 external/wpt/pointerevents/pointerevent_touch-action-inherit_child-pan-x-child-pan-y_touch-manual.html [ Crash Pass Timeout ] +crbug.com/591099 external/wpt/pointerevents/pointerevent_touch-action-inherit_parent-none_touch-manual.html [ Crash Pass Timeout ] +crbug.com/591099 external/wpt/pointerevents/pointerevent_touch-action-none-css_touch-manual.html [ Crash Pass Timeout ] +crbug.com/591099 external/wpt/pointerevents/pointerevent_touch-action-pan-down-css_touch-manual.html [ Crash Pass Timeout ] +crbug.com/591099 external/wpt/pointerevents/pointerevent_touch-action-pan-left-css_touch-manual.html [ Crash Pass Timeout ] +crbug.com/591099 external/wpt/pointerevents/pointerevent_touch-action-pan-right-css_touch-manual.html [ Crash Pass Timeout ] +crbug.com/591099 external/wpt/pointerevents/pointerevent_touch-action-pan-up-css_touch-manual.html [ Crash Pass Timeout ] +crbug.com/591099 external/wpt/pointerevents/pointerevent_touch-action-pan-x-css_touch-manual.html [ Crash Pass Timeout ] +crbug.com/591099 external/wpt/pointerevents/pointerevent_touch-action-pan-x-pan-y-pan-y_touch-manual.html [ Crash Pass Timeout ] +crbug.com/591099 external/wpt/pointerevents/pointerevent_touch-action-pan-y-css_touch-manual.html [ Crash Pass Timeout ] crbug.com/591099 external/wpt/pointerevents/pointerevent_touch-action-span-test_touch-manual.html [ Crash Timeout ] -crbug.com/591099 external/wpt/pointerevents/pointerevent_touch-action-svg-test_touch-manual.html [ Crash Timeout ] -crbug.com/591099 external/wpt/pointerevents/pointerevent_touch-action-table-test_touch-manual.html [ Crash Timeout ] +crbug.com/591099 external/wpt/pointerevents/pointerevent_touch-action-svg-test_touch-manual.html [ Crash Failure Timeout ] +crbug.com/591099 external/wpt/pointerevents/pointerevent_touch-action-table-test_touch-manual.html [ Crash Pass Timeout ] crbug.com/591099 external/wpt/quirks-mode/blocks-ignore-line-height.html [ Failure ] -crbug.com/591099 external/wpt/quirks-mode/classname-query-after-sibling-adoption.html [ Crash ] +crbug.com/591099 external/wpt/quirks-mode/classname-query-after-sibling-adoption.html [ Crash Pass ] crbug.com/591099 external/wpt/quirks-mode/hashless-hex-color.html [ Pass Timeout ] -crbug.com/591099 external/wpt/quirks-mode/line-height-calculation.html [ Crash ] -crbug.com/591099 external/wpt/quirks-mode/table-cell-width-calculation.html [ Crash ] -crbug.com/591099 external/wpt/referrer-policy/css-integration/external-import-stylesheet.html [ Crash ] -crbug.com/591099 external/wpt/referrer-policy/css-integration/external-stylesheet.html [ Crash ] -crbug.com/591099 external/wpt/referrer-policy/css-integration/internal-import-stylesheet.html [ Crash ] -crbug.com/591099 external/wpt/referrer-policy/css-integration/internal-stylesheet.html [ Crash ] -crbug.com/591099 external/wpt/referrer-policy/css-integration/processing-instruction.html [ Crash ] -crbug.com/591099 external/wpt/referrer-policy/generic/sandboxed-iframe-with-opaque-origin.html [ Crash ] -crbug.com/591099 external/wpt/referrer-policy/generic/subresource-test/area-navigate.html [ Crash ] -crbug.com/591099 external/wpt/referrer-policy/generic/subresource-test/iframe-messaging.html [ Crash ] -crbug.com/591099 external/wpt/referrer-policy/generic/subresource-test/image-decoding.html [ Crash ] -crbug.com/591099 external/wpt/referrer-policy/generic/subresource-test/link-navigate.html [ Crash ] -crbug.com/591099 external/wpt/referrer-policy/generic/unsupported-csp-referrer-directive.html [ Crash ] -crbug.com/591099 external/wpt/referrer-policy/no-referrer-when-downgrade/attr-referrer/cross-origin/http-http/iframe-tag/insecure-protocol.keep-origin-redirect.http.html [ Crash ] -crbug.com/591099 external/wpt/referrer-policy/no-referrer-when-downgrade/attr-referrer/cross-origin/http-http/iframe-tag/insecure-protocol.no-redirect.http.html [ Crash ] -crbug.com/591099 external/wpt/referrer-policy/no-referrer-when-downgrade/attr-referrer/cross-origin/http-http/iframe-tag/insecure-protocol.swap-origin-redirect.http.html [ Crash ] -crbug.com/591099 external/wpt/referrer-policy/no-referrer-when-downgrade/attr-referrer/cross-origin/http-http/img-tag/insecure-protocol.keep-origin-redirect.http.html [ Crash ] -crbug.com/591099 external/wpt/referrer-policy/no-referrer-when-downgrade/attr-referrer/cross-origin/http-http/img-tag/insecure-protocol.no-redirect.http.html [ Crash ] -crbug.com/591099 external/wpt/referrer-policy/no-referrer-when-downgrade/attr-referrer/cross-origin/http-http/img-tag/insecure-protocol.swap-origin-redirect.http.html [ Crash ] -crbug.com/591099 external/wpt/referrer-policy/no-referrer-when-downgrade/attr-referrer/cross-origin/http-https/iframe-tag/upgrade-protocol.keep-origin-redirect.http.html [ Crash ] -crbug.com/591099 external/wpt/referrer-policy/no-referrer-when-downgrade/attr-referrer/cross-origin/http-https/iframe-tag/upgrade-protocol.no-redirect.http.html [ Crash ] -crbug.com/591099 external/wpt/referrer-policy/no-referrer-when-downgrade/attr-referrer/cross-origin/http-https/iframe-tag/upgrade-protocol.swap-origin-redirect.http.html [ Crash ] -crbug.com/591099 external/wpt/referrer-policy/no-referrer-when-downgrade/attr-referrer/cross-origin/http-https/img-tag/upgrade-protocol.keep-origin-redirect.http.html [ Crash ] -crbug.com/591099 external/wpt/referrer-policy/no-referrer-when-downgrade/attr-referrer/cross-origin/http-https/img-tag/upgrade-protocol.no-redirect.http.html [ Crash ] -crbug.com/591099 external/wpt/referrer-policy/no-referrer-when-downgrade/attr-referrer/cross-origin/http-https/img-tag/upgrade-protocol.swap-origin-redirect.http.html [ Crash ] -crbug.com/591099 external/wpt/referrer-policy/no-referrer-when-downgrade/attr-referrer/same-origin/http-http/iframe-tag/insecure-protocol.keep-origin-redirect.http.html [ Crash ] -crbug.com/591099 external/wpt/referrer-policy/no-referrer-when-downgrade/attr-referrer/same-origin/http-http/iframe-tag/insecure-protocol.no-redirect.http.html [ Crash ] -crbug.com/591099 external/wpt/referrer-policy/no-referrer-when-downgrade/attr-referrer/same-origin/http-http/iframe-tag/insecure-protocol.swap-origin-redirect.http.html [ Crash ] -crbug.com/591099 external/wpt/referrer-policy/no-referrer-when-downgrade/attr-referrer/same-origin/http-http/img-tag/insecure-protocol.keep-origin-redirect.http.html [ Crash ] -crbug.com/591099 external/wpt/referrer-policy/no-referrer-when-downgrade/attr-referrer/same-origin/http-http/img-tag/insecure-protocol.no-redirect.http.html [ Crash ] -crbug.com/591099 external/wpt/referrer-policy/no-referrer-when-downgrade/attr-referrer/same-origin/http-http/img-tag/insecure-protocol.swap-origin-redirect.http.html [ Crash ] -crbug.com/591099 external/wpt/referrer-policy/no-referrer-when-downgrade/attr-referrer/same-origin/http-https/iframe-tag/upgrade-protocol.keep-origin-redirect.http.html [ Crash ] -crbug.com/591099 external/wpt/referrer-policy/no-referrer-when-downgrade/attr-referrer/same-origin/http-https/iframe-tag/upgrade-protocol.no-redirect.http.html [ Crash ] -crbug.com/591099 external/wpt/referrer-policy/no-referrer-when-downgrade/attr-referrer/same-origin/http-https/iframe-tag/upgrade-protocol.swap-origin-redirect.http.html [ Crash ] -crbug.com/591099 external/wpt/referrer-policy/no-referrer-when-downgrade/attr-referrer/same-origin/http-https/img-tag/upgrade-protocol.keep-origin-redirect.http.html [ Crash ] -crbug.com/591099 external/wpt/referrer-policy/no-referrer-when-downgrade/attr-referrer/same-origin/http-https/img-tag/upgrade-protocol.no-redirect.http.html [ Crash ] -crbug.com/591099 external/wpt/referrer-policy/no-referrer-when-downgrade/attr-referrer/same-origin/http-https/img-tag/upgrade-protocol.swap-origin-redirect.http.html [ Crash ] -crbug.com/591099 external/wpt/referrer-policy/no-referrer-when-downgrade/http-rp/cross-origin/http-http/iframe-tag/insecure-protocol.keep-origin-redirect.http.html [ Crash ] -crbug.com/591099 external/wpt/referrer-policy/no-referrer-when-downgrade/http-rp/cross-origin/http-http/iframe-tag/insecure-protocol.no-redirect.http.html [ Crash ] -crbug.com/591099 external/wpt/referrer-policy/no-referrer-when-downgrade/http-rp/cross-origin/http-http/iframe-tag/insecure-protocol.swap-origin-redirect.http.html [ Crash ] -crbug.com/591099 external/wpt/referrer-policy/no-referrer-when-downgrade/http-rp/cross-origin/http-http/img-tag/insecure-protocol.keep-origin-redirect.http.html [ Crash ] -crbug.com/591099 external/wpt/referrer-policy/no-referrer-when-downgrade/http-rp/cross-origin/http-http/img-tag/insecure-protocol.no-redirect.http.html [ Crash ] -crbug.com/591099 external/wpt/referrer-policy/no-referrer-when-downgrade/http-rp/cross-origin/http-http/img-tag/insecure-protocol.swap-origin-redirect.http.html [ Crash ] -crbug.com/591099 external/wpt/referrer-policy/no-referrer-when-downgrade/http-rp/cross-origin/http-https/iframe-tag/upgrade-protocol.keep-origin-redirect.http.html [ Crash ] -crbug.com/591099 external/wpt/referrer-policy/no-referrer-when-downgrade/http-rp/cross-origin/http-https/iframe-tag/upgrade-protocol.no-redirect.http.html [ Crash ] -crbug.com/591099 external/wpt/referrer-policy/no-referrer-when-downgrade/http-rp/cross-origin/http-https/iframe-tag/upgrade-protocol.swap-origin-redirect.http.html [ Crash ] -crbug.com/591099 external/wpt/referrer-policy/no-referrer-when-downgrade/http-rp/cross-origin/http-https/img-tag/upgrade-protocol.keep-origin-redirect.http.html [ Crash ] -crbug.com/591099 external/wpt/referrer-policy/no-referrer-when-downgrade/http-rp/cross-origin/http-https/img-tag/upgrade-protocol.no-redirect.http.html [ Crash ] -crbug.com/591099 external/wpt/referrer-policy/no-referrer-when-downgrade/http-rp/cross-origin/http-https/img-tag/upgrade-protocol.swap-origin-redirect.http.html [ Crash ] -crbug.com/591099 external/wpt/referrer-policy/no-referrer-when-downgrade/http-rp/same-origin/http-http/iframe-tag/insecure-protocol.keep-origin-redirect.http.html [ Crash ] -crbug.com/591099 external/wpt/referrer-policy/no-referrer-when-downgrade/http-rp/same-origin/http-http/iframe-tag/insecure-protocol.no-redirect.http.html [ Crash ] -crbug.com/591099 external/wpt/referrer-policy/no-referrer-when-downgrade/http-rp/same-origin/http-http/iframe-tag/insecure-protocol.swap-origin-redirect.http.html [ Crash ] -crbug.com/591099 external/wpt/referrer-policy/no-referrer-when-downgrade/http-rp/same-origin/http-http/img-tag/insecure-protocol.keep-origin-redirect.http.html [ Crash ] -crbug.com/591099 external/wpt/referrer-policy/no-referrer-when-downgrade/http-rp/same-origin/http-http/img-tag/insecure-protocol.no-redirect.http.html [ Crash ] -crbug.com/591099 external/wpt/referrer-policy/no-referrer-when-downgrade/http-rp/same-origin/http-http/img-tag/insecure-protocol.swap-origin-redirect.http.html [ Crash ] -crbug.com/591099 external/wpt/referrer-policy/no-referrer-when-downgrade/http-rp/same-origin/http-https/iframe-tag/upgrade-protocol.keep-origin-redirect.http.html [ Crash ] -crbug.com/591099 external/wpt/referrer-policy/no-referrer-when-downgrade/http-rp/same-origin/http-https/iframe-tag/upgrade-protocol.no-redirect.http.html [ Crash ] -crbug.com/591099 external/wpt/referrer-policy/no-referrer-when-downgrade/http-rp/same-origin/http-https/iframe-tag/upgrade-protocol.swap-origin-redirect.http.html [ Crash ] -crbug.com/591099 external/wpt/referrer-policy/no-referrer-when-downgrade/http-rp/same-origin/http-https/img-tag/upgrade-protocol.keep-origin-redirect.http.html [ Crash ] -crbug.com/591099 external/wpt/referrer-policy/no-referrer-when-downgrade/http-rp/same-origin/http-https/img-tag/upgrade-protocol.no-redirect.http.html [ Crash ] -crbug.com/591099 external/wpt/referrer-policy/no-referrer-when-downgrade/http-rp/same-origin/http-https/img-tag/upgrade-protocol.swap-origin-redirect.http.html [ Crash ] -crbug.com/591099 external/wpt/referrer-policy/no-referrer-when-downgrade/meta-referrer/cross-origin/http-http/iframe-tag/insecure-protocol.keep-origin-redirect.http.html [ Crash ] -crbug.com/591099 external/wpt/referrer-policy/no-referrer-when-downgrade/meta-referrer/cross-origin/http-http/iframe-tag/insecure-protocol.no-redirect.http.html [ Crash ] -crbug.com/591099 external/wpt/referrer-policy/no-referrer-when-downgrade/meta-referrer/cross-origin/http-http/iframe-tag/insecure-protocol.swap-origin-redirect.http.html [ Crash ] -crbug.com/591099 external/wpt/referrer-policy/no-referrer-when-downgrade/meta-referrer/cross-origin/http-http/img-tag/insecure-protocol.keep-origin-redirect.http.html [ Crash ] -crbug.com/591099 external/wpt/referrer-policy/no-referrer-when-downgrade/meta-referrer/cross-origin/http-http/img-tag/insecure-protocol.no-redirect.http.html [ Crash ] -crbug.com/591099 external/wpt/referrer-policy/no-referrer-when-downgrade/meta-referrer/cross-origin/http-http/img-tag/insecure-protocol.swap-origin-redirect.http.html [ Crash ] -crbug.com/591099 external/wpt/referrer-policy/no-referrer-when-downgrade/meta-referrer/cross-origin/http-https/iframe-tag/upgrade-protocol.keep-origin-redirect.http.html [ Crash ] -crbug.com/591099 external/wpt/referrer-policy/no-referrer-when-downgrade/meta-referrer/cross-origin/http-https/iframe-tag/upgrade-protocol.no-redirect.http.html [ Crash ] -crbug.com/591099 external/wpt/referrer-policy/no-referrer-when-downgrade/meta-referrer/cross-origin/http-https/iframe-tag/upgrade-protocol.swap-origin-redirect.http.html [ Crash ] -crbug.com/591099 external/wpt/referrer-policy/no-referrer-when-downgrade/meta-referrer/cross-origin/http-https/img-tag/upgrade-protocol.keep-origin-redirect.http.html [ Crash ] -crbug.com/591099 external/wpt/referrer-policy/no-referrer-when-downgrade/meta-referrer/cross-origin/http-https/img-tag/upgrade-protocol.no-redirect.http.html [ Crash ] -crbug.com/591099 external/wpt/referrer-policy/no-referrer-when-downgrade/meta-referrer/cross-origin/http-https/img-tag/upgrade-protocol.swap-origin-redirect.http.html [ Crash ] -crbug.com/591099 external/wpt/referrer-policy/no-referrer-when-downgrade/meta-referrer/same-origin/http-http/iframe-tag/insecure-protocol.keep-origin-redirect.http.html [ Crash ] -crbug.com/591099 external/wpt/referrer-policy/no-referrer-when-downgrade/meta-referrer/same-origin/http-http/iframe-tag/insecure-protocol.no-redirect.http.html [ Crash ] -crbug.com/591099 external/wpt/referrer-policy/no-referrer-when-downgrade/meta-referrer/same-origin/http-http/iframe-tag/insecure-protocol.swap-origin-redirect.http.html [ Crash ] -crbug.com/591099 external/wpt/referrer-policy/no-referrer-when-downgrade/meta-referrer/same-origin/http-http/img-tag/insecure-protocol.keep-origin-redirect.http.html [ Crash ] -crbug.com/591099 external/wpt/referrer-policy/no-referrer-when-downgrade/meta-referrer/same-origin/http-http/img-tag/insecure-protocol.no-redirect.http.html [ Crash ] -crbug.com/591099 external/wpt/referrer-policy/no-referrer-when-downgrade/meta-referrer/same-origin/http-http/img-tag/insecure-protocol.swap-origin-redirect.http.html [ Crash ] -crbug.com/591099 external/wpt/referrer-policy/no-referrer-when-downgrade/meta-referrer/same-origin/http-https/iframe-tag/upgrade-protocol.keep-origin-redirect.http.html [ Crash ] -crbug.com/591099 external/wpt/referrer-policy/no-referrer-when-downgrade/meta-referrer/same-origin/http-https/iframe-tag/upgrade-protocol.no-redirect.http.html [ Crash ] -crbug.com/591099 external/wpt/referrer-policy/no-referrer-when-downgrade/meta-referrer/same-origin/http-https/iframe-tag/upgrade-protocol.swap-origin-redirect.http.html [ Crash ] -crbug.com/591099 external/wpt/referrer-policy/no-referrer-when-downgrade/meta-referrer/same-origin/http-https/img-tag/upgrade-protocol.keep-origin-redirect.http.html [ Crash ] -crbug.com/591099 external/wpt/referrer-policy/no-referrer-when-downgrade/meta-referrer/same-origin/http-https/img-tag/upgrade-protocol.no-redirect.http.html [ Crash ] -crbug.com/591099 external/wpt/referrer-policy/no-referrer-when-downgrade/meta-referrer/same-origin/http-https/img-tag/upgrade-protocol.swap-origin-redirect.http.html [ Crash ] -crbug.com/591099 external/wpt/referrer-policy/no-referrer/attr-referrer/cross-origin/http-http/iframe-tag/generic.keep-origin-redirect.http.html [ Crash ] -crbug.com/591099 external/wpt/referrer-policy/no-referrer/attr-referrer/cross-origin/http-http/iframe-tag/generic.no-redirect.http.html [ Crash ] -crbug.com/591099 external/wpt/referrer-policy/no-referrer/attr-referrer/cross-origin/http-http/iframe-tag/generic.swap-origin-redirect.http.html [ Crash ] -crbug.com/591099 external/wpt/referrer-policy/no-referrer/attr-referrer/cross-origin/http-http/img-tag/generic.keep-origin-redirect.http.html [ Crash ] -crbug.com/591099 external/wpt/referrer-policy/no-referrer/attr-referrer/cross-origin/http-http/img-tag/generic.no-redirect.http.html [ Crash ] -crbug.com/591099 external/wpt/referrer-policy/no-referrer/attr-referrer/cross-origin/http-http/img-tag/generic.swap-origin-redirect.http.html [ Crash ] -crbug.com/591099 external/wpt/referrer-policy/no-referrer/attr-referrer/cross-origin/http-https/iframe-tag/generic.keep-origin-redirect.http.html [ Crash ] -crbug.com/591099 external/wpt/referrer-policy/no-referrer/attr-referrer/cross-origin/http-https/iframe-tag/generic.no-redirect.http.html [ Crash ] -crbug.com/591099 external/wpt/referrer-policy/no-referrer/attr-referrer/cross-origin/http-https/iframe-tag/generic.swap-origin-redirect.http.html [ Crash ] -crbug.com/591099 external/wpt/referrer-policy/no-referrer/attr-referrer/cross-origin/http-https/img-tag/generic.keep-origin-redirect.http.html [ Crash ] -crbug.com/591099 external/wpt/referrer-policy/no-referrer/attr-referrer/cross-origin/http-https/img-tag/generic.no-redirect.http.html [ Crash ] -crbug.com/591099 external/wpt/referrer-policy/no-referrer/attr-referrer/cross-origin/http-https/img-tag/generic.swap-origin-redirect.http.html [ Crash ] -crbug.com/591099 external/wpt/referrer-policy/no-referrer/attr-referrer/same-origin/http-http/iframe-tag/generic.keep-origin-redirect.http.html [ Crash ] -crbug.com/591099 external/wpt/referrer-policy/no-referrer/attr-referrer/same-origin/http-http/iframe-tag/generic.no-redirect.http.html [ Crash ] -crbug.com/591099 external/wpt/referrer-policy/no-referrer/attr-referrer/same-origin/http-http/iframe-tag/generic.swap-origin-redirect.http.html [ Crash ] -crbug.com/591099 external/wpt/referrer-policy/no-referrer/attr-referrer/same-origin/http-http/img-tag/generic.keep-origin-redirect.http.html [ Crash ] -crbug.com/591099 external/wpt/referrer-policy/no-referrer/attr-referrer/same-origin/http-http/img-tag/generic.no-redirect.http.html [ Crash ] -crbug.com/591099 external/wpt/referrer-policy/no-referrer/attr-referrer/same-origin/http-http/img-tag/generic.swap-origin-redirect.http.html [ Crash ] -crbug.com/591099 external/wpt/referrer-policy/no-referrer/attr-referrer/same-origin/http-https/iframe-tag/generic.keep-origin-redirect.http.html [ Crash ] -crbug.com/591099 external/wpt/referrer-policy/no-referrer/attr-referrer/same-origin/http-https/iframe-tag/generic.no-redirect.http.html [ Crash ] -crbug.com/591099 external/wpt/referrer-policy/no-referrer/attr-referrer/same-origin/http-https/iframe-tag/generic.swap-origin-redirect.http.html [ Crash ] -crbug.com/591099 external/wpt/referrer-policy/no-referrer/attr-referrer/same-origin/http-https/img-tag/generic.keep-origin-redirect.http.html [ Crash ] -crbug.com/591099 external/wpt/referrer-policy/no-referrer/attr-referrer/same-origin/http-https/img-tag/generic.no-redirect.http.html [ Crash ] -crbug.com/591099 external/wpt/referrer-policy/no-referrer/attr-referrer/same-origin/http-https/img-tag/generic.swap-origin-redirect.http.html [ Crash ] -crbug.com/591099 external/wpt/referrer-policy/no-referrer/http-rp/cross-origin/http-http/iframe-tag/generic.keep-origin-redirect.http.html [ Crash ] -crbug.com/591099 external/wpt/referrer-policy/no-referrer/http-rp/cross-origin/http-http/iframe-tag/generic.no-redirect.http.html [ Crash ] -crbug.com/591099 external/wpt/referrer-policy/no-referrer/http-rp/cross-origin/http-http/iframe-tag/generic.swap-origin-redirect.http.html [ Crash ] -crbug.com/591099 external/wpt/referrer-policy/no-referrer/http-rp/cross-origin/http-http/img-tag/generic.keep-origin-redirect.http.html [ Crash ] -crbug.com/591099 external/wpt/referrer-policy/no-referrer/http-rp/cross-origin/http-http/img-tag/generic.no-redirect.http.html [ Crash ] -crbug.com/591099 external/wpt/referrer-policy/no-referrer/http-rp/cross-origin/http-http/img-tag/generic.swap-origin-redirect.http.html [ Crash ] -crbug.com/591099 external/wpt/referrer-policy/no-referrer/http-rp/cross-origin/http-https/iframe-tag/generic.keep-origin-redirect.http.html [ Crash ] -crbug.com/591099 external/wpt/referrer-policy/no-referrer/http-rp/cross-origin/http-https/iframe-tag/generic.no-redirect.http.html [ Crash ] -crbug.com/591099 external/wpt/referrer-policy/no-referrer/http-rp/cross-origin/http-https/iframe-tag/generic.swap-origin-redirect.http.html [ Crash ] -crbug.com/591099 external/wpt/referrer-policy/no-referrer/http-rp/cross-origin/http-https/img-tag/generic.keep-origin-redirect.http.html [ Crash ] -crbug.com/591099 external/wpt/referrer-policy/no-referrer/http-rp/cross-origin/http-https/img-tag/generic.no-redirect.http.html [ Crash ] -crbug.com/591099 external/wpt/referrer-policy/no-referrer/http-rp/cross-origin/http-https/img-tag/generic.swap-origin-redirect.http.html [ Crash ] -crbug.com/591099 external/wpt/referrer-policy/no-referrer/http-rp/same-origin/http-http/iframe-tag/generic.keep-origin-redirect.http.html [ Crash ] -crbug.com/591099 external/wpt/referrer-policy/no-referrer/http-rp/same-origin/http-http/iframe-tag/generic.no-redirect.http.html [ Crash ] -crbug.com/591099 external/wpt/referrer-policy/no-referrer/http-rp/same-origin/http-http/iframe-tag/generic.swap-origin-redirect.http.html [ Crash ] -crbug.com/591099 external/wpt/referrer-policy/no-referrer/http-rp/same-origin/http-http/img-tag/generic.keep-origin-redirect.http.html [ Crash ] -crbug.com/591099 external/wpt/referrer-policy/no-referrer/http-rp/same-origin/http-http/img-tag/generic.no-redirect.http.html [ Crash ] -crbug.com/591099 external/wpt/referrer-policy/no-referrer/http-rp/same-origin/http-http/img-tag/generic.swap-origin-redirect.http.html [ Crash ] -crbug.com/591099 external/wpt/referrer-policy/no-referrer/http-rp/same-origin/http-https/iframe-tag/generic.keep-origin-redirect.http.html [ Crash ] -crbug.com/591099 external/wpt/referrer-policy/no-referrer/http-rp/same-origin/http-https/iframe-tag/generic.no-redirect.http.html [ Crash ] -crbug.com/591099 external/wpt/referrer-policy/no-referrer/http-rp/same-origin/http-https/iframe-tag/generic.swap-origin-redirect.http.html [ Crash ] -crbug.com/591099 external/wpt/referrer-policy/no-referrer/http-rp/same-origin/http-https/img-tag/generic.keep-origin-redirect.http.html [ Crash ] -crbug.com/591099 external/wpt/referrer-policy/no-referrer/http-rp/same-origin/http-https/img-tag/generic.no-redirect.http.html [ Crash ] -crbug.com/591099 external/wpt/referrer-policy/no-referrer/http-rp/same-origin/http-https/img-tag/generic.swap-origin-redirect.http.html [ Crash ] -crbug.com/591099 external/wpt/referrer-policy/no-referrer/meta-referrer/cross-origin/http-http/iframe-tag/generic.keep-origin-redirect.http.html [ Crash ] -crbug.com/591099 external/wpt/referrer-policy/no-referrer/meta-referrer/cross-origin/http-http/iframe-tag/generic.no-redirect.http.html [ Crash ] -crbug.com/591099 external/wpt/referrer-policy/no-referrer/meta-referrer/cross-origin/http-http/iframe-tag/generic.swap-origin-redirect.http.html [ Crash ] -crbug.com/591099 external/wpt/referrer-policy/no-referrer/meta-referrer/cross-origin/http-http/img-tag/generic.keep-origin-redirect.http.html [ Crash ] -crbug.com/591099 external/wpt/referrer-policy/no-referrer/meta-referrer/cross-origin/http-http/img-tag/generic.no-redirect.http.html [ Crash ] -crbug.com/591099 external/wpt/referrer-policy/no-referrer/meta-referrer/cross-origin/http-http/img-tag/generic.swap-origin-redirect.http.html [ Crash ] -crbug.com/591099 external/wpt/referrer-policy/no-referrer/meta-referrer/cross-origin/http-https/iframe-tag/generic.keep-origin-redirect.http.html [ Crash ] -crbug.com/591099 external/wpt/referrer-policy/no-referrer/meta-referrer/cross-origin/http-https/iframe-tag/generic.no-redirect.http.html [ Crash ] -crbug.com/591099 external/wpt/referrer-policy/no-referrer/meta-referrer/cross-origin/http-https/iframe-tag/generic.swap-origin-redirect.http.html [ Crash ] -crbug.com/591099 external/wpt/referrer-policy/no-referrer/meta-referrer/cross-origin/http-https/img-tag/generic.keep-origin-redirect.http.html [ Crash ] -crbug.com/591099 external/wpt/referrer-policy/no-referrer/meta-referrer/cross-origin/http-https/img-tag/generic.no-redirect.http.html [ Crash ] -crbug.com/591099 external/wpt/referrer-policy/no-referrer/meta-referrer/cross-origin/http-https/img-tag/generic.swap-origin-redirect.http.html [ Crash ] -crbug.com/591099 external/wpt/referrer-policy/no-referrer/meta-referrer/same-origin/http-http/iframe-tag/generic.keep-origin-redirect.http.html [ Crash ] -crbug.com/591099 external/wpt/referrer-policy/no-referrer/meta-referrer/same-origin/http-http/iframe-tag/generic.no-redirect.http.html [ Crash ] -crbug.com/591099 external/wpt/referrer-policy/no-referrer/meta-referrer/same-origin/http-http/iframe-tag/generic.swap-origin-redirect.http.html [ Crash ] -crbug.com/591099 external/wpt/referrer-policy/no-referrer/meta-referrer/same-origin/http-http/img-tag/generic.keep-origin-redirect.http.html [ Crash ] -crbug.com/591099 external/wpt/referrer-policy/no-referrer/meta-referrer/same-origin/http-http/img-tag/generic.no-redirect.http.html [ Crash ] -crbug.com/591099 external/wpt/referrer-policy/no-referrer/meta-referrer/same-origin/http-http/img-tag/generic.swap-origin-redirect.http.html [ Crash ] -crbug.com/591099 external/wpt/referrer-policy/no-referrer/meta-referrer/same-origin/http-https/iframe-tag/generic.keep-origin-redirect.http.html [ Crash ] -crbug.com/591099 external/wpt/referrer-policy/no-referrer/meta-referrer/same-origin/http-https/iframe-tag/generic.no-redirect.http.html [ Crash ] -crbug.com/591099 external/wpt/referrer-policy/no-referrer/meta-referrer/same-origin/http-https/iframe-tag/generic.swap-origin-redirect.http.html [ Crash ] -crbug.com/591099 external/wpt/referrer-policy/no-referrer/meta-referrer/same-origin/http-https/img-tag/generic.keep-origin-redirect.http.html [ Crash ] -crbug.com/591099 external/wpt/referrer-policy/no-referrer/meta-referrer/same-origin/http-https/img-tag/generic.no-redirect.http.html [ Crash ] -crbug.com/591099 external/wpt/referrer-policy/no-referrer/meta-referrer/same-origin/http-https/img-tag/generic.swap-origin-redirect.http.html [ Crash ] -crbug.com/591099 external/wpt/referrer-policy/origin-when-cross-origin/attr-referrer/cross-origin/http-http/iframe-tag/cross-origin.keep-origin-redirect.http.html [ Crash ] -crbug.com/591099 external/wpt/referrer-policy/origin-when-cross-origin/attr-referrer/cross-origin/http-http/iframe-tag/cross-origin.no-redirect.http.html [ Crash ] -crbug.com/591099 external/wpt/referrer-policy/origin-when-cross-origin/attr-referrer/cross-origin/http-http/iframe-tag/cross-origin.swap-origin-redirect.http.html [ Crash ] -crbug.com/591099 external/wpt/referrer-policy/origin-when-cross-origin/attr-referrer/cross-origin/http-http/img-tag/cross-origin.keep-origin-redirect.http.html [ Crash ] -crbug.com/591099 external/wpt/referrer-policy/origin-when-cross-origin/attr-referrer/cross-origin/http-http/img-tag/cross-origin.no-redirect.http.html [ Crash ] -crbug.com/591099 external/wpt/referrer-policy/origin-when-cross-origin/attr-referrer/cross-origin/http-http/img-tag/cross-origin.swap-origin-redirect.http.html [ Crash ] -crbug.com/591099 external/wpt/referrer-policy/origin-when-cross-origin/attr-referrer/cross-origin/http-https/iframe-tag/cross-origin.keep-origin-redirect.http.html [ Crash ] -crbug.com/591099 external/wpt/referrer-policy/origin-when-cross-origin/attr-referrer/cross-origin/http-https/iframe-tag/cross-origin.no-redirect.http.html [ Crash ] -crbug.com/591099 external/wpt/referrer-policy/origin-when-cross-origin/attr-referrer/cross-origin/http-https/iframe-tag/cross-origin.swap-origin-redirect.http.html [ Crash ] -crbug.com/591099 external/wpt/referrer-policy/origin-when-cross-origin/attr-referrer/cross-origin/http-https/img-tag/cross-origin.keep-origin-redirect.http.html [ Crash ] -crbug.com/591099 external/wpt/referrer-policy/origin-when-cross-origin/attr-referrer/cross-origin/http-https/img-tag/cross-origin.no-redirect.http.html [ Crash ] -crbug.com/591099 external/wpt/referrer-policy/origin-when-cross-origin/attr-referrer/cross-origin/http-https/img-tag/cross-origin.swap-origin-redirect.http.html [ Crash ] -crbug.com/591099 external/wpt/referrer-policy/origin-when-cross-origin/attr-referrer/same-origin/http-http/iframe-tag/same-origin-insecure.keep-origin-redirect.http.html [ Crash ] -crbug.com/591099 external/wpt/referrer-policy/origin-when-cross-origin/attr-referrer/same-origin/http-http/iframe-tag/same-origin-insecure.no-redirect.http.html [ Crash ] -crbug.com/591099 external/wpt/referrer-policy/origin-when-cross-origin/attr-referrer/same-origin/http-http/iframe-tag/same-origin-insecure.swap-origin-redirect.http.html [ Crash ] -crbug.com/591099 external/wpt/referrer-policy/origin-when-cross-origin/attr-referrer/same-origin/http-http/img-tag/same-origin-insecure.keep-origin-redirect.http.html [ Crash ] -crbug.com/591099 external/wpt/referrer-policy/origin-when-cross-origin/attr-referrer/same-origin/http-http/img-tag/same-origin-insecure.no-redirect.http.html [ Crash ] -crbug.com/591099 external/wpt/referrer-policy/origin-when-cross-origin/attr-referrer/same-origin/http-http/img-tag/same-origin-insecure.swap-origin-redirect.http.html [ Crash ] -crbug.com/591099 external/wpt/referrer-policy/origin-when-cross-origin/attr-referrer/same-origin/http-https/iframe-tag/same-origin-downgrade.keep-origin-redirect.http.html [ Crash ] -crbug.com/591099 external/wpt/referrer-policy/origin-when-cross-origin/attr-referrer/same-origin/http-https/iframe-tag/same-origin-downgrade.no-redirect.http.html [ Crash ] -crbug.com/591099 external/wpt/referrer-policy/origin-when-cross-origin/attr-referrer/same-origin/http-https/iframe-tag/same-origin-downgrade.swap-origin-redirect.http.html [ Crash ] -crbug.com/591099 external/wpt/referrer-policy/origin-when-cross-origin/attr-referrer/same-origin/http-https/iframe-tag/same-origin-insecure.swap-origin-redirect.http.html [ Crash ] -crbug.com/591099 external/wpt/referrer-policy/origin-when-cross-origin/attr-referrer/same-origin/http-https/iframe-tag/same-origin-upgrade.keep-origin-redirect.http.html [ Crash ] -crbug.com/591099 external/wpt/referrer-policy/origin-when-cross-origin/attr-referrer/same-origin/http-https/iframe-tag/same-origin-upgrade.no-redirect.http.html [ Crash ] -crbug.com/591099 external/wpt/referrer-policy/origin-when-cross-origin/attr-referrer/same-origin/http-https/iframe-tag/same-origin-upgrade.swap-origin-redirect.http.html [ Crash ] -crbug.com/591099 external/wpt/referrer-policy/origin-when-cross-origin/attr-referrer/same-origin/http-https/img-tag/same-origin-downgrade.keep-origin-redirect.http.html [ Crash ] -crbug.com/591099 external/wpt/referrer-policy/origin-when-cross-origin/attr-referrer/same-origin/http-https/img-tag/same-origin-downgrade.no-redirect.http.html [ Crash ] -crbug.com/591099 external/wpt/referrer-policy/origin-when-cross-origin/attr-referrer/same-origin/http-https/img-tag/same-origin-downgrade.swap-origin-redirect.http.html [ Crash ] -crbug.com/591099 external/wpt/referrer-policy/origin-when-cross-origin/attr-referrer/same-origin/http-https/img-tag/same-origin-insecure.swap-origin-redirect.http.html [ Crash ] -crbug.com/591099 external/wpt/referrer-policy/origin-when-cross-origin/attr-referrer/same-origin/http-https/img-tag/same-origin-upgrade.keep-origin-redirect.http.html [ Crash ] -crbug.com/591099 external/wpt/referrer-policy/origin-when-cross-origin/attr-referrer/same-origin/http-https/img-tag/same-origin-upgrade.no-redirect.http.html [ Crash ] -crbug.com/591099 external/wpt/referrer-policy/origin-when-cross-origin/attr-referrer/same-origin/http-https/img-tag/same-origin-upgrade.swap-origin-redirect.http.html [ Crash ] -crbug.com/591099 external/wpt/referrer-policy/origin-when-cross-origin/http-rp/cross-origin/http-http/iframe-tag/cross-origin.keep-origin-redirect.http.html [ Crash ] -crbug.com/591099 external/wpt/referrer-policy/origin-when-cross-origin/http-rp/cross-origin/http-http/iframe-tag/cross-origin.no-redirect.http.html [ Crash ] -crbug.com/591099 external/wpt/referrer-policy/origin-when-cross-origin/http-rp/cross-origin/http-http/iframe-tag/cross-origin.swap-origin-redirect.http.html [ Crash ] -crbug.com/591099 external/wpt/referrer-policy/origin-when-cross-origin/http-rp/cross-origin/http-http/img-tag/cross-origin.keep-origin-redirect.http.html [ Crash ] -crbug.com/591099 external/wpt/referrer-policy/origin-when-cross-origin/http-rp/cross-origin/http-http/img-tag/cross-origin.no-redirect.http.html [ Crash ] -crbug.com/591099 external/wpt/referrer-policy/origin-when-cross-origin/http-rp/cross-origin/http-http/img-tag/cross-origin.swap-origin-redirect.http.html [ Crash ] -crbug.com/591099 external/wpt/referrer-policy/origin-when-cross-origin/http-rp/cross-origin/http-https/iframe-tag/cross-origin.keep-origin-redirect.http.html [ Crash ] -crbug.com/591099 external/wpt/referrer-policy/origin-when-cross-origin/http-rp/cross-origin/http-https/iframe-tag/cross-origin.no-redirect.http.html [ Crash ] -crbug.com/591099 external/wpt/referrer-policy/origin-when-cross-origin/http-rp/cross-origin/http-https/iframe-tag/cross-origin.swap-origin-redirect.http.html [ Crash ] -crbug.com/591099 external/wpt/referrer-policy/origin-when-cross-origin/http-rp/cross-origin/http-https/img-tag/cross-origin.keep-origin-redirect.http.html [ Crash ] -crbug.com/591099 external/wpt/referrer-policy/origin-when-cross-origin/http-rp/cross-origin/http-https/img-tag/cross-origin.no-redirect.http.html [ Crash ] -crbug.com/591099 external/wpt/referrer-policy/origin-when-cross-origin/http-rp/cross-origin/http-https/img-tag/cross-origin.swap-origin-redirect.http.html [ Crash ] -crbug.com/591099 external/wpt/referrer-policy/origin-when-cross-origin/http-rp/same-origin/http-http/iframe-tag/same-origin-insecure.keep-origin-redirect.http.html [ Crash ] -crbug.com/591099 external/wpt/referrer-policy/origin-when-cross-origin/http-rp/same-origin/http-http/iframe-tag/same-origin-insecure.no-redirect.http.html [ Crash ] -crbug.com/591099 external/wpt/referrer-policy/origin-when-cross-origin/http-rp/same-origin/http-http/iframe-tag/same-origin-insecure.swap-origin-redirect.http.html [ Crash ] -crbug.com/591099 external/wpt/referrer-policy/origin-when-cross-origin/http-rp/same-origin/http-http/img-tag/same-origin-insecure.keep-origin-redirect.http.html [ Crash ] -crbug.com/591099 external/wpt/referrer-policy/origin-when-cross-origin/http-rp/same-origin/http-http/img-tag/same-origin-insecure.no-redirect.http.html [ Crash ] -crbug.com/591099 external/wpt/referrer-policy/origin-when-cross-origin/http-rp/same-origin/http-http/img-tag/same-origin-insecure.swap-origin-redirect.http.html [ Crash ] -crbug.com/591099 external/wpt/referrer-policy/origin-when-cross-origin/http-rp/same-origin/http-https/iframe-tag/same-origin-downgrade.keep-origin-redirect.http.html [ Crash ] -crbug.com/591099 external/wpt/referrer-policy/origin-when-cross-origin/http-rp/same-origin/http-https/iframe-tag/same-origin-downgrade.no-redirect.http.html [ Crash ] -crbug.com/591099 external/wpt/referrer-policy/origin-when-cross-origin/http-rp/same-origin/http-https/iframe-tag/same-origin-downgrade.swap-origin-redirect.http.html [ Crash ] -crbug.com/591099 external/wpt/referrer-policy/origin-when-cross-origin/http-rp/same-origin/http-https/iframe-tag/same-origin-insecure.swap-origin-redirect.http.html [ Crash ] -crbug.com/591099 external/wpt/referrer-policy/origin-when-cross-origin/http-rp/same-origin/http-https/iframe-tag/same-origin-upgrade.keep-origin-redirect.http.html [ Crash ] -crbug.com/591099 external/wpt/referrer-policy/origin-when-cross-origin/http-rp/same-origin/http-https/iframe-tag/same-origin-upgrade.no-redirect.http.html [ Crash ] -crbug.com/591099 external/wpt/referrer-policy/origin-when-cross-origin/http-rp/same-origin/http-https/iframe-tag/same-origin-upgrade.swap-origin-redirect.http.html [ Crash ] -crbug.com/591099 external/wpt/referrer-policy/origin-when-cross-origin/http-rp/same-origin/http-https/img-tag/same-origin-downgrade.keep-origin-redirect.http.html [ Crash ] -crbug.com/591099 external/wpt/referrer-policy/origin-when-cross-origin/http-rp/same-origin/http-https/img-tag/same-origin-downgrade.no-redirect.http.html [ Crash ] -crbug.com/591099 external/wpt/referrer-policy/origin-when-cross-origin/http-rp/same-origin/http-https/img-tag/same-origin-downgrade.swap-origin-redirect.http.html [ Crash ] -crbug.com/591099 external/wpt/referrer-policy/origin-when-cross-origin/http-rp/same-origin/http-https/img-tag/same-origin-insecure.swap-origin-redirect.http.html [ Crash ] -crbug.com/591099 external/wpt/referrer-policy/origin-when-cross-origin/http-rp/same-origin/http-https/img-tag/same-origin-upgrade.keep-origin-redirect.http.html [ Crash ] -crbug.com/591099 external/wpt/referrer-policy/origin-when-cross-origin/http-rp/same-origin/http-https/img-tag/same-origin-upgrade.no-redirect.http.html [ Crash ] -crbug.com/591099 external/wpt/referrer-policy/origin-when-cross-origin/http-rp/same-origin/http-https/img-tag/same-origin-upgrade.swap-origin-redirect.http.html [ Crash ] -crbug.com/591099 external/wpt/referrer-policy/origin-when-cross-origin/meta-referrer/cross-origin/http-http/iframe-tag/cross-origin.keep-origin-redirect.http.html [ Crash ] -crbug.com/591099 external/wpt/referrer-policy/origin-when-cross-origin/meta-referrer/cross-origin/http-http/iframe-tag/cross-origin.no-redirect.http.html [ Crash ] -crbug.com/591099 external/wpt/referrer-policy/origin-when-cross-origin/meta-referrer/cross-origin/http-http/iframe-tag/cross-origin.swap-origin-redirect.http.html [ Crash ] -crbug.com/591099 external/wpt/referrer-policy/origin-when-cross-origin/meta-referrer/cross-origin/http-http/img-tag/cross-origin.keep-origin-redirect.http.html [ Crash ] -crbug.com/591099 external/wpt/referrer-policy/origin-when-cross-origin/meta-referrer/cross-origin/http-http/img-tag/cross-origin.no-redirect.http.html [ Crash ] -crbug.com/591099 external/wpt/referrer-policy/origin-when-cross-origin/meta-referrer/cross-origin/http-http/img-tag/cross-origin.swap-origin-redirect.http.html [ Crash ] -crbug.com/591099 external/wpt/referrer-policy/origin-when-cross-origin/meta-referrer/cross-origin/http-https/iframe-tag/cross-origin.keep-origin-redirect.http.html [ Crash ] -crbug.com/591099 external/wpt/referrer-policy/origin-when-cross-origin/meta-referrer/cross-origin/http-https/iframe-tag/cross-origin.no-redirect.http.html [ Crash ] -crbug.com/591099 external/wpt/referrer-policy/origin-when-cross-origin/meta-referrer/cross-origin/http-https/iframe-tag/cross-origin.swap-origin-redirect.http.html [ Crash ] -crbug.com/591099 external/wpt/referrer-policy/origin-when-cross-origin/meta-referrer/cross-origin/http-https/img-tag/cross-origin.keep-origin-redirect.http.html [ Crash ] -crbug.com/591099 external/wpt/referrer-policy/origin-when-cross-origin/meta-referrer/cross-origin/http-https/img-tag/cross-origin.no-redirect.http.html [ Crash ] -crbug.com/591099 external/wpt/referrer-policy/origin-when-cross-origin/meta-referrer/cross-origin/http-https/img-tag/cross-origin.swap-origin-redirect.http.html [ Crash ] -crbug.com/591099 external/wpt/referrer-policy/origin-when-cross-origin/meta-referrer/same-origin/http-http/iframe-tag/same-origin-insecure.keep-origin-redirect.http.html [ Crash ] -crbug.com/591099 external/wpt/referrer-policy/origin-when-cross-origin/meta-referrer/same-origin/http-http/iframe-tag/same-origin-insecure.no-redirect.http.html [ Crash ] -crbug.com/591099 external/wpt/referrer-policy/origin-when-cross-origin/meta-referrer/same-origin/http-http/iframe-tag/same-origin-insecure.swap-origin-redirect.http.html [ Crash ] -crbug.com/591099 external/wpt/referrer-policy/origin-when-cross-origin/meta-referrer/same-origin/http-http/img-tag/same-origin-insecure.keep-origin-redirect.http.html [ Crash ] -crbug.com/591099 external/wpt/referrer-policy/origin-when-cross-origin/meta-referrer/same-origin/http-http/img-tag/same-origin-insecure.no-redirect.http.html [ Crash ] -crbug.com/591099 external/wpt/referrer-policy/origin-when-cross-origin/meta-referrer/same-origin/http-http/img-tag/same-origin-insecure.swap-origin-redirect.http.html [ Crash ] -crbug.com/591099 external/wpt/referrer-policy/origin-when-cross-origin/meta-referrer/same-origin/http-https/iframe-tag/same-origin-downgrade.keep-origin-redirect.http.html [ Crash ] -crbug.com/591099 external/wpt/referrer-policy/origin-when-cross-origin/meta-referrer/same-origin/http-https/iframe-tag/same-origin-downgrade.no-redirect.http.html [ Crash ] -crbug.com/591099 external/wpt/referrer-policy/origin-when-cross-origin/meta-referrer/same-origin/http-https/iframe-tag/same-origin-downgrade.swap-origin-redirect.http.html [ Crash ] -crbug.com/591099 external/wpt/referrer-policy/origin-when-cross-origin/meta-referrer/same-origin/http-https/iframe-tag/same-origin-insecure.swap-origin-redirect.http.html [ Crash ] -crbug.com/591099 external/wpt/referrer-policy/origin-when-cross-origin/meta-referrer/same-origin/http-https/iframe-tag/same-origin-upgrade.keep-origin-redirect.http.html [ Crash ] -crbug.com/591099 external/wpt/referrer-policy/origin-when-cross-origin/meta-referrer/same-origin/http-https/iframe-tag/same-origin-upgrade.no-redirect.http.html [ Crash ] -crbug.com/591099 external/wpt/referrer-policy/origin-when-cross-origin/meta-referrer/same-origin/http-https/iframe-tag/same-origin-upgrade.swap-origin-redirect.http.html [ Crash ] -crbug.com/591099 external/wpt/referrer-policy/origin-when-cross-origin/meta-referrer/same-origin/http-https/img-tag/same-origin-downgrade.keep-origin-redirect.http.html [ Crash ] -crbug.com/591099 external/wpt/referrer-policy/origin-when-cross-origin/meta-referrer/same-origin/http-https/img-tag/same-origin-downgrade.no-redirect.http.html [ Crash ] -crbug.com/591099 external/wpt/referrer-policy/origin-when-cross-origin/meta-referrer/same-origin/http-https/img-tag/same-origin-downgrade.swap-origin-redirect.http.html [ Crash ] -crbug.com/591099 external/wpt/referrer-policy/origin-when-cross-origin/meta-referrer/same-origin/http-https/img-tag/same-origin-insecure.swap-origin-redirect.http.html [ Crash ] -crbug.com/591099 external/wpt/referrer-policy/origin-when-cross-origin/meta-referrer/same-origin/http-https/img-tag/same-origin-upgrade.keep-origin-redirect.http.html [ Crash ] -crbug.com/591099 external/wpt/referrer-policy/origin-when-cross-origin/meta-referrer/same-origin/http-https/img-tag/same-origin-upgrade.no-redirect.http.html [ Crash ] -crbug.com/591099 external/wpt/referrer-policy/origin-when-cross-origin/meta-referrer/same-origin/http-https/img-tag/same-origin-upgrade.swap-origin-redirect.http.html [ Crash ] -crbug.com/591099 external/wpt/referrer-policy/origin/attr-referrer/cross-origin/http-http/iframe-tag/generic.keep-origin-redirect.http.html [ Crash ] -crbug.com/591099 external/wpt/referrer-policy/origin/attr-referrer/cross-origin/http-http/iframe-tag/generic.no-redirect.http.html [ Crash ] -crbug.com/591099 external/wpt/referrer-policy/origin/attr-referrer/cross-origin/http-http/iframe-tag/generic.swap-origin-redirect.http.html [ Crash ] -crbug.com/591099 external/wpt/referrer-policy/origin/attr-referrer/cross-origin/http-http/img-tag/generic.keep-origin-redirect.http.html [ Crash ] -crbug.com/591099 external/wpt/referrer-policy/origin/attr-referrer/cross-origin/http-http/img-tag/generic.no-redirect.http.html [ Crash ] -crbug.com/591099 external/wpt/referrer-policy/origin/attr-referrer/cross-origin/http-http/img-tag/generic.swap-origin-redirect.http.html [ Crash ] -crbug.com/591099 external/wpt/referrer-policy/origin/attr-referrer/cross-origin/http-https/iframe-tag/generic.keep-origin-redirect.http.html [ Crash ] -crbug.com/591099 external/wpt/referrer-policy/origin/attr-referrer/cross-origin/http-https/iframe-tag/generic.no-redirect.http.html [ Crash ] -crbug.com/591099 external/wpt/referrer-policy/origin/attr-referrer/cross-origin/http-https/iframe-tag/generic.swap-origin-redirect.http.html [ Crash ] -crbug.com/591099 external/wpt/referrer-policy/origin/attr-referrer/cross-origin/http-https/img-tag/generic.keep-origin-redirect.http.html [ Crash ] -crbug.com/591099 external/wpt/referrer-policy/origin/attr-referrer/cross-origin/http-https/img-tag/generic.no-redirect.http.html [ Crash ] -crbug.com/591099 external/wpt/referrer-policy/origin/attr-referrer/cross-origin/http-https/img-tag/generic.swap-origin-redirect.http.html [ Crash ] -crbug.com/591099 external/wpt/referrer-policy/origin/attr-referrer/same-origin/http-http/iframe-tag/generic.keep-origin-redirect.http.html [ Crash ] -crbug.com/591099 external/wpt/referrer-policy/origin/attr-referrer/same-origin/http-http/iframe-tag/generic.no-redirect.http.html [ Crash ] -crbug.com/591099 external/wpt/referrer-policy/origin/attr-referrer/same-origin/http-http/iframe-tag/generic.swap-origin-redirect.http.html [ Crash ] -crbug.com/591099 external/wpt/referrer-policy/origin/attr-referrer/same-origin/http-http/img-tag/generic.keep-origin-redirect.http.html [ Crash ] -crbug.com/591099 external/wpt/referrer-policy/origin/attr-referrer/same-origin/http-http/img-tag/generic.no-redirect.http.html [ Crash ] -crbug.com/591099 external/wpt/referrer-policy/origin/attr-referrer/same-origin/http-http/img-tag/generic.swap-origin-redirect.http.html [ Crash ] -crbug.com/591099 external/wpt/referrer-policy/origin/attr-referrer/same-origin/http-https/iframe-tag/generic.keep-origin-redirect.http.html [ Crash ] -crbug.com/591099 external/wpt/referrer-policy/origin/attr-referrer/same-origin/http-https/iframe-tag/generic.no-redirect.http.html [ Crash ] -crbug.com/591099 external/wpt/referrer-policy/origin/attr-referrer/same-origin/http-https/iframe-tag/generic.swap-origin-redirect.http.html [ Crash ] -crbug.com/591099 external/wpt/referrer-policy/origin/attr-referrer/same-origin/http-https/img-tag/generic.keep-origin-redirect.http.html [ Crash ] -crbug.com/591099 external/wpt/referrer-policy/origin/attr-referrer/same-origin/http-https/img-tag/generic.no-redirect.http.html [ Crash ] -crbug.com/591099 external/wpt/referrer-policy/origin/attr-referrer/same-origin/http-https/img-tag/generic.swap-origin-redirect.http.html [ Crash ] -crbug.com/591099 external/wpt/referrer-policy/origin/http-rp/cross-origin/http-http/iframe-tag/generic.keep-origin-redirect.http.html [ Crash ] -crbug.com/591099 external/wpt/referrer-policy/origin/http-rp/cross-origin/http-http/iframe-tag/generic.no-redirect.http.html [ Crash ] -crbug.com/591099 external/wpt/referrer-policy/origin/http-rp/cross-origin/http-http/iframe-tag/generic.swap-origin-redirect.http.html [ Crash ] -crbug.com/591099 external/wpt/referrer-policy/origin/http-rp/cross-origin/http-http/img-tag/generic.keep-origin-redirect.http.html [ Crash ] -crbug.com/591099 external/wpt/referrer-policy/origin/http-rp/cross-origin/http-http/img-tag/generic.no-redirect.http.html [ Crash ] -crbug.com/591099 external/wpt/referrer-policy/origin/http-rp/cross-origin/http-http/img-tag/generic.swap-origin-redirect.http.html [ Crash ] -crbug.com/591099 external/wpt/referrer-policy/origin/http-rp/cross-origin/http-https/iframe-tag/generic.keep-origin-redirect.http.html [ Crash ] -crbug.com/591099 external/wpt/referrer-policy/origin/http-rp/cross-origin/http-https/iframe-tag/generic.no-redirect.http.html [ Crash ] -crbug.com/591099 external/wpt/referrer-policy/origin/http-rp/cross-origin/http-https/iframe-tag/generic.swap-origin-redirect.http.html [ Crash ] -crbug.com/591099 external/wpt/referrer-policy/origin/http-rp/cross-origin/http-https/img-tag/generic.keep-origin-redirect.http.html [ Crash ] -crbug.com/591099 external/wpt/referrer-policy/origin/http-rp/cross-origin/http-https/img-tag/generic.no-redirect.http.html [ Crash ] -crbug.com/591099 external/wpt/referrer-policy/origin/http-rp/cross-origin/http-https/img-tag/generic.swap-origin-redirect.http.html [ Crash ] -crbug.com/591099 external/wpt/referrer-policy/origin/http-rp/same-origin/http-http/iframe-tag/generic.keep-origin-redirect.http.html [ Crash ] -crbug.com/591099 external/wpt/referrer-policy/origin/http-rp/same-origin/http-http/iframe-tag/generic.no-redirect.http.html [ Crash ] -crbug.com/591099 external/wpt/referrer-policy/origin/http-rp/same-origin/http-http/iframe-tag/generic.swap-origin-redirect.http.html [ Crash ] -crbug.com/591099 external/wpt/referrer-policy/origin/http-rp/same-origin/http-http/img-tag/generic.keep-origin-redirect.http.html [ Crash ] -crbug.com/591099 external/wpt/referrer-policy/origin/http-rp/same-origin/http-http/img-tag/generic.no-redirect.http.html [ Crash ] -crbug.com/591099 external/wpt/referrer-policy/origin/http-rp/same-origin/http-http/img-tag/generic.swap-origin-redirect.http.html [ Crash ] -crbug.com/591099 external/wpt/referrer-policy/origin/http-rp/same-origin/http-https/iframe-tag/generic.keep-origin-redirect.http.html [ Crash ] -crbug.com/591099 external/wpt/referrer-policy/origin/http-rp/same-origin/http-https/iframe-tag/generic.no-redirect.http.html [ Crash ] -crbug.com/591099 external/wpt/referrer-policy/origin/http-rp/same-origin/http-https/iframe-tag/generic.swap-origin-redirect.http.html [ Crash ] -crbug.com/591099 external/wpt/referrer-policy/origin/http-rp/same-origin/http-https/img-tag/generic.keep-origin-redirect.http.html [ Crash ] -crbug.com/591099 external/wpt/referrer-policy/origin/http-rp/same-origin/http-https/img-tag/generic.no-redirect.http.html [ Crash ] -crbug.com/591099 external/wpt/referrer-policy/origin/http-rp/same-origin/http-https/img-tag/generic.swap-origin-redirect.http.html [ Crash ] -crbug.com/591099 external/wpt/referrer-policy/origin/meta-referrer/cross-origin/http-http/iframe-tag/generic.keep-origin-redirect.http.html [ Crash ] -crbug.com/591099 external/wpt/referrer-policy/origin/meta-referrer/cross-origin/http-http/iframe-tag/generic.no-redirect.http.html [ Crash ] -crbug.com/591099 external/wpt/referrer-policy/origin/meta-referrer/cross-origin/http-http/iframe-tag/generic.swap-origin-redirect.http.html [ Crash ] -crbug.com/591099 external/wpt/referrer-policy/origin/meta-referrer/cross-origin/http-http/img-tag/generic.keep-origin-redirect.http.html [ Crash ] -crbug.com/591099 external/wpt/referrer-policy/origin/meta-referrer/cross-origin/http-http/img-tag/generic.no-redirect.http.html [ Crash ] -crbug.com/591099 external/wpt/referrer-policy/origin/meta-referrer/cross-origin/http-http/img-tag/generic.swap-origin-redirect.http.html [ Crash ] -crbug.com/591099 external/wpt/referrer-policy/origin/meta-referrer/cross-origin/http-https/iframe-tag/generic.keep-origin-redirect.http.html [ Crash ] -crbug.com/591099 external/wpt/referrer-policy/origin/meta-referrer/cross-origin/http-https/iframe-tag/generic.no-redirect.http.html [ Crash ] -crbug.com/591099 external/wpt/referrer-policy/origin/meta-referrer/cross-origin/http-https/iframe-tag/generic.swap-origin-redirect.http.html [ Crash ] -crbug.com/591099 external/wpt/referrer-policy/origin/meta-referrer/cross-origin/http-https/img-tag/generic.keep-origin-redirect.http.html [ Crash ] -crbug.com/591099 external/wpt/referrer-policy/origin/meta-referrer/cross-origin/http-https/img-tag/generic.no-redirect.http.html [ Crash ] -crbug.com/591099 external/wpt/referrer-policy/origin/meta-referrer/cross-origin/http-https/img-tag/generic.swap-origin-redirect.http.html [ Crash ] -crbug.com/591099 external/wpt/referrer-policy/origin/meta-referrer/same-origin/http-http/iframe-tag/generic.keep-origin-redirect.http.html [ Crash ] -crbug.com/591099 external/wpt/referrer-policy/origin/meta-referrer/same-origin/http-http/iframe-tag/generic.no-redirect.http.html [ Crash ] -crbug.com/591099 external/wpt/referrer-policy/origin/meta-referrer/same-origin/http-http/iframe-tag/generic.swap-origin-redirect.http.html [ Crash ] -crbug.com/591099 external/wpt/referrer-policy/origin/meta-referrer/same-origin/http-http/img-tag/generic.keep-origin-redirect.http.html [ Crash ] -crbug.com/591099 external/wpt/referrer-policy/origin/meta-referrer/same-origin/http-http/img-tag/generic.no-redirect.http.html [ Crash ] -crbug.com/591099 external/wpt/referrer-policy/origin/meta-referrer/same-origin/http-http/img-tag/generic.swap-origin-redirect.http.html [ Crash ] -crbug.com/591099 external/wpt/referrer-policy/origin/meta-referrer/same-origin/http-https/iframe-tag/generic.keep-origin-redirect.http.html [ Crash ] -crbug.com/591099 external/wpt/referrer-policy/origin/meta-referrer/same-origin/http-https/iframe-tag/generic.no-redirect.http.html [ Crash ] -crbug.com/591099 external/wpt/referrer-policy/origin/meta-referrer/same-origin/http-https/iframe-tag/generic.swap-origin-redirect.http.html [ Crash ] -crbug.com/591099 external/wpt/referrer-policy/origin/meta-referrer/same-origin/http-https/img-tag/generic.keep-origin-redirect.http.html [ Crash ] -crbug.com/591099 external/wpt/referrer-policy/origin/meta-referrer/same-origin/http-https/img-tag/generic.no-redirect.http.html [ Crash ] -crbug.com/591099 external/wpt/referrer-policy/origin/meta-referrer/same-origin/http-https/img-tag/generic.swap-origin-redirect.http.html [ Crash ] -crbug.com/591099 external/wpt/referrer-policy/same-origin/attr-referrer/cross-origin/http-http/iframe-tag/cross-origin.keep-origin-redirect.http.html [ Crash ] -crbug.com/591099 external/wpt/referrer-policy/same-origin/attr-referrer/cross-origin/http-http/iframe-tag/cross-origin.no-redirect.http.html [ Crash ] -crbug.com/591099 external/wpt/referrer-policy/same-origin/attr-referrer/cross-origin/http-http/iframe-tag/cross-origin.swap-origin-redirect.http.html [ Crash ] -crbug.com/591099 external/wpt/referrer-policy/same-origin/attr-referrer/cross-origin/http-http/img-tag/cross-origin.keep-origin-redirect.http.html [ Crash ] -crbug.com/591099 external/wpt/referrer-policy/same-origin/attr-referrer/cross-origin/http-http/img-tag/cross-origin.no-redirect.http.html [ Crash ] -crbug.com/591099 external/wpt/referrer-policy/same-origin/attr-referrer/cross-origin/http-http/img-tag/cross-origin.swap-origin-redirect.http.html [ Crash ] -crbug.com/591099 external/wpt/referrer-policy/same-origin/attr-referrer/cross-origin/http-https/iframe-tag/cross-origin.keep-origin-redirect.http.html [ Crash ] -crbug.com/591099 external/wpt/referrer-policy/same-origin/attr-referrer/cross-origin/http-https/iframe-tag/cross-origin.no-redirect.http.html [ Crash ] -crbug.com/591099 external/wpt/referrer-policy/same-origin/attr-referrer/cross-origin/http-https/iframe-tag/cross-origin.swap-origin-redirect.http.html [ Crash ] -crbug.com/591099 external/wpt/referrer-policy/same-origin/attr-referrer/cross-origin/http-https/img-tag/cross-origin.keep-origin-redirect.http.html [ Crash ] -crbug.com/591099 external/wpt/referrer-policy/same-origin/attr-referrer/cross-origin/http-https/img-tag/cross-origin.no-redirect.http.html [ Crash ] -crbug.com/591099 external/wpt/referrer-policy/same-origin/attr-referrer/cross-origin/http-https/img-tag/cross-origin.swap-origin-redirect.http.html [ Crash ] -crbug.com/591099 external/wpt/referrer-policy/same-origin/attr-referrer/same-origin/http-http/iframe-tag/same-origin-insecure.keep-origin-redirect.http.html [ Crash ] -crbug.com/591099 external/wpt/referrer-policy/same-origin/attr-referrer/same-origin/http-http/iframe-tag/same-origin-insecure.no-redirect.http.html [ Crash ] -crbug.com/591099 external/wpt/referrer-policy/same-origin/attr-referrer/same-origin/http-http/iframe-tag/same-origin-insecure.swap-origin-redirect.http.html [ Crash ] -crbug.com/591099 external/wpt/referrer-policy/same-origin/attr-referrer/same-origin/http-http/img-tag/same-origin-insecure.keep-origin-redirect.http.html [ Crash ] -crbug.com/591099 external/wpt/referrer-policy/same-origin/attr-referrer/same-origin/http-http/img-tag/same-origin-insecure.no-redirect.http.html [ Crash ] -crbug.com/591099 external/wpt/referrer-policy/same-origin/attr-referrer/same-origin/http-http/img-tag/same-origin-insecure.swap-origin-redirect.http.html [ Crash ] -crbug.com/591099 external/wpt/referrer-policy/same-origin/attr-referrer/same-origin/http-https/iframe-tag/same-origin-insecure.swap-origin-redirect.http.html [ Crash ] -crbug.com/591099 external/wpt/referrer-policy/same-origin/attr-referrer/same-origin/http-https/img-tag/same-origin-insecure.swap-origin-redirect.http.html [ Crash ] -crbug.com/591099 external/wpt/referrer-policy/same-origin/http-rp/cross-origin/http-http/iframe-tag/cross-origin.keep-origin-redirect.http.html [ Crash ] -crbug.com/591099 external/wpt/referrer-policy/same-origin/http-rp/cross-origin/http-http/iframe-tag/cross-origin.no-redirect.http.html [ Crash ] -crbug.com/591099 external/wpt/referrer-policy/same-origin/http-rp/cross-origin/http-http/iframe-tag/cross-origin.swap-origin-redirect.http.html [ Crash ] -crbug.com/591099 external/wpt/referrer-policy/same-origin/http-rp/cross-origin/http-http/img-tag/cross-origin.keep-origin-redirect.http.html [ Crash ] -crbug.com/591099 external/wpt/referrer-policy/same-origin/http-rp/cross-origin/http-http/img-tag/cross-origin.no-redirect.http.html [ Crash ] -crbug.com/591099 external/wpt/referrer-policy/same-origin/http-rp/cross-origin/http-http/img-tag/cross-origin.swap-origin-redirect.http.html [ Crash ] -crbug.com/591099 external/wpt/referrer-policy/same-origin/http-rp/cross-origin/http-https/iframe-tag/cross-origin.keep-origin-redirect.http.html [ Crash ] -crbug.com/591099 external/wpt/referrer-policy/same-origin/http-rp/cross-origin/http-https/iframe-tag/cross-origin.no-redirect.http.html [ Crash ] -crbug.com/591099 external/wpt/referrer-policy/same-origin/http-rp/cross-origin/http-https/iframe-tag/cross-origin.swap-origin-redirect.http.html [ Crash ] -crbug.com/591099 external/wpt/referrer-policy/same-origin/http-rp/cross-origin/http-https/img-tag/cross-origin.keep-origin-redirect.http.html [ Crash ] -crbug.com/591099 external/wpt/referrer-policy/same-origin/http-rp/cross-origin/http-https/img-tag/cross-origin.no-redirect.http.html [ Crash ] -crbug.com/591099 external/wpt/referrer-policy/same-origin/http-rp/cross-origin/http-https/img-tag/cross-origin.swap-origin-redirect.http.html [ Crash ] -crbug.com/591099 external/wpt/referrer-policy/same-origin/http-rp/same-origin/http-http/iframe-tag/same-origin-insecure.keep-origin-redirect.http.html [ Crash ] -crbug.com/591099 external/wpt/referrer-policy/same-origin/http-rp/same-origin/http-http/iframe-tag/same-origin-insecure.no-redirect.http.html [ Crash ] -crbug.com/591099 external/wpt/referrer-policy/same-origin/http-rp/same-origin/http-http/iframe-tag/same-origin-insecure.swap-origin-redirect.http.html [ Crash ] -crbug.com/591099 external/wpt/referrer-policy/same-origin/http-rp/same-origin/http-http/img-tag/same-origin-insecure.keep-origin-redirect.http.html [ Crash ] -crbug.com/591099 external/wpt/referrer-policy/same-origin/http-rp/same-origin/http-http/img-tag/same-origin-insecure.no-redirect.http.html [ Crash ] -crbug.com/591099 external/wpt/referrer-policy/same-origin/http-rp/same-origin/http-http/img-tag/same-origin-insecure.swap-origin-redirect.http.html [ Crash ] -crbug.com/591099 external/wpt/referrer-policy/same-origin/http-rp/same-origin/http-https/iframe-tag/same-origin-insecure.swap-origin-redirect.http.html [ Crash ] -crbug.com/591099 external/wpt/referrer-policy/same-origin/http-rp/same-origin/http-https/img-tag/same-origin-insecure.swap-origin-redirect.http.html [ Crash ] -crbug.com/591099 external/wpt/referrer-policy/same-origin/meta-referrer/cross-origin/http-http/iframe-tag/cross-origin.keep-origin-redirect.http.html [ Crash ] -crbug.com/591099 external/wpt/referrer-policy/same-origin/meta-referrer/cross-origin/http-http/iframe-tag/cross-origin.no-redirect.http.html [ Crash ] -crbug.com/591099 external/wpt/referrer-policy/same-origin/meta-referrer/cross-origin/http-http/iframe-tag/cross-origin.swap-origin-redirect.http.html [ Crash ] -crbug.com/591099 external/wpt/referrer-policy/same-origin/meta-referrer/cross-origin/http-http/img-tag/cross-origin.keep-origin-redirect.http.html [ Crash ] -crbug.com/591099 external/wpt/referrer-policy/same-origin/meta-referrer/cross-origin/http-http/img-tag/cross-origin.no-redirect.http.html [ Crash ] -crbug.com/591099 external/wpt/referrer-policy/same-origin/meta-referrer/cross-origin/http-http/img-tag/cross-origin.swap-origin-redirect.http.html [ Crash ] -crbug.com/591099 external/wpt/referrer-policy/same-origin/meta-referrer/cross-origin/http-https/iframe-tag/cross-origin.keep-origin-redirect.http.html [ Crash ] -crbug.com/591099 external/wpt/referrer-policy/same-origin/meta-referrer/cross-origin/http-https/iframe-tag/cross-origin.no-redirect.http.html [ Crash ] -crbug.com/591099 external/wpt/referrer-policy/same-origin/meta-referrer/cross-origin/http-https/iframe-tag/cross-origin.swap-origin-redirect.http.html [ Crash ] -crbug.com/591099 external/wpt/referrer-policy/same-origin/meta-referrer/cross-origin/http-https/img-tag/cross-origin.keep-origin-redirect.http.html [ Crash ] -crbug.com/591099 external/wpt/referrer-policy/same-origin/meta-referrer/cross-origin/http-https/img-tag/cross-origin.no-redirect.http.html [ Crash ] -crbug.com/591099 external/wpt/referrer-policy/same-origin/meta-referrer/cross-origin/http-https/img-tag/cross-origin.swap-origin-redirect.http.html [ Crash ] -crbug.com/591099 external/wpt/referrer-policy/same-origin/meta-referrer/same-origin/http-http/iframe-tag/same-origin-insecure.keep-origin-redirect.http.html [ Crash ] -crbug.com/591099 external/wpt/referrer-policy/same-origin/meta-referrer/same-origin/http-http/iframe-tag/same-origin-insecure.no-redirect.http.html [ Crash ] -crbug.com/591099 external/wpt/referrer-policy/same-origin/meta-referrer/same-origin/http-http/iframe-tag/same-origin-insecure.swap-origin-redirect.http.html [ Crash ] -crbug.com/591099 external/wpt/referrer-policy/same-origin/meta-referrer/same-origin/http-http/img-tag/same-origin-insecure.keep-origin-redirect.http.html [ Crash ] -crbug.com/591099 external/wpt/referrer-policy/same-origin/meta-referrer/same-origin/http-http/img-tag/same-origin-insecure.no-redirect.http.html [ Crash ] -crbug.com/591099 external/wpt/referrer-policy/same-origin/meta-referrer/same-origin/http-http/img-tag/same-origin-insecure.swap-origin-redirect.http.html [ Crash ] -crbug.com/591099 external/wpt/referrer-policy/same-origin/meta-referrer/same-origin/http-https/iframe-tag/same-origin-insecure.swap-origin-redirect.http.html [ Crash ] -crbug.com/591099 external/wpt/referrer-policy/same-origin/meta-referrer/same-origin/http-https/img-tag/same-origin-insecure.swap-origin-redirect.http.html [ Crash ] -crbug.com/591099 external/wpt/referrer-policy/strict-origin-when-cross-origin/attr-referrer/cross-origin/http-http/iframe-tag/cross-insecure.keep-origin-redirect.http.html [ Crash ] -crbug.com/591099 external/wpt/referrer-policy/strict-origin-when-cross-origin/attr-referrer/cross-origin/http-http/iframe-tag/cross-insecure.no-redirect.http.html [ Crash ] -crbug.com/591099 external/wpt/referrer-policy/strict-origin-when-cross-origin/attr-referrer/cross-origin/http-http/iframe-tag/cross-insecure.swap-origin-redirect.http.html [ Crash ] -crbug.com/591099 external/wpt/referrer-policy/strict-origin-when-cross-origin/attr-referrer/cross-origin/http-http/img-tag/cross-insecure.keep-origin-redirect.http.html [ Crash ] -crbug.com/591099 external/wpt/referrer-policy/strict-origin-when-cross-origin/attr-referrer/cross-origin/http-http/img-tag/cross-insecure.no-redirect.http.html [ Crash ] -crbug.com/591099 external/wpt/referrer-policy/strict-origin-when-cross-origin/attr-referrer/cross-origin/http-http/img-tag/cross-insecure.swap-origin-redirect.http.html [ Crash ] -crbug.com/591099 external/wpt/referrer-policy/strict-origin-when-cross-origin/attr-referrer/cross-origin/http-https/iframe-tag/upgrade-protocol.keep-origin-redirect.http.html [ Crash ] -crbug.com/591099 external/wpt/referrer-policy/strict-origin-when-cross-origin/attr-referrer/cross-origin/http-https/iframe-tag/upgrade-protocol.no-redirect.http.html [ Crash ] -crbug.com/591099 external/wpt/referrer-policy/strict-origin-when-cross-origin/attr-referrer/cross-origin/http-https/iframe-tag/upgrade-protocol.swap-origin-redirect.http.html [ Crash ] -crbug.com/591099 external/wpt/referrer-policy/strict-origin-when-cross-origin/attr-referrer/cross-origin/http-https/img-tag/upgrade-protocol.keep-origin-redirect.http.html [ Crash ] -crbug.com/591099 external/wpt/referrer-policy/strict-origin-when-cross-origin/attr-referrer/cross-origin/http-https/img-tag/upgrade-protocol.no-redirect.http.html [ Crash ] -crbug.com/591099 external/wpt/referrer-policy/strict-origin-when-cross-origin/attr-referrer/cross-origin/http-https/img-tag/upgrade-protocol.swap-origin-redirect.http.html [ Crash ] -crbug.com/591099 external/wpt/referrer-policy/strict-origin-when-cross-origin/attr-referrer/same-origin/http-http/iframe-tag/same-insecure.keep-origin-redirect.http.html [ Crash ] -crbug.com/591099 external/wpt/referrer-policy/strict-origin-when-cross-origin/attr-referrer/same-origin/http-http/iframe-tag/same-insecure.no-redirect.http.html [ Crash ] -crbug.com/591099 external/wpt/referrer-policy/strict-origin-when-cross-origin/attr-referrer/same-origin/http-http/iframe-tag/same-insecure.swap-origin-redirect.http.html [ Crash ] -crbug.com/591099 external/wpt/referrer-policy/strict-origin-when-cross-origin/attr-referrer/same-origin/http-http/img-tag/same-insecure.keep-origin-redirect.http.html [ Crash ] -crbug.com/591099 external/wpt/referrer-policy/strict-origin-when-cross-origin/attr-referrer/same-origin/http-http/img-tag/same-insecure.no-redirect.http.html [ Crash ] -crbug.com/591099 external/wpt/referrer-policy/strict-origin-when-cross-origin/attr-referrer/same-origin/http-http/img-tag/same-insecure.swap-origin-redirect.http.html [ Crash ] -crbug.com/591099 external/wpt/referrer-policy/strict-origin-when-cross-origin/attr-referrer/same-origin/http-https/iframe-tag/upgrade-protocol.keep-origin-redirect.http.html [ Crash ] -crbug.com/591099 external/wpt/referrer-policy/strict-origin-when-cross-origin/attr-referrer/same-origin/http-https/iframe-tag/upgrade-protocol.no-redirect.http.html [ Crash ] -crbug.com/591099 external/wpt/referrer-policy/strict-origin-when-cross-origin/attr-referrer/same-origin/http-https/iframe-tag/upgrade-protocol.swap-origin-redirect.http.html [ Crash ] -crbug.com/591099 external/wpt/referrer-policy/strict-origin-when-cross-origin/attr-referrer/same-origin/http-https/img-tag/upgrade-protocol.keep-origin-redirect.http.html [ Crash ] -crbug.com/591099 external/wpt/referrer-policy/strict-origin-when-cross-origin/attr-referrer/same-origin/http-https/img-tag/upgrade-protocol.no-redirect.http.html [ Crash ] -crbug.com/591099 external/wpt/referrer-policy/strict-origin-when-cross-origin/attr-referrer/same-origin/http-https/img-tag/upgrade-protocol.swap-origin-redirect.http.html [ Crash ] -crbug.com/591099 external/wpt/referrer-policy/strict-origin-when-cross-origin/http-rp/cross-origin/http-http/iframe-tag/cross-insecure.keep-origin-redirect.http.html [ Crash ] -crbug.com/591099 external/wpt/referrer-policy/strict-origin-when-cross-origin/http-rp/cross-origin/http-http/iframe-tag/cross-insecure.no-redirect.http.html [ Crash ] -crbug.com/591099 external/wpt/referrer-policy/strict-origin-when-cross-origin/http-rp/cross-origin/http-http/iframe-tag/cross-insecure.swap-origin-redirect.http.html [ Crash ] -crbug.com/591099 external/wpt/referrer-policy/strict-origin-when-cross-origin/http-rp/cross-origin/http-http/img-tag/cross-insecure.keep-origin-redirect.http.html [ Crash ] -crbug.com/591099 external/wpt/referrer-policy/strict-origin-when-cross-origin/http-rp/cross-origin/http-http/img-tag/cross-insecure.no-redirect.http.html [ Crash ] -crbug.com/591099 external/wpt/referrer-policy/strict-origin-when-cross-origin/http-rp/cross-origin/http-http/img-tag/cross-insecure.swap-origin-redirect.http.html [ Crash ] -crbug.com/591099 external/wpt/referrer-policy/strict-origin-when-cross-origin/http-rp/cross-origin/http-https/iframe-tag/upgrade-protocol.keep-origin-redirect.http.html [ Crash ] -crbug.com/591099 external/wpt/referrer-policy/strict-origin-when-cross-origin/http-rp/cross-origin/http-https/iframe-tag/upgrade-protocol.no-redirect.http.html [ Crash ] -crbug.com/591099 external/wpt/referrer-policy/strict-origin-when-cross-origin/http-rp/cross-origin/http-https/iframe-tag/upgrade-protocol.swap-origin-redirect.http.html [ Crash ] -crbug.com/591099 external/wpt/referrer-policy/strict-origin-when-cross-origin/http-rp/cross-origin/http-https/img-tag/upgrade-protocol.keep-origin-redirect.http.html [ Crash ] -crbug.com/591099 external/wpt/referrer-policy/strict-origin-when-cross-origin/http-rp/cross-origin/http-https/img-tag/upgrade-protocol.no-redirect.http.html [ Crash ] -crbug.com/591099 external/wpt/referrer-policy/strict-origin-when-cross-origin/http-rp/cross-origin/http-https/img-tag/upgrade-protocol.swap-origin-redirect.http.html [ Crash ] -crbug.com/591099 external/wpt/referrer-policy/strict-origin-when-cross-origin/http-rp/same-origin/http-http/iframe-tag/same-insecure.keep-origin-redirect.http.html [ Crash ] -crbug.com/591099 external/wpt/referrer-policy/strict-origin-when-cross-origin/http-rp/same-origin/http-http/iframe-tag/same-insecure.no-redirect.http.html [ Crash ] -crbug.com/591099 external/wpt/referrer-policy/strict-origin-when-cross-origin/http-rp/same-origin/http-http/iframe-tag/same-insecure.swap-origin-redirect.http.html [ Crash ] -crbug.com/591099 external/wpt/referrer-policy/strict-origin-when-cross-origin/http-rp/same-origin/http-http/img-tag/same-insecure.keep-origin-redirect.http.html [ Crash ] -crbug.com/591099 external/wpt/referrer-policy/strict-origin-when-cross-origin/http-rp/same-origin/http-http/img-tag/same-insecure.no-redirect.http.html [ Crash ] -crbug.com/591099 external/wpt/referrer-policy/strict-origin-when-cross-origin/http-rp/same-origin/http-http/img-tag/same-insecure.swap-origin-redirect.http.html [ Crash ] -crbug.com/591099 external/wpt/referrer-policy/strict-origin-when-cross-origin/http-rp/same-origin/http-https/iframe-tag/upgrade-protocol.keep-origin-redirect.http.html [ Crash ] -crbug.com/591099 external/wpt/referrer-policy/strict-origin-when-cross-origin/http-rp/same-origin/http-https/iframe-tag/upgrade-protocol.no-redirect.http.html [ Crash ] -crbug.com/591099 external/wpt/referrer-policy/strict-origin-when-cross-origin/http-rp/same-origin/http-https/iframe-tag/upgrade-protocol.swap-origin-redirect.http.html [ Crash ] -crbug.com/591099 external/wpt/referrer-policy/strict-origin-when-cross-origin/http-rp/same-origin/http-https/img-tag/upgrade-protocol.keep-origin-redirect.http.html [ Crash ] -crbug.com/591099 external/wpt/referrer-policy/strict-origin-when-cross-origin/http-rp/same-origin/http-https/img-tag/upgrade-protocol.no-redirect.http.html [ Crash ] -crbug.com/591099 external/wpt/referrer-policy/strict-origin-when-cross-origin/http-rp/same-origin/http-https/img-tag/upgrade-protocol.swap-origin-redirect.http.html [ Crash ] -crbug.com/591099 external/wpt/referrer-policy/strict-origin-when-cross-origin/meta-referrer/cross-origin/http-http/iframe-tag/cross-insecure.keep-origin-redirect.http.html [ Crash ] -crbug.com/591099 external/wpt/referrer-policy/strict-origin-when-cross-origin/meta-referrer/cross-origin/http-http/iframe-tag/cross-insecure.no-redirect.http.html [ Crash ] -crbug.com/591099 external/wpt/referrer-policy/strict-origin-when-cross-origin/meta-referrer/cross-origin/http-http/iframe-tag/cross-insecure.swap-origin-redirect.http.html [ Crash ] -crbug.com/591099 external/wpt/referrer-policy/strict-origin-when-cross-origin/meta-referrer/cross-origin/http-http/img-tag/cross-insecure.keep-origin-redirect.http.html [ Crash ] -crbug.com/591099 external/wpt/referrer-policy/strict-origin-when-cross-origin/meta-referrer/cross-origin/http-http/img-tag/cross-insecure.no-redirect.http.html [ Crash ] -crbug.com/591099 external/wpt/referrer-policy/strict-origin-when-cross-origin/meta-referrer/cross-origin/http-http/img-tag/cross-insecure.swap-origin-redirect.http.html [ Crash ] -crbug.com/591099 external/wpt/referrer-policy/strict-origin-when-cross-origin/meta-referrer/cross-origin/http-https/iframe-tag/upgrade-protocol.keep-origin-redirect.http.html [ Crash ] -crbug.com/591099 external/wpt/referrer-policy/strict-origin-when-cross-origin/meta-referrer/cross-origin/http-https/iframe-tag/upgrade-protocol.no-redirect.http.html [ Crash ] -crbug.com/591099 external/wpt/referrer-policy/strict-origin-when-cross-origin/meta-referrer/cross-origin/http-https/iframe-tag/upgrade-protocol.swap-origin-redirect.http.html [ Crash ] -crbug.com/591099 external/wpt/referrer-policy/strict-origin-when-cross-origin/meta-referrer/cross-origin/http-https/img-tag/upgrade-protocol.keep-origin-redirect.http.html [ Crash ] -crbug.com/591099 external/wpt/referrer-policy/strict-origin-when-cross-origin/meta-referrer/cross-origin/http-https/img-tag/upgrade-protocol.no-redirect.http.html [ Crash ] -crbug.com/591099 external/wpt/referrer-policy/strict-origin-when-cross-origin/meta-referrer/cross-origin/http-https/img-tag/upgrade-protocol.swap-origin-redirect.http.html [ Crash ] -crbug.com/591099 external/wpt/referrer-policy/strict-origin-when-cross-origin/meta-referrer/same-origin/http-http/iframe-tag/same-insecure.keep-origin-redirect.http.html [ Crash ] -crbug.com/591099 external/wpt/referrer-policy/strict-origin-when-cross-origin/meta-referrer/same-origin/http-http/iframe-tag/same-insecure.no-redirect.http.html [ Crash ] -crbug.com/591099 external/wpt/referrer-policy/strict-origin-when-cross-origin/meta-referrer/same-origin/http-http/iframe-tag/same-insecure.swap-origin-redirect.http.html [ Crash ] -crbug.com/591099 external/wpt/referrer-policy/strict-origin-when-cross-origin/meta-referrer/same-origin/http-http/img-tag/same-insecure.keep-origin-redirect.http.html [ Crash ] -crbug.com/591099 external/wpt/referrer-policy/strict-origin-when-cross-origin/meta-referrer/same-origin/http-http/img-tag/same-insecure.no-redirect.http.html [ Crash ] -crbug.com/591099 external/wpt/referrer-policy/strict-origin-when-cross-origin/meta-referrer/same-origin/http-http/img-tag/same-insecure.swap-origin-redirect.http.html [ Crash ] -crbug.com/591099 external/wpt/referrer-policy/strict-origin-when-cross-origin/meta-referrer/same-origin/http-https/iframe-tag/upgrade-protocol.keep-origin-redirect.http.html [ Crash ] -crbug.com/591099 external/wpt/referrer-policy/strict-origin-when-cross-origin/meta-referrer/same-origin/http-https/iframe-tag/upgrade-protocol.no-redirect.http.html [ Crash ] -crbug.com/591099 external/wpt/referrer-policy/strict-origin-when-cross-origin/meta-referrer/same-origin/http-https/iframe-tag/upgrade-protocol.swap-origin-redirect.http.html [ Crash ] -crbug.com/591099 external/wpt/referrer-policy/strict-origin-when-cross-origin/meta-referrer/same-origin/http-https/img-tag/upgrade-protocol.keep-origin-redirect.http.html [ Crash ] -crbug.com/591099 external/wpt/referrer-policy/strict-origin-when-cross-origin/meta-referrer/same-origin/http-https/img-tag/upgrade-protocol.no-redirect.http.html [ Crash ] -crbug.com/591099 external/wpt/referrer-policy/strict-origin-when-cross-origin/meta-referrer/same-origin/http-https/img-tag/upgrade-protocol.swap-origin-redirect.http.html [ Crash ] -crbug.com/591099 external/wpt/referrer-policy/strict-origin/attr-referrer/cross-origin/http-http/iframe-tag/insecure-protocol.keep-origin-redirect.http.html [ Crash ] -crbug.com/591099 external/wpt/referrer-policy/strict-origin/attr-referrer/cross-origin/http-http/iframe-tag/insecure-protocol.no-redirect.http.html [ Crash ] -crbug.com/591099 external/wpt/referrer-policy/strict-origin/attr-referrer/cross-origin/http-http/iframe-tag/insecure-protocol.swap-origin-redirect.http.html [ Crash ] -crbug.com/591099 external/wpt/referrer-policy/strict-origin/attr-referrer/cross-origin/http-http/img-tag/insecure-protocol.keep-origin-redirect.http.html [ Crash ] -crbug.com/591099 external/wpt/referrer-policy/strict-origin/attr-referrer/cross-origin/http-http/img-tag/insecure-protocol.no-redirect.http.html [ Crash ] -crbug.com/591099 external/wpt/referrer-policy/strict-origin/attr-referrer/cross-origin/http-http/img-tag/insecure-protocol.swap-origin-redirect.http.html [ Crash ] -crbug.com/591099 external/wpt/referrer-policy/strict-origin/attr-referrer/cross-origin/http-https/iframe-tag/upgrade-protocol.keep-origin-redirect.http.html [ Crash ] -crbug.com/591099 external/wpt/referrer-policy/strict-origin/attr-referrer/cross-origin/http-https/iframe-tag/upgrade-protocol.no-redirect.http.html [ Crash ] -crbug.com/591099 external/wpt/referrer-policy/strict-origin/attr-referrer/cross-origin/http-https/iframe-tag/upgrade-protocol.swap-origin-redirect.http.html [ Crash ] -crbug.com/591099 external/wpt/referrer-policy/strict-origin/attr-referrer/cross-origin/http-https/img-tag/upgrade-protocol.keep-origin-redirect.http.html [ Crash ] -crbug.com/591099 external/wpt/referrer-policy/strict-origin/attr-referrer/cross-origin/http-https/img-tag/upgrade-protocol.no-redirect.http.html [ Crash ] -crbug.com/591099 external/wpt/referrer-policy/strict-origin/attr-referrer/cross-origin/http-https/img-tag/upgrade-protocol.swap-origin-redirect.http.html [ Crash ] -crbug.com/591099 external/wpt/referrer-policy/strict-origin/attr-referrer/same-origin/http-http/iframe-tag/insecure-protocol.keep-origin-redirect.http.html [ Crash ] -crbug.com/591099 external/wpt/referrer-policy/strict-origin/attr-referrer/same-origin/http-http/iframe-tag/insecure-protocol.no-redirect.http.html [ Crash ] -crbug.com/591099 external/wpt/referrer-policy/strict-origin/attr-referrer/same-origin/http-http/iframe-tag/insecure-protocol.swap-origin-redirect.http.html [ Crash ] -crbug.com/591099 external/wpt/referrer-policy/strict-origin/attr-referrer/same-origin/http-http/img-tag/insecure-protocol.keep-origin-redirect.http.html [ Crash ] -crbug.com/591099 external/wpt/referrer-policy/strict-origin/attr-referrer/same-origin/http-http/img-tag/insecure-protocol.no-redirect.http.html [ Crash ] -crbug.com/591099 external/wpt/referrer-policy/strict-origin/attr-referrer/same-origin/http-http/img-tag/insecure-protocol.swap-origin-redirect.http.html [ Crash ] -crbug.com/591099 external/wpt/referrer-policy/strict-origin/attr-referrer/same-origin/http-https/iframe-tag/upgrade-protocol.keep-origin-redirect.http.html [ Crash ] -crbug.com/591099 external/wpt/referrer-policy/strict-origin/attr-referrer/same-origin/http-https/iframe-tag/upgrade-protocol.no-redirect.http.html [ Crash ] -crbug.com/591099 external/wpt/referrer-policy/strict-origin/attr-referrer/same-origin/http-https/iframe-tag/upgrade-protocol.swap-origin-redirect.http.html [ Crash ] -crbug.com/591099 external/wpt/referrer-policy/strict-origin/attr-referrer/same-origin/http-https/img-tag/upgrade-protocol.keep-origin-redirect.http.html [ Crash ] -crbug.com/591099 external/wpt/referrer-policy/strict-origin/attr-referrer/same-origin/http-https/img-tag/upgrade-protocol.no-redirect.http.html [ Crash ] -crbug.com/591099 external/wpt/referrer-policy/strict-origin/attr-referrer/same-origin/http-https/img-tag/upgrade-protocol.swap-origin-redirect.http.html [ Crash ] -crbug.com/591099 external/wpt/referrer-policy/strict-origin/http-rp/cross-origin/http-http/iframe-tag/insecure-protocol.keep-origin-redirect.http.html [ Crash ] -crbug.com/591099 external/wpt/referrer-policy/strict-origin/http-rp/cross-origin/http-http/iframe-tag/insecure-protocol.no-redirect.http.html [ Crash ] -crbug.com/591099 external/wpt/referrer-policy/strict-origin/http-rp/cross-origin/http-http/iframe-tag/insecure-protocol.swap-origin-redirect.http.html [ Crash ] -crbug.com/591099 external/wpt/referrer-policy/strict-origin/http-rp/cross-origin/http-http/img-tag/insecure-protocol.keep-origin-redirect.http.html [ Crash ] -crbug.com/591099 external/wpt/referrer-policy/strict-origin/http-rp/cross-origin/http-http/img-tag/insecure-protocol.no-redirect.http.html [ Crash ] -crbug.com/591099 external/wpt/referrer-policy/strict-origin/http-rp/cross-origin/http-http/img-tag/insecure-protocol.swap-origin-redirect.http.html [ Crash ] -crbug.com/591099 external/wpt/referrer-policy/strict-origin/http-rp/cross-origin/http-https/iframe-tag/upgrade-protocol.keep-origin-redirect.http.html [ Crash ] -crbug.com/591099 external/wpt/referrer-policy/strict-origin/http-rp/cross-origin/http-https/iframe-tag/upgrade-protocol.no-redirect.http.html [ Crash ] -crbug.com/591099 external/wpt/referrer-policy/strict-origin/http-rp/cross-origin/http-https/iframe-tag/upgrade-protocol.swap-origin-redirect.http.html [ Crash ] -crbug.com/591099 external/wpt/referrer-policy/strict-origin/http-rp/cross-origin/http-https/img-tag/upgrade-protocol.keep-origin-redirect.http.html [ Crash ] -crbug.com/591099 external/wpt/referrer-policy/strict-origin/http-rp/cross-origin/http-https/img-tag/upgrade-protocol.no-redirect.http.html [ Crash ] -crbug.com/591099 external/wpt/referrer-policy/strict-origin/http-rp/cross-origin/http-https/img-tag/upgrade-protocol.swap-origin-redirect.http.html [ Crash ] -crbug.com/591099 external/wpt/referrer-policy/strict-origin/http-rp/same-origin/http-http/iframe-tag/insecure-protocol.keep-origin-redirect.http.html [ Crash ] -crbug.com/591099 external/wpt/referrer-policy/strict-origin/http-rp/same-origin/http-http/iframe-tag/insecure-protocol.no-redirect.http.html [ Crash ] -crbug.com/591099 external/wpt/referrer-policy/strict-origin/http-rp/same-origin/http-http/iframe-tag/insecure-protocol.swap-origin-redirect.http.html [ Crash ] -crbug.com/591099 external/wpt/referrer-policy/strict-origin/http-rp/same-origin/http-http/img-tag/insecure-protocol.keep-origin-redirect.http.html [ Crash ] -crbug.com/591099 external/wpt/referrer-policy/strict-origin/http-rp/same-origin/http-http/img-tag/insecure-protocol.no-redirect.http.html [ Crash ] -crbug.com/591099 external/wpt/referrer-policy/strict-origin/http-rp/same-origin/http-http/img-tag/insecure-protocol.swap-origin-redirect.http.html [ Crash ] -crbug.com/591099 external/wpt/referrer-policy/strict-origin/http-rp/same-origin/http-https/iframe-tag/upgrade-protocol.keep-origin-redirect.http.html [ Crash ] -crbug.com/591099 external/wpt/referrer-policy/strict-origin/http-rp/same-origin/http-https/iframe-tag/upgrade-protocol.no-redirect.http.html [ Crash ] -crbug.com/591099 external/wpt/referrer-policy/strict-origin/http-rp/same-origin/http-https/iframe-tag/upgrade-protocol.swap-origin-redirect.http.html [ Crash ] -crbug.com/591099 external/wpt/referrer-policy/strict-origin/http-rp/same-origin/http-https/img-tag/upgrade-protocol.keep-origin-redirect.http.html [ Crash ] -crbug.com/591099 external/wpt/referrer-policy/strict-origin/http-rp/same-origin/http-https/img-tag/upgrade-protocol.no-redirect.http.html [ Crash ] -crbug.com/591099 external/wpt/referrer-policy/strict-origin/http-rp/same-origin/http-https/img-tag/upgrade-protocol.swap-origin-redirect.http.html [ Crash ] -crbug.com/591099 external/wpt/referrer-policy/strict-origin/meta-referrer/cross-origin/http-http/iframe-tag/insecure-protocol.keep-origin-redirect.http.html [ Crash ] -crbug.com/591099 external/wpt/referrer-policy/strict-origin/meta-referrer/cross-origin/http-http/iframe-tag/insecure-protocol.no-redirect.http.html [ Crash ] -crbug.com/591099 external/wpt/referrer-policy/strict-origin/meta-referrer/cross-origin/http-http/iframe-tag/insecure-protocol.swap-origin-redirect.http.html [ Crash ] -crbug.com/591099 external/wpt/referrer-policy/strict-origin/meta-referrer/cross-origin/http-http/img-tag/insecure-protocol.keep-origin-redirect.http.html [ Crash ] -crbug.com/591099 external/wpt/referrer-policy/strict-origin/meta-referrer/cross-origin/http-http/img-tag/insecure-protocol.no-redirect.http.html [ Crash ] -crbug.com/591099 external/wpt/referrer-policy/strict-origin/meta-referrer/cross-origin/http-http/img-tag/insecure-protocol.swap-origin-redirect.http.html [ Crash ] -crbug.com/591099 external/wpt/referrer-policy/strict-origin/meta-referrer/cross-origin/http-https/iframe-tag/upgrade-protocol.keep-origin-redirect.http.html [ Crash ] -crbug.com/591099 external/wpt/referrer-policy/strict-origin/meta-referrer/cross-origin/http-https/iframe-tag/upgrade-protocol.no-redirect.http.html [ Crash ] -crbug.com/591099 external/wpt/referrer-policy/strict-origin/meta-referrer/cross-origin/http-https/iframe-tag/upgrade-protocol.swap-origin-redirect.http.html [ Crash ] -crbug.com/591099 external/wpt/referrer-policy/strict-origin/meta-referrer/cross-origin/http-https/img-tag/upgrade-protocol.keep-origin-redirect.http.html [ Crash ] -crbug.com/591099 external/wpt/referrer-policy/strict-origin/meta-referrer/cross-origin/http-https/img-tag/upgrade-protocol.no-redirect.http.html [ Crash ] -crbug.com/591099 external/wpt/referrer-policy/strict-origin/meta-referrer/cross-origin/http-https/img-tag/upgrade-protocol.swap-origin-redirect.http.html [ Crash ] -crbug.com/591099 external/wpt/referrer-policy/strict-origin/meta-referrer/same-origin/http-http/iframe-tag/insecure-protocol.keep-origin-redirect.http.html [ Crash ] -crbug.com/591099 external/wpt/referrer-policy/strict-origin/meta-referrer/same-origin/http-http/iframe-tag/insecure-protocol.no-redirect.http.html [ Crash ] -crbug.com/591099 external/wpt/referrer-policy/strict-origin/meta-referrer/same-origin/http-http/iframe-tag/insecure-protocol.swap-origin-redirect.http.html [ Crash ] -crbug.com/591099 external/wpt/referrer-policy/strict-origin/meta-referrer/same-origin/http-http/img-tag/insecure-protocol.keep-origin-redirect.http.html [ Crash ] -crbug.com/591099 external/wpt/referrer-policy/strict-origin/meta-referrer/same-origin/http-http/img-tag/insecure-protocol.no-redirect.http.html [ Crash ] -crbug.com/591099 external/wpt/referrer-policy/strict-origin/meta-referrer/same-origin/http-http/img-tag/insecure-protocol.swap-origin-redirect.http.html [ Crash ] -crbug.com/591099 external/wpt/referrer-policy/strict-origin/meta-referrer/same-origin/http-https/iframe-tag/upgrade-protocol.keep-origin-redirect.http.html [ Crash ] -crbug.com/591099 external/wpt/referrer-policy/strict-origin/meta-referrer/same-origin/http-https/iframe-tag/upgrade-protocol.no-redirect.http.html [ Crash ] -crbug.com/591099 external/wpt/referrer-policy/strict-origin/meta-referrer/same-origin/http-https/iframe-tag/upgrade-protocol.swap-origin-redirect.http.html [ Crash ] -crbug.com/591099 external/wpt/referrer-policy/strict-origin/meta-referrer/same-origin/http-https/img-tag/upgrade-protocol.keep-origin-redirect.http.html [ Crash ] -crbug.com/591099 external/wpt/referrer-policy/strict-origin/meta-referrer/same-origin/http-https/img-tag/upgrade-protocol.no-redirect.http.html [ Crash ] -crbug.com/591099 external/wpt/referrer-policy/strict-origin/meta-referrer/same-origin/http-https/img-tag/upgrade-protocol.swap-origin-redirect.http.html [ Crash ] -crbug.com/591099 external/wpt/referrer-policy/unsafe-url/attr-referrer/cross-origin/http-http/iframe-tag/generic.keep-origin-redirect.http.html [ Crash ] -crbug.com/591099 external/wpt/referrer-policy/unsafe-url/attr-referrer/cross-origin/http-http/iframe-tag/generic.no-redirect.http.html [ Crash ] -crbug.com/591099 external/wpt/referrer-policy/unsafe-url/attr-referrer/cross-origin/http-http/iframe-tag/generic.swap-origin-redirect.http.html [ Crash ] -crbug.com/591099 external/wpt/referrer-policy/unsafe-url/attr-referrer/cross-origin/http-http/img-tag/generic.keep-origin-redirect.http.html [ Crash ] -crbug.com/591099 external/wpt/referrer-policy/unsafe-url/attr-referrer/cross-origin/http-http/img-tag/generic.no-redirect.http.html [ Crash ] -crbug.com/591099 external/wpt/referrer-policy/unsafe-url/attr-referrer/cross-origin/http-http/img-tag/generic.swap-origin-redirect.http.html [ Crash ] -crbug.com/591099 external/wpt/referrer-policy/unsafe-url/attr-referrer/cross-origin/http-https/iframe-tag/generic.keep-origin-redirect.http.html [ Crash ] -crbug.com/591099 external/wpt/referrer-policy/unsafe-url/attr-referrer/cross-origin/http-https/iframe-tag/generic.no-redirect.http.html [ Crash ] -crbug.com/591099 external/wpt/referrer-policy/unsafe-url/attr-referrer/cross-origin/http-https/iframe-tag/generic.swap-origin-redirect.http.html [ Crash ] -crbug.com/591099 external/wpt/referrer-policy/unsafe-url/attr-referrer/cross-origin/http-https/img-tag/generic.keep-origin-redirect.http.html [ Crash ] -crbug.com/591099 external/wpt/referrer-policy/unsafe-url/attr-referrer/cross-origin/http-https/img-tag/generic.no-redirect.http.html [ Crash ] -crbug.com/591099 external/wpt/referrer-policy/unsafe-url/attr-referrer/cross-origin/http-https/img-tag/generic.swap-origin-redirect.http.html [ Crash ] -crbug.com/591099 external/wpt/referrer-policy/unsafe-url/attr-referrer/same-origin/http-http/iframe-tag/generic.keep-origin-redirect.http.html [ Crash ] -crbug.com/591099 external/wpt/referrer-policy/unsafe-url/attr-referrer/same-origin/http-http/iframe-tag/generic.no-redirect.http.html [ Crash ] -crbug.com/591099 external/wpt/referrer-policy/unsafe-url/attr-referrer/same-origin/http-http/iframe-tag/generic.swap-origin-redirect.http.html [ Crash ] -crbug.com/591099 external/wpt/referrer-policy/unsafe-url/attr-referrer/same-origin/http-http/img-tag/generic.keep-origin-redirect.http.html [ Crash ] -crbug.com/591099 external/wpt/referrer-policy/unsafe-url/attr-referrer/same-origin/http-http/img-tag/generic.no-redirect.http.html [ Crash ] -crbug.com/591099 external/wpt/referrer-policy/unsafe-url/attr-referrer/same-origin/http-http/img-tag/generic.swap-origin-redirect.http.html [ Crash ] -crbug.com/591099 external/wpt/referrer-policy/unsafe-url/attr-referrer/same-origin/http-https/iframe-tag/generic.keep-origin-redirect.http.html [ Crash ] -crbug.com/591099 external/wpt/referrer-policy/unsafe-url/attr-referrer/same-origin/http-https/iframe-tag/generic.no-redirect.http.html [ Crash ] -crbug.com/591099 external/wpt/referrer-policy/unsafe-url/attr-referrer/same-origin/http-https/iframe-tag/generic.swap-origin-redirect.http.html [ Crash ] -crbug.com/591099 external/wpt/referrer-policy/unsafe-url/attr-referrer/same-origin/http-https/img-tag/generic.keep-origin-redirect.http.html [ Crash ] -crbug.com/591099 external/wpt/referrer-policy/unsafe-url/attr-referrer/same-origin/http-https/img-tag/generic.no-redirect.http.html [ Crash ] -crbug.com/591099 external/wpt/referrer-policy/unsafe-url/attr-referrer/same-origin/http-https/img-tag/generic.swap-origin-redirect.http.html [ Crash ] -crbug.com/591099 external/wpt/referrer-policy/unsafe-url/http-rp/cross-origin/http-http/iframe-tag/generic.keep-origin-redirect.http.html [ Crash ] -crbug.com/591099 external/wpt/referrer-policy/unsafe-url/http-rp/cross-origin/http-http/iframe-tag/generic.no-redirect.http.html [ Crash ] -crbug.com/591099 external/wpt/referrer-policy/unsafe-url/http-rp/cross-origin/http-http/iframe-tag/generic.swap-origin-redirect.http.html [ Crash ] -crbug.com/591099 external/wpt/referrer-policy/unsafe-url/http-rp/cross-origin/http-http/img-tag/generic.keep-origin-redirect.http.html [ Crash ] -crbug.com/591099 external/wpt/referrer-policy/unsafe-url/http-rp/cross-origin/http-http/img-tag/generic.no-redirect.http.html [ Crash ] -crbug.com/591099 external/wpt/referrer-policy/unsafe-url/http-rp/cross-origin/http-http/img-tag/generic.swap-origin-redirect.http.html [ Crash ] -crbug.com/591099 external/wpt/referrer-policy/unsafe-url/http-rp/cross-origin/http-https/iframe-tag/generic.keep-origin-redirect.http.html [ Crash ] -crbug.com/591099 external/wpt/referrer-policy/unsafe-url/http-rp/cross-origin/http-https/iframe-tag/generic.no-redirect.http.html [ Crash ] -crbug.com/591099 external/wpt/referrer-policy/unsafe-url/http-rp/cross-origin/http-https/iframe-tag/generic.swap-origin-redirect.http.html [ Crash ] -crbug.com/591099 external/wpt/referrer-policy/unsafe-url/http-rp/cross-origin/http-https/img-tag/generic.keep-origin-redirect.http.html [ Crash ] -crbug.com/591099 external/wpt/referrer-policy/unsafe-url/http-rp/cross-origin/http-https/img-tag/generic.no-redirect.http.html [ Crash ] -crbug.com/591099 external/wpt/referrer-policy/unsafe-url/http-rp/cross-origin/http-https/img-tag/generic.swap-origin-redirect.http.html [ Crash ] -crbug.com/591099 external/wpt/referrer-policy/unsafe-url/http-rp/same-origin/http-http/iframe-tag/generic.keep-origin-redirect.http.html [ Crash ] -crbug.com/591099 external/wpt/referrer-policy/unsafe-url/http-rp/same-origin/http-http/iframe-tag/generic.no-redirect.http.html [ Crash ] -crbug.com/591099 external/wpt/referrer-policy/unsafe-url/http-rp/same-origin/http-http/iframe-tag/generic.swap-origin-redirect.http.html [ Crash ] -crbug.com/591099 external/wpt/referrer-policy/unsafe-url/http-rp/same-origin/http-http/img-tag/generic.keep-origin-redirect.http.html [ Crash ] -crbug.com/591099 external/wpt/referrer-policy/unsafe-url/http-rp/same-origin/http-http/img-tag/generic.no-redirect.http.html [ Crash ] -crbug.com/591099 external/wpt/referrer-policy/unsafe-url/http-rp/same-origin/http-http/img-tag/generic.swap-origin-redirect.http.html [ Crash ] -crbug.com/591099 external/wpt/referrer-policy/unsafe-url/http-rp/same-origin/http-https/iframe-tag/generic.keep-origin-redirect.http.html [ Crash ] -crbug.com/591099 external/wpt/referrer-policy/unsafe-url/http-rp/same-origin/http-https/iframe-tag/generic.no-redirect.http.html [ Crash ] -crbug.com/591099 external/wpt/referrer-policy/unsafe-url/http-rp/same-origin/http-https/iframe-tag/generic.swap-origin-redirect.http.html [ Crash ] -crbug.com/591099 external/wpt/referrer-policy/unsafe-url/http-rp/same-origin/http-https/img-tag/generic.keep-origin-redirect.http.html [ Crash ] -crbug.com/591099 external/wpt/referrer-policy/unsafe-url/http-rp/same-origin/http-https/img-tag/generic.no-redirect.http.html [ Crash ] -crbug.com/591099 external/wpt/referrer-policy/unsafe-url/http-rp/same-origin/http-https/img-tag/generic.swap-origin-redirect.http.html [ Crash ] -crbug.com/591099 external/wpt/referrer-policy/unsafe-url/meta-referrer/cross-origin/http-http/iframe-tag/generic.keep-origin-redirect.http.html [ Crash ] -crbug.com/591099 external/wpt/referrer-policy/unsafe-url/meta-referrer/cross-origin/http-http/iframe-tag/generic.no-redirect.http.html [ Crash ] -crbug.com/591099 external/wpt/referrer-policy/unsafe-url/meta-referrer/cross-origin/http-http/iframe-tag/generic.swap-origin-redirect.http.html [ Crash ] -crbug.com/591099 external/wpt/referrer-policy/unsafe-url/meta-referrer/cross-origin/http-http/img-tag/generic.keep-origin-redirect.http.html [ Crash ] -crbug.com/591099 external/wpt/referrer-policy/unsafe-url/meta-referrer/cross-origin/http-http/img-tag/generic.no-redirect.http.html [ Crash ] -crbug.com/591099 external/wpt/referrer-policy/unsafe-url/meta-referrer/cross-origin/http-http/img-tag/generic.swap-origin-redirect.http.html [ Crash ] -crbug.com/591099 external/wpt/referrer-policy/unsafe-url/meta-referrer/cross-origin/http-https/iframe-tag/generic.keep-origin-redirect.http.html [ Crash ] -crbug.com/591099 external/wpt/referrer-policy/unsafe-url/meta-referrer/cross-origin/http-https/iframe-tag/generic.no-redirect.http.html [ Crash ] -crbug.com/591099 external/wpt/referrer-policy/unsafe-url/meta-referrer/cross-origin/http-https/iframe-tag/generic.swap-origin-redirect.http.html [ Crash ] -crbug.com/591099 external/wpt/referrer-policy/unsafe-url/meta-referrer/cross-origin/http-https/img-tag/generic.keep-origin-redirect.http.html [ Crash ] -crbug.com/591099 external/wpt/referrer-policy/unsafe-url/meta-referrer/cross-origin/http-https/img-tag/generic.no-redirect.http.html [ Crash ] -crbug.com/591099 external/wpt/referrer-policy/unsafe-url/meta-referrer/cross-origin/http-https/img-tag/generic.swap-origin-redirect.http.html [ Crash ] -crbug.com/591099 external/wpt/referrer-policy/unsafe-url/meta-referrer/same-origin/http-http/iframe-tag/generic.keep-origin-redirect.http.html [ Crash ] -crbug.com/591099 external/wpt/referrer-policy/unsafe-url/meta-referrer/same-origin/http-http/iframe-tag/generic.no-redirect.http.html [ Crash ] -crbug.com/591099 external/wpt/referrer-policy/unsafe-url/meta-referrer/same-origin/http-http/iframe-tag/generic.swap-origin-redirect.http.html [ Crash ] -crbug.com/591099 external/wpt/referrer-policy/unsafe-url/meta-referrer/same-origin/http-http/img-tag/generic.keep-origin-redirect.http.html [ Crash ] -crbug.com/591099 external/wpt/referrer-policy/unsafe-url/meta-referrer/same-origin/http-http/img-tag/generic.no-redirect.http.html [ Crash ] -crbug.com/591099 external/wpt/referrer-policy/unsafe-url/meta-referrer/same-origin/http-http/img-tag/generic.swap-origin-redirect.http.html [ Crash ] -crbug.com/591099 external/wpt/referrer-policy/unsafe-url/meta-referrer/same-origin/http-https/iframe-tag/generic.keep-origin-redirect.http.html [ Crash ] -crbug.com/591099 external/wpt/referrer-policy/unsafe-url/meta-referrer/same-origin/http-https/iframe-tag/generic.no-redirect.http.html [ Crash ] -crbug.com/591099 external/wpt/referrer-policy/unsafe-url/meta-referrer/same-origin/http-https/iframe-tag/generic.swap-origin-redirect.http.html [ Crash ] -crbug.com/591099 external/wpt/referrer-policy/unsafe-url/meta-referrer/same-origin/http-https/img-tag/generic.keep-origin-redirect.http.html [ Crash ] -crbug.com/591099 external/wpt/referrer-policy/unsafe-url/meta-referrer/same-origin/http-https/img-tag/generic.no-redirect.http.html [ Crash ] -crbug.com/591099 external/wpt/referrer-policy/unsafe-url/meta-referrer/same-origin/http-https/img-tag/generic.swap-origin-redirect.http.html [ Crash ] -crbug.com/591099 external/wpt/referrer-policy/unset-referrer-policy/attr-referrer/cross-origin/http-http/iframe-tag/insecure-protocol.keep-origin-redirect.http.html [ Crash ] -crbug.com/591099 external/wpt/referrer-policy/unset-referrer-policy/attr-referrer/cross-origin/http-http/iframe-tag/insecure-protocol.no-redirect.http.html [ Crash ] -crbug.com/591099 external/wpt/referrer-policy/unset-referrer-policy/attr-referrer/cross-origin/http-http/iframe-tag/insecure-protocol.swap-origin-redirect.http.html [ Crash ] -crbug.com/591099 external/wpt/referrer-policy/unset-referrer-policy/attr-referrer/cross-origin/http-http/img-tag/insecure-protocol.keep-origin-redirect.http.html [ Crash ] -crbug.com/591099 external/wpt/referrer-policy/unset-referrer-policy/attr-referrer/cross-origin/http-http/img-tag/insecure-protocol.no-redirect.http.html [ Crash ] -crbug.com/591099 external/wpt/referrer-policy/unset-referrer-policy/attr-referrer/cross-origin/http-http/img-tag/insecure-protocol.swap-origin-redirect.http.html [ Crash ] -crbug.com/591099 external/wpt/referrer-policy/unset-referrer-policy/attr-referrer/cross-origin/http-https/iframe-tag/upgrade-protocol.keep-origin-redirect.http.html [ Crash ] -crbug.com/591099 external/wpt/referrer-policy/unset-referrer-policy/attr-referrer/cross-origin/http-https/iframe-tag/upgrade-protocol.no-redirect.http.html [ Crash ] -crbug.com/591099 external/wpt/referrer-policy/unset-referrer-policy/attr-referrer/cross-origin/http-https/iframe-tag/upgrade-protocol.swap-origin-redirect.http.html [ Crash ] -crbug.com/591099 external/wpt/referrer-policy/unset-referrer-policy/attr-referrer/cross-origin/http-https/img-tag/upgrade-protocol.keep-origin-redirect.http.html [ Crash ] -crbug.com/591099 external/wpt/referrer-policy/unset-referrer-policy/attr-referrer/cross-origin/http-https/img-tag/upgrade-protocol.no-redirect.http.html [ Crash ] -crbug.com/591099 external/wpt/referrer-policy/unset-referrer-policy/attr-referrer/cross-origin/http-https/img-tag/upgrade-protocol.swap-origin-redirect.http.html [ Crash ] -crbug.com/591099 external/wpt/referrer-policy/unset-referrer-policy/attr-referrer/same-origin/http-http/iframe-tag/insecure-protocol.keep-origin-redirect.http.html [ Crash ] -crbug.com/591099 external/wpt/referrer-policy/unset-referrer-policy/attr-referrer/same-origin/http-http/iframe-tag/insecure-protocol.no-redirect.http.html [ Crash ] -crbug.com/591099 external/wpt/referrer-policy/unset-referrer-policy/attr-referrer/same-origin/http-http/iframe-tag/insecure-protocol.swap-origin-redirect.http.html [ Crash ] -crbug.com/591099 external/wpt/referrer-policy/unset-referrer-policy/attr-referrer/same-origin/http-http/img-tag/insecure-protocol.keep-origin-redirect.http.html [ Crash ] -crbug.com/591099 external/wpt/referrer-policy/unset-referrer-policy/attr-referrer/same-origin/http-http/img-tag/insecure-protocol.no-redirect.http.html [ Crash ] -crbug.com/591099 external/wpt/referrer-policy/unset-referrer-policy/attr-referrer/same-origin/http-http/img-tag/insecure-protocol.swap-origin-redirect.http.html [ Crash ] -crbug.com/591099 external/wpt/referrer-policy/unset-referrer-policy/attr-referrer/same-origin/http-https/iframe-tag/upgrade-protocol.keep-origin-redirect.http.html [ Crash ] -crbug.com/591099 external/wpt/referrer-policy/unset-referrer-policy/attr-referrer/same-origin/http-https/iframe-tag/upgrade-protocol.no-redirect.http.html [ Crash ] -crbug.com/591099 external/wpt/referrer-policy/unset-referrer-policy/attr-referrer/same-origin/http-https/iframe-tag/upgrade-protocol.swap-origin-redirect.http.html [ Crash ] -crbug.com/591099 external/wpt/referrer-policy/unset-referrer-policy/attr-referrer/same-origin/http-https/img-tag/upgrade-protocol.keep-origin-redirect.http.html [ Crash ] -crbug.com/591099 external/wpt/referrer-policy/unset-referrer-policy/attr-referrer/same-origin/http-https/img-tag/upgrade-protocol.no-redirect.http.html [ Crash ] -crbug.com/591099 external/wpt/referrer-policy/unset-referrer-policy/attr-referrer/same-origin/http-https/img-tag/upgrade-protocol.swap-origin-redirect.http.html [ Crash ] -crbug.com/591099 external/wpt/referrer-policy/unset-referrer-policy/http-rp/cross-origin/http-http/iframe-tag/insecure-protocol.keep-origin-redirect.http.html [ Crash ] -crbug.com/591099 external/wpt/referrer-policy/unset-referrer-policy/http-rp/cross-origin/http-http/iframe-tag/insecure-protocol.no-redirect.http.html [ Crash ] -crbug.com/591099 external/wpt/referrer-policy/unset-referrer-policy/http-rp/cross-origin/http-http/iframe-tag/insecure-protocol.swap-origin-redirect.http.html [ Crash ] -crbug.com/591099 external/wpt/referrer-policy/unset-referrer-policy/http-rp/cross-origin/http-http/img-tag/insecure-protocol.keep-origin-redirect.http.html [ Crash ] -crbug.com/591099 external/wpt/referrer-policy/unset-referrer-policy/http-rp/cross-origin/http-http/img-tag/insecure-protocol.no-redirect.http.html [ Crash ] -crbug.com/591099 external/wpt/referrer-policy/unset-referrer-policy/http-rp/cross-origin/http-http/img-tag/insecure-protocol.swap-origin-redirect.http.html [ Crash ] -crbug.com/591099 external/wpt/referrer-policy/unset-referrer-policy/http-rp/cross-origin/http-https/iframe-tag/upgrade-protocol.keep-origin-redirect.http.html [ Crash ] -crbug.com/591099 external/wpt/referrer-policy/unset-referrer-policy/http-rp/cross-origin/http-https/iframe-tag/upgrade-protocol.no-redirect.http.html [ Crash ] -crbug.com/591099 external/wpt/referrer-policy/unset-referrer-policy/http-rp/cross-origin/http-https/iframe-tag/upgrade-protocol.swap-origin-redirect.http.html [ Crash ] -crbug.com/591099 external/wpt/referrer-policy/unset-referrer-policy/http-rp/cross-origin/http-https/img-tag/upgrade-protocol.keep-origin-redirect.http.html [ Crash ] -crbug.com/591099 external/wpt/referrer-policy/unset-referrer-policy/http-rp/cross-origin/http-https/img-tag/upgrade-protocol.no-redirect.http.html [ Crash ] -crbug.com/591099 external/wpt/referrer-policy/unset-referrer-policy/http-rp/cross-origin/http-https/img-tag/upgrade-protocol.swap-origin-redirect.http.html [ Crash ] -crbug.com/591099 external/wpt/referrer-policy/unset-referrer-policy/http-rp/same-origin/http-http/iframe-tag/insecure-protocol.keep-origin-redirect.http.html [ Crash ] -crbug.com/591099 external/wpt/referrer-policy/unset-referrer-policy/http-rp/same-origin/http-http/iframe-tag/insecure-protocol.no-redirect.http.html [ Crash ] -crbug.com/591099 external/wpt/referrer-policy/unset-referrer-policy/http-rp/same-origin/http-http/iframe-tag/insecure-protocol.swap-origin-redirect.http.html [ Crash ] -crbug.com/591099 external/wpt/referrer-policy/unset-referrer-policy/http-rp/same-origin/http-http/img-tag/insecure-protocol.keep-origin-redirect.http.html [ Crash ] -crbug.com/591099 external/wpt/referrer-policy/unset-referrer-policy/http-rp/same-origin/http-http/img-tag/insecure-protocol.no-redirect.http.html [ Crash ] -crbug.com/591099 external/wpt/referrer-policy/unset-referrer-policy/http-rp/same-origin/http-http/img-tag/insecure-protocol.swap-origin-redirect.http.html [ Crash ] -crbug.com/591099 external/wpt/referrer-policy/unset-referrer-policy/http-rp/same-origin/http-https/iframe-tag/upgrade-protocol.keep-origin-redirect.http.html [ Crash ] -crbug.com/591099 external/wpt/referrer-policy/unset-referrer-policy/http-rp/same-origin/http-https/iframe-tag/upgrade-protocol.no-redirect.http.html [ Crash ] -crbug.com/591099 external/wpt/referrer-policy/unset-referrer-policy/http-rp/same-origin/http-https/iframe-tag/upgrade-protocol.swap-origin-redirect.http.html [ Crash ] -crbug.com/591099 external/wpt/referrer-policy/unset-referrer-policy/http-rp/same-origin/http-https/img-tag/upgrade-protocol.keep-origin-redirect.http.html [ Crash ] -crbug.com/591099 external/wpt/referrer-policy/unset-referrer-policy/http-rp/same-origin/http-https/img-tag/upgrade-protocol.no-redirect.http.html [ Crash ] -crbug.com/591099 external/wpt/referrer-policy/unset-referrer-policy/http-rp/same-origin/http-https/img-tag/upgrade-protocol.swap-origin-redirect.http.html [ Crash ] -crbug.com/591099 external/wpt/referrer-policy/unset-referrer-policy/meta-referrer/cross-origin/http-http/iframe-tag/insecure-protocol.keep-origin-redirect.http.html [ Crash ] -crbug.com/591099 external/wpt/referrer-policy/unset-referrer-policy/meta-referrer/cross-origin/http-http/iframe-tag/insecure-protocol.no-redirect.http.html [ Crash ] -crbug.com/591099 external/wpt/referrer-policy/unset-referrer-policy/meta-referrer/cross-origin/http-http/iframe-tag/insecure-protocol.swap-origin-redirect.http.html [ Crash ] -crbug.com/591099 external/wpt/referrer-policy/unset-referrer-policy/meta-referrer/cross-origin/http-http/img-tag/insecure-protocol.keep-origin-redirect.http.html [ Crash ] -crbug.com/591099 external/wpt/referrer-policy/unset-referrer-policy/meta-referrer/cross-origin/http-http/img-tag/insecure-protocol.no-redirect.http.html [ Crash ] -crbug.com/591099 external/wpt/referrer-policy/unset-referrer-policy/meta-referrer/cross-origin/http-http/img-tag/insecure-protocol.swap-origin-redirect.http.html [ Crash ] -crbug.com/591099 external/wpt/referrer-policy/unset-referrer-policy/meta-referrer/cross-origin/http-https/iframe-tag/upgrade-protocol.keep-origin-redirect.http.html [ Crash ] -crbug.com/591099 external/wpt/referrer-policy/unset-referrer-policy/meta-referrer/cross-origin/http-https/iframe-tag/upgrade-protocol.no-redirect.http.html [ Crash ] -crbug.com/591099 external/wpt/referrer-policy/unset-referrer-policy/meta-referrer/cross-origin/http-https/iframe-tag/upgrade-protocol.swap-origin-redirect.http.html [ Crash ] -crbug.com/591099 external/wpt/referrer-policy/unset-referrer-policy/meta-referrer/cross-origin/http-https/img-tag/upgrade-protocol.keep-origin-redirect.http.html [ Crash ] -crbug.com/591099 external/wpt/referrer-policy/unset-referrer-policy/meta-referrer/cross-origin/http-https/img-tag/upgrade-protocol.no-redirect.http.html [ Crash ] -crbug.com/591099 external/wpt/referrer-policy/unset-referrer-policy/meta-referrer/cross-origin/http-https/img-tag/upgrade-protocol.swap-origin-redirect.http.html [ Crash ] -crbug.com/591099 external/wpt/referrer-policy/unset-referrer-policy/meta-referrer/same-origin/http-http/iframe-tag/insecure-protocol.keep-origin-redirect.http.html [ Crash ] -crbug.com/591099 external/wpt/referrer-policy/unset-referrer-policy/meta-referrer/same-origin/http-http/iframe-tag/insecure-protocol.no-redirect.http.html [ Crash ] -crbug.com/591099 external/wpt/referrer-policy/unset-referrer-policy/meta-referrer/same-origin/http-http/iframe-tag/insecure-protocol.swap-origin-redirect.http.html [ Crash ] -crbug.com/591099 external/wpt/referrer-policy/unset-referrer-policy/meta-referrer/same-origin/http-http/img-tag/insecure-protocol.keep-origin-redirect.http.html [ Crash ] -crbug.com/591099 external/wpt/referrer-policy/unset-referrer-policy/meta-referrer/same-origin/http-http/img-tag/insecure-protocol.no-redirect.http.html [ Crash ] -crbug.com/591099 external/wpt/referrer-policy/unset-referrer-policy/meta-referrer/same-origin/http-http/img-tag/insecure-protocol.swap-origin-redirect.http.html [ Crash ] -crbug.com/591099 external/wpt/referrer-policy/unset-referrer-policy/meta-referrer/same-origin/http-https/iframe-tag/upgrade-protocol.keep-origin-redirect.http.html [ Crash ] -crbug.com/591099 external/wpt/referrer-policy/unset-referrer-policy/meta-referrer/same-origin/http-https/iframe-tag/upgrade-protocol.no-redirect.http.html [ Crash ] -crbug.com/591099 external/wpt/referrer-policy/unset-referrer-policy/meta-referrer/same-origin/http-https/iframe-tag/upgrade-protocol.swap-origin-redirect.http.html [ Crash ] -crbug.com/591099 external/wpt/referrer-policy/unset-referrer-policy/meta-referrer/same-origin/http-https/img-tag/upgrade-protocol.keep-origin-redirect.http.html [ Crash ] -crbug.com/591099 external/wpt/referrer-policy/unset-referrer-policy/meta-referrer/same-origin/http-https/img-tag/upgrade-protocol.no-redirect.http.html [ Crash ] -crbug.com/591099 external/wpt/referrer-policy/unset-referrer-policy/meta-referrer/same-origin/http-https/img-tag/upgrade-protocol.swap-origin-redirect.http.html [ Crash ] -crbug.com/591099 external/wpt/remote-playback/idlharness.html [ Crash ] +crbug.com/591099 external/wpt/quirks-mode/line-height-calculation.html [ Crash Failure ] +crbug.com/591099 external/wpt/quirks-mode/table-cell-width-calculation.html [ Crash Failure ] +crbug.com/591099 external/wpt/referrer-policy/css-integration/external-import-stylesheet.html [ Crash Pass ] +crbug.com/591099 external/wpt/referrer-policy/css-integration/external-stylesheet.html [ Crash Pass ] +crbug.com/591099 external/wpt/referrer-policy/css-integration/internal-import-stylesheet.html [ Crash Pass ] +crbug.com/591099 external/wpt/referrer-policy/css-integration/internal-stylesheet.html [ Crash Pass ] +crbug.com/591099 external/wpt/referrer-policy/css-integration/processing-instruction.html [ Crash Pass ] +crbug.com/591099 external/wpt/referrer-policy/generic/sandboxed-iframe-with-opaque-origin.html [ Crash Pass ] +crbug.com/591099 external/wpt/referrer-policy/generic/subresource-test/area-navigate.html [ Crash Pass ] +crbug.com/591099 external/wpt/referrer-policy/generic/subresource-test/iframe-messaging.html [ Crash Pass ] +crbug.com/591099 external/wpt/referrer-policy/generic/subresource-test/image-decoding.html [ Crash Pass ] +crbug.com/591099 external/wpt/referrer-policy/generic/subresource-test/link-navigate.html [ Crash Pass ] +crbug.com/591099 external/wpt/referrer-policy/generic/unsupported-csp-referrer-directive.html [ Crash Pass ] +crbug.com/591099 external/wpt/referrer-policy/no-referrer-when-downgrade/attr-referrer/cross-origin/http-http/iframe-tag/insecure-protocol.keep-origin-redirect.http.html [ Crash Pass ] +crbug.com/591099 external/wpt/referrer-policy/no-referrer-when-downgrade/attr-referrer/cross-origin/http-http/iframe-tag/insecure-protocol.no-redirect.http.html [ Crash Pass ] +crbug.com/591099 external/wpt/referrer-policy/no-referrer-when-downgrade/attr-referrer/cross-origin/http-http/iframe-tag/insecure-protocol.swap-origin-redirect.http.html [ Crash Pass ] +crbug.com/591099 external/wpt/referrer-policy/no-referrer-when-downgrade/attr-referrer/cross-origin/http-http/img-tag/insecure-protocol.keep-origin-redirect.http.html [ Crash Pass ] +crbug.com/591099 external/wpt/referrer-policy/no-referrer-when-downgrade/attr-referrer/cross-origin/http-http/img-tag/insecure-protocol.no-redirect.http.html [ Crash Pass ] +crbug.com/591099 external/wpt/referrer-policy/no-referrer-when-downgrade/attr-referrer/cross-origin/http-http/img-tag/insecure-protocol.swap-origin-redirect.http.html [ Crash Pass ] +crbug.com/591099 external/wpt/referrer-policy/no-referrer-when-downgrade/attr-referrer/cross-origin/http-https/iframe-tag/upgrade-protocol.keep-origin-redirect.http.html [ Crash Pass ] +crbug.com/591099 external/wpt/referrer-policy/no-referrer-when-downgrade/attr-referrer/cross-origin/http-https/iframe-tag/upgrade-protocol.no-redirect.http.html [ Crash Pass ] +crbug.com/591099 external/wpt/referrer-policy/no-referrer-when-downgrade/attr-referrer/cross-origin/http-https/iframe-tag/upgrade-protocol.swap-origin-redirect.http.html [ Crash Pass ] +crbug.com/591099 external/wpt/referrer-policy/no-referrer-when-downgrade/attr-referrer/cross-origin/http-https/img-tag/upgrade-protocol.keep-origin-redirect.http.html [ Crash Pass ] +crbug.com/591099 external/wpt/referrer-policy/no-referrer-when-downgrade/attr-referrer/cross-origin/http-https/img-tag/upgrade-protocol.no-redirect.http.html [ Crash Pass ] +crbug.com/591099 external/wpt/referrer-policy/no-referrer-when-downgrade/attr-referrer/cross-origin/http-https/img-tag/upgrade-protocol.swap-origin-redirect.http.html [ Crash Pass ] +crbug.com/591099 external/wpt/referrer-policy/no-referrer-when-downgrade/attr-referrer/same-origin/http-http/iframe-tag/insecure-protocol.keep-origin-redirect.http.html [ Crash Pass ] +crbug.com/591099 external/wpt/referrer-policy/no-referrer-when-downgrade/attr-referrer/same-origin/http-http/iframe-tag/insecure-protocol.no-redirect.http.html [ Crash Pass ] +crbug.com/591099 external/wpt/referrer-policy/no-referrer-when-downgrade/attr-referrer/same-origin/http-http/iframe-tag/insecure-protocol.swap-origin-redirect.http.html [ Crash Pass ] +crbug.com/591099 external/wpt/referrer-policy/no-referrer-when-downgrade/attr-referrer/same-origin/http-http/img-tag/insecure-protocol.keep-origin-redirect.http.html [ Crash Pass ] +crbug.com/591099 external/wpt/referrer-policy/no-referrer-when-downgrade/attr-referrer/same-origin/http-http/img-tag/insecure-protocol.no-redirect.http.html [ Crash Pass ] +crbug.com/591099 external/wpt/referrer-policy/no-referrer-when-downgrade/attr-referrer/same-origin/http-http/img-tag/insecure-protocol.swap-origin-redirect.http.html [ Crash Pass ] +crbug.com/591099 external/wpt/referrer-policy/no-referrer-when-downgrade/attr-referrer/same-origin/http-https/iframe-tag/upgrade-protocol.keep-origin-redirect.http.html [ Crash Pass ] +crbug.com/591099 external/wpt/referrer-policy/no-referrer-when-downgrade/attr-referrer/same-origin/http-https/iframe-tag/upgrade-protocol.no-redirect.http.html [ Crash Pass ] +crbug.com/591099 external/wpt/referrer-policy/no-referrer-when-downgrade/attr-referrer/same-origin/http-https/iframe-tag/upgrade-protocol.swap-origin-redirect.http.html [ Crash Pass ] +crbug.com/591099 external/wpt/referrer-policy/no-referrer-when-downgrade/attr-referrer/same-origin/http-https/img-tag/upgrade-protocol.keep-origin-redirect.http.html [ Crash Pass ] +crbug.com/591099 external/wpt/referrer-policy/no-referrer-when-downgrade/attr-referrer/same-origin/http-https/img-tag/upgrade-protocol.no-redirect.http.html [ Crash Pass ] +crbug.com/591099 external/wpt/referrer-policy/no-referrer-when-downgrade/attr-referrer/same-origin/http-https/img-tag/upgrade-protocol.swap-origin-redirect.http.html [ Crash Pass ] +crbug.com/591099 external/wpt/referrer-policy/no-referrer-when-downgrade/http-rp/cross-origin/http-http/iframe-tag/insecure-protocol.keep-origin-redirect.http.html [ Crash Pass ] +crbug.com/591099 external/wpt/referrer-policy/no-referrer-when-downgrade/http-rp/cross-origin/http-http/iframe-tag/insecure-protocol.no-redirect.http.html [ Crash Pass ] +crbug.com/591099 external/wpt/referrer-policy/no-referrer-when-downgrade/http-rp/cross-origin/http-http/iframe-tag/insecure-protocol.swap-origin-redirect.http.html [ Crash Pass ] +crbug.com/591099 external/wpt/referrer-policy/no-referrer-when-downgrade/http-rp/cross-origin/http-http/img-tag/insecure-protocol.keep-origin-redirect.http.html [ Crash Pass ] +crbug.com/591099 external/wpt/referrer-policy/no-referrer-when-downgrade/http-rp/cross-origin/http-http/img-tag/insecure-protocol.no-redirect.http.html [ Crash Pass ] +crbug.com/591099 external/wpt/referrer-policy/no-referrer-when-downgrade/http-rp/cross-origin/http-http/img-tag/insecure-protocol.swap-origin-redirect.http.html [ Crash Pass ] +crbug.com/591099 external/wpt/referrer-policy/no-referrer-when-downgrade/http-rp/cross-origin/http-https/iframe-tag/upgrade-protocol.keep-origin-redirect.http.html [ Crash Pass ] +crbug.com/591099 external/wpt/referrer-policy/no-referrer-when-downgrade/http-rp/cross-origin/http-https/iframe-tag/upgrade-protocol.no-redirect.http.html [ Crash Pass ] +crbug.com/591099 external/wpt/referrer-policy/no-referrer-when-downgrade/http-rp/cross-origin/http-https/iframe-tag/upgrade-protocol.swap-origin-redirect.http.html [ Crash Pass ] +crbug.com/591099 external/wpt/referrer-policy/no-referrer-when-downgrade/http-rp/cross-origin/http-https/img-tag/upgrade-protocol.keep-origin-redirect.http.html [ Crash Pass ] +crbug.com/591099 external/wpt/referrer-policy/no-referrer-when-downgrade/http-rp/cross-origin/http-https/img-tag/upgrade-protocol.no-redirect.http.html [ Crash Pass ] +crbug.com/591099 external/wpt/referrer-policy/no-referrer-when-downgrade/http-rp/cross-origin/http-https/img-tag/upgrade-protocol.swap-origin-redirect.http.html [ Crash Pass ] +crbug.com/591099 external/wpt/referrer-policy/no-referrer-when-downgrade/http-rp/same-origin/http-http/iframe-tag/insecure-protocol.keep-origin-redirect.http.html [ Crash Pass ] +crbug.com/591099 external/wpt/referrer-policy/no-referrer-when-downgrade/http-rp/same-origin/http-http/iframe-tag/insecure-protocol.no-redirect.http.html [ Crash Pass ] +crbug.com/591099 external/wpt/referrer-policy/no-referrer-when-downgrade/http-rp/same-origin/http-http/iframe-tag/insecure-protocol.swap-origin-redirect.http.html [ Crash Pass ] +crbug.com/591099 external/wpt/referrer-policy/no-referrer-when-downgrade/http-rp/same-origin/http-http/img-tag/insecure-protocol.keep-origin-redirect.http.html [ Crash Pass ] +crbug.com/591099 external/wpt/referrer-policy/no-referrer-when-downgrade/http-rp/same-origin/http-http/img-tag/insecure-protocol.no-redirect.http.html [ Crash Pass ] +crbug.com/591099 external/wpt/referrer-policy/no-referrer-when-downgrade/http-rp/same-origin/http-http/img-tag/insecure-protocol.swap-origin-redirect.http.html [ Crash Pass ] +crbug.com/591099 external/wpt/referrer-policy/no-referrer-when-downgrade/http-rp/same-origin/http-https/iframe-tag/upgrade-protocol.keep-origin-redirect.http.html [ Crash Pass ] +crbug.com/591099 external/wpt/referrer-policy/no-referrer-when-downgrade/http-rp/same-origin/http-https/iframe-tag/upgrade-protocol.no-redirect.http.html [ Crash Pass ] +crbug.com/591099 external/wpt/referrer-policy/no-referrer-when-downgrade/http-rp/same-origin/http-https/iframe-tag/upgrade-protocol.swap-origin-redirect.http.html [ Crash Pass ] +crbug.com/591099 external/wpt/referrer-policy/no-referrer-when-downgrade/http-rp/same-origin/http-https/img-tag/upgrade-protocol.keep-origin-redirect.http.html [ Crash Pass ] +crbug.com/591099 external/wpt/referrer-policy/no-referrer-when-downgrade/http-rp/same-origin/http-https/img-tag/upgrade-protocol.no-redirect.http.html [ Crash Pass ] +crbug.com/591099 external/wpt/referrer-policy/no-referrer-when-downgrade/http-rp/same-origin/http-https/img-tag/upgrade-protocol.swap-origin-redirect.http.html [ Crash Pass ] +crbug.com/591099 external/wpt/referrer-policy/no-referrer-when-downgrade/meta-referrer/cross-origin/http-http/iframe-tag/insecure-protocol.keep-origin-redirect.http.html [ Crash Pass ] +crbug.com/591099 external/wpt/referrer-policy/no-referrer-when-downgrade/meta-referrer/cross-origin/http-http/iframe-tag/insecure-protocol.no-redirect.http.html [ Crash Pass ] +crbug.com/591099 external/wpt/referrer-policy/no-referrer-when-downgrade/meta-referrer/cross-origin/http-http/iframe-tag/insecure-protocol.swap-origin-redirect.http.html [ Crash Pass ] +crbug.com/591099 external/wpt/referrer-policy/no-referrer-when-downgrade/meta-referrer/cross-origin/http-http/img-tag/insecure-protocol.keep-origin-redirect.http.html [ Crash Pass ] +crbug.com/591099 external/wpt/referrer-policy/no-referrer-when-downgrade/meta-referrer/cross-origin/http-http/img-tag/insecure-protocol.no-redirect.http.html [ Crash Pass ] +crbug.com/591099 external/wpt/referrer-policy/no-referrer-when-downgrade/meta-referrer/cross-origin/http-http/img-tag/insecure-protocol.swap-origin-redirect.http.html [ Crash Pass ] +crbug.com/591099 external/wpt/referrer-policy/no-referrer-when-downgrade/meta-referrer/cross-origin/http-https/iframe-tag/upgrade-protocol.keep-origin-redirect.http.html [ Crash Pass ] +crbug.com/591099 external/wpt/referrer-policy/no-referrer-when-downgrade/meta-referrer/cross-origin/http-https/iframe-tag/upgrade-protocol.no-redirect.http.html [ Crash Pass ] +crbug.com/591099 external/wpt/referrer-policy/no-referrer-when-downgrade/meta-referrer/cross-origin/http-https/iframe-tag/upgrade-protocol.swap-origin-redirect.http.html [ Crash Pass ] +crbug.com/591099 external/wpt/referrer-policy/no-referrer-when-downgrade/meta-referrer/cross-origin/http-https/img-tag/upgrade-protocol.keep-origin-redirect.http.html [ Crash Pass ] +crbug.com/591099 external/wpt/referrer-policy/no-referrer-when-downgrade/meta-referrer/cross-origin/http-https/img-tag/upgrade-protocol.no-redirect.http.html [ Crash Pass ] +crbug.com/591099 external/wpt/referrer-policy/no-referrer-when-downgrade/meta-referrer/cross-origin/http-https/img-tag/upgrade-protocol.swap-origin-redirect.http.html [ Crash Pass ] +crbug.com/591099 external/wpt/referrer-policy/no-referrer-when-downgrade/meta-referrer/same-origin/http-http/iframe-tag/insecure-protocol.keep-origin-redirect.http.html [ Crash Pass ] +crbug.com/591099 external/wpt/referrer-policy/no-referrer-when-downgrade/meta-referrer/same-origin/http-http/iframe-tag/insecure-protocol.no-redirect.http.html [ Crash Pass ] +crbug.com/591099 external/wpt/referrer-policy/no-referrer-when-downgrade/meta-referrer/same-origin/http-http/iframe-tag/insecure-protocol.swap-origin-redirect.http.html [ Crash Pass ] +crbug.com/591099 external/wpt/referrer-policy/no-referrer-when-downgrade/meta-referrer/same-origin/http-http/img-tag/insecure-protocol.keep-origin-redirect.http.html [ Crash Pass ] +crbug.com/591099 external/wpt/referrer-policy/no-referrer-when-downgrade/meta-referrer/same-origin/http-http/img-tag/insecure-protocol.no-redirect.http.html [ Crash Pass ] +crbug.com/591099 external/wpt/referrer-policy/no-referrer-when-downgrade/meta-referrer/same-origin/http-http/img-tag/insecure-protocol.swap-origin-redirect.http.html [ Crash Pass ] +crbug.com/591099 external/wpt/referrer-policy/no-referrer-when-downgrade/meta-referrer/same-origin/http-https/iframe-tag/upgrade-protocol.keep-origin-redirect.http.html [ Crash Pass ] +crbug.com/591099 external/wpt/referrer-policy/no-referrer-when-downgrade/meta-referrer/same-origin/http-https/iframe-tag/upgrade-protocol.no-redirect.http.html [ Crash Pass ] +crbug.com/591099 external/wpt/referrer-policy/no-referrer-when-downgrade/meta-referrer/same-origin/http-https/iframe-tag/upgrade-protocol.swap-origin-redirect.http.html [ Crash Pass ] +crbug.com/591099 external/wpt/referrer-policy/no-referrer-when-downgrade/meta-referrer/same-origin/http-https/img-tag/upgrade-protocol.keep-origin-redirect.http.html [ Crash Pass ] +crbug.com/591099 external/wpt/referrer-policy/no-referrer-when-downgrade/meta-referrer/same-origin/http-https/img-tag/upgrade-protocol.no-redirect.http.html [ Crash Pass ] +crbug.com/591099 external/wpt/referrer-policy/no-referrer-when-downgrade/meta-referrer/same-origin/http-https/img-tag/upgrade-protocol.swap-origin-redirect.http.html [ Crash Pass ] +crbug.com/591099 external/wpt/referrer-policy/no-referrer/attr-referrer/cross-origin/http-http/iframe-tag/generic.keep-origin-redirect.http.html [ Crash Pass ] +crbug.com/591099 external/wpt/referrer-policy/no-referrer/attr-referrer/cross-origin/http-http/iframe-tag/generic.no-redirect.http.html [ Crash Pass ] +crbug.com/591099 external/wpt/referrer-policy/no-referrer/attr-referrer/cross-origin/http-http/iframe-tag/generic.swap-origin-redirect.http.html [ Crash Pass ] +crbug.com/591099 external/wpt/referrer-policy/no-referrer/attr-referrer/cross-origin/http-http/img-tag/generic.keep-origin-redirect.http.html [ Crash Pass ] +crbug.com/591099 external/wpt/referrer-policy/no-referrer/attr-referrer/cross-origin/http-http/img-tag/generic.no-redirect.http.html [ Crash Pass ] +crbug.com/591099 external/wpt/referrer-policy/no-referrer/attr-referrer/cross-origin/http-http/img-tag/generic.swap-origin-redirect.http.html [ Crash Pass ] +crbug.com/591099 external/wpt/referrer-policy/no-referrer/attr-referrer/cross-origin/http-https/iframe-tag/generic.keep-origin-redirect.http.html [ Crash Pass ] +crbug.com/591099 external/wpt/referrer-policy/no-referrer/attr-referrer/cross-origin/http-https/iframe-tag/generic.no-redirect.http.html [ Crash Pass ] +crbug.com/591099 external/wpt/referrer-policy/no-referrer/attr-referrer/cross-origin/http-https/iframe-tag/generic.swap-origin-redirect.http.html [ Crash Pass ] +crbug.com/591099 external/wpt/referrer-policy/no-referrer/attr-referrer/cross-origin/http-https/img-tag/generic.keep-origin-redirect.http.html [ Crash Pass ] +crbug.com/591099 external/wpt/referrer-policy/no-referrer/attr-referrer/cross-origin/http-https/img-tag/generic.no-redirect.http.html [ Crash Pass ] +crbug.com/591099 external/wpt/referrer-policy/no-referrer/attr-referrer/cross-origin/http-https/img-tag/generic.swap-origin-redirect.http.html [ Crash Pass ] +crbug.com/591099 external/wpt/referrer-policy/no-referrer/attr-referrer/same-origin/http-http/iframe-tag/generic.keep-origin-redirect.http.html [ Crash Pass ] +crbug.com/591099 external/wpt/referrer-policy/no-referrer/attr-referrer/same-origin/http-http/iframe-tag/generic.no-redirect.http.html [ Crash Pass ] +crbug.com/591099 external/wpt/referrer-policy/no-referrer/attr-referrer/same-origin/http-http/iframe-tag/generic.swap-origin-redirect.http.html [ Crash Pass ] +crbug.com/591099 external/wpt/referrer-policy/no-referrer/attr-referrer/same-origin/http-http/img-tag/generic.keep-origin-redirect.http.html [ Crash Pass ] +crbug.com/591099 external/wpt/referrer-policy/no-referrer/attr-referrer/same-origin/http-http/img-tag/generic.no-redirect.http.html [ Crash Pass ] +crbug.com/591099 external/wpt/referrer-policy/no-referrer/attr-referrer/same-origin/http-http/img-tag/generic.swap-origin-redirect.http.html [ Crash Pass ] +crbug.com/591099 external/wpt/referrer-policy/no-referrer/attr-referrer/same-origin/http-https/iframe-tag/generic.keep-origin-redirect.http.html [ Crash Pass ] +crbug.com/591099 external/wpt/referrer-policy/no-referrer/attr-referrer/same-origin/http-https/iframe-tag/generic.no-redirect.http.html [ Crash Pass ] +crbug.com/591099 external/wpt/referrer-policy/no-referrer/attr-referrer/same-origin/http-https/iframe-tag/generic.swap-origin-redirect.http.html [ Crash Pass ] +crbug.com/591099 external/wpt/referrer-policy/no-referrer/attr-referrer/same-origin/http-https/img-tag/generic.keep-origin-redirect.http.html [ Crash Pass ] +crbug.com/591099 external/wpt/referrer-policy/no-referrer/attr-referrer/same-origin/http-https/img-tag/generic.no-redirect.http.html [ Crash Pass ] +crbug.com/591099 external/wpt/referrer-policy/no-referrer/attr-referrer/same-origin/http-https/img-tag/generic.swap-origin-redirect.http.html [ Crash Pass ] +crbug.com/591099 external/wpt/referrer-policy/no-referrer/http-rp/cross-origin/http-http/iframe-tag/generic.keep-origin-redirect.http.html [ Crash Pass ] +crbug.com/591099 external/wpt/referrer-policy/no-referrer/http-rp/cross-origin/http-http/iframe-tag/generic.no-redirect.http.html [ Crash Pass ] +crbug.com/591099 external/wpt/referrer-policy/no-referrer/http-rp/cross-origin/http-http/iframe-tag/generic.swap-origin-redirect.http.html [ Crash Pass ] +crbug.com/591099 external/wpt/referrer-policy/no-referrer/http-rp/cross-origin/http-http/img-tag/generic.keep-origin-redirect.http.html [ Crash Pass ] +crbug.com/591099 external/wpt/referrer-policy/no-referrer/http-rp/cross-origin/http-http/img-tag/generic.no-redirect.http.html [ Crash Pass ] +crbug.com/591099 external/wpt/referrer-policy/no-referrer/http-rp/cross-origin/http-http/img-tag/generic.swap-origin-redirect.http.html [ Crash Pass ] +crbug.com/591099 external/wpt/referrer-policy/no-referrer/http-rp/cross-origin/http-https/iframe-tag/generic.keep-origin-redirect.http.html [ Crash Pass ] +crbug.com/591099 external/wpt/referrer-policy/no-referrer/http-rp/cross-origin/http-https/iframe-tag/generic.no-redirect.http.html [ Crash Pass ] +crbug.com/591099 external/wpt/referrer-policy/no-referrer/http-rp/cross-origin/http-https/iframe-tag/generic.swap-origin-redirect.http.html [ Crash Pass ] +crbug.com/591099 external/wpt/referrer-policy/no-referrer/http-rp/cross-origin/http-https/img-tag/generic.keep-origin-redirect.http.html [ Crash Pass ] +crbug.com/591099 external/wpt/referrer-policy/no-referrer/http-rp/cross-origin/http-https/img-tag/generic.no-redirect.http.html [ Crash Pass ] +crbug.com/591099 external/wpt/referrer-policy/no-referrer/http-rp/cross-origin/http-https/img-tag/generic.swap-origin-redirect.http.html [ Crash Pass ] +crbug.com/591099 external/wpt/referrer-policy/no-referrer/http-rp/same-origin/http-http/iframe-tag/generic.keep-origin-redirect.http.html [ Crash Pass ] +crbug.com/591099 external/wpt/referrer-policy/no-referrer/http-rp/same-origin/http-http/iframe-tag/generic.no-redirect.http.html [ Crash Pass ] +crbug.com/591099 external/wpt/referrer-policy/no-referrer/http-rp/same-origin/http-http/iframe-tag/generic.swap-origin-redirect.http.html [ Crash Pass ] +crbug.com/591099 external/wpt/referrer-policy/no-referrer/http-rp/same-origin/http-http/img-tag/generic.keep-origin-redirect.http.html [ Crash Pass ] +crbug.com/591099 external/wpt/referrer-policy/no-referrer/http-rp/same-origin/http-http/img-tag/generic.no-redirect.http.html [ Crash Pass ] +crbug.com/591099 external/wpt/referrer-policy/no-referrer/http-rp/same-origin/http-http/img-tag/generic.swap-origin-redirect.http.html [ Crash Pass ] +crbug.com/591099 external/wpt/referrer-policy/no-referrer/http-rp/same-origin/http-https/iframe-tag/generic.keep-origin-redirect.http.html [ Crash Pass ] +crbug.com/591099 external/wpt/referrer-policy/no-referrer/http-rp/same-origin/http-https/iframe-tag/generic.no-redirect.http.html [ Crash Pass ] +crbug.com/591099 external/wpt/referrer-policy/no-referrer/http-rp/same-origin/http-https/iframe-tag/generic.swap-origin-redirect.http.html [ Crash Pass ] +crbug.com/591099 external/wpt/referrer-policy/no-referrer/http-rp/same-origin/http-https/img-tag/generic.keep-origin-redirect.http.html [ Crash Pass ] +crbug.com/591099 external/wpt/referrer-policy/no-referrer/http-rp/same-origin/http-https/img-tag/generic.no-redirect.http.html [ Crash Pass ] +crbug.com/591099 external/wpt/referrer-policy/no-referrer/http-rp/same-origin/http-https/img-tag/generic.swap-origin-redirect.http.html [ Crash Pass ] +crbug.com/591099 external/wpt/referrer-policy/no-referrer/meta-referrer/cross-origin/http-http/iframe-tag/generic.keep-origin-redirect.http.html [ Crash Pass ] +crbug.com/591099 external/wpt/referrer-policy/no-referrer/meta-referrer/cross-origin/http-http/iframe-tag/generic.no-redirect.http.html [ Crash Pass ] +crbug.com/591099 external/wpt/referrer-policy/no-referrer/meta-referrer/cross-origin/http-http/iframe-tag/generic.swap-origin-redirect.http.html [ Crash Pass ] +crbug.com/591099 external/wpt/referrer-policy/no-referrer/meta-referrer/cross-origin/http-http/img-tag/generic.keep-origin-redirect.http.html [ Crash Pass ] +crbug.com/591099 external/wpt/referrer-policy/no-referrer/meta-referrer/cross-origin/http-http/img-tag/generic.no-redirect.http.html [ Crash Pass ] +crbug.com/591099 external/wpt/referrer-policy/no-referrer/meta-referrer/cross-origin/http-http/img-tag/generic.swap-origin-redirect.http.html [ Crash Pass ] +crbug.com/591099 external/wpt/referrer-policy/no-referrer/meta-referrer/cross-origin/http-https/iframe-tag/generic.keep-origin-redirect.http.html [ Crash Pass ] +crbug.com/591099 external/wpt/referrer-policy/no-referrer/meta-referrer/cross-origin/http-https/iframe-tag/generic.no-redirect.http.html [ Crash Pass ] +crbug.com/591099 external/wpt/referrer-policy/no-referrer/meta-referrer/cross-origin/http-https/iframe-tag/generic.swap-origin-redirect.http.html [ Crash Pass ] +crbug.com/591099 external/wpt/referrer-policy/no-referrer/meta-referrer/cross-origin/http-https/img-tag/generic.keep-origin-redirect.http.html [ Crash Pass ] +crbug.com/591099 external/wpt/referrer-policy/no-referrer/meta-referrer/cross-origin/http-https/img-tag/generic.no-redirect.http.html [ Crash Pass ] +crbug.com/591099 external/wpt/referrer-policy/no-referrer/meta-referrer/cross-origin/http-https/img-tag/generic.swap-origin-redirect.http.html [ Crash Pass ] +crbug.com/591099 external/wpt/referrer-policy/no-referrer/meta-referrer/same-origin/http-http/iframe-tag/generic.keep-origin-redirect.http.html [ Crash Pass ] +crbug.com/591099 external/wpt/referrer-policy/no-referrer/meta-referrer/same-origin/http-http/iframe-tag/generic.no-redirect.http.html [ Crash Pass ] +crbug.com/591099 external/wpt/referrer-policy/no-referrer/meta-referrer/same-origin/http-http/iframe-tag/generic.swap-origin-redirect.http.html [ Crash Pass ] +crbug.com/591099 external/wpt/referrer-policy/no-referrer/meta-referrer/same-origin/http-http/img-tag/generic.keep-origin-redirect.http.html [ Crash Pass ] +crbug.com/591099 external/wpt/referrer-policy/no-referrer/meta-referrer/same-origin/http-http/img-tag/generic.no-redirect.http.html [ Crash Pass ] +crbug.com/591099 external/wpt/referrer-policy/no-referrer/meta-referrer/same-origin/http-http/img-tag/generic.swap-origin-redirect.http.html [ Crash Pass ] +crbug.com/591099 external/wpt/referrer-policy/no-referrer/meta-referrer/same-origin/http-https/iframe-tag/generic.keep-origin-redirect.http.html [ Crash Pass ] +crbug.com/591099 external/wpt/referrer-policy/no-referrer/meta-referrer/same-origin/http-https/iframe-tag/generic.no-redirect.http.html [ Crash Pass ] +crbug.com/591099 external/wpt/referrer-policy/no-referrer/meta-referrer/same-origin/http-https/iframe-tag/generic.swap-origin-redirect.http.html [ Crash Pass ] +crbug.com/591099 external/wpt/referrer-policy/no-referrer/meta-referrer/same-origin/http-https/img-tag/generic.keep-origin-redirect.http.html [ Crash Pass ] +crbug.com/591099 external/wpt/referrer-policy/no-referrer/meta-referrer/same-origin/http-https/img-tag/generic.no-redirect.http.html [ Crash Pass ] +crbug.com/591099 external/wpt/referrer-policy/no-referrer/meta-referrer/same-origin/http-https/img-tag/generic.swap-origin-redirect.http.html [ Crash Pass ] +crbug.com/591099 external/wpt/referrer-policy/origin-when-cross-origin/attr-referrer/cross-origin/http-http/iframe-tag/cross-origin.keep-origin-redirect.http.html [ Crash Pass ] +crbug.com/591099 external/wpt/referrer-policy/origin-when-cross-origin/attr-referrer/cross-origin/http-http/iframe-tag/cross-origin.no-redirect.http.html [ Crash Pass ] +crbug.com/591099 external/wpt/referrer-policy/origin-when-cross-origin/attr-referrer/cross-origin/http-http/iframe-tag/cross-origin.swap-origin-redirect.http.html [ Crash Pass ] +crbug.com/591099 external/wpt/referrer-policy/origin-when-cross-origin/attr-referrer/cross-origin/http-http/img-tag/cross-origin.keep-origin-redirect.http.html [ Crash Pass ] +crbug.com/591099 external/wpt/referrer-policy/origin-when-cross-origin/attr-referrer/cross-origin/http-http/img-tag/cross-origin.no-redirect.http.html [ Crash Pass ] +crbug.com/591099 external/wpt/referrer-policy/origin-when-cross-origin/attr-referrer/cross-origin/http-http/img-tag/cross-origin.swap-origin-redirect.http.html [ Crash Pass ] +crbug.com/591099 external/wpt/referrer-policy/origin-when-cross-origin/attr-referrer/cross-origin/http-https/iframe-tag/cross-origin.keep-origin-redirect.http.html [ Crash Pass ] +crbug.com/591099 external/wpt/referrer-policy/origin-when-cross-origin/attr-referrer/cross-origin/http-https/iframe-tag/cross-origin.no-redirect.http.html [ Crash Pass ] +crbug.com/591099 external/wpt/referrer-policy/origin-when-cross-origin/attr-referrer/cross-origin/http-https/iframe-tag/cross-origin.swap-origin-redirect.http.html [ Crash Pass ] +crbug.com/591099 external/wpt/referrer-policy/origin-when-cross-origin/attr-referrer/cross-origin/http-https/img-tag/cross-origin.keep-origin-redirect.http.html [ Crash Pass ] +crbug.com/591099 external/wpt/referrer-policy/origin-when-cross-origin/attr-referrer/cross-origin/http-https/img-tag/cross-origin.no-redirect.http.html [ Crash Pass ] +crbug.com/591099 external/wpt/referrer-policy/origin-when-cross-origin/attr-referrer/cross-origin/http-https/img-tag/cross-origin.swap-origin-redirect.http.html [ Crash Pass ] +crbug.com/591099 external/wpt/referrer-policy/origin-when-cross-origin/attr-referrer/same-origin/http-http/iframe-tag/same-origin-insecure.keep-origin-redirect.http.html [ Crash Pass ] +crbug.com/591099 external/wpt/referrer-policy/origin-when-cross-origin/attr-referrer/same-origin/http-http/iframe-tag/same-origin-insecure.no-redirect.http.html [ Crash Pass ] +crbug.com/591099 external/wpt/referrer-policy/origin-when-cross-origin/attr-referrer/same-origin/http-http/iframe-tag/same-origin-insecure.swap-origin-redirect.http.html [ Crash Pass ] +crbug.com/591099 external/wpt/referrer-policy/origin-when-cross-origin/attr-referrer/same-origin/http-http/img-tag/same-origin-insecure.keep-origin-redirect.http.html [ Crash Pass ] +crbug.com/591099 external/wpt/referrer-policy/origin-when-cross-origin/attr-referrer/same-origin/http-http/img-tag/same-origin-insecure.no-redirect.http.html [ Crash Pass ] +crbug.com/591099 external/wpt/referrer-policy/origin-when-cross-origin/attr-referrer/same-origin/http-http/img-tag/same-origin-insecure.swap-origin-redirect.http.html [ Crash Pass ] +crbug.com/591099 external/wpt/referrer-policy/origin-when-cross-origin/attr-referrer/same-origin/http-https/iframe-tag/same-origin-downgrade.keep-origin-redirect.http.html [ Crash Pass ] +crbug.com/591099 external/wpt/referrer-policy/origin-when-cross-origin/attr-referrer/same-origin/http-https/iframe-tag/same-origin-downgrade.no-redirect.http.html [ Crash Pass ] +crbug.com/591099 external/wpt/referrer-policy/origin-when-cross-origin/attr-referrer/same-origin/http-https/iframe-tag/same-origin-downgrade.swap-origin-redirect.http.html [ Crash Pass ] +crbug.com/591099 external/wpt/referrer-policy/origin-when-cross-origin/attr-referrer/same-origin/http-https/iframe-tag/same-origin-insecure.swap-origin-redirect.http.html [ Crash Pass ] +crbug.com/591099 external/wpt/referrer-policy/origin-when-cross-origin/attr-referrer/same-origin/http-https/iframe-tag/same-origin-upgrade.keep-origin-redirect.http.html [ Crash Pass ] +crbug.com/591099 external/wpt/referrer-policy/origin-when-cross-origin/attr-referrer/same-origin/http-https/iframe-tag/same-origin-upgrade.no-redirect.http.html [ Crash Pass ] +crbug.com/591099 external/wpt/referrer-policy/origin-when-cross-origin/attr-referrer/same-origin/http-https/iframe-tag/same-origin-upgrade.swap-origin-redirect.http.html [ Crash Pass ] +crbug.com/591099 external/wpt/referrer-policy/origin-when-cross-origin/attr-referrer/same-origin/http-https/img-tag/same-origin-downgrade.keep-origin-redirect.http.html [ Crash Pass ] +crbug.com/591099 external/wpt/referrer-policy/origin-when-cross-origin/attr-referrer/same-origin/http-https/img-tag/same-origin-downgrade.no-redirect.http.html [ Crash Pass ] +crbug.com/591099 external/wpt/referrer-policy/origin-when-cross-origin/attr-referrer/same-origin/http-https/img-tag/same-origin-downgrade.swap-origin-redirect.http.html [ Crash Pass ] +crbug.com/591099 external/wpt/referrer-policy/origin-when-cross-origin/attr-referrer/same-origin/http-https/img-tag/same-origin-insecure.swap-origin-redirect.http.html [ Crash Pass ] +crbug.com/591099 external/wpt/referrer-policy/origin-when-cross-origin/attr-referrer/same-origin/http-https/img-tag/same-origin-upgrade.keep-origin-redirect.http.html [ Crash Pass ] +crbug.com/591099 external/wpt/referrer-policy/origin-when-cross-origin/attr-referrer/same-origin/http-https/img-tag/same-origin-upgrade.no-redirect.http.html [ Crash Pass ] +crbug.com/591099 external/wpt/referrer-policy/origin-when-cross-origin/attr-referrer/same-origin/http-https/img-tag/same-origin-upgrade.swap-origin-redirect.http.html [ Crash Pass ] +crbug.com/591099 external/wpt/referrer-policy/origin-when-cross-origin/http-rp/cross-origin/http-http/iframe-tag/cross-origin.keep-origin-redirect.http.html [ Crash Pass ] +crbug.com/591099 external/wpt/referrer-policy/origin-when-cross-origin/http-rp/cross-origin/http-http/iframe-tag/cross-origin.no-redirect.http.html [ Crash Pass ] +crbug.com/591099 external/wpt/referrer-policy/origin-when-cross-origin/http-rp/cross-origin/http-http/iframe-tag/cross-origin.swap-origin-redirect.http.html [ Crash Pass ] +crbug.com/591099 external/wpt/referrer-policy/origin-when-cross-origin/http-rp/cross-origin/http-http/img-tag/cross-origin.keep-origin-redirect.http.html [ Crash Pass ] +crbug.com/591099 external/wpt/referrer-policy/origin-when-cross-origin/http-rp/cross-origin/http-http/img-tag/cross-origin.no-redirect.http.html [ Crash Pass ] +crbug.com/591099 external/wpt/referrer-policy/origin-when-cross-origin/http-rp/cross-origin/http-http/img-tag/cross-origin.swap-origin-redirect.http.html [ Crash Pass ] +crbug.com/591099 external/wpt/referrer-policy/origin-when-cross-origin/http-rp/cross-origin/http-https/iframe-tag/cross-origin.keep-origin-redirect.http.html [ Crash Pass ] +crbug.com/591099 external/wpt/referrer-policy/origin-when-cross-origin/http-rp/cross-origin/http-https/iframe-tag/cross-origin.no-redirect.http.html [ Crash Pass ] +crbug.com/591099 external/wpt/referrer-policy/origin-when-cross-origin/http-rp/cross-origin/http-https/iframe-tag/cross-origin.swap-origin-redirect.http.html [ Crash Pass ] +crbug.com/591099 external/wpt/referrer-policy/origin-when-cross-origin/http-rp/cross-origin/http-https/img-tag/cross-origin.keep-origin-redirect.http.html [ Crash Pass ] +crbug.com/591099 external/wpt/referrer-policy/origin-when-cross-origin/http-rp/cross-origin/http-https/img-tag/cross-origin.no-redirect.http.html [ Crash Pass ] +crbug.com/591099 external/wpt/referrer-policy/origin-when-cross-origin/http-rp/cross-origin/http-https/img-tag/cross-origin.swap-origin-redirect.http.html [ Crash Pass ] +crbug.com/591099 external/wpt/referrer-policy/origin-when-cross-origin/http-rp/same-origin/http-http/iframe-tag/same-origin-insecure.keep-origin-redirect.http.html [ Crash Pass ] +crbug.com/591099 external/wpt/referrer-policy/origin-when-cross-origin/http-rp/same-origin/http-http/iframe-tag/same-origin-insecure.no-redirect.http.html [ Crash Pass ] +crbug.com/591099 external/wpt/referrer-policy/origin-when-cross-origin/http-rp/same-origin/http-http/iframe-tag/same-origin-insecure.swap-origin-redirect.http.html [ Crash Pass ] +crbug.com/591099 external/wpt/referrer-policy/origin-when-cross-origin/http-rp/same-origin/http-http/img-tag/same-origin-insecure.keep-origin-redirect.http.html [ Crash Pass ] +crbug.com/591099 external/wpt/referrer-policy/origin-when-cross-origin/http-rp/same-origin/http-http/img-tag/same-origin-insecure.no-redirect.http.html [ Crash Pass ] +crbug.com/591099 external/wpt/referrer-policy/origin-when-cross-origin/http-rp/same-origin/http-http/img-tag/same-origin-insecure.swap-origin-redirect.http.html [ Crash Pass ] +crbug.com/591099 external/wpt/referrer-policy/origin-when-cross-origin/http-rp/same-origin/http-https/iframe-tag/same-origin-downgrade.keep-origin-redirect.http.html [ Crash Pass ] +crbug.com/591099 external/wpt/referrer-policy/origin-when-cross-origin/http-rp/same-origin/http-https/iframe-tag/same-origin-downgrade.no-redirect.http.html [ Crash Pass ] +crbug.com/591099 external/wpt/referrer-policy/origin-when-cross-origin/http-rp/same-origin/http-https/iframe-tag/same-origin-downgrade.swap-origin-redirect.http.html [ Crash Pass ] +crbug.com/591099 external/wpt/referrer-policy/origin-when-cross-origin/http-rp/same-origin/http-https/iframe-tag/same-origin-insecure.swap-origin-redirect.http.html [ Crash Pass ] +crbug.com/591099 external/wpt/referrer-policy/origin-when-cross-origin/http-rp/same-origin/http-https/iframe-tag/same-origin-upgrade.keep-origin-redirect.http.html [ Crash Pass ] +crbug.com/591099 external/wpt/referrer-policy/origin-when-cross-origin/http-rp/same-origin/http-https/iframe-tag/same-origin-upgrade.no-redirect.http.html [ Crash Pass ] +crbug.com/591099 external/wpt/referrer-policy/origin-when-cross-origin/http-rp/same-origin/http-https/iframe-tag/same-origin-upgrade.swap-origin-redirect.http.html [ Crash Pass ] +crbug.com/591099 external/wpt/referrer-policy/origin-when-cross-origin/http-rp/same-origin/http-https/img-tag/same-origin-downgrade.keep-origin-redirect.http.html [ Crash Pass ] +crbug.com/591099 external/wpt/referrer-policy/origin-when-cross-origin/http-rp/same-origin/http-https/img-tag/same-origin-downgrade.no-redirect.http.html [ Crash Pass ] +crbug.com/591099 external/wpt/referrer-policy/origin-when-cross-origin/http-rp/same-origin/http-https/img-tag/same-origin-downgrade.swap-origin-redirect.http.html [ Crash Pass ] +crbug.com/591099 external/wpt/referrer-policy/origin-when-cross-origin/http-rp/same-origin/http-https/img-tag/same-origin-insecure.swap-origin-redirect.http.html [ Crash Pass ] +crbug.com/591099 external/wpt/referrer-policy/origin-when-cross-origin/http-rp/same-origin/http-https/img-tag/same-origin-upgrade.keep-origin-redirect.http.html [ Crash Pass ] +crbug.com/591099 external/wpt/referrer-policy/origin-when-cross-origin/http-rp/same-origin/http-https/img-tag/same-origin-upgrade.no-redirect.http.html [ Crash Pass ] +crbug.com/591099 external/wpt/referrer-policy/origin-when-cross-origin/http-rp/same-origin/http-https/img-tag/same-origin-upgrade.swap-origin-redirect.http.html [ Crash Pass ] +crbug.com/591099 external/wpt/referrer-policy/origin-when-cross-origin/meta-referrer/cross-origin/http-http/iframe-tag/cross-origin.keep-origin-redirect.http.html [ Crash Pass ] +crbug.com/591099 external/wpt/referrer-policy/origin-when-cross-origin/meta-referrer/cross-origin/http-http/iframe-tag/cross-origin.no-redirect.http.html [ Crash Pass ] +crbug.com/591099 external/wpt/referrer-policy/origin-when-cross-origin/meta-referrer/cross-origin/http-http/iframe-tag/cross-origin.swap-origin-redirect.http.html [ Crash Pass ] +crbug.com/591099 external/wpt/referrer-policy/origin-when-cross-origin/meta-referrer/cross-origin/http-http/img-tag/cross-origin.keep-origin-redirect.http.html [ Crash Pass ] +crbug.com/591099 external/wpt/referrer-policy/origin-when-cross-origin/meta-referrer/cross-origin/http-http/img-tag/cross-origin.no-redirect.http.html [ Crash Pass ] +crbug.com/591099 external/wpt/referrer-policy/origin-when-cross-origin/meta-referrer/cross-origin/http-http/img-tag/cross-origin.swap-origin-redirect.http.html [ Crash Pass ] +crbug.com/591099 external/wpt/referrer-policy/origin-when-cross-origin/meta-referrer/cross-origin/http-https/iframe-tag/cross-origin.keep-origin-redirect.http.html [ Crash Pass ] +crbug.com/591099 external/wpt/referrer-policy/origin-when-cross-origin/meta-referrer/cross-origin/http-https/iframe-tag/cross-origin.no-redirect.http.html [ Crash Pass ] +crbug.com/591099 external/wpt/referrer-policy/origin-when-cross-origin/meta-referrer/cross-origin/http-https/iframe-tag/cross-origin.swap-origin-redirect.http.html [ Crash Pass ] +crbug.com/591099 external/wpt/referrer-policy/origin-when-cross-origin/meta-referrer/cross-origin/http-https/img-tag/cross-origin.keep-origin-redirect.http.html [ Crash Pass ] +crbug.com/591099 external/wpt/referrer-policy/origin-when-cross-origin/meta-referrer/cross-origin/http-https/img-tag/cross-origin.no-redirect.http.html [ Crash Pass ] +crbug.com/591099 external/wpt/referrer-policy/origin-when-cross-origin/meta-referrer/cross-origin/http-https/img-tag/cross-origin.swap-origin-redirect.http.html [ Crash Pass ] +crbug.com/591099 external/wpt/referrer-policy/origin-when-cross-origin/meta-referrer/same-origin/http-http/iframe-tag/same-origin-insecure.keep-origin-redirect.http.html [ Crash Pass ] +crbug.com/591099 external/wpt/referrer-policy/origin-when-cross-origin/meta-referrer/same-origin/http-http/iframe-tag/same-origin-insecure.no-redirect.http.html [ Crash Pass ] +crbug.com/591099 external/wpt/referrer-policy/origin-when-cross-origin/meta-referrer/same-origin/http-http/iframe-tag/same-origin-insecure.swap-origin-redirect.http.html [ Crash Pass ] +crbug.com/591099 external/wpt/referrer-policy/origin-when-cross-origin/meta-referrer/same-origin/http-http/img-tag/same-origin-insecure.keep-origin-redirect.http.html [ Crash Pass ] +crbug.com/591099 external/wpt/referrer-policy/origin-when-cross-origin/meta-referrer/same-origin/http-http/img-tag/same-origin-insecure.no-redirect.http.html [ Crash Pass ] +crbug.com/591099 external/wpt/referrer-policy/origin-when-cross-origin/meta-referrer/same-origin/http-http/img-tag/same-origin-insecure.swap-origin-redirect.http.html [ Crash Pass ] +crbug.com/591099 external/wpt/referrer-policy/origin-when-cross-origin/meta-referrer/same-origin/http-https/iframe-tag/same-origin-downgrade.keep-origin-redirect.http.html [ Crash Pass ] +crbug.com/591099 external/wpt/referrer-policy/origin-when-cross-origin/meta-referrer/same-origin/http-https/iframe-tag/same-origin-downgrade.no-redirect.http.html [ Crash Pass ] +crbug.com/591099 external/wpt/referrer-policy/origin-when-cross-origin/meta-referrer/same-origin/http-https/iframe-tag/same-origin-downgrade.swap-origin-redirect.http.html [ Crash Pass ] +crbug.com/591099 external/wpt/referrer-policy/origin-when-cross-origin/meta-referrer/same-origin/http-https/iframe-tag/same-origin-insecure.swap-origin-redirect.http.html [ Crash Pass ] +crbug.com/591099 external/wpt/referrer-policy/origin-when-cross-origin/meta-referrer/same-origin/http-https/iframe-tag/same-origin-upgrade.keep-origin-redirect.http.html [ Crash Pass ] +crbug.com/591099 external/wpt/referrer-policy/origin-when-cross-origin/meta-referrer/same-origin/http-https/iframe-tag/same-origin-upgrade.no-redirect.http.html [ Crash Pass ] +crbug.com/591099 external/wpt/referrer-policy/origin-when-cross-origin/meta-referrer/same-origin/http-https/iframe-tag/same-origin-upgrade.swap-origin-redirect.http.html [ Crash Pass ] +crbug.com/591099 external/wpt/referrer-policy/origin-when-cross-origin/meta-referrer/same-origin/http-https/img-tag/same-origin-downgrade.keep-origin-redirect.http.html [ Crash Pass ] +crbug.com/591099 external/wpt/referrer-policy/origin-when-cross-origin/meta-referrer/same-origin/http-https/img-tag/same-origin-downgrade.no-redirect.http.html [ Crash Pass ] +crbug.com/591099 external/wpt/referrer-policy/origin-when-cross-origin/meta-referrer/same-origin/http-https/img-tag/same-origin-downgrade.swap-origin-redirect.http.html [ Crash Pass ] +crbug.com/591099 external/wpt/referrer-policy/origin-when-cross-origin/meta-referrer/same-origin/http-https/img-tag/same-origin-insecure.swap-origin-redirect.http.html [ Crash Pass ] +crbug.com/591099 external/wpt/referrer-policy/origin-when-cross-origin/meta-referrer/same-origin/http-https/img-tag/same-origin-upgrade.keep-origin-redirect.http.html [ Crash Pass ] +crbug.com/591099 external/wpt/referrer-policy/origin-when-cross-origin/meta-referrer/same-origin/http-https/img-tag/same-origin-upgrade.no-redirect.http.html [ Crash Pass ] +crbug.com/591099 external/wpt/referrer-policy/origin-when-cross-origin/meta-referrer/same-origin/http-https/img-tag/same-origin-upgrade.swap-origin-redirect.http.html [ Crash Pass ] +crbug.com/591099 external/wpt/referrer-policy/origin/attr-referrer/cross-origin/http-http/iframe-tag/generic.keep-origin-redirect.http.html [ Crash Pass ] +crbug.com/591099 external/wpt/referrer-policy/origin/attr-referrer/cross-origin/http-http/iframe-tag/generic.no-redirect.http.html [ Crash Pass ] +crbug.com/591099 external/wpt/referrer-policy/origin/attr-referrer/cross-origin/http-http/iframe-tag/generic.swap-origin-redirect.http.html [ Crash Pass ] +crbug.com/591099 external/wpt/referrer-policy/origin/attr-referrer/cross-origin/http-http/img-tag/generic.keep-origin-redirect.http.html [ Crash Pass ] +crbug.com/591099 external/wpt/referrer-policy/origin/attr-referrer/cross-origin/http-http/img-tag/generic.no-redirect.http.html [ Crash Pass ] +crbug.com/591099 external/wpt/referrer-policy/origin/attr-referrer/cross-origin/http-http/img-tag/generic.swap-origin-redirect.http.html [ Crash Pass ] +crbug.com/591099 external/wpt/referrer-policy/origin/attr-referrer/cross-origin/http-https/iframe-tag/generic.keep-origin-redirect.http.html [ Crash Pass ] +crbug.com/591099 external/wpt/referrer-policy/origin/attr-referrer/cross-origin/http-https/iframe-tag/generic.no-redirect.http.html [ Crash Pass ] +crbug.com/591099 external/wpt/referrer-policy/origin/attr-referrer/cross-origin/http-https/iframe-tag/generic.swap-origin-redirect.http.html [ Crash Pass ] +crbug.com/591099 external/wpt/referrer-policy/origin/attr-referrer/cross-origin/http-https/img-tag/generic.keep-origin-redirect.http.html [ Crash Pass ] +crbug.com/591099 external/wpt/referrer-policy/origin/attr-referrer/cross-origin/http-https/img-tag/generic.no-redirect.http.html [ Crash Pass ] +crbug.com/591099 external/wpt/referrer-policy/origin/attr-referrer/cross-origin/http-https/img-tag/generic.swap-origin-redirect.http.html [ Crash Pass ] +crbug.com/591099 external/wpt/referrer-policy/origin/attr-referrer/same-origin/http-http/iframe-tag/generic.keep-origin-redirect.http.html [ Crash Pass ] +crbug.com/591099 external/wpt/referrer-policy/origin/attr-referrer/same-origin/http-http/iframe-tag/generic.no-redirect.http.html [ Crash Pass ] +crbug.com/591099 external/wpt/referrer-policy/origin/attr-referrer/same-origin/http-http/iframe-tag/generic.swap-origin-redirect.http.html [ Crash Pass ] +crbug.com/591099 external/wpt/referrer-policy/origin/attr-referrer/same-origin/http-http/img-tag/generic.keep-origin-redirect.http.html [ Crash Pass ] +crbug.com/591099 external/wpt/referrer-policy/origin/attr-referrer/same-origin/http-http/img-tag/generic.no-redirect.http.html [ Crash Pass ] +crbug.com/591099 external/wpt/referrer-policy/origin/attr-referrer/same-origin/http-http/img-tag/generic.swap-origin-redirect.http.html [ Crash Pass ] +crbug.com/591099 external/wpt/referrer-policy/origin/attr-referrer/same-origin/http-https/iframe-tag/generic.keep-origin-redirect.http.html [ Crash Pass ] +crbug.com/591099 external/wpt/referrer-policy/origin/attr-referrer/same-origin/http-https/iframe-tag/generic.no-redirect.http.html [ Crash Pass ] +crbug.com/591099 external/wpt/referrer-policy/origin/attr-referrer/same-origin/http-https/iframe-tag/generic.swap-origin-redirect.http.html [ Crash Pass ] +crbug.com/591099 external/wpt/referrer-policy/origin/attr-referrer/same-origin/http-https/img-tag/generic.keep-origin-redirect.http.html [ Crash Pass ] +crbug.com/591099 external/wpt/referrer-policy/origin/attr-referrer/same-origin/http-https/img-tag/generic.no-redirect.http.html [ Crash Pass ] +crbug.com/591099 external/wpt/referrer-policy/origin/attr-referrer/same-origin/http-https/img-tag/generic.swap-origin-redirect.http.html [ Crash Pass ] +crbug.com/591099 external/wpt/referrer-policy/origin/http-rp/cross-origin/http-http/iframe-tag/generic.keep-origin-redirect.http.html [ Crash Pass ] +crbug.com/591099 external/wpt/referrer-policy/origin/http-rp/cross-origin/http-http/iframe-tag/generic.no-redirect.http.html [ Crash Pass ] +crbug.com/591099 external/wpt/referrer-policy/origin/http-rp/cross-origin/http-http/iframe-tag/generic.swap-origin-redirect.http.html [ Crash Pass ] +crbug.com/591099 external/wpt/referrer-policy/origin/http-rp/cross-origin/http-http/img-tag/generic.keep-origin-redirect.http.html [ Crash Pass ] +crbug.com/591099 external/wpt/referrer-policy/origin/http-rp/cross-origin/http-http/img-tag/generic.no-redirect.http.html [ Crash Pass ] +crbug.com/591099 external/wpt/referrer-policy/origin/http-rp/cross-origin/http-http/img-tag/generic.swap-origin-redirect.http.html [ Crash Pass ] +crbug.com/591099 external/wpt/referrer-policy/origin/http-rp/cross-origin/http-https/iframe-tag/generic.keep-origin-redirect.http.html [ Crash Pass ] +crbug.com/591099 external/wpt/referrer-policy/origin/http-rp/cross-origin/http-https/iframe-tag/generic.no-redirect.http.html [ Crash Pass ] +crbug.com/591099 external/wpt/referrer-policy/origin/http-rp/cross-origin/http-https/iframe-tag/generic.swap-origin-redirect.http.html [ Crash Pass ] +crbug.com/591099 external/wpt/referrer-policy/origin/http-rp/cross-origin/http-https/img-tag/generic.keep-origin-redirect.http.html [ Crash Pass ] +crbug.com/591099 external/wpt/referrer-policy/origin/http-rp/cross-origin/http-https/img-tag/generic.no-redirect.http.html [ Crash Pass ] +crbug.com/591099 external/wpt/referrer-policy/origin/http-rp/cross-origin/http-https/img-tag/generic.swap-origin-redirect.http.html [ Crash Pass ] +crbug.com/591099 external/wpt/referrer-policy/origin/http-rp/same-origin/http-http/iframe-tag/generic.keep-origin-redirect.http.html [ Crash Pass ] +crbug.com/591099 external/wpt/referrer-policy/origin/http-rp/same-origin/http-http/iframe-tag/generic.no-redirect.http.html [ Crash Pass ] +crbug.com/591099 external/wpt/referrer-policy/origin/http-rp/same-origin/http-http/iframe-tag/generic.swap-origin-redirect.http.html [ Crash Pass ] +crbug.com/591099 external/wpt/referrer-policy/origin/http-rp/same-origin/http-http/img-tag/generic.keep-origin-redirect.http.html [ Crash Pass ] +crbug.com/591099 external/wpt/referrer-policy/origin/http-rp/same-origin/http-http/img-tag/generic.no-redirect.http.html [ Crash Pass ] +crbug.com/591099 external/wpt/referrer-policy/origin/http-rp/same-origin/http-http/img-tag/generic.swap-origin-redirect.http.html [ Crash Pass ] +crbug.com/591099 external/wpt/referrer-policy/origin/http-rp/same-origin/http-https/iframe-tag/generic.keep-origin-redirect.http.html [ Crash Pass ] +crbug.com/591099 external/wpt/referrer-policy/origin/http-rp/same-origin/http-https/iframe-tag/generic.no-redirect.http.html [ Crash Pass ] +crbug.com/591099 external/wpt/referrer-policy/origin/http-rp/same-origin/http-https/iframe-tag/generic.swap-origin-redirect.http.html [ Crash Pass ] +crbug.com/591099 external/wpt/referrer-policy/origin/http-rp/same-origin/http-https/img-tag/generic.keep-origin-redirect.http.html [ Crash Pass ] +crbug.com/591099 external/wpt/referrer-policy/origin/http-rp/same-origin/http-https/img-tag/generic.no-redirect.http.html [ Crash Pass ] +crbug.com/591099 external/wpt/referrer-policy/origin/http-rp/same-origin/http-https/img-tag/generic.swap-origin-redirect.http.html [ Crash Pass ] +crbug.com/591099 external/wpt/referrer-policy/origin/meta-referrer/cross-origin/http-http/iframe-tag/generic.keep-origin-redirect.http.html [ Crash Pass ] +crbug.com/591099 external/wpt/referrer-policy/origin/meta-referrer/cross-origin/http-http/iframe-tag/generic.no-redirect.http.html [ Crash Pass ] +crbug.com/591099 external/wpt/referrer-policy/origin/meta-referrer/cross-origin/http-http/iframe-tag/generic.swap-origin-redirect.http.html [ Crash Pass ] +crbug.com/591099 external/wpt/referrer-policy/origin/meta-referrer/cross-origin/http-http/img-tag/generic.keep-origin-redirect.http.html [ Crash Pass ] +crbug.com/591099 external/wpt/referrer-policy/origin/meta-referrer/cross-origin/http-http/img-tag/generic.no-redirect.http.html [ Crash Pass ] +crbug.com/591099 external/wpt/referrer-policy/origin/meta-referrer/cross-origin/http-http/img-tag/generic.swap-origin-redirect.http.html [ Crash Pass ] +crbug.com/591099 external/wpt/referrer-policy/origin/meta-referrer/cross-origin/http-https/iframe-tag/generic.keep-origin-redirect.http.html [ Crash Pass ] +crbug.com/591099 external/wpt/referrer-policy/origin/meta-referrer/cross-origin/http-https/iframe-tag/generic.no-redirect.http.html [ Crash Pass ] +crbug.com/591099 external/wpt/referrer-policy/origin/meta-referrer/cross-origin/http-https/iframe-tag/generic.swap-origin-redirect.http.html [ Crash Pass ] +crbug.com/591099 external/wpt/referrer-policy/origin/meta-referrer/cross-origin/http-https/img-tag/generic.keep-origin-redirect.http.html [ Crash Pass ] +crbug.com/591099 external/wpt/referrer-policy/origin/meta-referrer/cross-origin/http-https/img-tag/generic.no-redirect.http.html [ Crash Pass ] +crbug.com/591099 external/wpt/referrer-policy/origin/meta-referrer/cross-origin/http-https/img-tag/generic.swap-origin-redirect.http.html [ Crash Pass ] +crbug.com/591099 external/wpt/referrer-policy/origin/meta-referrer/same-origin/http-http/iframe-tag/generic.keep-origin-redirect.http.html [ Crash Pass ] +crbug.com/591099 external/wpt/referrer-policy/origin/meta-referrer/same-origin/http-http/iframe-tag/generic.no-redirect.http.html [ Crash Pass ] +crbug.com/591099 external/wpt/referrer-policy/origin/meta-referrer/same-origin/http-http/iframe-tag/generic.swap-origin-redirect.http.html [ Crash Pass ] +crbug.com/591099 external/wpt/referrer-policy/origin/meta-referrer/same-origin/http-http/img-tag/generic.keep-origin-redirect.http.html [ Crash Pass ] +crbug.com/591099 external/wpt/referrer-policy/origin/meta-referrer/same-origin/http-http/img-tag/generic.no-redirect.http.html [ Crash Pass ] +crbug.com/591099 external/wpt/referrer-policy/origin/meta-referrer/same-origin/http-http/img-tag/generic.swap-origin-redirect.http.html [ Crash Pass ] +crbug.com/591099 external/wpt/referrer-policy/origin/meta-referrer/same-origin/http-https/iframe-tag/generic.keep-origin-redirect.http.html [ Crash Pass ] +crbug.com/591099 external/wpt/referrer-policy/origin/meta-referrer/same-origin/http-https/iframe-tag/generic.no-redirect.http.html [ Crash Pass ] +crbug.com/591099 external/wpt/referrer-policy/origin/meta-referrer/same-origin/http-https/iframe-tag/generic.swap-origin-redirect.http.html [ Crash Pass ] +crbug.com/591099 external/wpt/referrer-policy/origin/meta-referrer/same-origin/http-https/img-tag/generic.keep-origin-redirect.http.html [ Crash Pass ] +crbug.com/591099 external/wpt/referrer-policy/origin/meta-referrer/same-origin/http-https/img-tag/generic.no-redirect.http.html [ Crash Pass ] +crbug.com/591099 external/wpt/referrer-policy/origin/meta-referrer/same-origin/http-https/img-tag/generic.swap-origin-redirect.http.html [ Crash Pass ] +crbug.com/591099 external/wpt/referrer-policy/same-origin/attr-referrer/cross-origin/http-http/iframe-tag/cross-origin.keep-origin-redirect.http.html [ Crash Pass ] +crbug.com/591099 external/wpt/referrer-policy/same-origin/attr-referrer/cross-origin/http-http/iframe-tag/cross-origin.no-redirect.http.html [ Crash Pass ] +crbug.com/591099 external/wpt/referrer-policy/same-origin/attr-referrer/cross-origin/http-http/iframe-tag/cross-origin.swap-origin-redirect.http.html [ Crash Pass ] +crbug.com/591099 external/wpt/referrer-policy/same-origin/attr-referrer/cross-origin/http-http/img-tag/cross-origin.keep-origin-redirect.http.html [ Crash Pass ] +crbug.com/591099 external/wpt/referrer-policy/same-origin/attr-referrer/cross-origin/http-http/img-tag/cross-origin.no-redirect.http.html [ Crash Pass ] +crbug.com/591099 external/wpt/referrer-policy/same-origin/attr-referrer/cross-origin/http-http/img-tag/cross-origin.swap-origin-redirect.http.html [ Crash Pass ] +crbug.com/591099 external/wpt/referrer-policy/same-origin/attr-referrer/cross-origin/http-https/iframe-tag/cross-origin.keep-origin-redirect.http.html [ Crash Pass ] +crbug.com/591099 external/wpt/referrer-policy/same-origin/attr-referrer/cross-origin/http-https/iframe-tag/cross-origin.no-redirect.http.html [ Crash Pass ] +crbug.com/591099 external/wpt/referrer-policy/same-origin/attr-referrer/cross-origin/http-https/iframe-tag/cross-origin.swap-origin-redirect.http.html [ Crash Pass ] +crbug.com/591099 external/wpt/referrer-policy/same-origin/attr-referrer/cross-origin/http-https/img-tag/cross-origin.keep-origin-redirect.http.html [ Crash Pass ] +crbug.com/591099 external/wpt/referrer-policy/same-origin/attr-referrer/cross-origin/http-https/img-tag/cross-origin.no-redirect.http.html [ Crash Pass ] +crbug.com/591099 external/wpt/referrer-policy/same-origin/attr-referrer/cross-origin/http-https/img-tag/cross-origin.swap-origin-redirect.http.html [ Crash Pass ] +crbug.com/591099 external/wpt/referrer-policy/same-origin/attr-referrer/same-origin/http-http/iframe-tag/same-origin-insecure.keep-origin-redirect.http.html [ Crash Pass ] +crbug.com/591099 external/wpt/referrer-policy/same-origin/attr-referrer/same-origin/http-http/iframe-tag/same-origin-insecure.no-redirect.http.html [ Crash Pass ] +crbug.com/591099 external/wpt/referrer-policy/same-origin/attr-referrer/same-origin/http-http/iframe-tag/same-origin-insecure.swap-origin-redirect.http.html [ Crash Pass ] +crbug.com/591099 external/wpt/referrer-policy/same-origin/attr-referrer/same-origin/http-http/img-tag/same-origin-insecure.keep-origin-redirect.http.html [ Crash Pass ] +crbug.com/591099 external/wpt/referrer-policy/same-origin/attr-referrer/same-origin/http-http/img-tag/same-origin-insecure.no-redirect.http.html [ Crash Pass ] +crbug.com/591099 external/wpt/referrer-policy/same-origin/attr-referrer/same-origin/http-http/img-tag/same-origin-insecure.swap-origin-redirect.http.html [ Crash Pass ] +crbug.com/591099 external/wpt/referrer-policy/same-origin/attr-referrer/same-origin/http-https/iframe-tag/same-origin-insecure.swap-origin-redirect.http.html [ Crash Pass ] +crbug.com/591099 external/wpt/referrer-policy/same-origin/attr-referrer/same-origin/http-https/img-tag/same-origin-insecure.swap-origin-redirect.http.html [ Crash Pass ] +crbug.com/591099 external/wpt/referrer-policy/same-origin/http-rp/cross-origin/http-http/iframe-tag/cross-origin.keep-origin-redirect.http.html [ Crash Pass ] +crbug.com/591099 external/wpt/referrer-policy/same-origin/http-rp/cross-origin/http-http/iframe-tag/cross-origin.no-redirect.http.html [ Crash Pass ] +crbug.com/591099 external/wpt/referrer-policy/same-origin/http-rp/cross-origin/http-http/iframe-tag/cross-origin.swap-origin-redirect.http.html [ Crash Pass ] +crbug.com/591099 external/wpt/referrer-policy/same-origin/http-rp/cross-origin/http-http/img-tag/cross-origin.keep-origin-redirect.http.html [ Crash Pass ] +crbug.com/591099 external/wpt/referrer-policy/same-origin/http-rp/cross-origin/http-http/img-tag/cross-origin.no-redirect.http.html [ Crash Pass ] +crbug.com/591099 external/wpt/referrer-policy/same-origin/http-rp/cross-origin/http-http/img-tag/cross-origin.swap-origin-redirect.http.html [ Crash Pass ] +crbug.com/591099 external/wpt/referrer-policy/same-origin/http-rp/cross-origin/http-https/iframe-tag/cross-origin.keep-origin-redirect.http.html [ Crash Pass ] +crbug.com/591099 external/wpt/referrer-policy/same-origin/http-rp/cross-origin/http-https/iframe-tag/cross-origin.no-redirect.http.html [ Crash Pass ] +crbug.com/591099 external/wpt/referrer-policy/same-origin/http-rp/cross-origin/http-https/iframe-tag/cross-origin.swap-origin-redirect.http.html [ Crash Pass ] +crbug.com/591099 external/wpt/referrer-policy/same-origin/http-rp/cross-origin/http-https/img-tag/cross-origin.keep-origin-redirect.http.html [ Crash Pass ] +crbug.com/591099 external/wpt/referrer-policy/same-origin/http-rp/cross-origin/http-https/img-tag/cross-origin.no-redirect.http.html [ Crash Pass ] +crbug.com/591099 external/wpt/referrer-policy/same-origin/http-rp/cross-origin/http-https/img-tag/cross-origin.swap-origin-redirect.http.html [ Crash Pass ] +crbug.com/591099 external/wpt/referrer-policy/same-origin/http-rp/same-origin/http-http/iframe-tag/same-origin-insecure.keep-origin-redirect.http.html [ Crash Pass ] +crbug.com/591099 external/wpt/referrer-policy/same-origin/http-rp/same-origin/http-http/iframe-tag/same-origin-insecure.no-redirect.http.html [ Crash Pass ] +crbug.com/591099 external/wpt/referrer-policy/same-origin/http-rp/same-origin/http-http/iframe-tag/same-origin-insecure.swap-origin-redirect.http.html [ Crash Pass ] +crbug.com/591099 external/wpt/referrer-policy/same-origin/http-rp/same-origin/http-http/img-tag/same-origin-insecure.keep-origin-redirect.http.html [ Crash Pass ] +crbug.com/591099 external/wpt/referrer-policy/same-origin/http-rp/same-origin/http-http/img-tag/same-origin-insecure.no-redirect.http.html [ Crash Pass ] +crbug.com/591099 external/wpt/referrer-policy/same-origin/http-rp/same-origin/http-http/img-tag/same-origin-insecure.swap-origin-redirect.http.html [ Crash Pass ] +crbug.com/591099 external/wpt/referrer-policy/same-origin/http-rp/same-origin/http-https/iframe-tag/same-origin-insecure.swap-origin-redirect.http.html [ Crash Pass ] +crbug.com/591099 external/wpt/referrer-policy/same-origin/http-rp/same-origin/http-https/img-tag/same-origin-insecure.swap-origin-redirect.http.html [ Crash Pass ] +crbug.com/591099 external/wpt/referrer-policy/same-origin/meta-referrer/cross-origin/http-http/iframe-tag/cross-origin.keep-origin-redirect.http.html [ Crash Pass ] +crbug.com/591099 external/wpt/referrer-policy/same-origin/meta-referrer/cross-origin/http-http/iframe-tag/cross-origin.no-redirect.http.html [ Crash Pass ] +crbug.com/591099 external/wpt/referrer-policy/same-origin/meta-referrer/cross-origin/http-http/iframe-tag/cross-origin.swap-origin-redirect.http.html [ Crash Pass ] +crbug.com/591099 external/wpt/referrer-policy/same-origin/meta-referrer/cross-origin/http-http/img-tag/cross-origin.keep-origin-redirect.http.html [ Crash Pass ] +crbug.com/591099 external/wpt/referrer-policy/same-origin/meta-referrer/cross-origin/http-http/img-tag/cross-origin.no-redirect.http.html [ Crash Pass ] +crbug.com/591099 external/wpt/referrer-policy/same-origin/meta-referrer/cross-origin/http-http/img-tag/cross-origin.swap-origin-redirect.http.html [ Crash Pass ] +crbug.com/591099 external/wpt/referrer-policy/same-origin/meta-referrer/cross-origin/http-https/iframe-tag/cross-origin.keep-origin-redirect.http.html [ Crash Pass ] +crbug.com/591099 external/wpt/referrer-policy/same-origin/meta-referrer/cross-origin/http-https/iframe-tag/cross-origin.no-redirect.http.html [ Crash Pass ] +crbug.com/591099 external/wpt/referrer-policy/same-origin/meta-referrer/cross-origin/http-https/iframe-tag/cross-origin.swap-origin-redirect.http.html [ Crash Pass ] +crbug.com/591099 external/wpt/referrer-policy/same-origin/meta-referrer/cross-origin/http-https/img-tag/cross-origin.keep-origin-redirect.http.html [ Crash Pass ] +crbug.com/591099 external/wpt/referrer-policy/same-origin/meta-referrer/cross-origin/http-https/img-tag/cross-origin.no-redirect.http.html [ Crash Pass ] +crbug.com/591099 external/wpt/referrer-policy/same-origin/meta-referrer/cross-origin/http-https/img-tag/cross-origin.swap-origin-redirect.http.html [ Crash Pass ] +crbug.com/591099 external/wpt/referrer-policy/same-origin/meta-referrer/same-origin/http-http/iframe-tag/same-origin-insecure.keep-origin-redirect.http.html [ Crash Pass ] +crbug.com/591099 external/wpt/referrer-policy/same-origin/meta-referrer/same-origin/http-http/iframe-tag/same-origin-insecure.no-redirect.http.html [ Crash Pass ] +crbug.com/591099 external/wpt/referrer-policy/same-origin/meta-referrer/same-origin/http-http/iframe-tag/same-origin-insecure.swap-origin-redirect.http.html [ Crash Pass ] +crbug.com/591099 external/wpt/referrer-policy/same-origin/meta-referrer/same-origin/http-http/img-tag/same-origin-insecure.keep-origin-redirect.http.html [ Crash Pass ] +crbug.com/591099 external/wpt/referrer-policy/same-origin/meta-referrer/same-origin/http-http/img-tag/same-origin-insecure.no-redirect.http.html [ Crash Pass ] +crbug.com/591099 external/wpt/referrer-policy/same-origin/meta-referrer/same-origin/http-http/img-tag/same-origin-insecure.swap-origin-redirect.http.html [ Crash Pass ] +crbug.com/591099 external/wpt/referrer-policy/same-origin/meta-referrer/same-origin/http-https/iframe-tag/same-origin-insecure.swap-origin-redirect.http.html [ Crash Pass ] +crbug.com/591099 external/wpt/referrer-policy/same-origin/meta-referrer/same-origin/http-https/img-tag/same-origin-insecure.swap-origin-redirect.http.html [ Crash Pass ] +crbug.com/591099 external/wpt/referrer-policy/strict-origin-when-cross-origin/attr-referrer/cross-origin/http-http/iframe-tag/cross-insecure.keep-origin-redirect.http.html [ Crash Pass ] +crbug.com/591099 external/wpt/referrer-policy/strict-origin-when-cross-origin/attr-referrer/cross-origin/http-http/iframe-tag/cross-insecure.no-redirect.http.html [ Crash Pass ] +crbug.com/591099 external/wpt/referrer-policy/strict-origin-when-cross-origin/attr-referrer/cross-origin/http-http/iframe-tag/cross-insecure.swap-origin-redirect.http.html [ Crash Pass ] +crbug.com/591099 external/wpt/referrer-policy/strict-origin-when-cross-origin/attr-referrer/cross-origin/http-http/img-tag/cross-insecure.keep-origin-redirect.http.html [ Crash Pass ] +crbug.com/591099 external/wpt/referrer-policy/strict-origin-when-cross-origin/attr-referrer/cross-origin/http-http/img-tag/cross-insecure.no-redirect.http.html [ Crash Pass ] +crbug.com/591099 external/wpt/referrer-policy/strict-origin-when-cross-origin/attr-referrer/cross-origin/http-http/img-tag/cross-insecure.swap-origin-redirect.http.html [ Crash Pass ] +crbug.com/591099 external/wpt/referrer-policy/strict-origin-when-cross-origin/attr-referrer/cross-origin/http-https/iframe-tag/upgrade-protocol.keep-origin-redirect.http.html [ Crash Pass ] +crbug.com/591099 external/wpt/referrer-policy/strict-origin-when-cross-origin/attr-referrer/cross-origin/http-https/iframe-tag/upgrade-protocol.no-redirect.http.html [ Crash Pass ] +crbug.com/591099 external/wpt/referrer-policy/strict-origin-when-cross-origin/attr-referrer/cross-origin/http-https/iframe-tag/upgrade-protocol.swap-origin-redirect.http.html [ Crash Pass ] +crbug.com/591099 external/wpt/referrer-policy/strict-origin-when-cross-origin/attr-referrer/cross-origin/http-https/img-tag/upgrade-protocol.keep-origin-redirect.http.html [ Crash Pass ] +crbug.com/591099 external/wpt/referrer-policy/strict-origin-when-cross-origin/attr-referrer/cross-origin/http-https/img-tag/upgrade-protocol.no-redirect.http.html [ Crash Pass ] +crbug.com/591099 external/wpt/referrer-policy/strict-origin-when-cross-origin/attr-referrer/cross-origin/http-https/img-tag/upgrade-protocol.swap-origin-redirect.http.html [ Crash Pass ] +crbug.com/591099 external/wpt/referrer-policy/strict-origin-when-cross-origin/attr-referrer/same-origin/http-http/iframe-tag/same-insecure.keep-origin-redirect.http.html [ Crash Pass ] +crbug.com/591099 external/wpt/referrer-policy/strict-origin-when-cross-origin/attr-referrer/same-origin/http-http/iframe-tag/same-insecure.no-redirect.http.html [ Crash Pass ] +crbug.com/591099 external/wpt/referrer-policy/strict-origin-when-cross-origin/attr-referrer/same-origin/http-http/iframe-tag/same-insecure.swap-origin-redirect.http.html [ Crash Pass ] +crbug.com/591099 external/wpt/referrer-policy/strict-origin-when-cross-origin/attr-referrer/same-origin/http-http/img-tag/same-insecure.keep-origin-redirect.http.html [ Crash Pass ] +crbug.com/591099 external/wpt/referrer-policy/strict-origin-when-cross-origin/attr-referrer/same-origin/http-http/img-tag/same-insecure.no-redirect.http.html [ Crash Pass ] +crbug.com/591099 external/wpt/referrer-policy/strict-origin-when-cross-origin/attr-referrer/same-origin/http-http/img-tag/same-insecure.swap-origin-redirect.http.html [ Crash Pass ] +crbug.com/591099 external/wpt/referrer-policy/strict-origin-when-cross-origin/attr-referrer/same-origin/http-https/iframe-tag/upgrade-protocol.keep-origin-redirect.http.html [ Crash Pass ] +crbug.com/591099 external/wpt/referrer-policy/strict-origin-when-cross-origin/attr-referrer/same-origin/http-https/iframe-tag/upgrade-protocol.no-redirect.http.html [ Crash Pass ] +crbug.com/591099 external/wpt/referrer-policy/strict-origin-when-cross-origin/attr-referrer/same-origin/http-https/iframe-tag/upgrade-protocol.swap-origin-redirect.http.html [ Crash Pass ] +crbug.com/591099 external/wpt/referrer-policy/strict-origin-when-cross-origin/attr-referrer/same-origin/http-https/img-tag/upgrade-protocol.keep-origin-redirect.http.html [ Crash Pass ] +crbug.com/591099 external/wpt/referrer-policy/strict-origin-when-cross-origin/attr-referrer/same-origin/http-https/img-tag/upgrade-protocol.no-redirect.http.html [ Crash Pass ] +crbug.com/591099 external/wpt/referrer-policy/strict-origin-when-cross-origin/attr-referrer/same-origin/http-https/img-tag/upgrade-protocol.swap-origin-redirect.http.html [ Crash Pass ] +crbug.com/591099 external/wpt/referrer-policy/strict-origin-when-cross-origin/http-rp/cross-origin/http-http/iframe-tag/cross-insecure.keep-origin-redirect.http.html [ Crash Pass ] +crbug.com/591099 external/wpt/referrer-policy/strict-origin-when-cross-origin/http-rp/cross-origin/http-http/iframe-tag/cross-insecure.no-redirect.http.html [ Crash Pass ] +crbug.com/591099 external/wpt/referrer-policy/strict-origin-when-cross-origin/http-rp/cross-origin/http-http/iframe-tag/cross-insecure.swap-origin-redirect.http.html [ Crash Pass ] +crbug.com/591099 external/wpt/referrer-policy/strict-origin-when-cross-origin/http-rp/cross-origin/http-http/img-tag/cross-insecure.keep-origin-redirect.http.html [ Crash Pass ] +crbug.com/591099 external/wpt/referrer-policy/strict-origin-when-cross-origin/http-rp/cross-origin/http-http/img-tag/cross-insecure.no-redirect.http.html [ Crash Pass ] +crbug.com/591099 external/wpt/referrer-policy/strict-origin-when-cross-origin/http-rp/cross-origin/http-http/img-tag/cross-insecure.swap-origin-redirect.http.html [ Crash Pass ] +crbug.com/591099 external/wpt/referrer-policy/strict-origin-when-cross-origin/http-rp/cross-origin/http-https/iframe-tag/upgrade-protocol.keep-origin-redirect.http.html [ Crash Pass ] +crbug.com/591099 external/wpt/referrer-policy/strict-origin-when-cross-origin/http-rp/cross-origin/http-https/iframe-tag/upgrade-protocol.no-redirect.http.html [ Crash Pass ] +crbug.com/591099 external/wpt/referrer-policy/strict-origin-when-cross-origin/http-rp/cross-origin/http-https/iframe-tag/upgrade-protocol.swap-origin-redirect.http.html [ Crash Pass ] +crbug.com/591099 external/wpt/referrer-policy/strict-origin-when-cross-origin/http-rp/cross-origin/http-https/img-tag/upgrade-protocol.keep-origin-redirect.http.html [ Crash Pass ] +crbug.com/591099 external/wpt/referrer-policy/strict-origin-when-cross-origin/http-rp/cross-origin/http-https/img-tag/upgrade-protocol.no-redirect.http.html [ Crash Pass ] +crbug.com/591099 external/wpt/referrer-policy/strict-origin-when-cross-origin/http-rp/cross-origin/http-https/img-tag/upgrade-protocol.swap-origin-redirect.http.html [ Crash Pass ] +crbug.com/591099 external/wpt/referrer-policy/strict-origin-when-cross-origin/http-rp/same-origin/http-http/iframe-tag/same-insecure.keep-origin-redirect.http.html [ Crash Pass ] +crbug.com/591099 external/wpt/referrer-policy/strict-origin-when-cross-origin/http-rp/same-origin/http-http/iframe-tag/same-insecure.no-redirect.http.html [ Crash Pass ] +crbug.com/591099 external/wpt/referrer-policy/strict-origin-when-cross-origin/http-rp/same-origin/http-http/iframe-tag/same-insecure.swap-origin-redirect.http.html [ Crash Pass ] +crbug.com/591099 external/wpt/referrer-policy/strict-origin-when-cross-origin/http-rp/same-origin/http-http/img-tag/same-insecure.keep-origin-redirect.http.html [ Crash Pass ] +crbug.com/591099 external/wpt/referrer-policy/strict-origin-when-cross-origin/http-rp/same-origin/http-http/img-tag/same-insecure.no-redirect.http.html [ Crash Pass ] +crbug.com/591099 external/wpt/referrer-policy/strict-origin-when-cross-origin/http-rp/same-origin/http-http/img-tag/same-insecure.swap-origin-redirect.http.html [ Crash Pass ] +crbug.com/591099 external/wpt/referrer-policy/strict-origin-when-cross-origin/http-rp/same-origin/http-https/iframe-tag/upgrade-protocol.keep-origin-redirect.http.html [ Crash Pass ] +crbug.com/591099 external/wpt/referrer-policy/strict-origin-when-cross-origin/http-rp/same-origin/http-https/iframe-tag/upgrade-protocol.no-redirect.http.html [ Crash Pass ] +crbug.com/591099 external/wpt/referrer-policy/strict-origin-when-cross-origin/http-rp/same-origin/http-https/iframe-tag/upgrade-protocol.swap-origin-redirect.http.html [ Crash Pass ] +crbug.com/591099 external/wpt/referrer-policy/strict-origin-when-cross-origin/http-rp/same-origin/http-https/img-tag/upgrade-protocol.keep-origin-redirect.http.html [ Crash Pass ] +crbug.com/591099 external/wpt/referrer-policy/strict-origin-when-cross-origin/http-rp/same-origin/http-https/img-tag/upgrade-protocol.no-redirect.http.html [ Crash Pass ] +crbug.com/591099 external/wpt/referrer-policy/strict-origin-when-cross-origin/http-rp/same-origin/http-https/img-tag/upgrade-protocol.swap-origin-redirect.http.html [ Crash Pass ] +crbug.com/591099 external/wpt/referrer-policy/strict-origin-when-cross-origin/meta-referrer/cross-origin/http-http/iframe-tag/cross-insecure.keep-origin-redirect.http.html [ Crash Pass ] +crbug.com/591099 external/wpt/referrer-policy/strict-origin-when-cross-origin/meta-referrer/cross-origin/http-http/iframe-tag/cross-insecure.no-redirect.http.html [ Crash Pass ] +crbug.com/591099 external/wpt/referrer-policy/strict-origin-when-cross-origin/meta-referrer/cross-origin/http-http/iframe-tag/cross-insecure.swap-origin-redirect.http.html [ Crash Pass ] +crbug.com/591099 external/wpt/referrer-policy/strict-origin-when-cross-origin/meta-referrer/cross-origin/http-http/img-tag/cross-insecure.keep-origin-redirect.http.html [ Crash Pass ] +crbug.com/591099 external/wpt/referrer-policy/strict-origin-when-cross-origin/meta-referrer/cross-origin/http-http/img-tag/cross-insecure.no-redirect.http.html [ Crash Pass ] +crbug.com/591099 external/wpt/referrer-policy/strict-origin-when-cross-origin/meta-referrer/cross-origin/http-http/img-tag/cross-insecure.swap-origin-redirect.http.html [ Crash Pass ] +crbug.com/591099 external/wpt/referrer-policy/strict-origin-when-cross-origin/meta-referrer/cross-origin/http-https/iframe-tag/upgrade-protocol.keep-origin-redirect.http.html [ Crash Pass ] +crbug.com/591099 external/wpt/referrer-policy/strict-origin-when-cross-origin/meta-referrer/cross-origin/http-https/iframe-tag/upgrade-protocol.no-redirect.http.html [ Crash Pass ] +crbug.com/591099 external/wpt/referrer-policy/strict-origin-when-cross-origin/meta-referrer/cross-origin/http-https/iframe-tag/upgrade-protocol.swap-origin-redirect.http.html [ Crash Pass ] +crbug.com/591099 external/wpt/referrer-policy/strict-origin-when-cross-origin/meta-referrer/cross-origin/http-https/img-tag/upgrade-protocol.keep-origin-redirect.http.html [ Crash Pass ] +crbug.com/591099 external/wpt/referrer-policy/strict-origin-when-cross-origin/meta-referrer/cross-origin/http-https/img-tag/upgrade-protocol.no-redirect.http.html [ Crash Pass ] +crbug.com/591099 external/wpt/referrer-policy/strict-origin-when-cross-origin/meta-referrer/cross-origin/http-https/img-tag/upgrade-protocol.swap-origin-redirect.http.html [ Crash Pass ] +crbug.com/591099 external/wpt/referrer-policy/strict-origin-when-cross-origin/meta-referrer/same-origin/http-http/iframe-tag/same-insecure.keep-origin-redirect.http.html [ Crash Pass ] +crbug.com/591099 external/wpt/referrer-policy/strict-origin-when-cross-origin/meta-referrer/same-origin/http-http/iframe-tag/same-insecure.no-redirect.http.html [ Crash Pass ] +crbug.com/591099 external/wpt/referrer-policy/strict-origin-when-cross-origin/meta-referrer/same-origin/http-http/iframe-tag/same-insecure.swap-origin-redirect.http.html [ Crash Pass ] +crbug.com/591099 external/wpt/referrer-policy/strict-origin-when-cross-origin/meta-referrer/same-origin/http-http/img-tag/same-insecure.keep-origin-redirect.http.html [ Crash Pass ] +crbug.com/591099 external/wpt/referrer-policy/strict-origin-when-cross-origin/meta-referrer/same-origin/http-http/img-tag/same-insecure.no-redirect.http.html [ Crash Pass ] +crbug.com/591099 external/wpt/referrer-policy/strict-origin-when-cross-origin/meta-referrer/same-origin/http-http/img-tag/same-insecure.swap-origin-redirect.http.html [ Crash Pass ] +crbug.com/591099 external/wpt/referrer-policy/strict-origin-when-cross-origin/meta-referrer/same-origin/http-https/iframe-tag/upgrade-protocol.keep-origin-redirect.http.html [ Crash Pass ] +crbug.com/591099 external/wpt/referrer-policy/strict-origin-when-cross-origin/meta-referrer/same-origin/http-https/iframe-tag/upgrade-protocol.no-redirect.http.html [ Crash Pass ] +crbug.com/591099 external/wpt/referrer-policy/strict-origin-when-cross-origin/meta-referrer/same-origin/http-https/iframe-tag/upgrade-protocol.swap-origin-redirect.http.html [ Crash Pass ] +crbug.com/591099 external/wpt/referrer-policy/strict-origin-when-cross-origin/meta-referrer/same-origin/http-https/img-tag/upgrade-protocol.keep-origin-redirect.http.html [ Crash Pass ] +crbug.com/591099 external/wpt/referrer-policy/strict-origin-when-cross-origin/meta-referrer/same-origin/http-https/img-tag/upgrade-protocol.no-redirect.http.html [ Crash Pass ] +crbug.com/591099 external/wpt/referrer-policy/strict-origin-when-cross-origin/meta-referrer/same-origin/http-https/img-tag/upgrade-protocol.swap-origin-redirect.http.html [ Crash Pass ] +crbug.com/591099 external/wpt/referrer-policy/strict-origin/attr-referrer/cross-origin/http-http/iframe-tag/insecure-protocol.keep-origin-redirect.http.html [ Crash Pass ] +crbug.com/591099 external/wpt/referrer-policy/strict-origin/attr-referrer/cross-origin/http-http/iframe-tag/insecure-protocol.no-redirect.http.html [ Crash Pass ] +crbug.com/591099 external/wpt/referrer-policy/strict-origin/attr-referrer/cross-origin/http-http/iframe-tag/insecure-protocol.swap-origin-redirect.http.html [ Crash Pass ] +crbug.com/591099 external/wpt/referrer-policy/strict-origin/attr-referrer/cross-origin/http-http/img-tag/insecure-protocol.keep-origin-redirect.http.html [ Crash Pass ] +crbug.com/591099 external/wpt/referrer-policy/strict-origin/attr-referrer/cross-origin/http-http/img-tag/insecure-protocol.no-redirect.http.html [ Crash Pass ] +crbug.com/591099 external/wpt/referrer-policy/strict-origin/attr-referrer/cross-origin/http-http/img-tag/insecure-protocol.swap-origin-redirect.http.html [ Crash Pass ] +crbug.com/591099 external/wpt/referrer-policy/strict-origin/attr-referrer/cross-origin/http-https/iframe-tag/upgrade-protocol.keep-origin-redirect.http.html [ Crash Pass ] +crbug.com/591099 external/wpt/referrer-policy/strict-origin/attr-referrer/cross-origin/http-https/iframe-tag/upgrade-protocol.no-redirect.http.html [ Crash Pass ] +crbug.com/591099 external/wpt/referrer-policy/strict-origin/attr-referrer/cross-origin/http-https/iframe-tag/upgrade-protocol.swap-origin-redirect.http.html [ Crash Pass ] +crbug.com/591099 external/wpt/referrer-policy/strict-origin/attr-referrer/cross-origin/http-https/img-tag/upgrade-protocol.keep-origin-redirect.http.html [ Crash Pass ] +crbug.com/591099 external/wpt/referrer-policy/strict-origin/attr-referrer/cross-origin/http-https/img-tag/upgrade-protocol.no-redirect.http.html [ Crash Pass ] +crbug.com/591099 external/wpt/referrer-policy/strict-origin/attr-referrer/cross-origin/http-https/img-tag/upgrade-protocol.swap-origin-redirect.http.html [ Crash Pass ] +crbug.com/591099 external/wpt/referrer-policy/strict-origin/attr-referrer/same-origin/http-http/iframe-tag/insecure-protocol.keep-origin-redirect.http.html [ Crash Pass ] +crbug.com/591099 external/wpt/referrer-policy/strict-origin/attr-referrer/same-origin/http-http/iframe-tag/insecure-protocol.no-redirect.http.html [ Crash Pass ] +crbug.com/591099 external/wpt/referrer-policy/strict-origin/attr-referrer/same-origin/http-http/iframe-tag/insecure-protocol.swap-origin-redirect.http.html [ Crash Pass ] +crbug.com/591099 external/wpt/referrer-policy/strict-origin/attr-referrer/same-origin/http-http/img-tag/insecure-protocol.keep-origin-redirect.http.html [ Crash Pass ] +crbug.com/591099 external/wpt/referrer-policy/strict-origin/attr-referrer/same-origin/http-http/img-tag/insecure-protocol.no-redirect.http.html [ Crash Pass ] +crbug.com/591099 external/wpt/referrer-policy/strict-origin/attr-referrer/same-origin/http-http/img-tag/insecure-protocol.swap-origin-redirect.http.html [ Crash Pass ] +crbug.com/591099 external/wpt/referrer-policy/strict-origin/attr-referrer/same-origin/http-https/iframe-tag/upgrade-protocol.keep-origin-redirect.http.html [ Crash Pass ] +crbug.com/591099 external/wpt/referrer-policy/strict-origin/attr-referrer/same-origin/http-https/iframe-tag/upgrade-protocol.no-redirect.http.html [ Crash Pass ] +crbug.com/591099 external/wpt/referrer-policy/strict-origin/attr-referrer/same-origin/http-https/iframe-tag/upgrade-protocol.swap-origin-redirect.http.html [ Crash Pass ] +crbug.com/591099 external/wpt/referrer-policy/strict-origin/attr-referrer/same-origin/http-https/img-tag/upgrade-protocol.keep-origin-redirect.http.html [ Crash Pass ] +crbug.com/591099 external/wpt/referrer-policy/strict-origin/attr-referrer/same-origin/http-https/img-tag/upgrade-protocol.no-redirect.http.html [ Crash Pass ] +crbug.com/591099 external/wpt/referrer-policy/strict-origin/attr-referrer/same-origin/http-https/img-tag/upgrade-protocol.swap-origin-redirect.http.html [ Crash Pass ] +crbug.com/591099 external/wpt/referrer-policy/strict-origin/http-rp/cross-origin/http-http/iframe-tag/insecure-protocol.keep-origin-redirect.http.html [ Crash Pass ] +crbug.com/591099 external/wpt/referrer-policy/strict-origin/http-rp/cross-origin/http-http/iframe-tag/insecure-protocol.no-redirect.http.html [ Crash Pass ] +crbug.com/591099 external/wpt/referrer-policy/strict-origin/http-rp/cross-origin/http-http/iframe-tag/insecure-protocol.swap-origin-redirect.http.html [ Crash Pass ] +crbug.com/591099 external/wpt/referrer-policy/strict-origin/http-rp/cross-origin/http-http/img-tag/insecure-protocol.keep-origin-redirect.http.html [ Crash Pass ] +crbug.com/591099 external/wpt/referrer-policy/strict-origin/http-rp/cross-origin/http-http/img-tag/insecure-protocol.no-redirect.http.html [ Crash Pass ] +crbug.com/591099 external/wpt/referrer-policy/strict-origin/http-rp/cross-origin/http-http/img-tag/insecure-protocol.swap-origin-redirect.http.html [ Crash Pass ] +crbug.com/591099 external/wpt/referrer-policy/strict-origin/http-rp/cross-origin/http-https/iframe-tag/upgrade-protocol.keep-origin-redirect.http.html [ Crash Pass ] +crbug.com/591099 external/wpt/referrer-policy/strict-origin/http-rp/cross-origin/http-https/iframe-tag/upgrade-protocol.no-redirect.http.html [ Crash Pass ] +crbug.com/591099 external/wpt/referrer-policy/strict-origin/http-rp/cross-origin/http-https/iframe-tag/upgrade-protocol.swap-origin-redirect.http.html [ Crash Pass ] +crbug.com/591099 external/wpt/referrer-policy/strict-origin/http-rp/cross-origin/http-https/img-tag/upgrade-protocol.keep-origin-redirect.http.html [ Crash Pass ] +crbug.com/591099 external/wpt/referrer-policy/strict-origin/http-rp/cross-origin/http-https/img-tag/upgrade-protocol.no-redirect.http.html [ Crash Pass ] +crbug.com/591099 external/wpt/referrer-policy/strict-origin/http-rp/cross-origin/http-https/img-tag/upgrade-protocol.swap-origin-redirect.http.html [ Crash Pass ] +crbug.com/591099 external/wpt/referrer-policy/strict-origin/http-rp/same-origin/http-http/iframe-tag/insecure-protocol.keep-origin-redirect.http.html [ Crash Pass ] +crbug.com/591099 external/wpt/referrer-policy/strict-origin/http-rp/same-origin/http-http/iframe-tag/insecure-protocol.no-redirect.http.html [ Crash Pass ] +crbug.com/591099 external/wpt/referrer-policy/strict-origin/http-rp/same-origin/http-http/iframe-tag/insecure-protocol.swap-origin-redirect.http.html [ Crash Pass ] +crbug.com/591099 external/wpt/referrer-policy/strict-origin/http-rp/same-origin/http-http/img-tag/insecure-protocol.keep-origin-redirect.http.html [ Crash Pass ] +crbug.com/591099 external/wpt/referrer-policy/strict-origin/http-rp/same-origin/http-http/img-tag/insecure-protocol.no-redirect.http.html [ Crash Pass ] +crbug.com/591099 external/wpt/referrer-policy/strict-origin/http-rp/same-origin/http-http/img-tag/insecure-protocol.swap-origin-redirect.http.html [ Crash Pass ] +crbug.com/591099 external/wpt/referrer-policy/strict-origin/http-rp/same-origin/http-https/iframe-tag/upgrade-protocol.keep-origin-redirect.http.html [ Crash Pass ] +crbug.com/591099 external/wpt/referrer-policy/strict-origin/http-rp/same-origin/http-https/iframe-tag/upgrade-protocol.no-redirect.http.html [ Crash Pass ] +crbug.com/591099 external/wpt/referrer-policy/strict-origin/http-rp/same-origin/http-https/iframe-tag/upgrade-protocol.swap-origin-redirect.http.html [ Crash Pass ] +crbug.com/591099 external/wpt/referrer-policy/strict-origin/http-rp/same-origin/http-https/img-tag/upgrade-protocol.keep-origin-redirect.http.html [ Crash Pass ] +crbug.com/591099 external/wpt/referrer-policy/strict-origin/http-rp/same-origin/http-https/img-tag/upgrade-protocol.no-redirect.http.html [ Crash Pass ] +crbug.com/591099 external/wpt/referrer-policy/strict-origin/http-rp/same-origin/http-https/img-tag/upgrade-protocol.swap-origin-redirect.http.html [ Crash Pass ] +crbug.com/591099 external/wpt/referrer-policy/strict-origin/meta-referrer/cross-origin/http-http/iframe-tag/insecure-protocol.keep-origin-redirect.http.html [ Crash Pass ] +crbug.com/591099 external/wpt/referrer-policy/strict-origin/meta-referrer/cross-origin/http-http/iframe-tag/insecure-protocol.no-redirect.http.html [ Crash Pass ] +crbug.com/591099 external/wpt/referrer-policy/strict-origin/meta-referrer/cross-origin/http-http/iframe-tag/insecure-protocol.swap-origin-redirect.http.html [ Crash Pass ] +crbug.com/591099 external/wpt/referrer-policy/strict-origin/meta-referrer/cross-origin/http-http/img-tag/insecure-protocol.keep-origin-redirect.http.html [ Crash Pass ] +crbug.com/591099 external/wpt/referrer-policy/strict-origin/meta-referrer/cross-origin/http-http/img-tag/insecure-protocol.no-redirect.http.html [ Crash Pass ] +crbug.com/591099 external/wpt/referrer-policy/strict-origin/meta-referrer/cross-origin/http-http/img-tag/insecure-protocol.swap-origin-redirect.http.html [ Crash Pass ] +crbug.com/591099 external/wpt/referrer-policy/strict-origin/meta-referrer/cross-origin/http-https/iframe-tag/upgrade-protocol.keep-origin-redirect.http.html [ Crash Pass ] +crbug.com/591099 external/wpt/referrer-policy/strict-origin/meta-referrer/cross-origin/http-https/iframe-tag/upgrade-protocol.no-redirect.http.html [ Crash Pass ] +crbug.com/591099 external/wpt/referrer-policy/strict-origin/meta-referrer/cross-origin/http-https/iframe-tag/upgrade-protocol.swap-origin-redirect.http.html [ Crash Pass ] +crbug.com/591099 external/wpt/referrer-policy/strict-origin/meta-referrer/cross-origin/http-https/img-tag/upgrade-protocol.keep-origin-redirect.http.html [ Crash Pass ] +crbug.com/591099 external/wpt/referrer-policy/strict-origin/meta-referrer/cross-origin/http-https/img-tag/upgrade-protocol.no-redirect.http.html [ Crash Pass ] +crbug.com/591099 external/wpt/referrer-policy/strict-origin/meta-referrer/cross-origin/http-https/img-tag/upgrade-protocol.swap-origin-redirect.http.html [ Crash Pass ] +crbug.com/591099 external/wpt/referrer-policy/strict-origin/meta-referrer/same-origin/http-http/iframe-tag/insecure-protocol.keep-origin-redirect.http.html [ Crash Pass ] +crbug.com/591099 external/wpt/referrer-policy/strict-origin/meta-referrer/same-origin/http-http/iframe-tag/insecure-protocol.no-redirect.http.html [ Crash Pass ] +crbug.com/591099 external/wpt/referrer-policy/strict-origin/meta-referrer/same-origin/http-http/iframe-tag/insecure-protocol.swap-origin-redirect.http.html [ Crash Pass ] +crbug.com/591099 external/wpt/referrer-policy/strict-origin/meta-referrer/same-origin/http-http/img-tag/insecure-protocol.keep-origin-redirect.http.html [ Crash Pass ] +crbug.com/591099 external/wpt/referrer-policy/strict-origin/meta-referrer/same-origin/http-http/img-tag/insecure-protocol.no-redirect.http.html [ Crash Pass ] +crbug.com/591099 external/wpt/referrer-policy/strict-origin/meta-referrer/same-origin/http-http/img-tag/insecure-protocol.swap-origin-redirect.http.html [ Crash Pass ] +crbug.com/591099 external/wpt/referrer-policy/strict-origin/meta-referrer/same-origin/http-https/iframe-tag/upgrade-protocol.keep-origin-redirect.http.html [ Crash Pass ] +crbug.com/591099 external/wpt/referrer-policy/strict-origin/meta-referrer/same-origin/http-https/iframe-tag/upgrade-protocol.no-redirect.http.html [ Crash Pass ] +crbug.com/591099 external/wpt/referrer-policy/strict-origin/meta-referrer/same-origin/http-https/iframe-tag/upgrade-protocol.swap-origin-redirect.http.html [ Crash Pass ] +crbug.com/591099 external/wpt/referrer-policy/strict-origin/meta-referrer/same-origin/http-https/img-tag/upgrade-protocol.keep-origin-redirect.http.html [ Crash Pass ] +crbug.com/591099 external/wpt/referrer-policy/strict-origin/meta-referrer/same-origin/http-https/img-tag/upgrade-protocol.no-redirect.http.html [ Crash Pass ] +crbug.com/591099 external/wpt/referrer-policy/strict-origin/meta-referrer/same-origin/http-https/img-tag/upgrade-protocol.swap-origin-redirect.http.html [ Crash Pass ] +crbug.com/591099 external/wpt/referrer-policy/unsafe-url/attr-referrer/cross-origin/http-http/iframe-tag/generic.keep-origin-redirect.http.html [ Crash Pass ] +crbug.com/591099 external/wpt/referrer-policy/unsafe-url/attr-referrer/cross-origin/http-http/iframe-tag/generic.no-redirect.http.html [ Crash Pass ] +crbug.com/591099 external/wpt/referrer-policy/unsafe-url/attr-referrer/cross-origin/http-http/iframe-tag/generic.swap-origin-redirect.http.html [ Crash Pass ] +crbug.com/591099 external/wpt/referrer-policy/unsafe-url/attr-referrer/cross-origin/http-http/img-tag/generic.keep-origin-redirect.http.html [ Crash Pass ] +crbug.com/591099 external/wpt/referrer-policy/unsafe-url/attr-referrer/cross-origin/http-http/img-tag/generic.no-redirect.http.html [ Crash Pass ] +crbug.com/591099 external/wpt/referrer-policy/unsafe-url/attr-referrer/cross-origin/http-http/img-tag/generic.swap-origin-redirect.http.html [ Crash Pass ] +crbug.com/591099 external/wpt/referrer-policy/unsafe-url/attr-referrer/cross-origin/http-https/iframe-tag/generic.keep-origin-redirect.http.html [ Crash Pass ] +crbug.com/591099 external/wpt/referrer-policy/unsafe-url/attr-referrer/cross-origin/http-https/iframe-tag/generic.no-redirect.http.html [ Crash Pass ] +crbug.com/591099 external/wpt/referrer-policy/unsafe-url/attr-referrer/cross-origin/http-https/iframe-tag/generic.swap-origin-redirect.http.html [ Crash Pass ] +crbug.com/591099 external/wpt/referrer-policy/unsafe-url/attr-referrer/cross-origin/http-https/img-tag/generic.keep-origin-redirect.http.html [ Crash Pass ] +crbug.com/591099 external/wpt/referrer-policy/unsafe-url/attr-referrer/cross-origin/http-https/img-tag/generic.no-redirect.http.html [ Crash Pass ] +crbug.com/591099 external/wpt/referrer-policy/unsafe-url/attr-referrer/cross-origin/http-https/img-tag/generic.swap-origin-redirect.http.html [ Crash Pass ] +crbug.com/591099 external/wpt/referrer-policy/unsafe-url/attr-referrer/same-origin/http-http/iframe-tag/generic.keep-origin-redirect.http.html [ Crash Pass ] +crbug.com/591099 external/wpt/referrer-policy/unsafe-url/attr-referrer/same-origin/http-http/iframe-tag/generic.no-redirect.http.html [ Crash Pass ] +crbug.com/591099 external/wpt/referrer-policy/unsafe-url/attr-referrer/same-origin/http-http/iframe-tag/generic.swap-origin-redirect.http.html [ Crash Pass ] +crbug.com/591099 external/wpt/referrer-policy/unsafe-url/attr-referrer/same-origin/http-http/img-tag/generic.keep-origin-redirect.http.html [ Crash Pass ] +crbug.com/591099 external/wpt/referrer-policy/unsafe-url/attr-referrer/same-origin/http-http/img-tag/generic.no-redirect.http.html [ Crash Pass ] +crbug.com/591099 external/wpt/referrer-policy/unsafe-url/attr-referrer/same-origin/http-http/img-tag/generic.swap-origin-redirect.http.html [ Crash Pass ] +crbug.com/591099 external/wpt/referrer-policy/unsafe-url/attr-referrer/same-origin/http-https/iframe-tag/generic.keep-origin-redirect.http.html [ Crash Pass ] +crbug.com/591099 external/wpt/referrer-policy/unsafe-url/attr-referrer/same-origin/http-https/iframe-tag/generic.no-redirect.http.html [ Crash Pass ] +crbug.com/591099 external/wpt/referrer-policy/unsafe-url/attr-referrer/same-origin/http-https/iframe-tag/generic.swap-origin-redirect.http.html [ Crash Pass ] +crbug.com/591099 external/wpt/referrer-policy/unsafe-url/attr-referrer/same-origin/http-https/img-tag/generic.keep-origin-redirect.http.html [ Crash Pass ] +crbug.com/591099 external/wpt/referrer-policy/unsafe-url/attr-referrer/same-origin/http-https/img-tag/generic.no-redirect.http.html [ Crash Pass ] +crbug.com/591099 external/wpt/referrer-policy/unsafe-url/attr-referrer/same-origin/http-https/img-tag/generic.swap-origin-redirect.http.html [ Crash Pass ] +crbug.com/591099 external/wpt/referrer-policy/unsafe-url/http-rp/cross-origin/http-http/iframe-tag/generic.keep-origin-redirect.http.html [ Crash Pass ] +crbug.com/591099 external/wpt/referrer-policy/unsafe-url/http-rp/cross-origin/http-http/iframe-tag/generic.no-redirect.http.html [ Crash Pass ] +crbug.com/591099 external/wpt/referrer-policy/unsafe-url/http-rp/cross-origin/http-http/iframe-tag/generic.swap-origin-redirect.http.html [ Crash Pass ] +crbug.com/591099 external/wpt/referrer-policy/unsafe-url/http-rp/cross-origin/http-http/img-tag/generic.keep-origin-redirect.http.html [ Crash Pass ] +crbug.com/591099 external/wpt/referrer-policy/unsafe-url/http-rp/cross-origin/http-http/img-tag/generic.no-redirect.http.html [ Crash Pass ] +crbug.com/591099 external/wpt/referrer-policy/unsafe-url/http-rp/cross-origin/http-http/img-tag/generic.swap-origin-redirect.http.html [ Crash Pass ] +crbug.com/591099 external/wpt/referrer-policy/unsafe-url/http-rp/cross-origin/http-https/iframe-tag/generic.keep-origin-redirect.http.html [ Crash Pass ] +crbug.com/591099 external/wpt/referrer-policy/unsafe-url/http-rp/cross-origin/http-https/iframe-tag/generic.no-redirect.http.html [ Crash Pass ] +crbug.com/591099 external/wpt/referrer-policy/unsafe-url/http-rp/cross-origin/http-https/iframe-tag/generic.swap-origin-redirect.http.html [ Crash Pass ] +crbug.com/591099 external/wpt/referrer-policy/unsafe-url/http-rp/cross-origin/http-https/img-tag/generic.keep-origin-redirect.http.html [ Crash Pass ] +crbug.com/591099 external/wpt/referrer-policy/unsafe-url/http-rp/cross-origin/http-https/img-tag/generic.no-redirect.http.html [ Crash Pass ] +crbug.com/591099 external/wpt/referrer-policy/unsafe-url/http-rp/cross-origin/http-https/img-tag/generic.swap-origin-redirect.http.html [ Crash Pass ] +crbug.com/591099 external/wpt/referrer-policy/unsafe-url/http-rp/same-origin/http-http/iframe-tag/generic.keep-origin-redirect.http.html [ Crash Pass ] +crbug.com/591099 external/wpt/referrer-policy/unsafe-url/http-rp/same-origin/http-http/iframe-tag/generic.no-redirect.http.html [ Crash Pass ] +crbug.com/591099 external/wpt/referrer-policy/unsafe-url/http-rp/same-origin/http-http/iframe-tag/generic.swap-origin-redirect.http.html [ Crash Pass ] +crbug.com/591099 external/wpt/referrer-policy/unsafe-url/http-rp/same-origin/http-http/img-tag/generic.keep-origin-redirect.http.html [ Crash Pass ] +crbug.com/591099 external/wpt/referrer-policy/unsafe-url/http-rp/same-origin/http-http/img-tag/generic.no-redirect.http.html [ Crash Pass ] +crbug.com/591099 external/wpt/referrer-policy/unsafe-url/http-rp/same-origin/http-http/img-tag/generic.swap-origin-redirect.http.html [ Crash Pass ] +crbug.com/591099 external/wpt/referrer-policy/unsafe-url/http-rp/same-origin/http-https/iframe-tag/generic.keep-origin-redirect.http.html [ Crash Pass ] +crbug.com/591099 external/wpt/referrer-policy/unsafe-url/http-rp/same-origin/http-https/iframe-tag/generic.no-redirect.http.html [ Crash Pass ] +crbug.com/591099 external/wpt/referrer-policy/unsafe-url/http-rp/same-origin/http-https/iframe-tag/generic.swap-origin-redirect.http.html [ Crash Pass ] +crbug.com/591099 external/wpt/referrer-policy/unsafe-url/http-rp/same-origin/http-https/img-tag/generic.keep-origin-redirect.http.html [ Crash Pass ] +crbug.com/591099 external/wpt/referrer-policy/unsafe-url/http-rp/same-origin/http-https/img-tag/generic.no-redirect.http.html [ Crash Pass ] +crbug.com/591099 external/wpt/referrer-policy/unsafe-url/http-rp/same-origin/http-https/img-tag/generic.swap-origin-redirect.http.html [ Crash Pass ] +crbug.com/591099 external/wpt/referrer-policy/unsafe-url/meta-referrer/cross-origin/http-http/iframe-tag/generic.keep-origin-redirect.http.html [ Crash Pass ] +crbug.com/591099 external/wpt/referrer-policy/unsafe-url/meta-referrer/cross-origin/http-http/iframe-tag/generic.no-redirect.http.html [ Crash Pass ] +crbug.com/591099 external/wpt/referrer-policy/unsafe-url/meta-referrer/cross-origin/http-http/iframe-tag/generic.swap-origin-redirect.http.html [ Crash Pass ] +crbug.com/591099 external/wpt/referrer-policy/unsafe-url/meta-referrer/cross-origin/http-http/img-tag/generic.keep-origin-redirect.http.html [ Crash Pass ] +crbug.com/591099 external/wpt/referrer-policy/unsafe-url/meta-referrer/cross-origin/http-http/img-tag/generic.no-redirect.http.html [ Crash Pass ] +crbug.com/591099 external/wpt/referrer-policy/unsafe-url/meta-referrer/cross-origin/http-http/img-tag/generic.swap-origin-redirect.http.html [ Crash Pass ] +crbug.com/591099 external/wpt/referrer-policy/unsafe-url/meta-referrer/cross-origin/http-https/iframe-tag/generic.keep-origin-redirect.http.html [ Crash Pass ] +crbug.com/591099 external/wpt/referrer-policy/unsafe-url/meta-referrer/cross-origin/http-https/iframe-tag/generic.no-redirect.http.html [ Crash Pass ] +crbug.com/591099 external/wpt/referrer-policy/unsafe-url/meta-referrer/cross-origin/http-https/iframe-tag/generic.swap-origin-redirect.http.html [ Crash Pass ] +crbug.com/591099 external/wpt/referrer-policy/unsafe-url/meta-referrer/cross-origin/http-https/img-tag/generic.keep-origin-redirect.http.html [ Crash Pass ] +crbug.com/591099 external/wpt/referrer-policy/unsafe-url/meta-referrer/cross-origin/http-https/img-tag/generic.no-redirect.http.html [ Crash Pass ] +crbug.com/591099 external/wpt/referrer-policy/unsafe-url/meta-referrer/cross-origin/http-https/img-tag/generic.swap-origin-redirect.http.html [ Crash Pass ] +crbug.com/591099 external/wpt/referrer-policy/unsafe-url/meta-referrer/same-origin/http-http/iframe-tag/generic.keep-origin-redirect.http.html [ Crash Pass ] +crbug.com/591099 external/wpt/referrer-policy/unsafe-url/meta-referrer/same-origin/http-http/iframe-tag/generic.no-redirect.http.html [ Crash Pass ] +crbug.com/591099 external/wpt/referrer-policy/unsafe-url/meta-referrer/same-origin/http-http/iframe-tag/generic.swap-origin-redirect.http.html [ Crash Pass ] +crbug.com/591099 external/wpt/referrer-policy/unsafe-url/meta-referrer/same-origin/http-http/img-tag/generic.keep-origin-redirect.http.html [ Crash Pass ] +crbug.com/591099 external/wpt/referrer-policy/unsafe-url/meta-referrer/same-origin/http-http/img-tag/generic.no-redirect.http.html [ Crash Pass ] +crbug.com/591099 external/wpt/referrer-policy/unsafe-url/meta-referrer/same-origin/http-http/img-tag/generic.swap-origin-redirect.http.html [ Crash Pass ] +crbug.com/591099 external/wpt/referrer-policy/unsafe-url/meta-referrer/same-origin/http-https/iframe-tag/generic.keep-origin-redirect.http.html [ Crash Pass ] +crbug.com/591099 external/wpt/referrer-policy/unsafe-url/meta-referrer/same-origin/http-https/iframe-tag/generic.no-redirect.http.html [ Crash Pass ] +crbug.com/591099 external/wpt/referrer-policy/unsafe-url/meta-referrer/same-origin/http-https/iframe-tag/generic.swap-origin-redirect.http.html [ Crash Pass ] +crbug.com/591099 external/wpt/referrer-policy/unsafe-url/meta-referrer/same-origin/http-https/img-tag/generic.keep-origin-redirect.http.html [ Crash Pass ] +crbug.com/591099 external/wpt/referrer-policy/unsafe-url/meta-referrer/same-origin/http-https/img-tag/generic.no-redirect.http.html [ Crash Pass ] +crbug.com/591099 external/wpt/referrer-policy/unsafe-url/meta-referrer/same-origin/http-https/img-tag/generic.swap-origin-redirect.http.html [ Crash Pass ] +crbug.com/591099 external/wpt/referrer-policy/unset-referrer-policy/attr-referrer/cross-origin/http-http/iframe-tag/insecure-protocol.keep-origin-redirect.http.html [ Crash Pass ] +crbug.com/591099 external/wpt/referrer-policy/unset-referrer-policy/attr-referrer/cross-origin/http-http/iframe-tag/insecure-protocol.no-redirect.http.html [ Crash Pass ] +crbug.com/591099 external/wpt/referrer-policy/unset-referrer-policy/attr-referrer/cross-origin/http-http/iframe-tag/insecure-protocol.swap-origin-redirect.http.html [ Crash Pass ] +crbug.com/591099 external/wpt/referrer-policy/unset-referrer-policy/attr-referrer/cross-origin/http-http/img-tag/insecure-protocol.keep-origin-redirect.http.html [ Crash Pass ] +crbug.com/591099 external/wpt/referrer-policy/unset-referrer-policy/attr-referrer/cross-origin/http-http/img-tag/insecure-protocol.no-redirect.http.html [ Crash Pass ] +crbug.com/591099 external/wpt/referrer-policy/unset-referrer-policy/attr-referrer/cross-origin/http-http/img-tag/insecure-protocol.swap-origin-redirect.http.html [ Crash Pass ] +crbug.com/591099 external/wpt/referrer-policy/unset-referrer-policy/attr-referrer/cross-origin/http-https/iframe-tag/upgrade-protocol.keep-origin-redirect.http.html [ Crash Pass ] +crbug.com/591099 external/wpt/referrer-policy/unset-referrer-policy/attr-referrer/cross-origin/http-https/iframe-tag/upgrade-protocol.no-redirect.http.html [ Crash Pass ] +crbug.com/591099 external/wpt/referrer-policy/unset-referrer-policy/attr-referrer/cross-origin/http-https/iframe-tag/upgrade-protocol.swap-origin-redirect.http.html [ Crash Pass ] +crbug.com/591099 external/wpt/referrer-policy/unset-referrer-policy/attr-referrer/cross-origin/http-https/img-tag/upgrade-protocol.keep-origin-redirect.http.html [ Crash Pass ] +crbug.com/591099 external/wpt/referrer-policy/unset-referrer-policy/attr-referrer/cross-origin/http-https/img-tag/upgrade-protocol.no-redirect.http.html [ Crash Pass ] +crbug.com/591099 external/wpt/referrer-policy/unset-referrer-policy/attr-referrer/cross-origin/http-https/img-tag/upgrade-protocol.swap-origin-redirect.http.html [ Crash Pass ] +crbug.com/591099 external/wpt/referrer-policy/unset-referrer-policy/attr-referrer/same-origin/http-http/iframe-tag/insecure-protocol.keep-origin-redirect.http.html [ Crash Pass ] +crbug.com/591099 external/wpt/referrer-policy/unset-referrer-policy/attr-referrer/same-origin/http-http/iframe-tag/insecure-protocol.no-redirect.http.html [ Crash Pass ] +crbug.com/591099 external/wpt/referrer-policy/unset-referrer-policy/attr-referrer/same-origin/http-http/iframe-tag/insecure-protocol.swap-origin-redirect.http.html [ Crash Pass ] +crbug.com/591099 external/wpt/referrer-policy/unset-referrer-policy/attr-referrer/same-origin/http-http/img-tag/insecure-protocol.keep-origin-redirect.http.html [ Crash Pass ] +crbug.com/591099 external/wpt/referrer-policy/unset-referrer-policy/attr-referrer/same-origin/http-http/img-tag/insecure-protocol.no-redirect.http.html [ Crash Pass ] +crbug.com/591099 external/wpt/referrer-policy/unset-referrer-policy/attr-referrer/same-origin/http-http/img-tag/insecure-protocol.swap-origin-redirect.http.html [ Crash Pass ] +crbug.com/591099 external/wpt/referrer-policy/unset-referrer-policy/attr-referrer/same-origin/http-https/iframe-tag/upgrade-protocol.keep-origin-redirect.http.html [ Crash Pass ] +crbug.com/591099 external/wpt/referrer-policy/unset-referrer-policy/attr-referrer/same-origin/http-https/iframe-tag/upgrade-protocol.no-redirect.http.html [ Crash Pass ] +crbug.com/591099 external/wpt/referrer-policy/unset-referrer-policy/attr-referrer/same-origin/http-https/iframe-tag/upgrade-protocol.swap-origin-redirect.http.html [ Crash Pass ] +crbug.com/591099 external/wpt/referrer-policy/unset-referrer-policy/attr-referrer/same-origin/http-https/img-tag/upgrade-protocol.keep-origin-redirect.http.html [ Crash Pass ] +crbug.com/591099 external/wpt/referrer-policy/unset-referrer-policy/attr-referrer/same-origin/http-https/img-tag/upgrade-protocol.no-redirect.http.html [ Crash Pass ] +crbug.com/591099 external/wpt/referrer-policy/unset-referrer-policy/attr-referrer/same-origin/http-https/img-tag/upgrade-protocol.swap-origin-redirect.http.html [ Crash Pass ] +crbug.com/591099 external/wpt/referrer-policy/unset-referrer-policy/http-rp/cross-origin/http-http/iframe-tag/insecure-protocol.keep-origin-redirect.http.html [ Crash Pass ] +crbug.com/591099 external/wpt/referrer-policy/unset-referrer-policy/http-rp/cross-origin/http-http/iframe-tag/insecure-protocol.no-redirect.http.html [ Crash Pass ] +crbug.com/591099 external/wpt/referrer-policy/unset-referrer-policy/http-rp/cross-origin/http-http/iframe-tag/insecure-protocol.swap-origin-redirect.http.html [ Crash Pass ] +crbug.com/591099 external/wpt/referrer-policy/unset-referrer-policy/http-rp/cross-origin/http-http/img-tag/insecure-protocol.keep-origin-redirect.http.html [ Crash Pass ] +crbug.com/591099 external/wpt/referrer-policy/unset-referrer-policy/http-rp/cross-origin/http-http/img-tag/insecure-protocol.no-redirect.http.html [ Crash Pass ] +crbug.com/591099 external/wpt/referrer-policy/unset-referrer-policy/http-rp/cross-origin/http-http/img-tag/insecure-protocol.swap-origin-redirect.http.html [ Crash Pass ] +crbug.com/591099 external/wpt/referrer-policy/unset-referrer-policy/http-rp/cross-origin/http-https/iframe-tag/upgrade-protocol.keep-origin-redirect.http.html [ Crash Pass ] +crbug.com/591099 external/wpt/referrer-policy/unset-referrer-policy/http-rp/cross-origin/http-https/iframe-tag/upgrade-protocol.no-redirect.http.html [ Crash Pass ] +crbug.com/591099 external/wpt/referrer-policy/unset-referrer-policy/http-rp/cross-origin/http-https/iframe-tag/upgrade-protocol.swap-origin-redirect.http.html [ Crash Pass ] +crbug.com/591099 external/wpt/referrer-policy/unset-referrer-policy/http-rp/cross-origin/http-https/img-tag/upgrade-protocol.keep-origin-redirect.http.html [ Crash Pass ] +crbug.com/591099 external/wpt/referrer-policy/unset-referrer-policy/http-rp/cross-origin/http-https/img-tag/upgrade-protocol.no-redirect.http.html [ Crash Pass ] +crbug.com/591099 external/wpt/referrer-policy/unset-referrer-policy/http-rp/cross-origin/http-https/img-tag/upgrade-protocol.swap-origin-redirect.http.html [ Crash Pass ] +crbug.com/591099 external/wpt/referrer-policy/unset-referrer-policy/http-rp/same-origin/http-http/iframe-tag/insecure-protocol.keep-origin-redirect.http.html [ Crash Pass ] +crbug.com/591099 external/wpt/referrer-policy/unset-referrer-policy/http-rp/same-origin/http-http/iframe-tag/insecure-protocol.no-redirect.http.html [ Crash Pass ] +crbug.com/591099 external/wpt/referrer-policy/unset-referrer-policy/http-rp/same-origin/http-http/iframe-tag/insecure-protocol.swap-origin-redirect.http.html [ Crash Pass ] +crbug.com/591099 external/wpt/referrer-policy/unset-referrer-policy/http-rp/same-origin/http-http/img-tag/insecure-protocol.keep-origin-redirect.http.html [ Crash Pass ] +crbug.com/591099 external/wpt/referrer-policy/unset-referrer-policy/http-rp/same-origin/http-http/img-tag/insecure-protocol.no-redirect.http.html [ Crash Pass ] +crbug.com/591099 external/wpt/referrer-policy/unset-referrer-policy/http-rp/same-origin/http-http/img-tag/insecure-protocol.swap-origin-redirect.http.html [ Crash Pass ] +crbug.com/591099 external/wpt/referrer-policy/unset-referrer-policy/http-rp/same-origin/http-https/iframe-tag/upgrade-protocol.keep-origin-redirect.http.html [ Crash Pass ] +crbug.com/591099 external/wpt/referrer-policy/unset-referrer-policy/http-rp/same-origin/http-https/iframe-tag/upgrade-protocol.no-redirect.http.html [ Crash Pass ] +crbug.com/591099 external/wpt/referrer-policy/unset-referrer-policy/http-rp/same-origin/http-https/iframe-tag/upgrade-protocol.swap-origin-redirect.http.html [ Crash Pass ] +crbug.com/591099 external/wpt/referrer-policy/unset-referrer-policy/http-rp/same-origin/http-https/img-tag/upgrade-protocol.keep-origin-redirect.http.html [ Crash Pass ] +crbug.com/591099 external/wpt/referrer-policy/unset-referrer-policy/http-rp/same-origin/http-https/img-tag/upgrade-protocol.no-redirect.http.html [ Crash Pass ] +crbug.com/591099 external/wpt/referrer-policy/unset-referrer-policy/http-rp/same-origin/http-https/img-tag/upgrade-protocol.swap-origin-redirect.http.html [ Crash Pass ] +crbug.com/591099 external/wpt/referrer-policy/unset-referrer-policy/meta-referrer/cross-origin/http-http/iframe-tag/insecure-protocol.keep-origin-redirect.http.html [ Crash Pass ] +crbug.com/591099 external/wpt/referrer-policy/unset-referrer-policy/meta-referrer/cross-origin/http-http/iframe-tag/insecure-protocol.no-redirect.http.html [ Crash Pass ] +crbug.com/591099 external/wpt/referrer-policy/unset-referrer-policy/meta-referrer/cross-origin/http-http/iframe-tag/insecure-protocol.swap-origin-redirect.http.html [ Crash Pass ] +crbug.com/591099 external/wpt/referrer-policy/unset-referrer-policy/meta-referrer/cross-origin/http-http/img-tag/insecure-protocol.keep-origin-redirect.http.html [ Crash Pass ] +crbug.com/591099 external/wpt/referrer-policy/unset-referrer-policy/meta-referrer/cross-origin/http-http/img-tag/insecure-protocol.no-redirect.http.html [ Crash Pass ] +crbug.com/591099 external/wpt/referrer-policy/unset-referrer-policy/meta-referrer/cross-origin/http-http/img-tag/insecure-protocol.swap-origin-redirect.http.html [ Crash Pass ] +crbug.com/591099 external/wpt/referrer-policy/unset-referrer-policy/meta-referrer/cross-origin/http-https/iframe-tag/upgrade-protocol.keep-origin-redirect.http.html [ Crash Pass ] +crbug.com/591099 external/wpt/referrer-policy/unset-referrer-policy/meta-referrer/cross-origin/http-https/iframe-tag/upgrade-protocol.no-redirect.http.html [ Crash Pass ] +crbug.com/591099 external/wpt/referrer-policy/unset-referrer-policy/meta-referrer/cross-origin/http-https/iframe-tag/upgrade-protocol.swap-origin-redirect.http.html [ Crash Pass ] +crbug.com/591099 external/wpt/referrer-policy/unset-referrer-policy/meta-referrer/cross-origin/http-https/img-tag/upgrade-protocol.keep-origin-redirect.http.html [ Crash Pass ] +crbug.com/591099 external/wpt/referrer-policy/unset-referrer-policy/meta-referrer/cross-origin/http-https/img-tag/upgrade-protocol.no-redirect.http.html [ Crash Pass ] +crbug.com/591099 external/wpt/referrer-policy/unset-referrer-policy/meta-referrer/cross-origin/http-https/img-tag/upgrade-protocol.swap-origin-redirect.http.html [ Crash Pass ] +crbug.com/591099 external/wpt/referrer-policy/unset-referrer-policy/meta-referrer/same-origin/http-http/iframe-tag/insecure-protocol.keep-origin-redirect.http.html [ Crash Pass ] +crbug.com/591099 external/wpt/referrer-policy/unset-referrer-policy/meta-referrer/same-origin/http-http/iframe-tag/insecure-protocol.no-redirect.http.html [ Crash Pass ] +crbug.com/591099 external/wpt/referrer-policy/unset-referrer-policy/meta-referrer/same-origin/http-http/iframe-tag/insecure-protocol.swap-origin-redirect.http.html [ Crash Pass ] +crbug.com/591099 external/wpt/referrer-policy/unset-referrer-policy/meta-referrer/same-origin/http-http/img-tag/insecure-protocol.keep-origin-redirect.http.html [ Crash Pass ] +crbug.com/591099 external/wpt/referrer-policy/unset-referrer-policy/meta-referrer/same-origin/http-http/img-tag/insecure-protocol.no-redirect.http.html [ Crash Pass ] +crbug.com/591099 external/wpt/referrer-policy/unset-referrer-policy/meta-referrer/same-origin/http-http/img-tag/insecure-protocol.swap-origin-redirect.http.html [ Crash Pass ] +crbug.com/591099 external/wpt/referrer-policy/unset-referrer-policy/meta-referrer/same-origin/http-https/iframe-tag/upgrade-protocol.keep-origin-redirect.http.html [ Crash Pass ] +crbug.com/591099 external/wpt/referrer-policy/unset-referrer-policy/meta-referrer/same-origin/http-https/iframe-tag/upgrade-protocol.no-redirect.http.html [ Crash Pass ] +crbug.com/591099 external/wpt/referrer-policy/unset-referrer-policy/meta-referrer/same-origin/http-https/iframe-tag/upgrade-protocol.swap-origin-redirect.http.html [ Crash Pass ] +crbug.com/591099 external/wpt/referrer-policy/unset-referrer-policy/meta-referrer/same-origin/http-https/img-tag/upgrade-protocol.keep-origin-redirect.http.html [ Crash Pass ] +crbug.com/591099 external/wpt/referrer-policy/unset-referrer-policy/meta-referrer/same-origin/http-https/img-tag/upgrade-protocol.no-redirect.http.html [ Crash Pass ] +crbug.com/591099 external/wpt/referrer-policy/unset-referrer-policy/meta-referrer/same-origin/http-https/img-tag/upgrade-protocol.swap-origin-redirect.http.html [ Crash Pass ] +crbug.com/591099 external/wpt/remote-playback/idlharness.html [ Crash Pass ] crbug.com/591099 external/wpt/scroll-anchoring/anchoring-with-bounds-clamping.html [ Failure ] crbug.com/591099 external/wpt/scroll-anchoring/clipped-scrollers-skipped.html [ Failure ] crbug.com/591099 external/wpt/scroll-anchoring/descend-into-container-with-float.html [ Failure ] -crbug.com/591099 external/wpt/scroll-anchoring/inline-block.html [ Crash ] +crbug.com/591099 external/wpt/scroll-anchoring/inline-block.html [ Crash Pass ] crbug.com/591099 external/wpt/scroll-anchoring/opt-out.html [ Failure ] crbug.com/591099 external/wpt/scroll-anchoring/position-change-heuristic.html [ Failure ] -crbug.com/591099 external/wpt/scroll-anchoring/start-edge-in-block-layout-direction.html [ Crash ] +crbug.com/591099 external/wpt/scroll-anchoring/start-edge-in-block-layout-direction.html [ Crash Failure ] crbug.com/591099 external/wpt/selection/addRange-00.html [ Pass Timeout ] crbug.com/591099 external/wpt/selection/addRange-04.html [ Pass Timeout ] crbug.com/591099 external/wpt/selection/addRange-12.html [ Pass Timeout ] @@ -6452,101 +6460,101 @@ crbug.com/591099 external/wpt/selection/collapse-15.html [ Pass Timeout ] crbug.com/591099 external/wpt/selection/collapse-30.html [ Pass Timeout ] crbug.com/591099 external/wpt/selection/collapse-45.html [ Pass Timeout ] -crbug.com/591099 external/wpt/selection/deleteFromDocument.html [ Crash ] +crbug.com/591099 external/wpt/selection/deleteFromDocument.html [ Crash Pass ] crbug.com/591099 external/wpt/selection/extend-00.html [ Pass Timeout ] crbug.com/591099 external/wpt/selection/extend-20.html [ Pass Timeout ] crbug.com/591099 external/wpt/selection/selectAllChildren.html [ Pass Timeout ] -crbug.com/591099 external/wpt/selectors/attribute-selectors/attribute-case/semantics.html [ Crash ] -crbug.com/591099 external/wpt/server-timing/test_server_timing.html [ Crash ] -crbug.com/591099 external/wpt/service-workers/service-worker/ServiceWorkerGlobalScope/extendable-message-event.https.html [ Crash Timeout ] +crbug.com/591099 external/wpt/selectors/attribute-selectors/attribute-case/semantics.html [ Crash Pass ] +crbug.com/591099 external/wpt/server-timing/test_server_timing.html [ Crash Pass ] +crbug.com/591099 external/wpt/service-workers/service-worker/ServiceWorkerGlobalScope/extendable-message-event.https.html [ Crash Pass Timeout ] crbug.com/591099 external/wpt/service-workers/service-worker/ServiceWorkerGlobalScope/registration-attribute.https.html [ Failure Pass ] -crbug.com/591099 external/wpt/service-workers/service-worker/ServiceWorkerGlobalScope/unregister.https.html [ Crash ] -crbug.com/591099 external/wpt/service-workers/service-worker/ServiceWorkerGlobalScope/update.https.html [ Crash ] -crbug.com/591099 external/wpt/service-workers/service-worker/activation.https.html [ Crash ] +crbug.com/591099 external/wpt/service-workers/service-worker/ServiceWorkerGlobalScope/unregister.https.html [ Crash Pass ] +crbug.com/591099 external/wpt/service-workers/service-worker/ServiceWorkerGlobalScope/update.https.html [ Crash Pass ] +crbug.com/591099 external/wpt/service-workers/service-worker/activation.https.html [ Crash Pass ] crbug.com/591099 external/wpt/service-workers/service-worker/claim-fetch.https.html [ Crash Pass ] -crbug.com/591099 external/wpt/service-workers/service-worker/claim-not-using-registration.https.html [ Crash ] -crbug.com/591099 external/wpt/service-workers/service-worker/client-id.https.html [ Crash ] -crbug.com/591099 external/wpt/service-workers/service-worker/clients-get-cross-origin.https.html [ Crash ] -crbug.com/591099 external/wpt/service-workers/service-worker/clients-get.https.html [ Crash ] -crbug.com/591099 external/wpt/service-workers/service-worker/clients-matchall-exact-controller.https.html [ Crash ] -crbug.com/591099 external/wpt/service-workers/service-worker/clients-matchall-include-uncontrolled.https.html [ Crash Timeout ] -crbug.com/591099 external/wpt/service-workers/service-worker/clients-matchall-order.https.html [ Crash ] -crbug.com/591099 external/wpt/service-workers/service-worker/clients-matchall.https.html [ Crash ] -crbug.com/591099 external/wpt/service-workers/service-worker/extendable-event-async-waituntil.https.html [ Crash ] -crbug.com/591099 external/wpt/service-workers/service-worker/fetch-canvas-tainting-cache.https.html [ Crash ] -crbug.com/591099 external/wpt/service-workers/service-worker/fetch-canvas-tainting.https.html [ Crash ] -crbug.com/591099 external/wpt/service-workers/service-worker/fetch-cors-xhr.https.html [ Crash ] -crbug.com/591099 external/wpt/service-workers/service-worker/fetch-event.https.html [ Crash ] -crbug.com/591099 external/wpt/service-workers/service-worker/fetch-frame-resource.https.html [ Crash ] -crbug.com/591099 external/wpt/service-workers/service-worker/fetch-mixed-content-to-inscope.https.html [ Crash ] -crbug.com/591099 external/wpt/service-workers/service-worker/fetch-mixed-content-to-outscope.https.html [ Crash ] -crbug.com/591099 external/wpt/service-workers/service-worker/fetch-request-css-images.https.html [ Crash ] +crbug.com/591099 external/wpt/service-workers/service-worker/claim-not-using-registration.https.html [ Crash Pass ] +crbug.com/591099 external/wpt/service-workers/service-worker/client-id.https.html [ Crash Pass ] +crbug.com/591099 external/wpt/service-workers/service-worker/clients-get-cross-origin.https.html [ Crash Pass ] +crbug.com/591099 external/wpt/service-workers/service-worker/clients-get.https.html [ Crash Pass ] +crbug.com/591099 external/wpt/service-workers/service-worker/clients-matchall-exact-controller.https.html [ Crash Pass ] +crbug.com/591099 external/wpt/service-workers/service-worker/clients-matchall-include-uncontrolled.https.html [ Crash Pass Timeout ] +crbug.com/591099 external/wpt/service-workers/service-worker/clients-matchall-order.https.html [ Crash Pass ] +crbug.com/591099 external/wpt/service-workers/service-worker/clients-matchall.https.html [ Crash Pass ] +crbug.com/591099 external/wpt/service-workers/service-worker/extendable-event-async-waituntil.https.html [ Crash Pass ] +crbug.com/591099 external/wpt/service-workers/service-worker/fetch-canvas-tainting-cache.https.html [ Crash Pass ] +crbug.com/591099 external/wpt/service-workers/service-worker/fetch-canvas-tainting.https.html [ Crash Pass ] +crbug.com/591099 external/wpt/service-workers/service-worker/fetch-cors-xhr.https.html [ Crash Pass ] +crbug.com/591099 external/wpt/service-workers/service-worker/fetch-event.https.html [ Crash Pass ] +crbug.com/591099 external/wpt/service-workers/service-worker/fetch-frame-resource.https.html [ Crash Timeout ] +crbug.com/591099 external/wpt/service-workers/service-worker/fetch-mixed-content-to-inscope.https.html [ Crash Pass ] +crbug.com/591099 external/wpt/service-workers/service-worker/fetch-mixed-content-to-outscope.https.html [ Crash Pass ] +crbug.com/591099 external/wpt/service-workers/service-worker/fetch-request-css-images.https.html [ Crash Pass ] crbug.com/591099 external/wpt/service-workers/service-worker/fetch-request-fallback.https.html [ Crash Pass ] -crbug.com/591099 external/wpt/service-workers/service-worker/fetch-request-redirect.https.html [ Crash ] +crbug.com/591099 external/wpt/service-workers/service-worker/fetch-request-redirect.https.html [ Crash Pass ] crbug.com/591099 external/wpt/service-workers/service-worker/fetch-response-taint.https.html [ Crash Pass ] -crbug.com/591099 external/wpt/service-workers/service-worker/foreign-fetch-basics.https.html [ Crash ] -crbug.com/591099 external/wpt/service-workers/service-worker/foreign-fetch-cors.https.html [ Crash ] -crbug.com/591099 external/wpt/service-workers/service-worker/foreign-fetch-workers.https.html [ Crash ] -crbug.com/591099 external/wpt/service-workers/service-worker/iframe-sandbox-register-link-element.https.html [ Crash ] -crbug.com/591099 external/wpt/service-workers/service-worker/multi-globals/url-parsing.https.html [ Crash ] -crbug.com/591099 external/wpt/service-workers/service-worker/navigation-preload/redirect.https.html [ Crash ] -crbug.com/591099 external/wpt/service-workers/service-worker/navigation-preload/resource-timing.https.html [ Crash ] -crbug.com/591099 external/wpt/service-workers/service-worker/navigation-redirect-to-http.https.html [ Crash ] -crbug.com/591099 external/wpt/service-workers/service-worker/navigation-redirect.https.html [ Crash ] -crbug.com/591099 external/wpt/service-workers/service-worker/ready.https.html [ Crash ] -crbug.com/591099 external/wpt/service-workers/service-worker/register-closed-window.https.html [ Crash ] -crbug.com/591099 external/wpt/service-workers/service-worker/register-link-header.https.html [ Crash ] -crbug.com/591099 external/wpt/service-workers/service-worker/register-same-scope-different-script-url.https.html [ Crash ] -crbug.com/591099 external/wpt/service-workers/service-worker/registration-iframe.https.html [ Crash ] -crbug.com/591099 external/wpt/service-workers/service-worker/unregister-controller.https.html [ Crash ] -crbug.com/591099 external/wpt/service-workers/service-worker/unregister-then-register-new-script.https.html [ Crash ] -crbug.com/591099 external/wpt/service-workers/service-worker/unregister-then-register.https.html [ Crash ] -crbug.com/591099 external/wpt/service-workers/service-worker/windowclient-navigate.https.html [ Crash ] -crbug.com/591099 external/wpt/shadow-dom/leaktests/html-collection.html [ Crash ] -crbug.com/591099 external/wpt/shadow-dom/leaktests/window-frames.html [ Crash ] -crbug.com/591099 external/wpt/shadow-dom/untriaged/events/event-retargeting/test-001.html [ Crash ] -crbug.com/591099 external/wpt/shadow-dom/untriaged/events/test-001.html [ Crash ] -crbug.com/591099 external/wpt/shadow-dom/untriaged/html-elements-in-shadow-trees/html-forms/test-003.html [ Crash ] -crbug.com/591099 external/wpt/shadow-dom/untriaged/html-elements-in-shadow-trees/inert-html-elements/test-001.html [ Crash ] +crbug.com/591099 external/wpt/service-workers/service-worker/foreign-fetch-basics.https.html [ Crash Pass ] +crbug.com/591099 external/wpt/service-workers/service-worker/foreign-fetch-cors.https.html [ Crash Pass ] +crbug.com/591099 external/wpt/service-workers/service-worker/foreign-fetch-workers.https.html [ Crash Pass ] +crbug.com/591099 external/wpt/service-workers/service-worker/iframe-sandbox-register-link-element.https.html [ Crash Pass ] +crbug.com/591099 external/wpt/service-workers/service-worker/multi-globals/url-parsing.https.html [ Crash Pass ] +crbug.com/591099 external/wpt/service-workers/service-worker/navigation-preload/redirect.https.html [ Crash Pass ] +crbug.com/591099 external/wpt/service-workers/service-worker/navigation-preload/resource-timing.https.html [ Crash Pass ] +crbug.com/591099 external/wpt/service-workers/service-worker/navigation-redirect-to-http.https.html [ Crash Pass ] +crbug.com/591099 external/wpt/service-workers/service-worker/navigation-redirect.https.html [ Crash Pass ] +crbug.com/591099 external/wpt/service-workers/service-worker/ready.https.html [ Crash Pass ] +crbug.com/591099 external/wpt/service-workers/service-worker/register-closed-window.https.html [ Crash Pass ] +crbug.com/591099 external/wpt/service-workers/service-worker/register-link-header.https.html [ Crash Pass ] +crbug.com/591099 external/wpt/service-workers/service-worker/register-same-scope-different-script-url.https.html [ Crash Pass ] +crbug.com/591099 external/wpt/service-workers/service-worker/registration-iframe.https.html [ Crash Pass ] +crbug.com/591099 external/wpt/service-workers/service-worker/unregister-controller.https.html [ Crash Pass ] +crbug.com/591099 external/wpt/service-workers/service-worker/unregister-then-register-new-script.https.html [ Crash Pass ] +crbug.com/591099 external/wpt/service-workers/service-worker/unregister-then-register.https.html [ Crash Pass ] +crbug.com/591099 external/wpt/service-workers/service-worker/windowclient-navigate.https.html [ Crash Pass ] +crbug.com/591099 external/wpt/shadow-dom/leaktests/html-collection.html [ Crash Pass ] +crbug.com/591099 external/wpt/shadow-dom/leaktests/window-frames.html [ Crash Pass ] +crbug.com/591099 external/wpt/shadow-dom/untriaged/events/event-retargeting/test-001.html [ Crash Pass ] +crbug.com/591099 external/wpt/shadow-dom/untriaged/events/test-001.html [ Crash Pass ] +crbug.com/591099 external/wpt/shadow-dom/untriaged/html-elements-in-shadow-trees/html-forms/test-003.html [ Crash Pass ] +crbug.com/591099 external/wpt/shadow-dom/untriaged/html-elements-in-shadow-trees/inert-html-elements/test-001.html [ Crash Pass ] crbug.com/591099 external/wpt/svg/interfaces.html [ Pass Timeout ] crbug.com/591099 external/wpt/svg/linking/reftests/href-filter-element.html [ Crash Failure ] crbug.com/591099 external/wpt/uievents/mouse/mouseevent_move_button-manual.html [ Crash Timeout ] -crbug.com/591099 external/wpt/uievents/order-of-events/focus-events/focus-automated-blink-webkit.html [ Crash ] +crbug.com/591099 external/wpt/uievents/order-of-events/focus-events/focus-automated-blink-webkit.html [ Crash Pass ] crbug.com/591099 external/wpt/uievents/order-of-events/focus-events/focus-manual.html [ Crash Failure Timeout ] crbug.com/591099 external/wpt/url/a-element-xhtml.xhtml [ Pass Timeout ] crbug.com/591099 external/wpt/url/a-element.html [ Pass Timeout ] crbug.com/591099 external/wpt/url/url-constructor.html [ Pass Timeout ] crbug.com/591099 external/wpt/url/url-setters.html [ Pass Timeout ] -crbug.com/591099 external/wpt/viewport/viewport-unscaled-scale-iframe.html [ Crash ] -crbug.com/591099 external/wpt/viewport/viewport-unscaled-scroll-iframe.html [ Crash ] -crbug.com/591099 external/wpt/viewport/viewport-unscaled-size-iframe.html [ Crash ] -crbug.com/591099 external/wpt/wasm/wasm_local_iframe_test.html [ Crash ] -crbug.com/591099 external/wpt/web-animations/interfaces/AnimationTimeline/document-timeline.html [ Crash ] -crbug.com/591099 external/wpt/webmessaging/broadcastchannel/sandbox.html [ Crash ] -crbug.com/591099 external/wpt/webmessaging/message-channels/004.html [ Crash ] -crbug.com/591099 external/wpt/webmessaging/with-ports/016.html [ Crash ] -crbug.com/591099 external/wpt/webmessaging/with-ports/017.html [ Crash ] -crbug.com/591099 external/wpt/webmessaging/with-ports/018.html [ Crash ] -crbug.com/591099 external/wpt/webmessaging/with-ports/019.html [ Crash ] -crbug.com/591099 external/wpt/webmessaging/with-ports/020.html [ Crash ] -crbug.com/591099 external/wpt/webmessaging/with-ports/021.html [ Crash ] -crbug.com/591099 external/wpt/webmessaging/without-ports/016.html [ Crash ] -crbug.com/591099 external/wpt/webmessaging/without-ports/017.html [ Crash ] -crbug.com/591099 external/wpt/webmessaging/without-ports/018.html [ Crash ] -crbug.com/591099 external/wpt/webmessaging/without-ports/019.html [ Crash ] -crbug.com/591099 external/wpt/webmessaging/without-ports/020.html [ Crash ] -crbug.com/591099 external/wpt/webmessaging/without-ports/021.html [ Crash ] -crbug.com/591099 external/wpt/webmessaging/without-ports/028.html [ Crash ] +crbug.com/591099 external/wpt/viewport/viewport-unscaled-scale-iframe.html [ Crash Pass ] +crbug.com/591099 external/wpt/viewport/viewport-unscaled-scroll-iframe.html [ Crash Pass ] +crbug.com/591099 external/wpt/viewport/viewport-unscaled-size-iframe.html [ Crash Pass ] +crbug.com/591099 external/wpt/wasm/wasm_local_iframe_test.html [ Crash Failure ] +crbug.com/591099 external/wpt/web-animations/interfaces/AnimationTimeline/document-timeline.html [ Crash Pass ] +crbug.com/591099 external/wpt/webmessaging/broadcastchannel/sandbox.html [ Crash Failure ] +crbug.com/591099 external/wpt/webmessaging/message-channels/004.html [ Crash Pass ] +crbug.com/591099 external/wpt/webmessaging/with-ports/016.html [ Crash Pass ] +crbug.com/591099 external/wpt/webmessaging/with-ports/017.html [ Crash Pass ] +crbug.com/591099 external/wpt/webmessaging/with-ports/018.html [ Crash Pass ] +crbug.com/591099 external/wpt/webmessaging/with-ports/019.html [ Crash Pass ] +crbug.com/591099 external/wpt/webmessaging/with-ports/020.html [ Crash Pass ] +crbug.com/591099 external/wpt/webmessaging/with-ports/021.html [ Crash Pass ] +crbug.com/591099 external/wpt/webmessaging/without-ports/016.html [ Crash Pass ] +crbug.com/591099 external/wpt/webmessaging/without-ports/017.html [ Crash Pass ] +crbug.com/591099 external/wpt/webmessaging/without-ports/018.html [ Crash Pass ] +crbug.com/591099 external/wpt/webmessaging/without-ports/019.html [ Crash Pass ] +crbug.com/591099 external/wpt/webmessaging/without-ports/020.html [ Crash Pass ] +crbug.com/591099 external/wpt/webmessaging/without-ports/021.html [ Crash Pass ] +crbug.com/591099 external/wpt/webmessaging/without-ports/028.html [ Crash Pass ] crbug.com/591099 external/wpt/webrtc/interfaces.html [ Pass Timeout ] -crbug.com/591099 external/wpt/webrtc/simplecall.html [ Crash ] -crbug.com/591099 external/wpt/websockets/multi-globals/message-received.html [ Crash ] -crbug.com/591099 external/wpt/webstorage/event_no_duplicates.html [ Crash ] +crbug.com/591099 external/wpt/webrtc/simplecall.html [ Crash Pass ] +crbug.com/591099 external/wpt/websockets/multi-globals/message-received.html [ Crash Pass ] +crbug.com/591099 external/wpt/webstorage/event_no_duplicates.html [ Crash Pass ] crbug.com/591099 external/wpt/webstorage/storage_setitem.html [ Pass Timeout ] -crbug.com/591099 external/wpt/webusb/usb-allowed-by-feature-policy-attribute-redirect-on-load.https.sub.html [ Crash ] -crbug.com/591099 external/wpt/webusb/usb-allowed-by-feature-policy-attribute.https.sub.html [ Crash ] -crbug.com/591099 external/wpt/webusb/usb-allowed-by-feature-policy.https.sub.html [ Crash ] -crbug.com/591099 external/wpt/webusb/usb-default-feature-policy.https.sub.html [ Crash ] -crbug.com/591099 external/wpt/webusb/usb-disabled-by-feature-policy.https.sub.html [ Crash ] +crbug.com/591099 external/wpt/webusb/usb-allowed-by-feature-policy-attribute-redirect-on-load.https.sub.html [ Crash Pass ] +crbug.com/591099 external/wpt/webusb/usb-allowed-by-feature-policy-attribute.https.sub.html [ Crash Pass ] +crbug.com/591099 external/wpt/webusb/usb-allowed-by-feature-policy.https.sub.html [ Crash Failure ] +crbug.com/591099 external/wpt/webusb/usb-default-feature-policy.https.sub.html [ Crash Pass ] +crbug.com/591099 external/wpt/webusb/usb-disabled-by-feature-policy.https.sub.html [ Crash Failure ] crbug.com/591099 external/wpt/webvtt/rendering/cues-with-video/processing-model/2_cues_overlapping_completely_move_up.html [ Crash Failure ] crbug.com/591099 external/wpt/webvtt/rendering/cues-with-video/processing-model/2_cues_overlapping_partially_move_up.html [ Crash Failure ] crbug.com/591099 external/wpt/webvtt/rendering/cues-with-video/processing-model/bidi/bidi_ruby.html [ Crash Failure ] @@ -6566,17 +6574,17 @@ crbug.com/591099 external/wpt/webvtt/rendering/cues-with-video/processing-model/selectors/cue_function/underline_object/underline_font_shorthand.html [ Crash Failure ] crbug.com/591099 external/wpt/webvtt/rendering/cues-with-video/processing-model/selectors/cue_function/voice_object/voice_font_properties.html [ Crash Failure ] crbug.com/591099 external/wpt/webvtt/rendering/cues-with-video/processing-model/selectors/cue_function/voice_object/voice_font_shorthand.html [ Crash Failure ] -crbug.com/591099 external/wpt/x-frame-options/deny.sub.html [ Crash ] -crbug.com/591099 external/wpt/x-frame-options/invalid.sub.html [ Crash ] -crbug.com/591099 external/wpt/x-frame-options/multiple.sub.html [ Crash ] -crbug.com/591099 external/wpt/x-frame-options/sameorigin.sub.html [ Crash ] +crbug.com/591099 external/wpt/x-frame-options/deny.sub.html [ Crash Pass ] +crbug.com/591099 external/wpt/x-frame-options/invalid.sub.html [ Crash Pass ] +crbug.com/591099 external/wpt/x-frame-options/multiple.sub.html [ Crash Pass ] +crbug.com/591099 external/wpt/x-frame-options/sameorigin.sub.html [ Crash Pass ] crbug.com/591099 fast/alignment/ensure-flexbox-compatibility-with-initial-values.html [ Failure ] crbug.com/591099 fast/alignment/overwrite-content-alignment.html [ Failure ] crbug.com/591099 fast/alignment/overwrite-self-alignment.html [ Failure ] crbug.com/591099 fast/animation/request-animation-frame-cancel.html [ Failure ] crbug.com/591099 fast/animation/request-animation-frame-cancel2.html [ Failure ] -crbug.com/591099 fast/animation/request-animation-frame-detach-element.html [ Crash ] -crbug.com/591099 fast/animation/request-animation-frame-detach-element2.html [ Crash ] +crbug.com/591099 fast/animation/request-animation-frame-detach-element.html [ Crash Pass ] +crbug.com/591099 fast/animation/request-animation-frame-detach-element2.html [ Crash Pass ] crbug.com/591099 fast/animation/request-animation-frame-iframe.html [ Failure ] crbug.com/591099 fast/animation/request-animation-frame-iframe2.html [ Failure ] crbug.com/591099 fast/animation/request-animation-frame-missing-arguments.html [ Failure ] @@ -6679,13 +6687,13 @@ crbug.com/591099 fast/block/basic/quirk-percent-height-grandchild.html [ Failure ] crbug.com/591099 fast/block/basic/text-indent-rtl.html [ Failure ] crbug.com/591099 fast/block/basic/white-space-pre-wraps.html [ Failure ] -crbug.com/591099 fast/block/block-not-removed-from-parent-lineboxes-crash.html [ Crash ] +crbug.com/591099 fast/block/block-not-removed-from-parent-lineboxes-crash.html [ Crash Pass ] crbug.com/591099 fast/block/block-parent-with-zero-width-child.html [ Failure ] crbug.com/591099 fast/block/block-remove-child-delete-line-box-crash.html [ Failure ] -crbug.com/591099 fast/block/block-width-recalc-with-relative-height.html [ Crash ] -crbug.com/591099 fast/block/block-with-inline-replaced-child-following-text.html [ Crash ] +crbug.com/591099 fast/block/block-width-recalc-with-relative-height.html [ Crash Failure ] +crbug.com/591099 fast/block/block-with-inline-replaced-child-following-text.html [ Crash Failure ] crbug.com/591099 fast/block/borderbox-percent-padding.html [ Failure ] -crbug.com/591099 fast/block/child-not-removed-from-parent-lineboxes-crash.html [ Crash ] +crbug.com/591099 fast/block/child-not-removed-from-parent-lineboxes-crash.html [ Crash Pass ] crbug.com/591099 fast/block/dynamic-padding-border.html [ Failure ] crbug.com/591099 fast/block/float/002.html [ Crash Failure ] crbug.com/591099 fast/block/float/003.html [ Failure ] @@ -6712,7 +6720,7 @@ crbug.com/591099 fast/block/float/034.html [ Failure ] crbug.com/591099 fast/block/float/035.html [ Failure ] crbug.com/591099 fast/block/float/add-float-back-to-anonymous-block.html [ Failure ] -crbug.com/591099 fast/block/float/assert-when-moving-float.html [ Crash ] +crbug.com/591099 fast/block/float/assert-when-moving-float.html [ Crash Failure ] crbug.com/591099 fast/block/float/avoid-floats-when-negative-margin-top-2.html [ Failure ] crbug.com/591099 fast/block/float/avoid-floats-when-negative-margin-top-3.html [ Failure ] crbug.com/591099 fast/block/float/avoid-floats-when-negative-margin-top-4.html [ Failure ] @@ -6738,15 +6746,15 @@ crbug.com/591099 fast/block/float/float-in-float-hit-testing.html [ Failure ] crbug.com/591099 fast/block/float/float-in-float-painting.html [ Failure ] crbug.com/591099 fast/block/float/float-inserted-into-clean-line.html [ Failure ] -crbug.com/591099 fast/block/float/float-list-changed-before-layout-crash.html [ Crash ] +crbug.com/591099 fast/block/float/float-list-changed-before-layout-crash.html [ Crash Pass ] crbug.com/591099 fast/block/float/float-not-removed-from-next-sibling-crash.html [ Failure ] crbug.com/591099 fast/block/float/float-not-removed-from-next-sibling5.html [ Crash Failure ] crbug.com/591099 fast/block/float/float-on-empty-line.html [ Failure ] -crbug.com/591099 fast/block/float/float-on-line-large-and-small-float-below.html [ Crash ] +crbug.com/591099 fast/block/float/float-on-line-large-and-small-float-below.html [ Crash Pass ] crbug.com/591099 fast/block/float/float-on-line-obeys-container-padding.html [ Failure ] crbug.com/591099 fast/block/float/float-on-zero-height-line.html [ Failure ] crbug.com/591099 fast/block/float/float-overflow-hidden-containing-block-width.html [ Failure ] -crbug.com/591099 fast/block/float/float-reparent-during-detach-crash.html [ Crash ] +crbug.com/591099 fast/block/float/float-reparent-during-detach-crash.html [ Crash Pass ] crbug.com/591099 fast/block/float/floats-and-text-indent-rl.html [ Failure ] crbug.com/591099 fast/block/float/floats-and-text-indent.html [ Failure ] crbug.com/591099 fast/block/float/floats-do-not-overhang-from-block-formatting-context.html [ Failure ] @@ -6768,7 +6776,7 @@ crbug.com/591099 fast/block/float/intruding-float-add-in-sibling-block-on-static-position2.html [ Crash Failure Pass ] crbug.com/591099 fast/block/float/intruding-painted-twice.html [ Failure ] crbug.com/591099 fast/block/float/logical-bottom-exceeds-layoutunit-max.html [ Failure ] -crbug.com/591099 fast/block/float/margin-top-changes.html [ Crash ] +crbug.com/591099 fast/block/float/margin-top-changes.html [ Crash Pass ] crbug.com/591099 fast/block/float/marquee-shrink-to-avoid-floats.html [ Failure ] crbug.com/591099 fast/block/float/max-width-clear-float-with-overflow-hidden.html [ Failure Pass ] crbug.com/591099 fast/block/float/multiple-float-positioning.html [ Failure ] @@ -6794,10 +6802,10 @@ crbug.com/591099 fast/block/float/selection-gap-clip-out-tiger-crash.html [ Failure Pass ] crbug.com/591099 fast/block/float/shrink-to-avoid-float-complexity.html [ Failure ] crbug.com/591099 fast/block/float/shrink-to-fit-width.html [ Failure ] -crbug.com/591099 fast/block/float/split-inline-sibling-of-float-crash.html [ Crash ] +crbug.com/591099 fast/block/float/split-inline-sibling-of-float-crash.html [ Crash Pass ] crbug.com/591099 fast/block/float/table-relayout.html [ Failure ] -crbug.com/591099 fast/block/float/trailing-float-layout-2.html [ Crash ] -crbug.com/591099 fast/block/float/trailing-float-layout.html [ Crash ] +crbug.com/591099 fast/block/float/trailing-float-layout-2.html [ Crash Pass ] +crbug.com/591099 fast/block/float/trailing-float-layout.html [ Crash Pass ] crbug.com/591099 fast/block/float/trailing-float-with-columns.html [ Failure ] crbug.com/591099 fast/block/float/vertical-move-relayout.html [ Failure ] crbug.com/591099 fast/block/float/width-update-after-clear.html [ Failure ] @@ -6913,7 +6921,7 @@ crbug.com/591099 fast/block/positioning/padding-percent.html [ Crash Failure ] crbug.com/591099 fast/block/positioning/positioned-child-inside-relative-positioned-anonymous-block.html [ Failure ] crbug.com/591099 fast/block/positioning/positioned-container-changes-block-direction-border-with-positioned-descendant.html [ Failure ] -crbug.com/591099 fast/block/positioning/positioned-layout-in-line.html [ Crash ] +crbug.com/591099 fast/block/positioning/positioned-layout-in-line.html [ Crash Pass ] crbug.com/591099 fast/block/positioning/rel-positioned-inline-changes-width.html [ Crash Failure ] crbug.com/591099 fast/block/positioning/relative-overflow-block.html [ Failure ] crbug.com/591099 fast/block/positioning/relative-overflow-replaced-float.html [ Crash Failure ] @@ -6921,7 +6929,7 @@ crbug.com/591099 fast/block/positioning/relative-positioned-inline-container.html [ Crash Failure ] crbug.com/591099 fast/block/positioning/relative-with-implicit-height-containing-block.html [ Failure ] crbug.com/591099 fast/block/positioning/relayout-nested-positioned-elements-crash-2.html [ Crash Failure Pass ] -crbug.com/591099 fast/block/positioning/relayout-nested-positioned-elements-crash.html [ Crash ] +crbug.com/591099 fast/block/positioning/relayout-nested-positioned-elements-crash.html [ Crash Failure ] crbug.com/591099 fast/block/positioning/relayout-on-position-change.html [ Failure ] crbug.com/591099 fast/block/positioning/replaced-inside-fixed-top-bottom.html [ Failure ] crbug.com/591099 fast/block/positioning/rtl-static-positioning-inline-block.html [ Crash Failure ] @@ -6940,7 +6948,7 @@ crbug.com/591099 fast/block/positioning/vertical-rl/fixed-positioning.html [ Failure ] crbug.com/591099 fast/block/positioning/window-height-change.html [ Failure ] crbug.com/591099 fast/block/scrollbar-wider-than-border-box.html [ Failure ] -crbug.com/591099 fast/block/skip-cleaning-up-anonymous-wrappers-when-subtree-being-destroyed.html [ Crash ] +crbug.com/591099 fast/block/skip-cleaning-up-anonymous-wrappers-when-subtree-being-destroyed.html [ Crash Pass ] crbug.com/591099 fast/block/strip-anonymous-blocks-when-block-child-becomes-float.html [ Failure ] crbug.com/591099 fast/body-propagation/background-color/001-xhtml.xhtml [ Failure Pass ] crbug.com/591099 fast/body-propagation/background-color/001.html [ Failure Pass ] @@ -7096,36 +7104,36 @@ crbug.com/591099 fast/box-shadow/spread.html [ Failure ] crbug.com/591099 fast/box-shadow/transform-fringing.html [ Failure ] crbug.com/591099 fast/box-sizing/box-sizing.html [ Failure ] -crbug.com/591099 fast/box-sizing/css-table-with-box-sizing.html [ Crash ] +crbug.com/591099 fast/box-sizing/css-table-with-box-sizing.html [ Crash Failure ] crbug.com/591099 fast/box-sizing/table-cell.html [ Failure ] -crbug.com/591099 fast/canvas/2d.composite.globalAlpha.fillPath.html [ Crash ] -crbug.com/591099 fast/canvas/2d.fillText.gradient.html [ Crash ] -crbug.com/591099 fast/canvas/2d.text.draw.fill.maxWidth.gradient.html [ Crash ] -crbug.com/591099 fast/canvas/2d.text.draw.fill.maxWidth.negative.html [ Crash ] -crbug.com/591099 fast/canvas/2d.text.draw.fill.maxWidth.veryLarge.html [ Crash ] -crbug.com/591099 fast/canvas/2d.text.draw.fill.maxWidth.verySmall.html [ Crash ] +crbug.com/591099 fast/canvas/2d.composite.globalAlpha.fillPath.html [ Crash Pass ] +crbug.com/591099 fast/canvas/2d.fillText.gradient.html [ Crash Pass ] +crbug.com/591099 fast/canvas/2d.text.draw.fill.maxWidth.gradient.html [ Crash Pass ] +crbug.com/591099 fast/canvas/2d.text.draw.fill.maxWidth.negative.html [ Crash Pass ] +crbug.com/591099 fast/canvas/2d.text.draw.fill.maxWidth.veryLarge.html [ Crash Pass ] +crbug.com/591099 fast/canvas/2d.text.draw.fill.maxWidth.verySmall.html [ Crash Pass ] crbug.com/591099 fast/canvas/OffscreenCanvas-constructor-in-worker.html [ Failure ] crbug.com/591099 fast/canvas/OffscreenCanvas-invalid-args-in-worker.html [ Failure ] crbug.com/591099 fast/canvas/OffscreenCanvas-transferable-exceptions.html [ Failure ] crbug.com/591099 fast/canvas/OffscreenCanvas-transferable.html [ Failure ] -crbug.com/591099 fast/canvas/access-zero-sized-canvas.html [ Crash ] -crbug.com/591099 fast/canvas/alpha.html [ Crash ] -crbug.com/591099 fast/canvas/arc-crash.html [ Crash ] -crbug.com/591099 fast/canvas/arc360.html [ Crash ] -crbug.com/591099 fast/canvas/bug544329.html [ Crash ] -crbug.com/591099 fast/canvas/canvas-2d-clip-anti-aliasing.html [ Crash ] +crbug.com/591099 fast/canvas/access-zero-sized-canvas.html [ Crash Pass ] +crbug.com/591099 fast/canvas/alpha.html [ Crash Pass ] +crbug.com/591099 fast/canvas/arc-crash.html [ Crash Pass ] +crbug.com/591099 fast/canvas/arc360.html [ Crash Pass ] +crbug.com/591099 fast/canvas/bug544329.html [ Crash Pass ] +crbug.com/591099 fast/canvas/canvas-2d-clip-anti-aliasing.html [ Crash Pass ] crbug.com/591099 fast/canvas/canvas-ImageBitmap-close.html [ Failure ] crbug.com/591099 fast/canvas/canvas-ImageBitmap-structured-clone.html [ Failure ] crbug.com/591099 fast/canvas/canvas-ImageBitmap-transferable.html [ Failure ] crbug.com/591099 fast/canvas/canvas-ImageData-neutered-source.html [ Failure ] crbug.com/591099 fast/canvas/canvas-ImageData-workers.html [ Failure ] -crbug.com/591099 fast/canvas/canvas-after-destroy-iframe.html [ Crash ] -crbug.com/591099 fast/canvas/canvas-alphaImageData-behavior.html [ Crash ] -crbug.com/591099 fast/canvas/canvas-arc-zero-lineto.html [ Crash ] -crbug.com/591099 fast/canvas/canvas-bezier-same-endpoint.html [ Crash ] +crbug.com/591099 fast/canvas/canvas-after-destroy-iframe.html [ Crash Pass ] +crbug.com/591099 fast/canvas/canvas-alphaImageData-behavior.html [ Crash Pass ] +crbug.com/591099 fast/canvas/canvas-arc-zero-lineto.html [ Crash Pass ] +crbug.com/591099 fast/canvas/canvas-bezier-same-endpoint.html [ Crash Pass ] crbug.com/591099 fast/canvas/canvas-blending-image-over-image.html [ Failure ] crbug.com/591099 fast/canvas/canvas-blending-text.html [ Failure ] -crbug.com/591099 fast/canvas/canvas-closePath-single-point.html [ Crash ] +crbug.com/591099 fast/canvas/canvas-closePath-single-point.html [ Crash Pass ] crbug.com/591099 fast/canvas/canvas-composite-alpha.html [ Crash Failure ] crbug.com/591099 fast/canvas/canvas-composite-canvas.html [ Failure ] crbug.com/591099 fast/canvas/canvas-composite-image.html [ Failure ] @@ -7144,25 +7152,25 @@ crbug.com/591099 fast/canvas/canvas-createImageBitmap-recursive.html [ Failure Timeout ] crbug.com/591099 fast/canvas/canvas-createImageBitmap-svg-no-intrinsic-size.html [ Failure ] crbug.com/591099 fast/canvas/canvas-createImageBitmap-svg.html [ Failure ] -crbug.com/591099 fast/canvas/canvas-createPattern-fillRect-shadow.html [ Crash ] -crbug.com/591099 fast/canvas/canvas-currentColor.html [ Crash ] -crbug.com/591099 fast/canvas/canvas-direction.html [ Crash ] -crbug.com/591099 fast/canvas/canvas-draw-canvas-on-canvas-shadow.html [ Crash ] +crbug.com/591099 fast/canvas/canvas-createPattern-fillRect-shadow.html [ Crash Pass ] +crbug.com/591099 fast/canvas/canvas-currentColor.html [ Crash Pass ] +crbug.com/591099 fast/canvas/canvas-direction.html [ Crash Pass ] +crbug.com/591099 fast/canvas/canvas-draw-canvas-on-canvas-shadow.html [ Crash Pass ] crbug.com/591099 fast/canvas/canvas-drawImage-animated-images.html [ Failure ] -crbug.com/591099 fast/canvas/canvas-drawImage-animated.html [ Crash ] -crbug.com/591099 fast/canvas/canvas-drawImage-live-video.html [ Crash ] -crbug.com/591099 fast/canvas/canvas-drawImage-shadow.html [ Crash ] -crbug.com/591099 fast/canvas/canvas-ellipse-360-winding.html [ Crash ] +crbug.com/591099 fast/canvas/canvas-drawImage-animated.html [ Crash Pass ] +crbug.com/591099 fast/canvas/canvas-drawImage-live-video.html [ Crash Pass ] +crbug.com/591099 fast/canvas/canvas-drawImage-shadow.html [ Crash Pass ] +crbug.com/591099 fast/canvas/canvas-ellipse-360-winding.html [ Crash Pass ] crbug.com/591099 fast/canvas/canvas-ellipse-connecting-line.html [ Failure Pass ] -crbug.com/591099 fast/canvas/canvas-ellipse-zero-lineto.html [ Crash ] -crbug.com/591099 fast/canvas/canvas-ellipse.html [ Crash ] -crbug.com/591099 fast/canvas/canvas-empty-image-pattern.html [ Crash ] -crbug.com/591099 fast/canvas/canvas-fillPath-alpha-shadow.html [ Crash ] -crbug.com/591099 fast/canvas/canvas-fillPath-gradient-shadow.html [ Crash ] -crbug.com/591099 fast/canvas/canvas-fillPath-pattern-shadow.html [ Crash ] -crbug.com/591099 fast/canvas/canvas-fillPath-shadow.html [ Crash ] -crbug.com/591099 fast/canvas/canvas-fillRect-gradient-shadow.html [ Crash ] -crbug.com/591099 fast/canvas/canvas-fillRect-shadow.html [ Crash ] +crbug.com/591099 fast/canvas/canvas-ellipse-zero-lineto.html [ Crash Pass ] +crbug.com/591099 fast/canvas/canvas-ellipse.html [ Crash Pass ] +crbug.com/591099 fast/canvas/canvas-empty-image-pattern.html [ Crash Pass ] +crbug.com/591099 fast/canvas/canvas-fillPath-alpha-shadow.html [ Crash Pass ] +crbug.com/591099 fast/canvas/canvas-fillPath-gradient-shadow.html [ Crash Failure ] +crbug.com/591099 fast/canvas/canvas-fillPath-pattern-shadow.html [ Crash Pass ] +crbug.com/591099 fast/canvas/canvas-fillPath-shadow.html [ Crash Pass ] +crbug.com/591099 fast/canvas/canvas-fillRect-gradient-shadow.html [ Crash Pass ] +crbug.com/591099 fast/canvas/canvas-fillRect-shadow.html [ Crash Pass ] crbug.com/591099 fast/canvas/canvas-filter-fill-liveness.html [ Failure ] crbug.com/591099 fast/canvas/canvas-filter-fill-paint-color.html [ Failure ] crbug.com/591099 fast/canvas/canvas-filter-fill-paint-gradient.html [ Failure ] @@ -7179,99 +7187,99 @@ crbug.com/591099 fast/canvas/canvas-filter-width-height-hidpi.html [ Failure ] crbug.com/591099 fast/canvas/canvas-filter-width-height-scale.html [ Failure ] crbug.com/591099 fast/canvas/canvas-filter-width-height.html [ Failure ] -crbug.com/591099 fast/canvas/canvas-font-cache.html [ Crash ] +crbug.com/591099 fast/canvas/canvas-font-cache.html [ Crash Pass ] crbug.com/591099 fast/canvas/canvas-hides-fallback.html [ Failure ] -crbug.com/591099 fast/canvas/canvas-hit-regions-accessibility-test.html [ Crash ] -crbug.com/591099 fast/canvas/canvas-hit-regions-basic-test.html [ Crash ] -crbug.com/591099 fast/canvas/canvas-hit-regions-clear-test.html [ Crash ] -crbug.com/591099 fast/canvas/canvas-hit-regions-clip-test.html [ Crash ] -crbug.com/591099 fast/canvas/canvas-hit-regions-css-transform-test.html [ Crash ] -crbug.com/591099 fast/canvas/canvas-hit-regions-device-pixel-ratio-test.html [ Crash ] -crbug.com/591099 fast/canvas/canvas-hit-regions-event-test.html [ Crash ] -crbug.com/591099 fast/canvas/canvas-hit-regions-exception-test.html [ Crash ] -crbug.com/591099 fast/canvas/canvas-hit-regions-fallback-element-test-1.html [ Crash ] -crbug.com/591099 fast/canvas/canvas-hit-regions-fallback-element-test-2.html [ Crash ] -crbug.com/591099 fast/canvas/canvas-hit-regions-fallback-element-test-3.html [ Crash ] -crbug.com/591099 fast/canvas/canvas-hit-regions-fill-rule-test.html [ Crash ] -crbug.com/591099 fast/canvas/canvas-hit-regions-path2d-test.html [ Crash ] -crbug.com/591099 fast/canvas/canvas-hit-regions-path2d-transform-test.html [ Crash ] -crbug.com/591099 fast/canvas/canvas-hit-regions-scale-factor.html [ Crash ] -crbug.com/591099 fast/canvas/canvas-hit-regions-transform-test.html [ Crash ] -crbug.com/591099 fast/canvas/canvas-imageSmoothingEnabled-repaint.html [ Crash ] -crbug.com/591099 fast/canvas/canvas-imageSmoothingQuality.html [ Crash ] -crbug.com/591099 fast/canvas/canvas-invalid-fillstyle.html [ Crash ] -crbug.com/591099 fast/canvas/canvas-invalid-strokestyle.html [ Crash ] +crbug.com/591099 fast/canvas/canvas-hit-regions-accessibility-test.html [ Crash Pass ] +crbug.com/591099 fast/canvas/canvas-hit-regions-basic-test.html [ Crash Pass ] +crbug.com/591099 fast/canvas/canvas-hit-regions-clear-test.html [ Crash Pass ] +crbug.com/591099 fast/canvas/canvas-hit-regions-clip-test.html [ Crash Pass ] +crbug.com/591099 fast/canvas/canvas-hit-regions-css-transform-test.html [ Crash Pass ] +crbug.com/591099 fast/canvas/canvas-hit-regions-device-pixel-ratio-test.html [ Crash Pass ] +crbug.com/591099 fast/canvas/canvas-hit-regions-event-test.html [ Crash Pass ] +crbug.com/591099 fast/canvas/canvas-hit-regions-exception-test.html [ Crash Pass ] +crbug.com/591099 fast/canvas/canvas-hit-regions-fallback-element-test-1.html [ Crash Pass ] +crbug.com/591099 fast/canvas/canvas-hit-regions-fallback-element-test-2.html [ Crash Pass ] +crbug.com/591099 fast/canvas/canvas-hit-regions-fallback-element-test-3.html [ Crash Pass ] +crbug.com/591099 fast/canvas/canvas-hit-regions-fill-rule-test.html [ Crash Pass ] +crbug.com/591099 fast/canvas/canvas-hit-regions-path2d-test.html [ Crash Pass ] +crbug.com/591099 fast/canvas/canvas-hit-regions-path2d-transform-test.html [ Crash Pass ] +crbug.com/591099 fast/canvas/canvas-hit-regions-scale-factor.html [ Crash Pass ] +crbug.com/591099 fast/canvas/canvas-hit-regions-transform-test.html [ Crash Pass ] +crbug.com/591099 fast/canvas/canvas-imageSmoothingEnabled-repaint.html [ Crash Pass ] +crbug.com/591099 fast/canvas/canvas-imageSmoothingQuality.html [ Crash Pass ] +crbug.com/591099 fast/canvas/canvas-invalid-fillstyle.html [ Crash Pass ] +crbug.com/591099 fast/canvas/canvas-invalid-strokestyle.html [ Crash Pass ] crbug.com/591099 fast/canvas/canvas-invalid-video.html [ Failure ] -crbug.com/591099 fast/canvas/canvas-isPointInStroke-with-path.html [ Crash ] -crbug.com/591099 fast/canvas/canvas-isPointInStroke.html [ Crash ] -crbug.com/591099 fast/canvas/canvas-large-dimensions.html [ Crash ] -crbug.com/591099 fast/canvas/canvas-lineDash-input-sequence.html [ Crash ] -crbug.com/591099 fast/canvas/canvas-lineDash-invalid.html [ Crash ] -crbug.com/591099 fast/canvas/canvas-lineDash.html [ Crash ] -crbug.com/591099 fast/canvas/canvas-lineWidth-intact-after-strokeRect.html [ Crash ] +crbug.com/591099 fast/canvas/canvas-isPointInStroke-with-path.html [ Crash Pass ] +crbug.com/591099 fast/canvas/canvas-isPointInStroke.html [ Crash Pass ] +crbug.com/591099 fast/canvas/canvas-large-dimensions.html [ Crash Pass ] +crbug.com/591099 fast/canvas/canvas-lineDash-input-sequence.html [ Crash Pass ] +crbug.com/591099 fast/canvas/canvas-lineDash-invalid.html [ Crash Pass ] +crbug.com/591099 fast/canvas/canvas-lineDash.html [ Crash Pass ] +crbug.com/591099 fast/canvas/canvas-lineWidth-intact-after-strokeRect.html [ Crash Pass ] crbug.com/591099 fast/canvas/canvas-measure-bidi-text.html [ Failure Pass ] crbug.com/591099 fast/canvas/canvas-negative-size.html [ Failure ] crbug.com/591099 fast/canvas/canvas-normalize-string.html [ Failure ] -crbug.com/591099 fast/canvas/canvas-path-context-clip.html [ Crash ] -crbug.com/591099 fast/canvas/canvas-path-context-fill.html [ Crash ] -crbug.com/591099 fast/canvas/canvas-path-context-stroke.html [ Crash ] -crbug.com/591099 fast/canvas/canvas-path-object.html [ Crash ] -crbug.com/591099 fast/canvas/canvas-path-with-inf-nan-dimensions.html [ Crash ] -crbug.com/591099 fast/canvas/canvas-pattern-set-transform.html [ Crash ] -crbug.com/591099 fast/canvas/canvas-putImageData.html [ Crash ] -crbug.com/591099 fast/canvas/canvas-quadratic-same-endpoint.html [ Crash ] +crbug.com/591099 fast/canvas/canvas-path-context-clip.html [ Crash Pass ] +crbug.com/591099 fast/canvas/canvas-path-context-fill.html [ Crash Pass ] +crbug.com/591099 fast/canvas/canvas-path-context-stroke.html [ Crash Pass ] +crbug.com/591099 fast/canvas/canvas-path-object.html [ Crash Pass ] +crbug.com/591099 fast/canvas/canvas-path-with-inf-nan-dimensions.html [ Crash Pass ] +crbug.com/591099 fast/canvas/canvas-pattern-set-transform.html [ Crash Pass ] +crbug.com/591099 fast/canvas/canvas-putImageData.html [ Crash Pass ] +crbug.com/591099 fast/canvas/canvas-quadratic-same-endpoint.html [ Crash Pass ] crbug.com/591099 fast/canvas/canvas-render-layer.html [ Failure Pass ] -crbug.com/591099 fast/canvas/canvas-resetTransform.html [ Crash ] -crbug.com/591099 fast/canvas/canvas-resize-after-paint.html [ Crash ] -crbug.com/591099 fast/canvas/canvas-scale-drawImage-shadow.html [ Crash ] -crbug.com/591099 fast/canvas/canvas-scale-fillPath-shadow.html [ Crash ] -crbug.com/591099 fast/canvas/canvas-scale-fillRect-shadow.html [ Crash ] -crbug.com/591099 fast/canvas/canvas-scale-shadowBlur.html [ Crash ] -crbug.com/591099 fast/canvas/canvas-scale-strokePath-shadow.html [ Crash ] +crbug.com/591099 fast/canvas/canvas-resetTransform.html [ Crash Pass ] +crbug.com/591099 fast/canvas/canvas-resize-after-paint.html [ Crash Pass ] +crbug.com/591099 fast/canvas/canvas-scale-drawImage-shadow.html [ Crash Pass ] +crbug.com/591099 fast/canvas/canvas-scale-fillPath-shadow.html [ Crash Pass ] +crbug.com/591099 fast/canvas/canvas-scale-fillRect-shadow.html [ Crash Pass ] +crbug.com/591099 fast/canvas/canvas-scale-shadowBlur.html [ Crash Pass ] +crbug.com/591099 fast/canvas/canvas-scale-strokePath-shadow.html [ Crash Pass ] crbug.com/591099 fast/canvas/canvas-scroll-path-into-view.html [ Failure Timeout ] -crbug.com/591099 fast/canvas/canvas-set-properties-with-non-invertible-ctm.html [ Crash ] +crbug.com/591099 fast/canvas/canvas-set-properties-with-non-invertible-ctm.html [ Crash Pass ] crbug.com/591099 fast/canvas/canvas-shadow-source-in.html [ Failure Pass ] -crbug.com/591099 fast/canvas/canvas-skia-excessive-size.html [ Crash ] -crbug.com/591099 fast/canvas/canvas-strokePath-alpha-shadow.html [ Crash ] -crbug.com/591099 fast/canvas/canvas-strokePath-cap-join.html [ Crash ] -crbug.com/591099 fast/canvas/canvas-strokePath-gradient-shadow.html [ Crash ] -crbug.com/591099 fast/canvas/canvas-strokePath-shadow.html [ Crash ] -crbug.com/591099 fast/canvas/canvas-strokeRect-alpha-shadow.html [ Crash ] -crbug.com/591099 fast/canvas/canvas-strokeRect-gradient-shadow.html [ Crash ] +crbug.com/591099 fast/canvas/canvas-skia-excessive-size.html [ Crash Pass ] +crbug.com/591099 fast/canvas/canvas-strokePath-alpha-shadow.html [ Crash Pass ] +crbug.com/591099 fast/canvas/canvas-strokePath-cap-join.html [ Crash Pass ] +crbug.com/591099 fast/canvas/canvas-strokePath-gradient-shadow.html [ Crash Pass ] +crbug.com/591099 fast/canvas/canvas-strokePath-shadow.html [ Crash Pass ] +crbug.com/591099 fast/canvas/canvas-strokeRect-alpha-shadow.html [ Crash Pass ] +crbug.com/591099 fast/canvas/canvas-strokeRect-gradient-shadow.html [ Crash Pass ] crbug.com/591099 fast/canvas/canvas-text-baseline-tiny-fonts.html [ Failure Pass ] -crbug.com/591099 fast/canvas/canvas-text-space-characters.html [ Crash ] +crbug.com/591099 fast/canvas/canvas-text-space-characters.html [ Crash Pass ] crbug.com/591099 fast/canvas/canvas-textMetrics-width.html [ Failure ] crbug.com/591099 fast/canvas/canvas-transforms-during-path.html [ Failure ] -crbug.com/591099 fast/canvas/canvas-transforms-fillRect-shadow.html [ Crash ] +crbug.com/591099 fast/canvas/canvas-transforms-fillRect-shadow.html [ Crash Pass ] crbug.com/591099 fast/canvas/currentTransform-null.html [ Failure ] -crbug.com/591099 fast/canvas/draw-focus-if-needed-invisible-crash.html [ Crash ] -crbug.com/591099 fast/canvas/draw-focus-if-needed-on-event.html [ Crash ] -crbug.com/591099 fast/canvas/draw-focus-if-needed-with-path2d.html [ Crash ] -crbug.com/591099 fast/canvas/draw-focus-if-needed.html [ Crash ] -crbug.com/591099 fast/canvas/drawImage-with-negative-source-destination.html [ Crash ] -crbug.com/591099 fast/canvas/fallback-content.html [ Crash ] -crbug.com/591099 fast/canvas/feimage-with-foreignobject-taint-canvas-2.html [ Crash ] -crbug.com/591099 fast/canvas/feimage-with-foreignobject-taint-canvas.html [ Crash ] +crbug.com/591099 fast/canvas/draw-focus-if-needed-invisible-crash.html [ Crash Pass ] +crbug.com/591099 fast/canvas/draw-focus-if-needed-on-event.html [ Crash Pass ] +crbug.com/591099 fast/canvas/draw-focus-if-needed-with-path2d.html [ Crash Pass ] +crbug.com/591099 fast/canvas/draw-focus-if-needed.html [ Crash Pass ] +crbug.com/591099 fast/canvas/drawImage-with-negative-source-destination.html [ Crash Pass ] +crbug.com/591099 fast/canvas/fallback-content.html [ Crash Pass ] +crbug.com/591099 fast/canvas/feimage-with-foreignobject-taint-canvas-2.html [ Crash Pass ] +crbug.com/591099 fast/canvas/feimage-with-foreignobject-taint-canvas.html [ Crash Pass ] crbug.com/591099 fast/canvas/fill-stroke-clip-reset-path.html [ Failure ] -crbug.com/591099 fast/canvas/fillText-shadow.html [ Crash ] +crbug.com/591099 fast/canvas/fillText-shadow.html [ Crash Pass ] crbug.com/591099 fast/canvas/fillrect_gradient.html [ Failure ] -crbug.com/591099 fast/canvas/font-no-zoom.html [ Crash ] -crbug.com/591099 fast/canvas/gradient-with-clip.html [ Crash ] +crbug.com/591099 fast/canvas/font-no-zoom.html [ Crash Pass ] +crbug.com/591099 fast/canvas/gradient-with-clip.html [ Crash Pass ] crbug.com/591099 fast/canvas/image-object-in-canvas.html [ Failure ] -crbug.com/591099 fast/canvas/image-with-foreignobject-taint-canvas-2.html [ Crash ] -crbug.com/591099 fast/canvas/image-with-foreignobject-taint-canvas.html [ Crash ] -crbug.com/591099 fast/canvas/painting-on-bad-canvas.html [ Crash ] -crbug.com/591099 fast/canvas/pattern-with-transform.html [ Crash ] +crbug.com/591099 fast/canvas/image-with-foreignobject-taint-canvas-2.html [ Crash Pass ] +crbug.com/591099 fast/canvas/image-with-foreignobject-taint-canvas.html [ Crash Pass ] +crbug.com/591099 fast/canvas/painting-on-bad-canvas.html [ Crash Pass ] +crbug.com/591099 fast/canvas/pattern-with-transform.html [ Crash Pass ] crbug.com/591099 fast/canvas/quadraticCurveTo.xml [ Failure ] -crbug.com/591099 fast/canvas/resize-while-save-active.html [ Crash ] -crbug.com/591099 fast/canvas/set-empty-font-crash.html [ Crash ] +crbug.com/591099 fast/canvas/resize-while-save-active.html [ Crash Pass ] +crbug.com/591099 fast/canvas/set-empty-font-crash.html [ Crash Pass ] crbug.com/591099 fast/canvas/setWidthResetAfterForcedRender.html [ Failure ] -crbug.com/591099 fast/canvas/shadow-huge-blur.html [ Crash ] +crbug.com/591099 fast/canvas/shadow-huge-blur.html [ Crash Pass ] crbug.com/591099 fast/canvas/shadow-offset-1.html [ Failure ] crbug.com/591099 fast/canvas/toDataURL-alpha.html [ Failure ] -crbug.com/591099 fast/canvas/toDataURL-noData.html [ Crash ] +crbug.com/591099 fast/canvas/toDataURL-noData.html [ Crash Pass ] crbug.com/591099 fast/canvas/toDataURL-supportedTypes.html [ Failure ] -crbug.com/591099 fast/canvas/transformed-canvas-reset.html [ Crash ] +crbug.com/591099 fast/canvas/transformed-canvas-reset.html [ Crash Pass ] crbug.com/591099 fast/canvas/unclosed-canvas-1.html [ Failure ] crbug.com/591099 fast/canvas/unclosed-canvas-3.html [ Failure ] crbug.com/591099 fast/canvas/unclosed-canvas-4.html [ Failure ] @@ -7282,11 +7290,11 @@ crbug.com/591099 fast/canvas/webgl/renderer-and-vendor-strings.html [ Failure ] crbug.com/591099 fast/canvas/webgl/shader-deleted-by-accessor.html [ Failure ] crbug.com/591099 fast/canvas/webgl/tex-sub-image-cube-maps.html [ Failure ] -crbug.com/591099 fast/canvas/webgl/texImage-imageBitmap-from-canvas-resize.html [ Crash ] +crbug.com/591099 fast/canvas/webgl/texImage-imageBitmap-from-canvas-resize.html [ Crash Pass ] crbug.com/591099 fast/canvas/webgl/texture-color-profile.html [ Failure ] crbug.com/591099 fast/canvas/webgl/webgl-texture-binding-preserved.html [ Failure ] crbug.com/591099 fast/canvas/webgl/webgl-viewport-parameters-preserved.html [ Failure ] -crbug.com/591099 fast/canvas/zero-size-fill-rect.html [ Crash ] +crbug.com/591099 fast/canvas/zero-size-fill-rect.html [ Crash Pass ] crbug.com/591099 fast/clip/001.html [ Failure ] crbug.com/591099 fast/clip/004.html [ Failure ] crbug.com/591099 fast/clip/008.html [ Failure ] @@ -7332,7 +7340,7 @@ crbug.com/591099 fast/css-generated-content/beforeAfter-interdocument.html [ Failure ] crbug.com/591099 fast/css-generated-content/block-after.html [ Failure ] crbug.com/591099 fast/css-generated-content/bug-106384.html [ Failure ] -crbug.com/591099 fast/css-generated-content/crash-selection-editing-removes-pseudo.html [ Crash ] +crbug.com/591099 fast/css-generated-content/crash-selection-editing-removes-pseudo.html [ Crash Failure ] crbug.com/591099 fast/css-generated-content/details-before-after-content.html [ Crash Failure ] crbug.com/591099 fast/css-generated-content/drag-state.html [ Failure ] crbug.com/591099 fast/css-generated-content/empty-content-with-float-crash.html [ Failure ] @@ -7415,7 +7423,7 @@ crbug.com/591099 fast/css-grid-layout/grid-auto-flow-update.html [ Failure ] crbug.com/591099 fast/css-grid-layout/grid-auto-repeat-inherit-initial-crash.html [ Failure ] crbug.com/591099 fast/css-grid-layout/grid-automatic-minimum-for-auto-rows.html [ Failure ] -crbug.com/591099 fast/css-grid-layout/grid-baseline-must-respect-grid-order.html [ Crash ] +crbug.com/591099 fast/css-grid-layout/grid-baseline-must-respect-grid-order.html [ Crash Failure ] crbug.com/591099 fast/css-grid-layout/grid-change-fit-content-argument.html [ Failure ] crbug.com/591099 fast/css-grid-layout/grid-columns-rows-get-set-multiple.html [ Timeout ] crbug.com/591099 fast/css-grid-layout/grid-columns-rows-get-set.html [ Timeout ] @@ -7639,7 +7647,7 @@ crbug.com/591099 fast/css-intrinsic-dimensions/fit-content-container-with-replaced-child.html [ Crash Failure Pass ] crbug.com/591099 fast/css-intrinsic-dimensions/fitcontent-minmax-content-inlinesize-contribution-nonreplaced-blocks.html [ Crash Failure ] crbug.com/591099 fast/css-intrinsic-dimensions/fixed-height-stf-img-block-child-percent-height.html [ Failure ] -crbug.com/591099 fast/css-intrinsic-dimensions/fixed-height-stf-img-inline-child-percent-height.html [ Crash ] +crbug.com/591099 fast/css-intrinsic-dimensions/fixed-height-stf-img-inline-child-percent-height.html [ Crash Failure ] crbug.com/591099 fast/css-intrinsic-dimensions/height-css-tables.html [ Failure ] crbug.com/591099 fast/css-intrinsic-dimensions/height-flexbox.html [ Failure Pass ] crbug.com/591099 fast/css-intrinsic-dimensions/height-positioned.html [ Crash Failure ] @@ -7672,9 +7680,9 @@ crbug.com/591099 fast/css/absolute-child-with-percent-height-inside-relative-parent.html [ Failure ] crbug.com/591099 fast/css/absolute-child-with-percent-padding-inside-relative-parent.html [ Failure Pass ] crbug.com/591099 fast/css/absolute-poition-in-rtl-parent.html [ Failure ] -crbug.com/591099 fast/css/acid2-pixel.html [ Crash ] -crbug.com/591099 fast/css/acid2.html [ Crash ] -crbug.com/591099 fast/css/active-pseudo-and-focus-move.html [ Crash ] +crbug.com/591099 fast/css/acid2-pixel.html [ Crash Failure ] +crbug.com/591099 fast/css/acid2.html [ Crash Failure ] +crbug.com/591099 fast/css/active-pseudo-and-focus-move.html [ Crash Pass ] crbug.com/591099 fast/css/all-shorthand-css-text.html [ Failure ] crbug.com/591099 fast/css/all-shorthand-first-letter.html [ Failure ] crbug.com/591099 fast/css/annotated-regions.html [ Failure ] @@ -7723,7 +7731,7 @@ crbug.com/591099 fast/css/box-sizing-backwards-compat-prefix.html [ Failure ] crbug.com/591099 fast/css/box-sizing-border-box-dynamic-padding-border-update.html [ Failure ] crbug.com/591099 fast/css/bug4860-absolute-block-child-does-not-inherit-alignment.html [ Failure ] -crbug.com/591099 fast/css/button-height.html [ Crash ] +crbug.com/591099 fast/css/button-height.html [ Crash Failure ] crbug.com/591099 fast/css/button-inner-child-crash.html [ Crash Pass ] crbug.com/591099 fast/css/calc-rounding.html [ Failure ] crbug.com/591099 fast/css/caption-width-absolute-position-offset-top.htm [ Failure ] @@ -7761,9 +7769,9 @@ crbug.com/591099 fast/css/computed-image-width-with-percent-height-quirksmode.html [ Failure ] crbug.com/591099 fast/css/computed-offset-with-zoom.html [ Failure ] crbug.com/591099 fast/css/containment/size-and-layout-containment.html [ Crash Failure ] -crbug.com/591099 fast/css/content-disallowed-url-crash.html [ Crash ] +crbug.com/591099 fast/css/content-disallowed-url-crash.html [ Crash Pass ] crbug.com/591099 fast/css/content-distributed-nodes.html [ Failure ] -crbug.com/591099 fast/css/content-image-set-disallowed-url-crash.html [ Crash ] +crbug.com/591099 fast/css/content-image-set-disallowed-url-crash.html [ Crash Pass ] crbug.com/591099 fast/css/content-language-case-insensitivity.html [ Failure ] crbug.com/591099 fast/css/content-language-comma-separated-list.html [ Failure ] crbug.com/591099 fast/css/content-language-dynamically-added.html [ Failure ] @@ -7800,14 +7808,14 @@ crbug.com/591099 fast/css/counters/counter-reset-000.html [ Failure ] crbug.com/591099 fast/css/counters/counter-reset-001.html [ Failure ] crbug.com/591099 fast/css/counters/counter-reset-002.html [ Failure ] -crbug.com/591099 fast/css/counters/counter-traverse-object-crash.html [ Crash ] +crbug.com/591099 fast/css/counters/counter-traverse-object-crash.html [ Crash Pass ] crbug.com/591099 fast/css/counters/counter-traverse-table-cell.html [ Failure ] crbug.com/591099 fast/css/counters/invalidate-cached-counter-node.html [ Failure ] crbug.com/591099 fast/css/counters/nesting.html [ Failure ] crbug.com/591099 fast/css/counters/remove-anonymous-block-wrapper-crash.html [ Crash Failure ] crbug.com/591099 fast/css/crash-corner-present.html [ Failure ] -crbug.com/591099 fast/css/crash-in-attachFirstLetterTextLayoutObjects.html [ Crash ] -crbug.com/591099 fast/css/crash-layout-detached-document.html [ Crash ] +crbug.com/591099 fast/css/crash-in-attachFirstLetterTextLayoutObjects.html [ Crash Pass ] +crbug.com/591099 fast/css/crash-layout-detached-document.html [ Crash Failure ] crbug.com/591099 fast/css/create_element_align.xhtml [ Failure ] crbug.com/591099 fast/css/css-imports.html [ Failure ] crbug.com/591099 fast/css/css-keyframe-style-parentRule.html [ Failure ] @@ -7869,7 +7877,7 @@ crbug.com/591099 fast/css/first-letter-float-after-float.html [ Failure ] crbug.com/591099 fast/css/first-letter-float.html [ Failure ] crbug.com/591099 fast/css/first-letter-hover.html [ Failure ] -crbug.com/591099 fast/css/first-letter-inline-flow-split-table-crash.html [ Crash ] +crbug.com/591099 fast/css/first-letter-inline-flow-split-table-crash.html [ Crash Pass ] crbug.com/591099 fast/css/first-letter-nested.html [ Failure ] crbug.com/591099 fast/css/first-letter-recalculation.html [ Failure Pass ] crbug.com/591099 fast/css/first-letter-removed-added.html [ Failure ] @@ -7892,7 +7900,7 @@ crbug.com/591099 fast/css/focus-ring-recursive-inlines.html [ Failure ] crbug.com/591099 fast/css/font-face-add-same-family-later.html [ Failure ] crbug.com/591099 fast/css/font-face-cache-bug.html [ Crash Failure ] -crbug.com/591099 fast/css/font-face-cache-version.html [ Crash ] +crbug.com/591099 fast/css/font-face-cache-version.html [ Crash Pass ] crbug.com/591099 fast/css/font-face-data-uri-invalid.html [ Failure ] crbug.com/591099 fast/css/font-face-data-uri.html [ Failure ] crbug.com/591099 fast/css/font-face-descending-unicode-range.html [ Failure ] @@ -7932,7 +7940,7 @@ crbug.com/591099 fast/css/fontface-methods.html [ Failure ] crbug.com/591099 fast/css/fontface-properties.html [ Failure ] crbug.com/591099 fast/css/fontface-single-font-family.html [ Failure ] -crbug.com/591099 fast/css/fontfaceset-cross-frame.html [ Crash ] +crbug.com/591099 fast/css/fontfaceset-cross-frame.html [ Crash Pass ] crbug.com/591099 fast/css/fontfaceset-download-error.html [ Failure ] crbug.com/591099 fast/css/fontfaceset-events.html [ Failure ] crbug.com/591099 fast/css/fontfaceset-in-detached-frame.html [ Failure ] @@ -7991,7 +7999,7 @@ crbug.com/591099 fast/css/getComputedStyle/getComputedStyle-outline-offset.html [ Failure ] crbug.com/591099 fast/css/getComputedStyle/getComputedStyle-outline-shorthand.html [ Failure ] crbug.com/591099 fast/css/getComputedStyle/getComputedStyle-padding-shorthand.html [ Failure ] -crbug.com/591099 fast/css/getComputedStyle/getComputedStyle-resolved-values.html [ Crash ] +crbug.com/591099 fast/css/getComputedStyle/getComputedStyle-resolved-values.html [ Crash Timeout ] crbug.com/591099 fast/css/getComputedStyle/getComputedStyle-text-decoration.html [ Failure ] crbug.com/591099 fast/css/getComputedStyle/getComputedStyle-text-overflow.html [ Failure ] crbug.com/591099 fast/css/getComputedStyle/getComputedStyle-webkit-columns-shorthand.html [ Failure ] @@ -8051,7 +8059,7 @@ crbug.com/591099 fast/css/input-search-padding.html [ Crash Failure ] crbug.com/591099 fast/css/insertRule-font-face.html [ Failure ] crbug.com/591099 fast/css/insertRule-media.html [ Failure ] -crbug.com/591099 fast/css/intruding-floats-crash.html [ Crash ] +crbug.com/591099 fast/css/intruding-floats-crash.html [ Crash Failure ] crbug.com/591099 fast/css/invalid-appearance-progress-bar-meter.html [ Failure ] crbug.com/591099 fast/css/invalid-not-with-pseudo-element.html [ Failure ] crbug.com/591099 fast/css/invalid-not-with-simple-selector-sequence.html [ Failure ] @@ -8083,8 +8091,8 @@ crbug.com/591099 fast/css/invalidation/full-page-media.html [ Failure ] crbug.com/591099 fast/css/invalidation/fullscreen.html [ Failure ] crbug.com/591099 fast/css/invalidation/hover-first-letter-sibling.html [ Failure ] -crbug.com/591099 fast/css/invalidation/in-and-out-of-range-pseudo.html [ Crash ] -crbug.com/591099 fast/css/invalidation/in-range-pseudo.html [ Crash ] +crbug.com/591099 fast/css/invalidation/in-and-out-of-range-pseudo.html [ Crash Pass ] +crbug.com/591099 fast/css/invalidation/in-range-pseudo.html [ Crash Pass ] crbug.com/591099 fast/css/invalidation/indeterminate-pseudo.html [ Failure ] crbug.com/591099 fast/css/invalidation/input-search-incremental.html [ Failure ] crbug.com/591099 fast/css/invalidation/invalidation-set-with-adjacent-combinators.html [ Failure ] @@ -8094,7 +8102,7 @@ crbug.com/591099 fast/css/invalidation/no-invalidation-set-local-style.html [ Failure ] crbug.com/591099 fast/css/invalidation/range-pseudo.html [ Crash Failure ] crbug.com/591099 fast/css/invalidation/read-only-write-pseudo.html [ Failure ] -crbug.com/591099 fast/css/invalidation/reattach-with-sibling-invalidation.html [ Crash ] +crbug.com/591099 fast/css/invalidation/reattach-with-sibling-invalidation.html [ Crash Failure ] crbug.com/591099 fast/css/invalidation/recalc-direct-adjacent-001.html [ Failure ] crbug.com/591099 fast/css/invalidation/recalc-direct-adjacent-002.html [ Failure ] crbug.com/591099 fast/css/invalidation/removed-hover-shadow-rule.html [ Failure ] @@ -8103,7 +8111,7 @@ crbug.com/591099 fast/css/invalidation/selection-pseudo.html [ Failure ] crbug.com/591099 fast/css/invalidation/shadow-add-sheet-content.html [ Failure ] crbug.com/591099 fast/css/invalidation/shadow-add-sheet-host.html [ Failure ] -crbug.com/591099 fast/css/invalidation/sheet-ruleset-invalidation.html [ Crash ] +crbug.com/591099 fast/css/invalidation/sheet-ruleset-invalidation.html [ Crash Pass ] crbug.com/591099 fast/css/invalidation/slotted.html [ Failure ] crbug.com/591099 fast/css/invalidation/style-update-with-added-stylesheet.html [ Failure ] crbug.com/591099 fast/css/invalidation/sub-selector-adjacent-cancellation.html [ Failure ] @@ -8164,15 +8172,15 @@ crbug.com/591099 fast/css/margin-start-end.html [ Failure ] crbug.com/591099 fast/css/margin-top-bottom-dynamic.html [ Failure ] crbug.com/591099 fast/css/marquee-in-template.html [ Crash Failure ] -crbug.com/591099 fast/css/mask-missing-image-crash.html [ Crash ] +crbug.com/591099 fast/css/mask-missing-image-crash.html [ Crash Failure ] crbug.com/591099 fast/css/matrix-as-function-crash.html [ Failure ] crbug.com/591099 fast/css/max-device-aspect-ratio.html [ Failure ] crbug.com/591099 fast/css/max-height-and-max-width.html [ Failure ] crbug.com/591099 fast/css/max-height-none.html [ Failure ] crbug.com/591099 fast/css/max-width-none.html [ Failure ] -crbug.com/591099 fast/css/media-attr-non-matching-dynamic.html [ Crash ] -crbug.com/591099 fast/css/media-query-in-supports-dynamic.html [ Crash ] -crbug.com/591099 fast/css/media-query-zero-viewport-crash.html [ Crash ] +crbug.com/591099 fast/css/media-attr-non-matching-dynamic.html [ Crash Pass ] +crbug.com/591099 fast/css/media-query-in-supports-dynamic.html [ Crash Pass ] +crbug.com/591099 fast/css/media-query-zero-viewport-crash.html [ Crash Pass ] crbug.com/591099 fast/css/media-rule-screenDepthPerComponent.html [ Failure ] crbug.com/591099 fast/css/min-device-aspect-ratio.html [ Failure ] crbug.com/591099 fast/css/min-max-width.html [ Failure ] @@ -8270,16 +8278,16 @@ crbug.com/591099 fast/css/pseudo-default-002.html [ Failure ] crbug.com/591099 fast/css/pseudo-default-003.html [ Failure ] crbug.com/591099 fast/css/pseudo-default-004.html [ Failure ] -crbug.com/591099 fast/css/pseudo-default-checkbox-radio.html [ Crash ] -crbug.com/591099 fast/css/pseudo-default-dynamic.html [ Crash ] -crbug.com/591099 fast/css/pseudo-default-option.html [ Crash ] +crbug.com/591099 fast/css/pseudo-default-checkbox-radio.html [ Crash Pass ] +crbug.com/591099 fast/css/pseudo-default-dynamic.html [ Crash Pass ] +crbug.com/591099 fast/css/pseudo-default-option.html [ Crash Pass ] crbug.com/591099 fast/css/pseudo-element-backdrop-hit-test.html [ Failure ] crbug.com/591099 fast/css/pseudo-element-line-break.html [ Failure ] crbug.com/591099 fast/css/pseudo-element-opagedxy-crash.html [ Failure ] crbug.com/591099 fast/css/pseudo-empty-adjacent-dynamic.html [ Failure ] crbug.com/591099 fast/css/pseudo-empty-display-none.html [ Failure ] crbug.com/591099 fast/css/pseudo-first-line-border-width.html [ Crash Failure ] -crbug.com/591099 fast/css/pseudo-hover-active-display-none.html [ Crash ] +crbug.com/591099 fast/css/pseudo-hover-active-display-none.html [ Crash Pass ] crbug.com/591099 fast/css/pseudo-in-range-invalid-value.html [ Crash Failure ] crbug.com/591099 fast/css/pseudo-in-range.html [ Crash Failure ] crbug.com/591099 fast/css/pseudo-invalid-001.html [ Crash Failure ] @@ -8312,7 +8320,7 @@ crbug.com/591099 fast/css/readonly-pseudoclass-opera-005.html [ Crash Failure ] crbug.com/591099 fast/css/recalc-inherit-001.html [ Failure ] crbug.com/591099 fast/css/recursive-delay-update-scroll.html [ Failure ] -crbug.com/591099 fast/css/relative-positioned-block-crash.html [ Crash ] +crbug.com/591099 fast/css/relative-positioned-block-crash.html [ Crash Pass ] crbug.com/591099 fast/css/relative-positioned-block-nested-with-inline-parent-dynamic-removed.html [ Failure ] crbug.com/591099 fast/css/relative-positioned-block-nested-with-inline-parent-dynamic.html [ Failure ] crbug.com/591099 fast/css/relative-positioned-block-nested-with-inline-parent-multiple-descendant-blocks-dynamic.html [ Failure ] @@ -8334,8 +8342,8 @@ crbug.com/591099 fast/css/remove-shorthand.html [ Crash Failure ] crbug.com/591099 fast/css/remove-style-after-insert-import-rule-crash.html [ Failure ] crbug.com/591099 fast/css/remove-stylesheet-from-shadow-form-crash.html [ Failure ] -crbug.com/591099 fast/css/render-quote-crash.html [ Crash ] -crbug.com/591099 fast/css/replaced-element-ignore-top-bottom.html [ Crash ] +crbug.com/591099 fast/css/render-quote-crash.html [ Crash Pass ] +crbug.com/591099 fast/css/replaced-element-ignore-top-bottom.html [ Crash Pass ] crbug.com/591099 fast/css/replaced-element-implicit-size.html [ Failure ] crbug.com/591099 fast/css/resize-corner-tracking-touch.html [ Crash Failure ] crbug.com/591099 fast/css/resize-corner-tracking-transformed-iframe.html [ Failure ] @@ -8354,7 +8362,7 @@ crbug.com/591099 fast/css/selector-set-attribute.html [ Failure ] crbug.com/591099 fast/css/selector-text-escape.html [ Crash Failure ] crbug.com/591099 fast/css/serialize-style-with-all-crash.html [ Failure ] -crbug.com/591099 fast/css/shadow-dom-scope.html [ Crash ] +crbug.com/591099 fast/css/shadow-dom-scope.html [ Crash Failure ] crbug.com/591099 fast/css/shadow-multiple.html [ Failure ] crbug.com/591099 fast/css/shadow-style-removed-out-of-document.html [ Failure ] crbug.com/591099 fast/css/sheet-collection-link.html [ Failure ] @@ -8374,7 +8382,7 @@ crbug.com/591099 fast/css/sticky/sticky-top-overflow-scroll-by-fragment.html [ Failure ] crbug.com/591099 fast/css/string-quote-binary.html [ Failure ] crbug.com/591099 fast/css/style-and-stylesheet-important.html [ Failure ] -crbug.com/591099 fast/css/style-element-process-crash.html [ Crash ] +crbug.com/591099 fast/css/style-element-process-crash.html [ Crash Pass ] crbug.com/591099 fast/css/style-outside-head.html [ Failure ] crbug.com/591099 fast/css/style-parsed-outside-head.html [ Failure ] crbug.com/591099 fast/css/style-sharing-inline-stylesheet.html [ Failure ] @@ -8423,11 +8431,11 @@ crbug.com/591099 fast/css/transition-shorthand-cssText.html [ Failure ] crbug.com/591099 fast/css/unicode-bidi-computed-value.html [ Failure ] crbug.com/591099 fast/css/universal-hover-quirk.html [ Failure ] -crbug.com/591099 fast/css/unknown-pseudo-element-matching.html [ Crash ] +crbug.com/591099 fast/css/unknown-pseudo-element-matching.html [ Crash Failure ] crbug.com/591099 fast/css/unused-data-url-fontface.html [ Failure ] crbug.com/591099 fast/css/uri-token-parsing.html [ Failure ] crbug.com/591099 fast/css/url-with-multi-byte-unicode-escape.html [ Failure ] -crbug.com/591099 fast/css/variables/matched-properties-cache-is-disabled.html [ Crash ] +crbug.com/591099 fast/css/variables/matched-properties-cache-is-disabled.html [ Crash Pass ] crbug.com/591099 fast/css/vertical-align-baseline-rowspan-003.htm [ Failure ] crbug.com/591099 fast/css/vertical-align-baseline-rowspan-004.htm [ Failure ] crbug.com/591099 fast/css/vertical-align-baseline-rowspan-005.htm [ Failure ] @@ -8524,13 +8532,13 @@ crbug.com/591099 fast/deprecated-flexbox/relpos-flex-item-with-percent-height-abspos-descendant.html [ Failure ] crbug.com/591099 fast/deprecated-flexbox/repaint-scrollbar.html [ Failure ] crbug.com/591099 fast/deprecated-flexbox/vertical-box-form-controls.html [ Failure ] -crbug.com/591099 fast/dnd/dropEffect-for-file.html [ Crash ] +crbug.com/591099 fast/dnd/dropEffect-for-file.html [ Crash Pass ] crbug.com/591099 fast/dnd/dropEffect-for-image.html [ Timeout ] crbug.com/591099 fast/doctypes/001.html [ Crash Failure ] crbug.com/591099 fast/doctypes/002.html [ Crash Failure ] crbug.com/591099 fast/doctypes/003.html [ Crash Failure ] crbug.com/591099 fast/doctypes/004.html [ Crash Failure ] -crbug.com/591099 fast/doctypes/doctype-parsing.html [ Crash ] +crbug.com/591099 fast/doctypes/doctype-parsing.html [ Crash Failure ] crbug.com/591099 fast/doctypes/xhtml-with-xhtmlmp-doctype.xhtml [ Failure ] crbug.com/591099 fast/doctypes/xhtml-with-xhtmlmp11-doctype.xhtml [ Failure ] crbug.com/591099 fast/doctypes/xhtml-with-xhtmlmp12-doctype.xhtml [ Failure ] @@ -8559,7 +8567,7 @@ crbug.com/591099 fast/dom/DOMImplementation/implementation-identity.html [ Crash Failure ] crbug.com/591099 fast/dom/Document/CaretRangeFromPoint/caretRangeFromPoint-with-before-style.html [ Failure ] crbug.com/591099 fast/dom/Document/CaretRangeFromPoint/hittest-relative-to-viewport.html [ Failure ] -crbug.com/591099 fast/dom/Document/CaretRangeFromPoint/replace-element.html [ Crash ] +crbug.com/591099 fast/dom/Document/CaretRangeFromPoint/replace-element.html [ Crash Pass ] crbug.com/591099 fast/dom/Document/clone-node.html [ Failure ] crbug.com/591099 fast/dom/Document/createAttributeNS-namespace-err.html [ Crash Failure ] crbug.com/591099 fast/dom/Document/createElement-invalid-names.html [ Failure ] @@ -8571,7 +8579,7 @@ crbug.com/591099 fast/dom/Document/document-current-script-async.html [ Failure ] crbug.com/591099 fast/dom/Document/document-current-script.html [ Failure ] crbug.com/591099 fast/dom/Document/document-elementFromPoint-empty-document.html [ Failure ] -crbug.com/591099 fast/dom/Document/document-elementFromPoint-on-option-element.html [ Crash ] +crbug.com/591099 fast/dom/Document/document-elementFromPoint-on-option-element.html [ Crash Failure ] crbug.com/591099 fast/dom/Document/document-title-get.html [ Failure ] crbug.com/591099 fast/dom/Document/document-write-doctype.html [ Failure ] crbug.com/591099 fast/dom/Document/embeds-non-html.html [ Failure ] @@ -8647,7 +8655,7 @@ crbug.com/591099 fast/dom/HTMLButtonElement/change-type.html [ Failure ] crbug.com/591099 fast/dom/HTMLButtonElement/value/getset.html [ Failure ] crbug.com/591099 fast/dom/HTMLCollection/HTMLCollection-namedItem-invalidate-no-crash.html [ Failure ] -crbug.com/591099 fast/dom/HTMLDialogElement-crash-style-recalc-after-dialog-close.html [ Crash ] +crbug.com/591099 fast/dom/HTMLDialogElement-crash-style-recalc-after-dialog-close.html [ Crash Pass ] crbug.com/591099 fast/dom/HTMLDivElement/align/getset.html [ Failure ] crbug.com/591099 fast/dom/HTMLDocument/active-element-frames.html [ Failure ] crbug.com/591099 fast/dom/HTMLDocument/active-element-gets-unforcusable.html [ Failure ] @@ -8655,15 +8663,15 @@ crbug.com/591099 fast/dom/HTMLDocument/clone-node.html [ Failure ] crbug.com/591099 fast/dom/HTMLDocument/document-open-return-value.html [ Failure ] crbug.com/591099 fast/dom/HTMLDocument/document-plugins.html [ Failure ] -crbug.com/591099 fast/dom/HTMLDocument/document-special-properties.html [ Crash ] +crbug.com/591099 fast/dom/HTMLDocument/document-special-properties.html [ Crash Failure ] crbug.com/591099 fast/dom/HTMLDocument/document-write-variadic.html [ Failure ] crbug.com/591099 fast/dom/HTMLDocument/frameless-location-bugzilla10837.html [ Failure ] crbug.com/591099 fast/dom/HTMLDocument/named-item-multiple-match.html [ Failure ] -crbug.com/591099 fast/dom/HTMLDocument/named-item-not-found.html [ Crash ] +crbug.com/591099 fast/dom/HTMLDocument/named-item-not-found.html [ Crash Pass ] crbug.com/591099 fast/dom/HTMLDocument/named-item.html [ Failure ] crbug.com/591099 fast/dom/HTMLDocument/object-by-name-or-id.html [ Crash Failure Timeout ] -crbug.com/591099 fast/dom/HTMLDocument/object-by-name-unknown-child-element.html [ Crash ] -crbug.com/591099 fast/dom/HTMLDocument/set-focus-on-valid-element.html [ Crash ] +crbug.com/591099 fast/dom/HTMLDocument/object-by-name-unknown-child-element.html [ Crash Pass ] +crbug.com/591099 fast/dom/HTMLDocument/set-focus-on-valid-element.html [ Crash Failure ] crbug.com/591099 fast/dom/HTMLDocument/title-get.html [ Failure ] crbug.com/591099 fast/dom/HTMLDocument/title-set.html [ Failure ] crbug.com/591099 fast/dom/HTMLDocument/url-getset.html [ Failure ] @@ -8698,7 +8706,7 @@ crbug.com/591099 fast/dom/HTMLElement/insertAdjacentHTML-errors.html [ Failure ] crbug.com/591099 fast/dom/HTMLElement/iscontenteditable-designmodeon-allinherit.html [ Failure ] crbug.com/591099 fast/dom/HTMLElement/iscontenteditable-designmodeon-ancestor.html [ Failure ] -crbug.com/591099 fast/dom/HTMLElement/iscontenteditable-designmodeon-subframe.html [ Crash ] +crbug.com/591099 fast/dom/HTMLElement/iscontenteditable-designmodeon-subframe.html [ Crash Failure ] crbug.com/591099 fast/dom/HTMLElement/iscontenteditable-designmodeon.html [ Failure ] crbug.com/591099 fast/dom/HTMLElement/set-false.html [ Failure ] crbug.com/591099 fast/dom/HTMLElement/set-inherit-parent-false.html [ Failure ] @@ -8713,32 +8721,32 @@ crbug.com/591099 fast/dom/HTMLFormElement/adopt-assertion.html [ Failure ] crbug.com/591099 fast/dom/HTMLFormElement/associated-elements-after-index-assertion-fail1.html [ Failure ] crbug.com/591099 fast/dom/HTMLFormElement/associated-elements-after-index-assertion-fail2.html [ Failure ] -crbug.com/591099 fast/dom/HTMLFormElement/document-deactivation-callback-crash.html [ Crash ] +crbug.com/591099 fast/dom/HTMLFormElement/document-deactivation-callback-crash.html [ Crash Failure ] crbug.com/591099 fast/dom/HTMLFormElement/elements-not-in-document.html [ Failure ] crbug.com/591099 fast/dom/HTMLFormElement/htmlformelement-indexed-getter.html [ Failure ] crbug.com/591099 fast/dom/HTMLHrElement/hr-color-noshade-attribute.html [ Failure ] crbug.com/591099 fast/dom/HTMLHtmlElement/set-version.html [ Failure ] crbug.com/591099 fast/dom/HTMLImageElement/constructor-mutation-event-dispatch.html [ Failure ] -crbug.com/591099 fast/dom/HTMLImageElement/fallback-image-moved-across-documents.html [ Crash ] +crbug.com/591099 fast/dom/HTMLImageElement/fallback-image-moved-across-documents.html [ Crash Pass ] crbug.com/591099 fast/dom/HTMLImageElement/image-alt-text.html [ Crash Failure ] crbug.com/591099 fast/dom/HTMLImageElement/image-crossOrigin.html [ Failure ] crbug.com/591099 fast/dom/HTMLImageElement/image-dynamic-width.html [ Failure ] crbug.com/591099 fast/dom/HTMLImageElement/image-innerHTML.html [ Failure ] -crbug.com/591099 fast/dom/HTMLImageElement/image-load-cross-document.html [ Crash ] +crbug.com/591099 fast/dom/HTMLImageElement/image-load-cross-document.html [ Crash Failure ] crbug.com/591099 fast/dom/HTMLImageElement/image-longdesc-absolute-url.html [ Failure ] crbug.com/591099 fast/dom/HTMLImageElement/image-lowsrc-getset.html [ Failure ] -crbug.com/591099 fast/dom/HTMLImageElement/image-natural-width-height-svg.html [ Crash ] -crbug.com/591099 fast/dom/HTMLImageElement/image-sizes-1x.html [ Crash ] +crbug.com/591099 fast/dom/HTMLImageElement/image-natural-width-height-svg.html [ Crash Pass ] +crbug.com/591099 fast/dom/HTMLImageElement/image-sizes-1x.html [ Crash Pass ] crbug.com/591099 fast/dom/HTMLImageElement/image-src-absolute-url.html [ Failure ] -crbug.com/591099 fast/dom/HTMLImageElement/image-srcset-1x.html [ Crash ] -crbug.com/591099 fast/dom/HTMLImageElement/image-srcset-duplicate-elimination.html [ Crash ] +crbug.com/591099 fast/dom/HTMLImageElement/image-srcset-1x.html [ Crash Pass ] +crbug.com/591099 fast/dom/HTMLImageElement/image-srcset-duplicate-elimination.html [ Crash Pass ] crbug.com/591099 fast/dom/HTMLImageElement/image-srcset-invalid-url-no-crash.html [ Crash Failure ] -crbug.com/591099 fast/dom/HTMLImageElement/image-srcset-react-to-media-changes-when-image-not-changed.html [ Crash ] -crbug.com/591099 fast/dom/HTMLImageElement/image-srcset-react-to-media-changes-when-viewport-downsized.html [ Crash ] -crbug.com/591099 fast/dom/HTMLImageElement/image-srcset-w-onerror.html [ Crash Failure ] +crbug.com/591099 fast/dom/HTMLImageElement/image-srcset-react-to-media-changes-when-image-not-changed.html [ Crash Pass ] +crbug.com/591099 fast/dom/HTMLImageElement/image-srcset-react-to-media-changes-when-viewport-downsized.html [ Crash Pass ] +crbug.com/591099 fast/dom/HTMLImageElement/image-srcset-w-onerror.html [ Crash Failure Pass ] crbug.com/591099 fast/dom/HTMLImageElement/image-without-renderer-width.html [ Failure ] crbug.com/591099 fast/dom/HTMLImageElement/parse-src.html [ Failure ] -crbug.com/591099 fast/dom/HTMLImageElement/sizes-changed-intrinsic-size-update.html [ Crash ] +crbug.com/591099 fast/dom/HTMLImageElement/sizes-changed-intrinsic-size-update.html [ Crash Pass ] crbug.com/591099 fast/dom/HTMLInputElement/border-attribute-crash.html [ Crash Failure ] crbug.com/591099 fast/dom/HTMLInputElement/clone-input-checked.html [ Failure ] crbug.com/591099 fast/dom/HTMLInputElement/cloned-input-checked-state.html [ Failure ] @@ -8776,8 +8784,8 @@ crbug.com/591099 fast/dom/HTMLLinkElement/programmatically-add-link-with-onload-handler.html [ Failure ] crbug.com/591099 fast/dom/HTMLLinkElement/resolve-url-on-insertion.html [ Failure ] crbug.com/591099 fast/dom/HTMLMeterElement/meter-boundary-values.html [ Crash Failure ] -crbug.com/591099 fast/dom/HTMLMeterElement/meter-element-crash.html [ Crash ] -crbug.com/591099 fast/dom/HTMLMeterElement/meter-element-markup.html [ Crash ] +crbug.com/591099 fast/dom/HTMLMeterElement/meter-element-crash.html [ Crash Pass ] +crbug.com/591099 fast/dom/HTMLMeterElement/meter-element-markup.html [ Crash Pass ] crbug.com/591099 fast/dom/HTMLMeterElement/meter-element-repaint-on-update-value.html [ Failure ] crbug.com/591099 fast/dom/HTMLMeterElement/meter-element-with-child-crash.html [ Failure ] crbug.com/591099 fast/dom/HTMLMeterElement/meter-element.html [ Failure ] @@ -8786,10 +8794,10 @@ crbug.com/591099 fast/dom/HTMLMeterElement/meter-styles-changing-pseudo.html [ Failure ] crbug.com/591099 fast/dom/HTMLMeterElement/meter-styles.html [ Crash Failure ] crbug.com/591099 fast/dom/HTMLMeterElement/set-meter-properties.html [ Failure ] -crbug.com/591099 fast/dom/HTMLObjectElement/HTMLObject-contentWindow-query.html [ Crash ] -crbug.com/591099 fast/dom/HTMLObjectElement/children-changed.html [ Crash ] -crbug.com/591099 fast/dom/HTMLObjectElement/fallback-content-behaviour.html [ Crash ] -crbug.com/591099 fast/dom/HTMLObjectElement/form/nested-form-element.html [ Crash ] +crbug.com/591099 fast/dom/HTMLObjectElement/HTMLObject-contentWindow-query.html [ Crash Pass ] +crbug.com/591099 fast/dom/HTMLObjectElement/children-changed.html [ Crash Pass ] +crbug.com/591099 fast/dom/HTMLObjectElement/fallback-content-behaviour.html [ Crash Failure ] +crbug.com/591099 fast/dom/HTMLObjectElement/form/nested-form-element.html [ Crash Failure ] crbug.com/591099 fast/dom/HTMLObjectElement/form/test1.html [ Failure ] crbug.com/591099 fast/dom/HTMLObjectElement/update-data.html [ Failure ] crbug.com/591099 fast/dom/HTMLObjectElement/vspace-hspace-as-number.html [ Failure ] @@ -8860,7 +8868,7 @@ crbug.com/591099 fast/dom/MutationObserver/observe-attributes.html [ Failure Timeout ] crbug.com/591099 fast/dom/MutationObserver/observe-characterdata.html [ Failure ] crbug.com/591099 fast/dom/MutationObserver/observe-childList.html [ Failure ] -crbug.com/591099 fast/dom/MutationObserver/observe-element-resize.html [ Crash ] +crbug.com/591099 fast/dom/MutationObserver/observe-element-resize.html [ Crash Pass ] crbug.com/591099 fast/dom/MutationObserver/observe-exceptions.html [ Failure ] crbug.com/591099 fast/dom/MutationObserver/observe-options-character-data.html [ Failure ] crbug.com/591099 fast/dom/MutationObserver/observe-subtree.html [ Failure ] @@ -8880,7 +8888,7 @@ crbug.com/591099 fast/dom/Node/initial-values.html [ Failure ] crbug.com/591099 fast/dom/Node/isEqualNode.html [ Failure ] crbug.com/591099 fast/dom/Node/isSupported.html [ Failure ] -crbug.com/591099 fast/dom/Node/mutation-blur.html [ Crash ] +crbug.com/591099 fast/dom/Node/mutation-blur.html [ Crash Failure ] crbug.com/591099 fast/dom/Node/normalize-with-cdata.html [ Failure ] crbug.com/591099 fast/dom/NodeIterator/detach-no-op.html [ Failure ] crbug.com/591099 fast/dom/NodeList/5725058-crash-scenario-1.html [ Failure ] @@ -8893,7 +8901,7 @@ crbug.com/591099 fast/dom/NodeList/nodelist-item-call-as-function.html [ Failure ] crbug.com/591099 fast/dom/NodeList/nodelist-item-with-index.html [ Failure ] crbug.com/591099 fast/dom/NodeList/nodelist-item-with-name.html [ Failure ] -crbug.com/591099 fast/dom/NodeList/nodelist-iterable.html [ Crash ] +crbug.com/591099 fast/dom/NodeList/nodelist-iterable.html [ Crash Pass ] crbug.com/591099 fast/dom/NodeList/nodelist-namespace-invalidation.html [ Failure ] crbug.com/591099 fast/dom/Range-insertNode-crash.html [ Failure ] crbug.com/591099 fast/dom/Range/13000.html [ Failure ] @@ -8922,7 +8930,7 @@ crbug.com/591099 fast/dom/Range/deleted-range-endpoints.html [ Failure ] crbug.com/591099 fast/dom/Range/detach-no-op.html [ Failure ] crbug.com/591099 fast/dom/Range/getClientRects-leading-trailing-whitespaces.html [ Failure ] -crbug.com/591099 fast/dom/Range/getClientRects.html [ Crash ] +crbug.com/591099 fast/dom/Range/getClientRects.html [ Crash Failure ] crbug.com/591099 fast/dom/Range/insertNode-empty-fragment-crash.html [ Failure ] crbug.com/591099 fast/dom/Range/range-clone-empty.html [ Failure ] crbug.com/591099 fast/dom/Range/range-constructor.html [ Failure ] @@ -8961,8 +8969,8 @@ crbug.com/591099 fast/dom/SelectorAPI/viewless-document.html [ Failure ] crbug.com/591099 fast/dom/StyleSheet/css-medialist-item.html [ Failure ] crbug.com/591099 fast/dom/StyleSheet/detached-parent-rule-without-wrapper.html [ Failure ] -crbug.com/591099 fast/dom/StyleSheet/detached-sheet-owner-node-link.html [ Crash ] -crbug.com/591099 fast/dom/StyleSheet/detached-sheet-owner-node.html [ Crash ] +crbug.com/591099 fast/dom/StyleSheet/detached-sheet-owner-node-link.html [ Crash Failure ] +crbug.com/591099 fast/dom/StyleSheet/detached-sheet-owner-node.html [ Crash Failure ] crbug.com/591099 fast/dom/StyleSheet/detached-style-2.html [ Failure ] crbug.com/591099 fast/dom/StyleSheet/detached-style-pi-2.xhtml [ Failure ] crbug.com/591099 fast/dom/StyleSheet/detached-style-pi.xhtml [ Failure ] @@ -9010,25 +9018,25 @@ crbug.com/591099 fast/dom/Window/getMatchedCSSRules-with-pseudo-elements.html [ Failure ] crbug.com/591099 fast/dom/Window/global-opener-function.html [ Crash Failure ] crbug.com/591099 fast/dom/Window/invalid-protocol.html [ Failure ] -crbug.com/591099 fast/dom/Window/lookup-behavior.html [ Crash ] +crbug.com/591099 fast/dom/Window/lookup-behavior.html [ Crash Pass ] crbug.com/591099 fast/dom/Window/mozilla-focus-blur.html [ Failure ] crbug.com/591099 fast/dom/Window/name-and-opener-on-detached-window.html [ Failure ] crbug.com/591099 fast/dom/Window/navigated-window-properties.html [ Failure ] crbug.com/591099 fast/dom/Window/new-window-opener.html [ Failure ] crbug.com/591099 fast/dom/Window/open-after-frame-detached.html [ Failure ] -crbug.com/591099 fast/dom/Window/open-as-popup-vs-tab.html [ Crash ] +crbug.com/591099 fast/dom/Window/open-as-popup-vs-tab.html [ Crash Pass ] crbug.com/591099 fast/dom/Window/open-existing-pop-up-blocking.html [ Failure ] crbug.com/591099 fast/dom/Window/open-invalid-arguments.html [ Failure ] crbug.com/591099 fast/dom/Window/post-message-crash.html [ Failure ] -crbug.com/591099 fast/dom/Window/post-message-detach-in-handler.html [ Crash ] +crbug.com/591099 fast/dom/Window/post-message-detach-in-handler.html [ Crash Failure ] crbug.com/591099 fast/dom/Window/post-message-to-self.html [ Failure ] crbug.com/591099 fast/dom/Window/property-access-in-closure-after-navigation.html [ Failure ] crbug.com/591099 fast/dom/Window/property-access-on-cached-properties-after-frame-navigated.html [ Failure ] -crbug.com/591099 fast/dom/Window/property-access-on-cached-properties-after-frame-removed-and-gced.html [ Crash ] -crbug.com/591099 fast/dom/Window/property-access-on-cached-properties-after-frame-removed.html [ Crash ] +crbug.com/591099 fast/dom/Window/property-access-on-cached-properties-after-frame-removed-and-gced.html [ Crash Failure ] +crbug.com/591099 fast/dom/Window/property-access-on-cached-properties-after-frame-removed.html [ Crash Failure ] crbug.com/591099 fast/dom/Window/property-access-on-cached-window-after-frame-navigated.html [ Timeout ] -crbug.com/591099 fast/dom/Window/property-access-on-cached-window-after-frame-removed-and-gced.html [ Crash ] -crbug.com/591099 fast/dom/Window/property-access-on-cached-window-after-frame-removed.html [ Crash ] +crbug.com/591099 fast/dom/Window/property-access-on-cached-window-after-frame-removed-and-gced.html [ Crash Failure ] +crbug.com/591099 fast/dom/Window/property-access-on-cached-window-after-frame-removed.html [ Crash Failure ] crbug.com/591099 fast/dom/Window/querySelectorAll-with-pseudo-elements.html [ Failure ] crbug.com/591099 fast/dom/Window/remove-timeout-crash.html [ Failure ] crbug.com/591099 fast/dom/Window/replaceable.html [ Failure ] @@ -9053,7 +9061,7 @@ crbug.com/591099 fast/dom/Window/window-lookup-precedence.html [ Crash Timeout ] crbug.com/591099 fast/dom/Window/window-object-cross-frame-calls.html [ Failure ] crbug.com/591099 fast/dom/Window/window-onFocus.html [ Crash Failure ] -crbug.com/591099 fast/dom/Window/window-open-no-multiple-windows-from-iframe.html [ Crash ] +crbug.com/591099 fast/dom/Window/window-open-no-multiple-windows-from-iframe.html [ Crash Pass ] crbug.com/591099 fast/dom/Window/window-open-pending-url.html [ Failure ] crbug.com/591099 fast/dom/Window/window-open-with-different-active-and-opener-windows.html [ Failure ] crbug.com/591099 fast/dom/Window/window-postmessage-args.html [ Failure ] @@ -9091,13 +9099,13 @@ crbug.com/591099 fast/dom/blur-contenteditable.html [ Failure ] crbug.com/591099 fast/dom/boolean-attribute-reflection.html [ Failure ] crbug.com/591099 fast/dom/call-a-constructor-as-a-function.html [ Failure ] -crbug.com/591099 fast/dom/canvas-fallback-focus-crash.html [ Crash ] +crbug.com/591099 fast/dom/canvas-fallback-focus-crash.html [ Crash Pass ] crbug.com/591099 fast/dom/canvasContext2d-element-attribute-js-null.html [ Failure ] crbug.com/591099 fast/dom/characterdata-api-arguments.html [ Failure ] crbug.com/591099 fast/dom/children-nodes.html [ Failure ] crbug.com/591099 fast/dom/class-all-whitespace.html [ Failure ] crbug.com/591099 fast/dom/click-method-on-html-element.html [ Failure ] -crbug.com/591099 fast/dom/clientWidthAfterDocumentIsRemoved.html [ Crash ] +crbug.com/591099 fast/dom/clientWidthAfterDocumentIsRemoved.html [ Crash Failure ] crbug.com/591099 fast/dom/clone-contents-0-end-offset.html [ Failure ] crbug.com/591099 fast/dom/clone-node-dynamic-style.html [ Failure ] crbug.com/591099 fast/dom/clone-node-load-event-crash.html [ Failure Pass ] @@ -9116,7 +9124,7 @@ crbug.com/591099 fast/dom/console-log-stack-overflow.html [ Failure ] crbug.com/591099 fast/dom/constants.html [ Crash Failure ] crbug.com/591099 fast/dom/constructed-objects-prototypes.html [ Failure ] -crbug.com/591099 fast/dom/constructor-in-removed-frame.html [ Crash ] +crbug.com/591099 fast/dom/constructor-in-removed-frame.html [ Crash Pass ] crbug.com/591099 fast/dom/constructor-proto.html [ Failure ] crbug.com/591099 fast/dom/constructors-cached.html [ Failure ] crbug.com/591099 fast/dom/constructors-overriding.html [ Failure ] @@ -9126,7 +9134,7 @@ crbug.com/591099 fast/dom/createDocumentType.html [ Failure ] crbug.com/591099 fast/dom/createElementNS-empty-namespace.html [ Failure ] crbug.com/591099 fast/dom/createElementNS-namespace-errors.html [ Failure ] -crbug.com/591099 fast/dom/cross-frame-accessor-throw.html [ Crash ] +crbug.com/591099 fast/dom/cross-frame-accessor-throw.html [ Crash Pass ] crbug.com/591099 fast/dom/cross-frame-node-prototype.html [ Failure ] crbug.com/591099 fast/dom/css-cached-import-rule.html [ Failure ] crbug.com/591099 fast/dom/css-element-attribute-js-null.html [ Failure ] @@ -9143,12 +9151,12 @@ crbug.com/591099 fast/dom/css-set-property-exception.html [ Crash Failure ] crbug.com/591099 fast/dom/css-shorthand-common-value.html [ Failure ] crbug.com/591099 fast/dom/css-stylesheet-candidate-ordering.html [ Failure ] -crbug.com/591099 fast/dom/cssTarget-crash.html [ Crash ] -crbug.com/591099 fast/dom/custom/callback-context.html [ Crash ] +crbug.com/591099 fast/dom/cssTarget-crash.html [ Crash Pass ] +crbug.com/591099 fast/dom/custom/callback-context.html [ Crash Pass ] crbug.com/591099 fast/dom/custom/callback-timing.html [ Failure ] crbug.com/591099 fast/dom/custom/constructor-calls-created-synchronously.html [ Failure ] -crbug.com/591099 fast/dom/custom/crash-without-dom-wrapper.html [ Crash ] -crbug.com/591099 fast/dom/custom/created-callback.html [ Crash ] +crbug.com/591099 fast/dom/custom/crash-without-dom-wrapper.html [ Crash Pass ] +crbug.com/591099 fast/dom/custom/created-callback.html [ Crash Pass ] crbug.com/591099 fast/dom/custom/document-register-basic.html [ Failure ] crbug.com/591099 fast/dom/custom/document-register-namespace.html [ Failure ] crbug.com/591099 fast/dom/custom/document-register-reentrant-null-constructor.html [ Failure ] @@ -9161,7 +9169,7 @@ crbug.com/591099 fast/dom/custom/exception-from-constructor.html [ Failure ] crbug.com/591099 fast/dom/custom/frameElement-crash.html [ Failure ] crbug.com/591099 fast/dom/custom/html-element-type-extension-assert.html [ Failure ] -crbug.com/591099 fast/dom/custom/imports-custom-element-abort.html [ Crash ] +crbug.com/591099 fast/dom/custom/imports-custom-element-abort.html [ Crash Pass ] crbug.com/591099 fast/dom/custom/isolated-world.html [ Failure ] crbug.com/591099 fast/dom/custom/lifecycle-created-createElement-reentrancy.html [ Failure ] crbug.com/591099 fast/dom/custom/lifecycle-created-creation-api.html [ Failure ] @@ -9169,18 +9177,18 @@ crbug.com/591099 fast/dom/custom/lifecycle-created-parser-script.html [ Failure ] crbug.com/591099 fast/dom/custom/lifecycle-created-paste.html [ Failure ] crbug.com/591099 fast/dom/custom/prerender-insert-after-stop.html [ Failure ] -crbug.com/591099 fast/dom/custom/registration-context-delete-during-attribute-changed-retrieval.html [ Crash ] -crbug.com/591099 fast/dom/custom/registration-context-delete-during-attribute-changed.html [ Crash ] -crbug.com/591099 fast/dom/custom/registration-context-delete-during-callback-recursion.html [ Crash ] -crbug.com/591099 fast/dom/custom/registration-context-delete-during-register-base-constructor-retrieval.html [ Crash ] -crbug.com/591099 fast/dom/custom/registration-context-delete-during-register-created-retrieval.html [ Crash ] -crbug.com/591099 fast/dom/custom/registration-context-delete-during-register-extends-retrieval-and-throw.html [ Crash ] -crbug.com/591099 fast/dom/custom/registration-context-delete-during-register-extends-retrieval.html [ Crash ] -crbug.com/591099 fast/dom/custom/registration-context-delete-during-register-prototype-retrieval-and-throw.html [ Crash ] -crbug.com/591099 fast/dom/custom/registration-context-delete-during-register-prototype-retrieval.html [ Crash ] -crbug.com/591099 fast/dom/custom/registration-context-delete-during-upgrade.html [ Crash ] -crbug.com/591099 fast/dom/custom/registration-context-delete-then-register.html [ Crash ] -crbug.com/591099 fast/dom/custom/registration-context-sharing.html [ Crash ] +crbug.com/591099 fast/dom/custom/registration-context-delete-during-attribute-changed-retrieval.html [ Crash Failure ] +crbug.com/591099 fast/dom/custom/registration-context-delete-during-attribute-changed.html [ Crash Failure ] +crbug.com/591099 fast/dom/custom/registration-context-delete-during-callback-recursion.html [ Crash Failure ] +crbug.com/591099 fast/dom/custom/registration-context-delete-during-register-base-constructor-retrieval.html [ Crash Failure ] +crbug.com/591099 fast/dom/custom/registration-context-delete-during-register-created-retrieval.html [ Crash Failure ] +crbug.com/591099 fast/dom/custom/registration-context-delete-during-register-extends-retrieval-and-throw.html [ Crash Failure ] +crbug.com/591099 fast/dom/custom/registration-context-delete-during-register-extends-retrieval.html [ Crash Failure ] +crbug.com/591099 fast/dom/custom/registration-context-delete-during-register-prototype-retrieval-and-throw.html [ Crash Failure ] +crbug.com/591099 fast/dom/custom/registration-context-delete-during-register-prototype-retrieval.html [ Crash Failure ] +crbug.com/591099 fast/dom/custom/registration-context-delete-during-upgrade.html [ Crash Failure ] +crbug.com/591099 fast/dom/custom/registration-context-delete-then-register.html [ Crash Failure ] +crbug.com/591099 fast/dom/custom/registration-context-sharing.html [ Crash Pass ] crbug.com/591099 fast/dom/custom/reparent-unwrapped-custom-element-crash.html [ Crash Pass ] crbug.com/591099 fast/dom/custom/type-extension-undo-assert.html [ Failure ] crbug.com/591099 fast/dom/custom/unresolved-pseudoclass.html [ Failure ] @@ -9188,7 +9196,7 @@ crbug.com/591099 fast/dom/custom/upgrade-candidate-remove-crash.html [ Failure ] crbug.com/591099 fast/dom/dataset-gc.html [ Failure ] crbug.com/591099 fast/dom/dataset-xhtml.xhtml [ Crash Failure ] -crbug.com/591099 fast/dom/defaultView-on-detached-document.html [ Crash ] +crbug.com/591099 fast/dom/defaultView-on-detached-document.html [ Crash Failure ] crbug.com/591099 fast/dom/defaultView.html [ Failure ] crbug.com/591099 fast/dom/dir-auto-insert-text-invalidation.html [ Failure ] crbug.com/591099 fast/dom/dir-no-body.html [ Failure ] @@ -9212,12 +9220,12 @@ crbug.com/591099 fast/dom/dom-add-optionelement.html [ Failure ] crbug.com/591099 fast/dom/dom-constructors.html [ Failure ] crbug.com/591099 fast/dom/dom-instanceof.html [ Failure ] -crbug.com/591099 fast/dom/domListEnumeration.html [ Crash ] +crbug.com/591099 fast/dom/domListEnumeration.html [ Crash Failure ] crbug.com/591099 fast/dom/domstring-attribute-reflection.html [ Timeout ] crbug.com/591099 fast/dom/domtimestamp-is-number.html [ Failure ] crbug.com/591099 fast/dom/element-attribute-js-null.html [ Timeout ] crbug.com/591099 fast/dom/element-bounding-client-rect-relative-to-viewport.html [ Failure ] -crbug.com/591099 fast/dom/elementFromPoint-relative-to-viewport.html [ Crash ] +crbug.com/591099 fast/dom/elementFromPoint-relative-to-viewport.html [ Crash Failure ] crbug.com/591099 fast/dom/elementsFromPoint/elementsFromPoint-iframes.html [ Failure ] crbug.com/591099 fast/dom/elementsFromPoint/elementsFromPoint-svg.html [ Failure ] crbug.com/591099 fast/dom/elementsFromPoint/elementsFromPoint-table.html [ Failure ] @@ -9233,8 +9241,8 @@ crbug.com/591099 fast/dom/exception-no-frame-timeout-crash.html [ Failure ] crbug.com/591099 fast/dom/firstline-fixed-crash.html [ Failure ] crbug.com/591099 fast/dom/focus-contenteditable.html [ Failure ] -crbug.com/591099 fast/dom/focus-navigation-in-plugin.html [ Crash ] -crbug.com/591099 fast/dom/focus-on-hidden-object.html [ Crash ] +crbug.com/591099 fast/dom/focus-navigation-in-plugin.html [ Crash Pass ] +crbug.com/591099 fast/dom/focus-on-hidden-object.html [ Crash Pass ] crbug.com/591099 fast/dom/forced-layout-only-in-document.html [ Failure ] crbug.com/591099 fast/dom/fragment-activation-focuses-target.html [ Crash Failure ] crbug.com/591099 fast/dom/frameElement-accessor-context.html [ Failure ] @@ -9261,7 +9269,7 @@ crbug.com/591099 fast/dom/getElementById-consistency5.html [ Failure ] crbug.com/591099 fast/dom/getElementsByClassName/dumpNodeList.html [ Crash Failure ] crbug.com/591099 fast/dom/getElementsByClassName/non-styled-elements.html [ Failure ] -crbug.com/591099 fast/dom/getelementsbyname-invalidation-cache.html [ Crash ] +crbug.com/591099 fast/dom/getelementsbyname-invalidation-cache.html [ Crash Failure ] crbug.com/591099 fast/dom/getter-on-window-object2.html [ Failure ] crbug.com/591099 fast/dom/global-constructors.html [ Failure ] crbug.com/591099 fast/dom/global-event-handlers.html [ Pass Timeout ] @@ -9270,7 +9278,7 @@ crbug.com/591099 fast/dom/horizontal-scrollbar-in-rtl.html [ Crash Failure ] crbug.com/591099 fast/dom/hover-after-dom-delete-child-invisible-cursor.html [ Failure ] crbug.com/591099 fast/dom/hover-after-dom-delete.html [ Failure ] -crbug.com/591099 fast/dom/hover-node-refcnt-asan-crash.html [ Crash ] +crbug.com/591099 fast/dom/hover-node-refcnt-asan-crash.html [ Crash Pass ] crbug.com/591099 fast/dom/html-collections-named-getter-mandatory-arg.html [ Failure ] crbug.com/591099 fast/dom/html-collections-named-getter.html [ Failure ] crbug.com/591099 fast/dom/html-options-collection-lifetime.html [ Failure ] @@ -9284,7 +9292,7 @@ crbug.com/591099 fast/dom/htmlcollection-protects-base.html [ Failure ] crbug.com/591099 fast/dom/htmlcollection-selectedOptions-namedItem-crash.html [ Failure ] crbug.com/591099 fast/dom/htmlformcontrolscollection-enumerated-properties.html [ Failure ] -crbug.com/591099 fast/dom/htmlformcontrolscollection-no-img.html [ Crash ] +crbug.com/591099 fast/dom/htmlformcontrolscollection-no-img.html [ Crash Pass ] crbug.com/591099 fast/dom/htmloptionscollection-enumerated-properties.html [ Failure ] crbug.com/591099 fast/dom/icon-size-property.html [ Failure ] crbug.com/591099 fast/dom/idl-dictionary-unittest.html [ Failure ] @@ -9301,11 +9309,11 @@ crbug.com/591099 fast/dom/importNodeHTML.html [ Failure ] crbug.com/591099 fast/dom/importNodeXML.xhtml [ Failure Pass ] crbug.com/591099 fast/dom/incompatible-operations.html [ Failure ] -crbug.com/591099 fast/dom/inert/inert-does-not-match-disabled-selector.html [ Crash ] -crbug.com/591099 fast/dom/inert/inert-focus-in-frames.html [ Crash ] -crbug.com/591099 fast/dom/inert/inert-inlines.html [ Crash ] -crbug.com/591099 fast/dom/inert/inert-label-focus.html [ Crash ] -crbug.com/591099 fast/dom/inert/inert-node-is-unfocusable.html [ Crash ] +crbug.com/591099 fast/dom/inert/inert-does-not-match-disabled-selector.html [ Crash Pass ] +crbug.com/591099 fast/dom/inert/inert-focus-in-frames.html [ Crash Pass ] +crbug.com/591099 fast/dom/inert/inert-inlines.html [ Crash Pass ] +crbug.com/591099 fast/dom/inert/inert-label-focus.html [ Crash Pass ] +crbug.com/591099 fast/dom/inert/inert-node-is-unfocusable.html [ Crash Pass ] crbug.com/591099 fast/dom/inline-event-attributes-crash.html [ Failure ] crbug.com/591099 fast/dom/inline-event-attributes-event-param-name.html [ Failure ] crbug.com/591099 fast/dom/inline-event-attributes-lookup-removed-form.html [ Failure ] @@ -9314,12 +9322,12 @@ crbug.com/591099 fast/dom/inline-event-attributes-moved.html [ Failure ] crbug.com/591099 fast/dom/inline-event-attributes-release.html [ Failure ] crbug.com/591099 fast/dom/inner-text-001.html [ Crash Failure ] -crbug.com/591099 fast/dom/inner-text-first-letter.html [ Crash ] +crbug.com/591099 fast/dom/inner-text-first-letter.html [ Crash Failure ] crbug.com/591099 fast/dom/inner-text-rtl.html [ Failure ] crbug.com/591099 fast/dom/inner-text.html [ Crash Failure ] -crbug.com/591099 fast/dom/insertedIntoDocument-child.html [ Crash ] +crbug.com/591099 fast/dom/insertedIntoDocument-child.html [ Crash Failure ] crbug.com/591099 fast/dom/insertedIntoDocument-no-crash.html [ Failure ] -crbug.com/591099 fast/dom/insertedIntoDocument-sibling.html [ Crash ] +crbug.com/591099 fast/dom/insertedIntoDocument-sibling.html [ Crash Failure ] crbug.com/591099 fast/dom/interface-object-proto.html [ Failure ] crbug.com/591099 fast/dom/isEqualNode-after-removeAttribute.html [ Failure ] crbug.com/591099 fast/dom/javascript-backslash.html [ Crash Failure ] @@ -9337,7 +9345,7 @@ crbug.com/591099 fast/dom/navigator-maxTouchPoints.html [ Failure ] crbug.com/591099 fast/dom/navigator-userAgent.html [ Failure ] crbug.com/591099 fast/dom/navigator-vendorSub.html [ Failure ] -crbug.com/591099 fast/dom/navigator-with-content-detached-no-crash.html [ Crash ] +crbug.com/591099 fast/dom/navigator-with-content-detached-no-crash.html [ Crash Failure ] crbug.com/591099 fast/dom/no-elements.html [ Crash Failure ] crbug.com/591099 fast/dom/node-childNodes-idempotence.html [ Failure ] crbug.com/591099 fast/dom/node-filter-detached-iframe-crash.html [ Failure ] @@ -9362,10 +9370,10 @@ crbug.com/591099 fast/dom/nodesFromRect/nodesFromRect-table.html [ Failure ] crbug.com/591099 fast/dom/non-numeric-values-numeric-parameters.html [ Failure ] crbug.com/591099 fast/dom/objc-big-method-name.html [ Failure ] -crbug.com/591099 fast/dom/object-plugin-hides-properties.html [ Crash ] +crbug.com/591099 fast/dom/object-plugin-hides-properties.html [ Crash Failure ] crbug.com/591099 fast/dom/offset-parent-positioned-and-inline.html [ Failure Pass ] crbug.com/591099 fast/dom/onerror-img.html [ Failure ] -crbug.com/591099 fast/dom/onload-open.html [ Crash ] +crbug.com/591099 fast/dom/onload-open.html [ Crash Failure ] crbug.com/591099 fast/dom/open-and-close-by-DOM.html [ Failure ] crbug.com/591099 fast/dom/option-properties.html [ Failure ] crbug.com/591099 fast/dom/outerText-no-element.html [ Failure ] @@ -9398,7 +9406,7 @@ crbug.com/591099 fast/dom/script-styled-size.html [ Failure ] crbug.com/591099 fast/dom/scroll-reveal-left-overflow.html [ Failure ] crbug.com/591099 fast/dom/scroll-reveal-top-overflow.html [ Failure ] -crbug.com/591099 fast/dom/search-shadow-host-crash.html [ Crash ] +crbug.com/591099 fast/dom/search-shadow-host-crash.html [ Crash Pass ] crbug.com/591099 fast/dom/serialize-attribute.xhtml [ Failure ] crbug.com/591099 fast/dom/set-innerHTML.xhtml [ Crash Failure ] crbug.com/591099 fast/dom/setAttribute-using-initial-input-value.html [ Failure ] @@ -9441,16 +9449,16 @@ crbug.com/591099 fast/dom/shadow/drag-to-meter-in-shadow-crash.html [ Failure ] crbug.com/591099 fast/dom/shadow/elements-in-frameless-document.html [ Failure ] crbug.com/591099 fast/dom/shadow/event-path-after-deleting-tree-scope-crash.html [ Failure ] -crbug.com/591099 fast/dom/shadow/event-path-after-iframe-removed.html [ Crash ] -crbug.com/591099 fast/dom/shadow/event-path-load.html [ Crash ] -crbug.com/591099 fast/dom/shadow/event-pseudo.html [ Crash ] +crbug.com/591099 fast/dom/shadow/event-path-after-iframe-removed.html [ Crash Pass ] +crbug.com/591099 fast/dom/shadow/event-path-load.html [ Crash Pass ] +crbug.com/591099 fast/dom/shadow/event-pseudo.html [ Crash Pass ] crbug.com/591099 fast/dom/shadow/events-stopped-at-shadow-boundary.html [ Failure ] -crbug.com/591099 fast/dom/shadow/exposed-object-within-shadow.html [ Crash ] +crbug.com/591099 fast/dom/shadow/exposed-object-within-shadow.html [ Crash Pass ] crbug.com/591099 fast/dom/shadow/flat-tree-traversal-shadow-reprojection.html [ Failure ] crbug.com/591099 fast/dom/shadow/flat-tree-traversal.html [ Failure ] crbug.com/591099 fast/dom/shadow/focus-navigation-negative-tabindex.html [ Failure ] crbug.com/591099 fast/dom/shadow/focus-navigation-skips-non-focusable-shadow-in-iframe.html [ Failure ] -crbug.com/591099 fast/dom/shadow/focus-navigation-with-distributed-nodes.html [ Crash ] +crbug.com/591099 fast/dom/shadow/focus-navigation-with-distributed-nodes.html [ Crash Failure ] crbug.com/591099 fast/dom/shadow/focus-navigation-with-multiple-shadow-roots.html [ Failure ] crbug.com/591099 fast/dom/shadow/focus-navigation.html [ Failure Timeout ] crbug.com/591099 fast/dom/shadow/frameless-media-element-crash.html [ Failure ] @@ -9481,7 +9489,7 @@ crbug.com/591099 fast/dom/shadow/multiple-shadowroot-adopt.html [ Failure ] crbug.com/591099 fast/dom/shadow/multiple-shadowroot.html [ Failure ] crbug.com/591099 fast/dom/shadow/nested-reprojection-inconsistent.html [ Failure ] -crbug.com/591099 fast/dom/shadow/node-distribution-recalc-crash.html [ Crash ] +crbug.com/591099 fast/dom/shadow/node-distribution-recalc-crash.html [ Crash Pass ] crbug.com/591099 fast/dom/shadow/normalize-progress-element-crash.html [ Crash Failure ] crbug.com/591099 fast/dom/shadow/offset-parent-does-not-leak-ua-shadow.html [ Failure ] crbug.com/591099 fast/dom/shadow/offsetWidth-host-style-change.html [ Failure ] @@ -9498,13 +9506,13 @@ crbug.com/591099 fast/dom/shadow/remove-styles-in-shadow-crash-3.html [ Failure ] crbug.com/591099 fast/dom/shadow/remove-stylesheet-from-shadow-crash.html [ Failure ] crbug.com/591099 fast/dom/shadow/select-in-shadowdom.html [ Failure ] -crbug.com/591099 fast/dom/shadow/selection-in-nested-shadow.html [ Crash ] +crbug.com/591099 fast/dom/shadow/selection-in-nested-shadow.html [ Crash Failure ] crbug.com/591099 fast/dom/shadow/selections-in-shadow.html [ Timeout ] crbug.com/591099 fast/dom/shadow/set-attribute-in-shadow-crash.html [ Failure ] crbug.com/591099 fast/dom/shadow/shadow-added-display-none-host.html [ Failure ] crbug.com/591099 fast/dom/shadow/shadow-aware-create-shadow-root.html [ Failure ] crbug.com/591099 fast/dom/shadow/shadow-aware-shadow-root.html [ Failure ] -crbug.com/591099 fast/dom/shadow/shadow-boundary-crossing.html [ Crash ] +crbug.com/591099 fast/dom/shadow/shadow-boundary-crossing.html [ Crash Failure ] crbug.com/591099 fast/dom/shadow/shadow-boundary-events.html [ Failure ] crbug.com/591099 fast/dom/shadow/shadow-contents-event.html [ Crash Failure ] crbug.com/591099 fast/dom/shadow/shadow-disable.html [ Failure ] @@ -9513,7 +9521,7 @@ crbug.com/591099 fast/dom/shadow/shadow-element-distributed-nodes.html [ Failure ] crbug.com/591099 fast/dom/shadow/shadow-element.html [ Failure ] crbug.com/591099 fast/dom/shadow/shadow-hierarchy-exception.html [ Failure ] -crbug.com/591099 fast/dom/shadow/shadow-removechild-and-blur-event.html [ Crash ] +crbug.com/591099 fast/dom/shadow/shadow-removechild-and-blur-event.html [ Crash Failure ] crbug.com/591099 fast/dom/shadow/shadow-reprojection-click.html [ Failure ] crbug.com/591099 fast/dom/shadow/shadow-root-activeElement.html [ Failure ] crbug.com/591099 fast/dom/shadow/shadow-root-append.html [ Failure ] @@ -9539,11 +9547,11 @@ crbug.com/591099 fast/dom/shadow/style-sharing-styles-in-older-shadow-roots.html [ Failure ] crbug.com/591099 fast/dom/shadow/suppress-mutation-events-in-shadow-characterdata.html [ Failure ] crbug.com/591099 fast/dom/shadow/suppress-mutation-events-in-shadow.html [ Crash Failure ] -crbug.com/591099 fast/dom/shadow/svg-style-in-shadow-tree-crash.html [ Crash ] +crbug.com/591099 fast/dom/shadow/svg-style-in-shadow-tree-crash.html [ Crash Pass ] crbug.com/591099 fast/dom/shadow/tab-order-iframe-and-shadow.html [ Failure ] crbug.com/591099 fast/dom/shadow/title-element-in-shadow.html [ Failure ] crbug.com/591099 fast/dom/shadow/touch-event-retargeting.html [ Failure ] -crbug.com/591099 fast/dom/shadow/touch-event.html [ Crash ] +crbug.com/591099 fast/dom/shadow/touch-event.html [ Crash Failure ] crbug.com/591099 fast/dom/shadow/tree-scope-crash.html [ Crash Failure ] crbug.com/591099 fast/dom/shadow/update-text-of-style-in-shadow-dom.html [ Failure ] crbug.com/591099 fast/dom/shadow/user-modify-inheritance.html [ Failure ] @@ -9553,18 +9561,18 @@ crbug.com/591099 fast/dom/style-sheet-candidate-remove-unrendered-document.html [ Failure ] crbug.com/591099 fast/dom/subtree-modified-attributes.html [ Failure ] crbug.com/591099 fast/dom/tab-in-right-alignment.html [ Crash Failure ] -crbug.com/591099 fast/dom/tabindex-behavior.html [ Crash ] +crbug.com/591099 fast/dom/tabindex-behavior.html [ Crash Pass ] crbug.com/591099 fast/dom/tabindex-clamp.html [ Failure ] crbug.com/591099 fast/dom/tabindex-defaults.html [ Failure ] crbug.com/591099 fast/dom/text-api-arguments.html [ Failure ] -crbug.com/591099 fast/dom/text-control-crash-on-select.html [ Crash ] +crbug.com/591099 fast/dom/text-control-crash-on-select.html [ Crash Pass ] crbug.com/591099 fast/dom/timer-throttling-background-page-near-alignment-interval.html [ Failure ] crbug.com/591099 fast/dom/timers-maintain-order-while-throttled.html [ Failure ] crbug.com/591099 fast/dom/title-content-set-innerText-get.xhtml [ Failure ] crbug.com/591099 fast/dom/title-content-write-set.html [ Failure ] crbug.com/591099 fast/dom/vertical-scrollbar-in-rtl-doesnt-fire-onscroll.html [ Failure ] crbug.com/591099 fast/dom/vertical-scrollbar-in-rtl.html [ Crash Failure ] -crbug.com/591099 fast/dom/viewport/viewport-dimensions-iframe.html [ Crash ] +crbug.com/591099 fast/dom/viewport/viewport-dimensions-iframe.html [ Crash Pass ] crbug.com/591099 fast/dom/webtiming-document-open.html [ Failure ] crbug.com/591099 fast/dom/webtiming-navigate-within-document.html [ Failure ] crbug.com/591099 fast/dom/webtiming.html [ Failure ] @@ -9691,7 +9699,7 @@ crbug.com/591099 fast/encoding/invalid-UTF-8-2.html [ Failure ] crbug.com/591099 fast/encoding/invalid-UTF-8.html [ Failure ] crbug.com/591099 fast/encoding/invalid-multi-byte-over-consumption.html [ Failure ] -crbug.com/591099 fast/encoding/invalid-xml.html [ Crash ] +crbug.com/591099 fast/encoding/invalid-xml.html [ Crash Pass ] crbug.com/591099 fast/encoding/japanese-encoding-mix.html [ Failure ] crbug.com/591099 fast/encoding/latin1-unencodables.html [ Crash Failure ] crbug.com/591099 fast/encoding/latin1-winlatin.html [ Failure ] @@ -9740,37 +9748,37 @@ crbug.com/591099 fast/events/anchor-image-scrolled-x-y.html [ Crash Pass Timeout ] crbug.com/591099 fast/events/arrow-keys-on-body.html [ Failure ] crbug.com/591099 fast/events/attempt-select-all-with-wrong-modifier.html [ Failure ] -crbug.com/591099 fast/events/attribute-listener-cloned-from-frameless-doc-context-2.html [ Crash ] -crbug.com/591099 fast/events/attribute-listener-cloned-from-frameless-doc-context.html [ Crash ] +crbug.com/591099 fast/events/attribute-listener-cloned-from-frameless-doc-context-2.html [ Crash Pass ] +crbug.com/591099 fast/events/attribute-listener-cloned-from-frameless-doc-context.html [ Crash Pass ] crbug.com/591099 fast/events/attribute-listener-cloned-from-frameless-doc.xhtml [ Failure ] -crbug.com/591099 fast/events/attribute-listener-extracted-from-frameless-doc-context-2.html [ Crash ] -crbug.com/591099 fast/events/attribute-listener-extracted-from-frameless-doc-context.html [ Crash ] +crbug.com/591099 fast/events/attribute-listener-extracted-from-frameless-doc-context-2.html [ Crash Pass ] +crbug.com/591099 fast/events/attribute-listener-extracted-from-frameless-doc-context.html [ Crash Pass ] crbug.com/591099 fast/events/autoscroll-in-overflow-hidden-html.html [ Failure ] crbug.com/591099 fast/events/autoscroll-in-textarea.html [ Crash Failure ] crbug.com/591099 fast/events/autoscroll-in-textfield.html [ Crash Failure ] crbug.com/591099 fast/events/autoscroll-nonscrollable-iframe-in-scrollable-div.html [ Failure ] -crbug.com/591099 fast/events/autoscroll-select-crash.html [ Crash ] +crbug.com/591099 fast/events/autoscroll-select-crash.html [ Crash Pass ] crbug.com/591099 fast/events/autoscroll-should-not-stop-on-keypress.html [ Failure ] -crbug.com/591099 fast/events/autoscroll-upwards-propagation-no-scroll-iframe.html [ Crash ] +crbug.com/591099 fast/events/autoscroll-upwards-propagation-no-scroll-iframe.html [ Crash Failure ] crbug.com/591099 fast/events/autoscroll-upwards-propagation-overflow-hidden-body.html [ Failure ] -crbug.com/591099 fast/events/autoscroll-upwards-propagation-overflow-hidden-iframe-body.html [ Crash ] +crbug.com/591099 fast/events/autoscroll-upwards-propagation-overflow-hidden-iframe-body.html [ Crash Failure ] crbug.com/591099 fast/events/autoscroll-upwards-propagation.html [ Crash Failure ] crbug.com/591099 fast/events/autoscroll-with-non-scrollable-parent.html [ Failure Pass ] crbug.com/591099 fast/events/autoscroll.html [ Crash Failure ] -crbug.com/591099 fast/events/before-unload-adopt-within-subframes.html [ Crash ] +crbug.com/591099 fast/events/before-unload-adopt-within-subframes.html [ Crash Failure ] crbug.com/591099 fast/events/before-unload-crash.html [ Failure ] crbug.com/591099 fast/events/before-unload-forbidden-navigation.html [ Failure ] crbug.com/591099 fast/events/before-unload-in-multiple-subframes.html [ Failure ] crbug.com/591099 fast/events/before-unload-in-subframe.html [ Failure ] crbug.com/591099 fast/events/before-unload-javascript-navigation.html [ Failure ] crbug.com/591099 fast/events/before-unload-remove-and-add-subframe.html [ Failure ] -crbug.com/591099 fast/events/before-unload-remove-itself.html [ Crash ] +crbug.com/591099 fast/events/before-unload-remove-itself.html [ Crash Failure ] crbug.com/591099 fast/events/before-unload-return-bad-value.html [ Failure ] crbug.com/591099 fast/events/before-unload-return-value-from-listener.html [ Failure ] crbug.com/591099 fast/events/before-unload-returnValue.html [ Failure ] crbug.com/591099 fast/events/before-unload-with-subframes.html [ Failure ] crbug.com/591099 fast/events/blur-focus-window-should-blur-focus-element.html [ Failure ] -crbug.com/591099 fast/events/blur-remove-parent-crash.html [ Crash ] +crbug.com/591099 fast/events/blur-remove-parent-crash.html [ Crash Pass ] crbug.com/591099 fast/events/bogus-dropEffect-effectAllowed.html [ Failure ] crbug.com/591099 fast/events/bogus-event-listener-invalidation.html [ Failure ] crbug.com/591099 fast/events/caller-access-from-event-listener.html [ Failure ] @@ -9783,7 +9791,7 @@ crbug.com/591099 fast/events/click-after-mousedown-cancel.html [ Failure ] crbug.com/591099 fast/events/click-focus-anchor.html [ Failure ] crbug.com/591099 fast/events/click-focus-svganchor-has-ring.html [ Failure ] -crbug.com/591099 fast/events/click-over-descendant-elements.html [ Crash ] +crbug.com/591099 fast/events/click-over-descendant-elements.html [ Crash Failure ] crbug.com/591099 fast/events/click-range-slider.html [ Failure ] crbug.com/591099 fast/events/click-svganchor-blur-refocus-window.html [ Failure ] crbug.com/591099 fast/events/click-svganchor-refocus-window.html [ Failure ] @@ -9825,7 +9833,7 @@ crbug.com/591099 fast/events/constructors/webkit-animation-event-constructor.html [ Failure ] crbug.com/591099 fast/events/constructors/webkit-transition-event-constructor.html [ Failure ] crbug.com/591099 fast/events/constructors/wheel-event-constructor.html [ Failure Timeout ] -crbug.com/591099 fast/events/content-changed-during-drop.html [ Crash ] +crbug.com/591099 fast/events/content-changed-during-drop.html [ Crash Failure ] crbug.com/591099 fast/events/context-no-deselect.html [ Crash Failure ] crbug.com/591099 fast/events/context-nodrag.html [ Failure ] crbug.com/591099 fast/events/contextmenu-scrolled-page-with-frame.html [ Failure ] @@ -9838,7 +9846,7 @@ crbug.com/591099 fast/events/dispatch-to-function-with-handle-event.html [ Failure ] crbug.com/591099 fast/events/dispatch-to-handle-event.html [ Failure ] crbug.com/591099 fast/events/document-elementFromPoint.html [ Failure Pass ] -crbug.com/591099 fast/events/domactivate-sets-underlying-click-event-as-handled.html [ Crash ] +crbug.com/591099 fast/events/domactivate-sets-underlying-click-event-as-handled.html [ Crash Failure ] crbug.com/591099 fast/events/domnodeinsertedintodocument-dispatched-post-rendering.html [ Failure ] crbug.com/591099 fast/events/dont-loose-last-event.html [ Failure ] crbug.com/591099 fast/events/drag-and-drop-autoscroll-inner-frame.html [ Timeout ] @@ -9846,8 +9854,8 @@ crbug.com/591099 fast/events/drag-and-drop-dataTransfer-types-nocrash.html [ Failure ] crbug.com/591099 fast/events/drag-and-drop-fire-drag-dragover.html [ Failure ] crbug.com/591099 fast/events/drag-and-drop-set-drag-data-arguments.html [ Failure ] -crbug.com/591099 fast/events/drag-and-drop-subframe-dataTransfer.html [ Crash ] -crbug.com/591099 fast/events/drag-and-drop.html [ Crash Timeout ] +crbug.com/591099 fast/events/drag-and-drop-subframe-dataTransfer.html [ Crash Pass ] +crbug.com/591099 fast/events/drag-and-drop.html [ Crash Failure Timeout ] crbug.com/591099 fast/events/drag-customData.html [ Failure Timeout ] crbug.com/591099 fast/events/drag-dataTransferItemList-file-handling.html [ Crash Failure ] crbug.com/591099 fast/events/drag-dataTransferItemList.html [ Failure ] @@ -9890,24 +9898,24 @@ crbug.com/591099 fast/events/event-on-culled_inline.html [ Failure ] crbug.com/591099 fast/events/event-properties-gc.html [ Failure ] crbug.com/591099 fast/events/event-sender-mouseleave.html [ Failure ] -crbug.com/591099 fast/events/event-targets.html [ Crash ] +crbug.com/591099 fast/events/event-targets.html [ Crash Failure ] crbug.com/591099 fast/events/event-trace.html [ Failure ] crbug.com/591099 fast/events/event-trusted.html [ Failure ] crbug.com/591099 fast/events/event-view-toString.html [ Failure ] -crbug.com/591099 fast/events/file-input-hidden-in-ondrop.html [ Crash ] -crbug.com/591099 fast/events/fire-mousedown-while-pressing-mouse-button.html [ Crash ] +crbug.com/591099 fast/events/file-input-hidden-in-ondrop.html [ Crash Pass ] +crbug.com/591099 fast/events/fire-mousedown-while-pressing-mouse-button.html [ Crash Failure ] crbug.com/591099 fast/events/fire-popstate-event.html [ Failure ] crbug.com/591099 fast/events/fire-scroll-event-element.html [ Failure Timeout ] crbug.com/591099 fast/events/fire-scroll-event.html [ Failure ] crbug.com/591099 fast/events/flags-unset-on-init-event.html [ Failure ] -crbug.com/591099 fast/events/focus-change-assertion.html [ Crash ] -crbug.com/591099 fast/events/focus-change-crash.html [ Crash Failure ] -crbug.com/591099 fast/events/focus-change-crash2.html [ Crash Timeout ] +crbug.com/591099 fast/events/focus-change-assertion.html [ Crash Pass ] +crbug.com/591099 fast/events/focus-change-crash.html [ Crash Failure Pass ] +crbug.com/591099 fast/events/focus-change-crash2.html [ Crash Failure Timeout ] crbug.com/591099 fast/events/focus-click-on-non-mouse-focusable-element.html [ Failure ] crbug.com/591099 fast/events/focus-event-source-device-from-keyboard.html [ Failure ] crbug.com/591099 fast/events/focus-event-source-device-from-mouse.html [ Failure ] crbug.com/591099 fast/events/focus-event-source-device-from-touch.html [ Failure ] -crbug.com/591099 fast/events/focus-iframe-crash.html [ Crash ] +crbug.com/591099 fast/events/focus-iframe-crash.html [ Crash Pass ] crbug.com/591099 fast/events/focus-remove-focuesed-node.html [ Failure ] crbug.com/591099 fast/events/form-onchange.html [ Failure ] crbug.com/591099 fast/events/frame-click-clear-focus.html [ Failure ] @@ -9934,19 +9942,19 @@ crbug.com/591099 fast/events/init-message-event-isolated-world.html [ Failure ] crbug.com/591099 fast/events/init-message-event.html [ Failure ] crbug.com/591099 fast/events/initkeyboardevent-crash.html [ Failure ] -crbug.com/591099 fast/events/input-element-display-none-in-dragleave-crash.html [ Crash ] +crbug.com/591099 fast/events/input-element-display-none-in-dragleave-crash.html [ Crash Pass ] crbug.com/591099 fast/events/input-focus-no-duplicate-events.html [ Failure ] crbug.com/591099 fast/events/input-tab-focus-no-duplicate-events.html [ Failure ] -crbug.com/591099 fast/events/inputText-never-fired-on-keydown-cancel.html [ Crash ] -crbug.com/591099 fast/events/inputevents/before-input-order-typing-command.html [ Crash ] -crbug.com/591099 fast/events/inputevents/before-input-ranges.html [ Crash ] -crbug.com/591099 fast/events/inputevents/beforeinput-remove-iframe-crash.html [ Crash ] +crbug.com/591099 fast/events/inputText-never-fired-on-keydown-cancel.html [ Crash Failure ] +crbug.com/591099 fast/events/inputevents/before-input-order-typing-command.html [ Crash Pass ] +crbug.com/591099 fast/events/inputevents/before-input-ranges.html [ Crash Pass ] +crbug.com/591099 fast/events/inputevents/beforeinput-remove-iframe-crash.html [ Crash Failure ] crbug.com/591099 fast/events/inputevents/inputevent-cut-paste.html [ Failure ] crbug.com/591099 fast/events/inputevents/inputevent-data-keyboard.html [ Failure ] -crbug.com/591099 fast/events/inputevents/inputevent-drag-drop.html [ Crash Failure ] +crbug.com/591099 fast/events/inputevents/inputevent-drag-drop.html [ Crash Failure Pass ] crbug.com/591099 fast/events/inputevents/inputevent-execcommand.html [ Failure ] -crbug.com/591099 fast/events/inputevents/inputevent-keyboard.html [ Crash ] -crbug.com/591099 fast/events/inputevents/inputevent-transpose.html [ Crash Failure ] +crbug.com/591099 fast/events/inputevents/inputevent-keyboard.html [ Crash Failure ] +crbug.com/591099 fast/events/inputevents/inputevent-transpose.html [ Crash Failure Pass ] crbug.com/591099 fast/events/invalid-001.html [ Crash Failure ] crbug.com/591099 fast/events/invalid-002.html [ Crash Failure ] crbug.com/591099 fast/events/invalid-003.html [ Crash Failure ] @@ -9969,20 +9977,20 @@ crbug.com/591099 fast/events/keydown-leftright-keys.html [ Failure ] crbug.com/591099 fast/events/keydown-numlock-standard-location.html [ Failure ] crbug.com/591099 fast/events/keydown-numpad-keys.html [ Failure ] -crbug.com/591099 fast/events/keydown-remove-frame.html [ Crash ] +crbug.com/591099 fast/events/keydown-remove-frame.html [ Crash Failure ] crbug.com/591099 fast/events/keyevent-iframe-removed-crash.html [ Failure ] crbug.com/591099 fast/events/keypress-focus-change.html [ Failure ] -crbug.com/591099 fast/events/keypress-removed-node.html [ Crash ] +crbug.com/591099 fast/events/keypress-removed-node.html [ Crash Failure ] crbug.com/591099 fast/events/main-world-does-not-override-keystate.html [ Failure ] -crbug.com/591099 fast/events/max-tabindex-focus.html [ Crash ] +crbug.com/591099 fast/events/max-tabindex-focus.html [ Crash Pass ] crbug.com/591099 fast/events/media-element-focus-tab.html [ Failure ] -crbug.com/591099 fast/events/media-focus-in-standalone-media-document.html [ Crash ] +crbug.com/591099 fast/events/media-focus-in-standalone-media-document.html [ Crash Pass ] crbug.com/591099 fast/events/menu-key-context-menu-document-pinch-zoom.html [ Failure ] crbug.com/591099 fast/events/menu-key-context-menu-document.html [ Failure ] crbug.com/591099 fast/events/menu-key-context-menu-position.html [ Failure ] -crbug.com/591099 fast/events/menu-key-context-menu-reveal-focus.html [ Crash ] +crbug.com/591099 fast/events/menu-key-context-menu-reveal-focus.html [ Crash Pass ] crbug.com/591099 fast/events/menu-key-context-menu.html [ Failure ] -crbug.com/591099 fast/events/menu-key-no-mouse-down.html [ Crash ] +crbug.com/591099 fast/events/menu-key-no-mouse-down.html [ Crash Pass ] crbug.com/591099 fast/events/message-channel-gc-2.html [ Failure ] crbug.com/591099 fast/events/message-channel-gc-3.html [ Failure ] crbug.com/591099 fast/events/message-channel-gc-4.html [ Failure ] @@ -9991,18 +9999,18 @@ crbug.com/591099 fast/events/message-event-max-ports.html [ Failure ] crbug.com/591099 fast/events/message-port-clone.html [ Failure ] crbug.com/591099 fast/events/message-port-close.html [ Failure ] -crbug.com/591099 fast/events/message-port-constructor-for-deleted-document.html [ Crash ] +crbug.com/591099 fast/events/message-port-constructor-for-deleted-document.html [ Crash Failure ] crbug.com/591099 fast/events/message-port-context-destroyed.html [ Failure ] -crbug.com/591099 fast/events/message-port-deleted-document.html [ Crash ] -crbug.com/591099 fast/events/message-port-deleted-frame.html [ Crash ] -crbug.com/591099 fast/events/message-port-gc-closed-cloned.html [ Crash ] -crbug.com/591099 fast/events/message-port-gc-closed.html [ Crash ] +crbug.com/591099 fast/events/message-port-deleted-document.html [ Crash Failure ] +crbug.com/591099 fast/events/message-port-deleted-frame.html [ Crash Failure ] +crbug.com/591099 fast/events/message-port-gc-closed-cloned.html [ Crash Failure ] +crbug.com/591099 fast/events/message-port-gc-closed.html [ Crash Failure ] crbug.com/591099 fast/events/message-port-inactive-document.html [ Failure ] crbug.com/591099 fast/events/message-port-multi.html [ Failure ] crbug.com/591099 fast/events/message-port-no-wrapper.html [ Failure ] crbug.com/591099 fast/events/message-port-start-and-close-different-microtask.html [ Failure ] crbug.com/591099 fast/events/message-port-start-and-close-same-microtask.html [ Failure ] -crbug.com/591099 fast/events/message-port-transferables.html [ Crash ] +crbug.com/591099 fast/events/message-port-transferables.html [ Crash Pass ] crbug.com/591099 fast/events/message-port.html [ Failure ] crbug.com/591099 fast/events/middleClickAutoscroll-click-hyperlink.html [ Failure ] crbug.com/591099 fast/events/middleClickAutoscroll-drag-scrollable-iframe-div.html [ Failure ] @@ -10052,18 +10060,18 @@ crbug.com/591099 fast/events/mutation-during-insert-before.html [ Failure ] crbug.com/591099 fast/events/mutation-during-replace-child-2.html [ Failure ] crbug.com/591099 fast/events/mutation-during-replace-child.html [ Failure ] -crbug.com/591099 fast/events/nested-event-remove-node-crash.html [ Crash ] +crbug.com/591099 fast/events/nested-event-remove-node-crash.html [ Crash Pass ] crbug.com/591099 fast/events/no-blur-on-enter-button.html [ Failure ] -crbug.com/591099 fast/events/offsetX-offsetY-svg.html [ Crash ] +crbug.com/591099 fast/events/offsetX-offsetY-svg.html [ Crash Pass ] crbug.com/591099 fast/events/offsetX-offsetY.html [ Failure Timeout ] crbug.com/591099 fast/events/onbeforeunload-focused-iframe.html [ Failure ] -crbug.com/591099 fast/events/onblur-remove.html [ Crash ] +crbug.com/591099 fast/events/onblur-remove.html [ Crash Failure ] crbug.com/591099 fast/events/onchange-passwordfield.html [ Failure ] crbug.com/591099 fast/events/onchange-range-slider.html [ Failure ] crbug.com/591099 fast/events/onchange-searchfield.html [ Failure ] crbug.com/591099 fast/events/onchange-select-popup.html [ Failure ] -crbug.com/591099 fast/events/onchange-setvalue.html [ Crash ] -crbug.com/591099 fast/events/onchange-text-form-field.html [ Crash ] +crbug.com/591099 fast/events/onchange-setvalue.html [ Crash Pass ] +crbug.com/591099 fast/events/onchange-text-form-field.html [ Crash Pass ] crbug.com/591099 fast/events/onchange-textfield.html [ Failure ] crbug.com/591099 fast/events/onclick-list-marker.html [ Crash Failure ] crbug.com/591099 fast/events/onload-after-document-close-no-subresource.html [ Failure ] @@ -10072,16 +10080,16 @@ crbug.com/591099 fast/events/onload-re-entry.html [ Failure ] crbug.com/591099 fast/events/onload-single-line-comment.html [ Failure ] crbug.com/591099 fast/events/onload-webkit-before-webcore.html [ Failure ] -crbug.com/591099 fast/events/onloadFrameCrash.html [ Crash ] +crbug.com/591099 fast/events/onloadFrameCrash.html [ Crash Pass ] crbug.com/591099 fast/events/only-valid-drop-targets-receive-file-drop.html [ Failure ] crbug.com/591099 fast/events/onsubmit-bubbling.html [ Failure ] crbug.com/591099 fast/events/page-scaled-mouse-click-iframe.html [ Failure ] crbug.com/591099 fast/events/page-scaled-mouse-click.html [ Failure ] crbug.com/591099 fast/events/page-visibility-bubble.html [ Failure ] -crbug.com/591099 fast/events/page-visibility-iframe-delete-test.html [ Crash ] +crbug.com/591099 fast/events/page-visibility-iframe-delete-test.html [ Crash Failure ] crbug.com/591099 fast/events/page-visibility-iframe-move-test.html [ Failure ] crbug.com/591099 fast/events/page-visibility-iframe-propagation-test.html [ Failure ] -crbug.com/591099 fast/events/page-visibility-iframe-unload.html [ Crash ] +crbug.com/591099 fast/events/page-visibility-iframe-unload.html [ Crash Failure ] crbug.com/591099 fast/events/page-visibility-null-view.html [ Failure ] crbug.com/591099 fast/events/page-visibility-prefixed.html [ Failure ] crbug.com/591099 fast/events/page-visibility-transition-test.html [ Failure ] @@ -10091,7 +10099,7 @@ crbug.com/591099 fast/events/pointer-events.html [ Failure ] crbug.com/591099 fast/events/pointerevents/fake-mouse-event-pointer-types.html [ Failure ] crbug.com/591099 fast/events/pointerevents/mouse-node-remove.html [ Failure ] -crbug.com/591099 fast/events/pointerevents/mouse-on-object.html [ Crash ] +crbug.com/591099 fast/events/pointerevents/mouse-on-object.html [ Crash Failure ] crbug.com/591099 fast/events/pointerevents/mouse-pointer-boundary-events-for-shadowdom.html [ Failure Pass ] crbug.com/591099 fast/events/pointerevents/mouse-pointer-capture-transition-events.html [ Timeout ] crbug.com/591099 fast/events/pointerevents/mouse-pointer-capture.html [ Failure Timeout ] @@ -10104,7 +10112,7 @@ crbug.com/591099 fast/events/pointerevents/multi-pointer-preventdefault.html [ Failure Timeout ] crbug.com/591099 fast/events/pointerevents/pointer-event-properties-in-iframe.html [ Failure ] crbug.com/591099 fast/events/pointerevents/pointer-use-count.html [ Failure ] -crbug.com/591099 fast/events/pointerevents/pointerevent_touch-action-pinch_zoom_touch.html [ Crash ] +crbug.com/591099 fast/events/pointerevents/pointerevent_touch-action-pinch_zoom_touch.html [ Crash Pass ] crbug.com/591099 fast/events/pointerevents/touch-capture-in-iframe.html [ Timeout ] crbug.com/591099 fast/events/pointerevents/touch-capture.html [ Failure Timeout ] crbug.com/591099 fast/events/pointerevents/touch-pointer-events.html [ Failure ] @@ -10115,30 +10123,30 @@ crbug.com/591099 fast/events/popup-allowed-from-gesture-only-once-iframes.html [ Timeout ] crbug.com/591099 fast/events/popup-allowed-from-gesture-only-once-two-events.html [ Failure ] crbug.com/591099 fast/events/popup-allowed-from-gesture-only-once.html [ Failure Timeout ] -crbug.com/591099 fast/events/popup-allowed-from-pointerup-exactly-once.html [ Crash ] +crbug.com/591099 fast/events/popup-allowed-from-pointerup-exactly-once.html [ Crash Pass ] crbug.com/591099 fast/events/popup-blocked-from-different-frames.html [ Failure ] crbug.com/591099 fast/events/popup-blocked-from-wrong-event.html [ Failure ] crbug.com/591099 fast/events/popup-blocking-click-in-iframe.html [ Timeout ] crbug.com/591099 fast/events/popup-forwarded-gesture-blocked.html [ Failure ] crbug.com/591099 fast/events/popup-forwarded-gesture.html [ Failure ] crbug.com/591099 fast/events/programmatic-check-no-change-event.html [ Failure ] -crbug.com/591099 fast/events/recorded-keydown-event.html [ Crash ] +crbug.com/591099 fast/events/recorded-keydown-event.html [ Crash Failure ] crbug.com/591099 fast/events/related-target-focusevent.html [ Failure Timeout ] crbug.com/591099 fast/events/related-target.html [ Failure ] crbug.com/591099 fast/events/relative-offset-of-simulated-click.html [ Failure ] crbug.com/591099 fast/events/remove-first-event-listener-while-firing.html [ Failure ] -crbug.com/591099 fast/events/remove-shadow-host-crash.html [ Crash ] +crbug.com/591099 fast/events/remove-shadow-host-crash.html [ Crash Failure ] crbug.com/591099 fast/events/remove-target-in-mouseup-deep.html [ Failure ] crbug.com/591099 fast/events/remove-target-in-mouseup-insertback.html [ Failure ] crbug.com/591099 fast/events/remove-target-in-mouseup-twice.html [ Failure ] crbug.com/591099 fast/events/remove-target-in-mouseup.html [ Crash Failure ] -crbug.com/591099 fast/events/remove-target-with-shadow-in-drag.html [ Crash ] +crbug.com/591099 fast/events/remove-target-with-shadow-in-drag.html [ Crash Failure ] crbug.com/591099 fast/events/remove-text-node-in-mouseup.html [ Failure ] crbug.com/591099 fast/events/resize-raf-timing.html [ Failure ] crbug.com/591099 fast/events/reveal-link-when-focused.html [ Failure ] crbug.com/591099 fast/events/right-click-focus.html [ Failure ] crbug.com/591099 fast/events/scale-and-scroll-div.html [ Failure ] -crbug.com/591099 fast/events/scoped/editing-commands.html [ Crash ] +crbug.com/591099 fast/events/scoped/editing-commands.html [ Crash Failure ] crbug.com/591099 fast/events/scroll-after-click-on-tab-index.html [ Failure ] crbug.com/591099 fast/events/scroll-div-with-prevent-default-in-subframe.html [ Failure Pass ] crbug.com/591099 fast/events/scroll-event-does-not-bubble.html [ Pass Timeout ] @@ -10148,9 +10156,9 @@ crbug.com/591099 fast/events/scroll-event-raf-timing.html [ Failure ] crbug.com/591099 fast/events/scroll-to-anchor-in-overflow-hidden.html [ Failure ] crbug.com/591099 fast/events/select-element.html [ Timeout ] -crbug.com/591099 fast/events/select-onchange-crash.html [ Crash ] -crbug.com/591099 fast/events/select-onchange-mouse-released-outside.html [ Crash ] -crbug.com/591099 fast/events/selectionchange-iframe.html [ Crash ] +crbug.com/591099 fast/events/select-onchange-crash.html [ Crash Failure ] +crbug.com/591099 fast/events/select-onchange-mouse-released-outside.html [ Crash Failure ] +crbug.com/591099 fast/events/selectionchange-iframe.html [ Crash Failure ] crbug.com/591099 fast/events/selectionchange-user-initiated.html [ Crash Failure ] crbug.com/591099 fast/events/selectstart-by-arrow-keys-prevent-default.html [ Failure ] crbug.com/591099 fast/events/selectstart-by-arrow-keys.html [ Failure ] @@ -10161,11 +10169,11 @@ crbug.com/591099 fast/events/selectstart-on-selectall.html [ Failure ] crbug.com/591099 fast/events/selectstart-prevent-selectall.html [ Crash Failure ] crbug.com/591099 fast/events/selectstart-prevent-selection-on-right-click.html [ Failure ] -crbug.com/591099 fast/events/sequential-focus-navigation-starting-point.html [ Crash ] +crbug.com/591099 fast/events/sequential-focus-navigation-starting-point.html [ Crash Failure ] crbug.com/591099 fast/events/setDragImage-with-detached-node.html [ Failure ] crbug.com/591099 fast/events/simulated-click-by-alt-enter.html [ Failure ] crbug.com/591099 fast/events/simulated-click-coords.html [ Failure ] -crbug.com/591099 fast/events/simulated-click-disabled.html [ Crash ] +crbug.com/591099 fast/events/simulated-click-disabled.html [ Crash Failure ] crbug.com/591099 fast/events/simulated-click-on-anchor-with-target-blank.html [ Failure ] crbug.com/591099 fast/events/space-scroll-event.html [ Failure ] crbug.com/591099 fast/events/space-scroll-textinput-canceled.html [ Failure ] @@ -10181,20 +10189,20 @@ crbug.com/591099 fast/events/tab-imagemap.html [ Failure ] crbug.com/591099 fast/events/tab-is-focusable-assert.html [ Failure ] crbug.com/591099 fast/events/tab-test-not-visible-imagemap.html [ Failure ] -crbug.com/591099 fast/events/tabindex-focus-chain.html [ Crash ] +crbug.com/591099 fast/events/tabindex-focus-chain.html [ Crash Pass ] crbug.com/591099 fast/events/touch/basic-multi-touch-events-limited.html [ Failure ] crbug.com/591099 fast/events/touch/basic-multi-touch-events.html [ Failure ] crbug.com/591099 fast/events/touch/basic-single-touch-events.html [ Failure ] crbug.com/591099 fast/events/touch/compositor-touch-hit-rects-animation.html [ Failure ] crbug.com/591099 fast/events/touch/compositor-touch-hit-rects-global.html [ Failure ] -crbug.com/591099 fast/events/touch/compositor-touch-hit-rects-iframe-disappears.html [ Crash ] +crbug.com/591099 fast/events/touch/compositor-touch-hit-rects-iframe-disappears.html [ Crash Pass ] crbug.com/591099 fast/events/touch/compositor-touch-hit-rects-many.html [ Failure ] crbug.com/591099 fast/events/touch/compositor-touch-hit-rects-non-composited-scroll.html [ Failure ] crbug.com/591099 fast/events/touch/compositor-touch-hit-rects-scroll.html [ Failure ] crbug.com/591099 fast/events/touch/compositor-touch-hit-rects-squashing.html [ Failure ] crbug.com/591099 fast/events/touch/compositor-touch-hit-rects-transform-changed-nolayout.html [ Failure ] crbug.com/591099 fast/events/touch/compositor-touch-hit-rects-trigger-commit.html [ Failure ] -crbug.com/591099 fast/events/touch/compositor-touch-hit-rects.html [ Crash ] +crbug.com/591099 fast/events/touch/compositor-touch-hit-rects.html [ Crash Failure ] crbug.com/591099 fast/events/touch/document-create-touch-list-crash.html [ Failure ] crbug.com/591099 fast/events/touch/document-create-touch-list.html [ Failure ] crbug.com/591099 fast/events/touch/document-create-touch.html [ Failure ] @@ -10224,7 +10232,7 @@ crbug.com/591099 fast/events/touch/gesture/gesture-tap-frame-scrolled.html [ Failure ] crbug.com/591099 fast/events/touch/gesture/gesture-tap-hover-clear.html [ Failure ] crbug.com/591099 fast/events/touch/gesture/gesture-tap-hover-state-iframe.html [ Failure ] -crbug.com/591099 fast/events/touch/gesture/gesture-tap-input-after-composition.html [ Crash ] +crbug.com/591099 fast/events/touch/gesture/gesture-tap-input-after-composition.html [ Crash Pass ] crbug.com/591099 fast/events/touch/gesture/gesture-tap-mouse-events-between-frames.html [ Failure ] crbug.com/591099 fast/events/touch/gesture/gesture-tap-mouse-events.html [ Failure ] crbug.com/591099 fast/events/touch/gesture/gesture-tap-near-iframe.html [ Failure ] @@ -10232,7 +10240,7 @@ crbug.com/591099 fast/events/touch/gesture/gesture-tap-paragraph-end.html [ Failure ] crbug.com/591099 fast/events/touch/gesture/gesture-tap-result.html [ Crash Failure ] crbug.com/591099 fast/events/touch/gesture/gesture-tap-scrolled.html [ Failure ] -crbug.com/591099 fast/events/touch/gesture/gesture-tap-setrangetext-with-events.html [ Crash ] +crbug.com/591099 fast/events/touch/gesture/gesture-tap-setrangetext-with-events.html [ Crash Pass ] crbug.com/591099 fast/events/touch/gesture/long-press-drag-drop-touch-editing-combined-in-iframe.html [ Failure ] crbug.com/591099 fast/events/touch/gesture/long-press-drag-drop-touch-editing-combined.html [ Failure ] crbug.com/591099 fast/events/touch/gesture/long-press-focuses-frame.html [ Failure ] @@ -10280,7 +10288,7 @@ crbug.com/591099 fast/events/touch/page-scaled-touch-gesture-click.html [ Failure ] crbug.com/591099 fast/events/touch/send-oncancel-event.html [ Failure ] crbug.com/591099 fast/events/touch/tap-highlight-color.html [ Failure ] -crbug.com/591099 fast/events/touch/touch-action-range-input-crash.html [ Crash ] +crbug.com/591099 fast/events/touch/touch-action-range-input-crash.html [ Crash Pass ] crbug.com/591099 fast/events/touch/touch-action-range-input.html [ Timeout ] crbug.com/591099 fast/events/touch/touch-action-touch-handlers.html [ Failure ] crbug.com/591099 fast/events/touch/touch-before-pressing-spin-button.html [ Crash Failure ] @@ -10288,7 +10296,7 @@ crbug.com/591099 fast/events/touch/touch-event-dispatch-no-crash.html [ Failure ] crbug.com/591099 fast/events/touch/touch-event-source-device-event-sender.html [ Failure ] crbug.com/591099 fast/events/touch/touch-fractional-coordinates.html [ Failure ] -crbug.com/591099 fast/events/touch/touch-handler-assert-input-range.html [ Crash ] +crbug.com/591099 fast/events/touch/touch-handler-assert-input-range.html [ Crash Failure ] crbug.com/591099 fast/events/touch/touch-handler-count.html [ Failure ] crbug.com/591099 fast/events/touch/touch-handler-iframe-plugin-assert.html [ Failure ] crbug.com/591099 fast/events/touch/touch-handler-iframe-unload-assert.html [ Failure ] @@ -10338,18 +10346,18 @@ crbug.com/591099 fast/events/xsl-onload.xhtml [ Failure ] crbug.com/591099 fast/eventsource/eventsource-attribute-listeners.html [ Failure ] crbug.com/591099 fast/eventsource/eventsource-constructor.html [ Failure ] -crbug.com/591099 fast/files/apply-blob-url-to-img.html [ Crash ] +crbug.com/591099 fast/files/apply-blob-url-to-img.html [ Crash Pass ] crbug.com/591099 fast/files/blob-close-read.html [ Failure ] crbug.com/591099 fast/files/blob-close-revoke.html [ Failure ] crbug.com/591099 fast/files/blob-close.html [ Failure ] crbug.com/591099 fast/files/blob-constructor.html [ Crash Failure ] crbug.com/591099 fast/files/blob-parts-slice-test.html [ Failure ] -crbug.com/591099 fast/files/blob-reading-from-form-file.html [ Crash ] +crbug.com/591099 fast/files/blob-reading-from-form-file.html [ Crash Pass ] crbug.com/591099 fast/files/blob-slice-test.html [ Crash Failure ] crbug.com/591099 fast/files/file-constructor.html [ Failure ] crbug.com/591099 fast/files/file-in-input-display.html [ Crash Failure ] crbug.com/591099 fast/files/file-list-test.html [ Crash Failure ] -crbug.com/591099 fast/files/file-reader-abort-gc-iframe.html [ Crash ] +crbug.com/591099 fast/files/file-reader-abort-gc-iframe.html [ Crash Failure ] crbug.com/591099 fast/files/file-reader-detached-no-crash.html [ Failure ] crbug.com/591099 fast/files/file-reader-fffd.html [ Failure ] crbug.com/591099 fast/files/file-reader-methods-illegal-arguments.html [ Failure ] @@ -10413,7 +10421,7 @@ crbug.com/591099 fast/forms/006.html [ Failure ] crbug.com/591099 fast/forms/007.html [ Failure ] crbug.com/591099 fast/forms/11423.html [ Crash Failure ] -crbug.com/591099 fast/forms/25153.html [ Crash ] +crbug.com/591099 fast/forms/25153.html [ Crash Pass ] crbug.com/591099 fast/forms/4628409.html [ Failure ] crbug.com/591099 fast/forms/8250.html [ Failure ] crbug.com/591099 fast/forms/ValidityState-customError.html [ Failure ] @@ -10425,7 +10433,7 @@ crbug.com/591099 fast/forms/ValidityState-stepMismatch.html [ Crash Failure ] crbug.com/591099 fast/forms/ValidityState-tooLong-input.html [ Crash Failure ] crbug.com/591099 fast/forms/ValidityState-tooLong-textarea.html [ Crash Failure ] -crbug.com/591099 fast/forms/ValidityState-tooShort-input.html [ Crash ] +crbug.com/591099 fast/forms/ValidityState-tooShort-input.html [ Crash Failure ] crbug.com/591099 fast/forms/ValidityState-tooShort-textarea.html [ Crash Failure ] crbug.com/591099 fast/forms/ValidityState-typeMismatch-email.html [ Failure ] crbug.com/591099 fast/forms/ValidityState-typeMismatch-url.html [ Failure ] @@ -10460,7 +10468,7 @@ crbug.com/591099 fast/forms/button/button-baseline-and-collapsing.html [ Failure ] crbug.com/591099 fast/forms/button/button-cannot-be-nested.html [ Failure Pass ] crbug.com/591099 fast/forms/button/button-click-DOM.html [ Failure ] -crbug.com/591099 fast/forms/button/button-disabled-blur.html [ Crash ] +crbug.com/591099 fast/forms/button/button-disabled-blur.html [ Crash Pass ] crbug.com/591099 fast/forms/button/button-first-line-first-letter.html [ Failure Pass ] crbug.com/591099 fast/forms/button/button-in-forms-collection.html [ Failure ] crbug.com/591099 fast/forms/button/button-inner-block-reuse.html [ Failure ] @@ -10471,37 +10479,37 @@ crbug.com/591099 fast/forms/calendar-picker/calendar-picker-date-types.html [ Failure Timeout ] crbug.com/591099 fast/forms/calendar-picker/calendar-picker-datetimelocal-with-step.html [ Crash Failure ] crbug.com/591099 fast/forms/calendar-picker/calendar-picker-datetimelocal.html [ Failure ] -crbug.com/591099 fast/forms/calendar-picker/calendar-picker-key-operations.html [ Crash ] -crbug.com/591099 fast/forms/calendar-picker/calendar-picker-mouse-operations.html [ Crash ] +crbug.com/591099 fast/forms/calendar-picker/calendar-picker-key-operations.html [ Crash Timeout ] +crbug.com/591099 fast/forms/calendar-picker/calendar-picker-mouse-operations.html [ Crash Failure ] crbug.com/591099 fast/forms/calendar-picker/calendar-picker-pre-100-year.html [ Crash Failure ] crbug.com/591099 fast/forms/calendar-picker/calendar-picker-should-not-change-datetimelocal-time.html [ Failure ] -crbug.com/591099 fast/forms/calendar-picker/calendar-picker-touch-operations.html [ Crash ] -crbug.com/591099 fast/forms/calendar-picker/calendar-picker-type-change-onchange.html [ Crash ] -crbug.com/591099 fast/forms/calendar-picker/calendar-picker-type-change-onclick.html [ Crash ] +crbug.com/591099 fast/forms/calendar-picker/calendar-picker-touch-operations.html [ Crash Failure ] +crbug.com/591099 fast/forms/calendar-picker/calendar-picker-type-change-onchange.html [ Crash Failure ] +crbug.com/591099 fast/forms/calendar-picker/calendar-picker-type-change-onclick.html [ Crash Failure ] crbug.com/591099 fast/forms/calendar-picker/calendar-picker-with-step.html [ Crash Failure ] crbug.com/591099 fast/forms/calendar-picker/date-open-picker-with-f4-key.html [ Failure ] -crbug.com/591099 fast/forms/calendar-picker/date-picker-ax.html [ Crash ] +crbug.com/591099 fast/forms/calendar-picker/date-picker-ax.html [ Crash Failure ] crbug.com/591099 fast/forms/calendar-picker/date-picker-choose-default-value-after-set-value.html [ Crash Failure ] crbug.com/591099 fast/forms/calendar-picker/date-picker-events.html [ Crash Failure Timeout ] crbug.com/591099 fast/forms/calendar-picker/date-picker-open-without-focus.html [ Failure ] -crbug.com/591099 fast/forms/calendar-picker/datetimelocal-change-type-on-input-crash.html [ Crash ] +crbug.com/591099 fast/forms/calendar-picker/datetimelocal-change-type-on-input-crash.html [ Crash Failure ] crbug.com/591099 fast/forms/calendar-picker/datetimelocal-open-picker-with-f4-key.html [ Failure ] crbug.com/591099 fast/forms/calendar-picker/datetimelocal-picker-choose-default-value-after-set-value.html [ Failure Timeout ] crbug.com/591099 fast/forms/calendar-picker/datetimelocal-picker-events.html [ Crash Failure ] crbug.com/591099 fast/forms/calendar-picker/month-open-picker-with-f4-key.html [ Failure ] crbug.com/591099 fast/forms/calendar-picker/month-picker-ax.html [ Crash Failure ] crbug.com/591099 fast/forms/calendar-picker/month-picker-choose-default-value-after-set-value.html [ Crash Failure ] -crbug.com/591099 fast/forms/calendar-picker/month-picker-key-operations.html [ Crash ] -crbug.com/591099 fast/forms/calendar-picker/month-picker-mouse-operations.html [ Crash Timeout ] -crbug.com/591099 fast/forms/calendar-picker/month-picker-touch-operations.html [ Crash Timeout ] +crbug.com/591099 fast/forms/calendar-picker/month-picker-key-operations.html [ Crash Timeout ] +crbug.com/591099 fast/forms/calendar-picker/month-picker-mouse-operations.html [ Crash Failure Timeout ] +crbug.com/591099 fast/forms/calendar-picker/month-picker-touch-operations.html [ Crash Failure Timeout ] crbug.com/591099 fast/forms/calendar-picker/month-picker-with-step.html [ Crash Failure ] crbug.com/591099 fast/forms/calendar-picker/week-open-picker-with-f4-key.html [ Failure ] crbug.com/591099 fast/forms/calendar-picker/week-picker-ax.html [ Crash Failure ] crbug.com/591099 fast/forms/calendar-picker/week-picker-choose-default-value-after-set-value.html [ Crash Failure ] -crbug.com/591099 fast/forms/calendar-picker/week-picker-close-no-crash.html [ Crash ] -crbug.com/591099 fast/forms/calendar-picker/week-picker-key-operations.html [ Crash ] -crbug.com/591099 fast/forms/calendar-picker/week-picker-mouse-operations.html [ Crash ] -crbug.com/591099 fast/forms/calendar-picker/week-picker-touch-operations.html [ Crash ] +crbug.com/591099 fast/forms/calendar-picker/week-picker-close-no-crash.html [ Crash Pass ] +crbug.com/591099 fast/forms/calendar-picker/week-picker-key-operations.html [ Crash Timeout ] +crbug.com/591099 fast/forms/calendar-picker/week-picker-mouse-operations.html [ Crash Failure ] +crbug.com/591099 fast/forms/calendar-picker/week-picker-touch-operations.html [ Crash Failure ] crbug.com/591099 fast/forms/caret-rtl.html [ Failure ] crbug.com/591099 fast/forms/change-form-element-document-crash.html [ Failure ] crbug.com/591099 fast/forms/checkValidity-cancel.html [ Failure ] @@ -10513,15 +10521,15 @@ crbug.com/591099 fast/forms/checkbox/checkbox-nested-click-event-on-label.html [ Failure ] crbug.com/591099 fast/forms/checkbox/checkbox-onchange.html [ Failure ] crbug.com/591099 fast/forms/clone-input-with-dirty-value.html [ Crash Failure ] -crbug.com/591099 fast/forms/color/color-no-event-during-detach.html [ Crash ] +crbug.com/591099 fast/forms/color/color-no-event-during-detach.html [ Crash Pass ] crbug.com/591099 fast/forms/color/color-setrangetext.html [ Failure ] crbug.com/591099 fast/forms/color/color-suggestion-picker-appearance-zoom125.html [ Failure ] crbug.com/591099 fast/forms/color/color-type-change-on-close.html [ Crash Failure ] crbug.com/591099 fast/forms/color/color-value-sanitization.html [ Failure ] crbug.com/591099 fast/forms/color/input-appearance-color.html [ Failure ] crbug.com/591099 fast/forms/color/input-color-choose-default-value-after-set-value.html [ Failure ] -crbug.com/591099 fast/forms/color/input-color-chooser-shown-readonly.html [ Crash ] -crbug.com/591099 fast/forms/color/input-color-chooser-shown.html [ Crash ] +crbug.com/591099 fast/forms/color/input-color-chooser-shown-readonly.html [ Crash Pass ] +crbug.com/591099 fast/forms/color/input-color-chooser-shown.html [ Crash Pass ] crbug.com/591099 fast/forms/color/input-color-onchange-event.html [ Failure ] crbug.com/591099 fast/forms/color/input-value-sanitization-color.html [ Failure ] crbug.com/591099 fast/forms/control-clip-overflow.html [ Failure ] @@ -10540,9 +10548,9 @@ crbug.com/591099 fast/forms/datalist/range-snap-to-datalist.html [ Failure ] crbug.com/591099 fast/forms/datalist/slider-appearance-with-ticks-crash.html [ Failure ] crbug.com/591099 fast/forms/date-multiple-fields/date-clearbutton-preventdefault-mousecapture-status.html [ Crash Failure ] -crbug.com/591099 fast/forms/date-multiple-fields/date-multiple-fields-ax-aria-attributes.html [ Crash ] -crbug.com/591099 fast/forms/date-multiple-fields/date-multiple-fields-ax-value-changed-notification.html [ Crash ] -crbug.com/591099 fast/forms/date-multiple-fields/date-multiple-fields-blur-and-focus-events.html [ Crash ] +crbug.com/591099 fast/forms/date-multiple-fields/date-multiple-fields-ax-aria-attributes.html [ Crash Failure ] +crbug.com/591099 fast/forms/date-multiple-fields/date-multiple-fields-ax-value-changed-notification.html [ Crash Failure ] +crbug.com/591099 fast/forms/date-multiple-fields/date-multiple-fields-blur-and-focus-events.html [ Crash Failure ] crbug.com/591099 fast/forms/date-multiple-fields/date-multiple-fields-change-layout-by-value.html [ Failure ] crbug.com/591099 fast/forms/date-multiple-fields/date-multiple-fields-choose-default-value-after-set-value.html [ Failure ] crbug.com/591099 fast/forms/date-multiple-fields/date-multiple-fields-clearbutton-change-and-input-events.html [ Crash Failure ] @@ -10555,19 +10563,19 @@ crbug.com/591099 fast/forms/date-multiple-fields/date-multiple-fields-onblur-setvalue-onfocusremoved.html [ Crash Failure ] crbug.com/591099 fast/forms/date-multiple-fields/date-multiple-fields-preserve-value-after-history-back.html [ Failure ] crbug.com/591099 fast/forms/date-multiple-fields/date-multiple-fields-readonly-subfield.html [ Failure ] -crbug.com/591099 fast/forms/date-multiple-fields/date-multiple-fields-reset-value-after-reloads.html [ Crash ] -crbug.com/591099 fast/forms/date-multiple-fields/date-multiple-fields-spinbutton-change-and-input-events.html [ Crash ] +crbug.com/591099 fast/forms/date-multiple-fields/date-multiple-fields-reset-value-after-reloads.html [ Crash Failure ] +crbug.com/591099 fast/forms/date-multiple-fields/date-multiple-fields-spinbutton-change-and-input-events.html [ Crash Failure ] crbug.com/591099 fast/forms/date-multiple-fields/date-multiple-fields-stepup-stepdown-from-renderer.html [ Crash Failure Timeout ] crbug.com/591099 fast/forms/date-multiple-fields/date-multiple-fields-validity-badinput.html [ Crash Failure ] crbug.com/591099 fast/forms/date-multiple-fields/date-multiple-fields-value-set-empty.html [ Failure ] -crbug.com/591099 fast/forms/date-multiple-fields/date-multiple-fields-wheel-event.html [ Crash ] +crbug.com/591099 fast/forms/date-multiple-fields/date-multiple-fields-wheel-event.html [ Crash Failure ] crbug.com/591099 fast/forms/date/ValidityState-rangeOverflow-date.html [ Failure ] crbug.com/591099 fast/forms/date/ValidityState-rangeUnderflow-date.html [ Failure ] crbug.com/591099 fast/forms/date/ValidityState-stepMismatch-date.html [ Failure ] crbug.com/591099 fast/forms/date/ValidityState-typeMismatch-date.html [ Failure ] crbug.com/591099 fast/forms/date/date-appearance-basic.html [ Crash Failure ] crbug.com/591099 fast/forms/date/date-appearance-pseudo-elements.html [ Crash Failure ] -crbug.com/591099 fast/forms/date/date-format-warning.html [ Crash ] +crbug.com/591099 fast/forms/date/date-format-warning.html [ Crash Pass ] crbug.com/591099 fast/forms/date/date-input-type.html [ Failure ] crbug.com/591099 fast/forms/date/date-interactive-validation-required.html [ Crash Failure ] crbug.com/591099 fast/forms/date/date-pseudo-classes.html [ Failure ] @@ -10578,9 +10586,9 @@ crbug.com/591099 fast/forms/date/input-valueasdate-date.html [ Failure ] crbug.com/591099 fast/forms/date/input-valueasnumber-date.html [ Failure ] crbug.com/591099 fast/forms/date/no-page-popup-controller.html [ Failure ] -crbug.com/591099 fast/forms/datetimelocal-multiple-fields/datetimelocal-multiple-fields-ax-aria-attributes.html [ Crash ] -crbug.com/591099 fast/forms/datetimelocal-multiple-fields/datetimelocal-multiple-fields-ax-value-changed-notification.html [ Crash ] -crbug.com/591099 fast/forms/datetimelocal-multiple-fields/datetimelocal-multiple-fields-blur-and-focus-events.html [ Crash ] +crbug.com/591099 fast/forms/datetimelocal-multiple-fields/datetimelocal-multiple-fields-ax-aria-attributes.html [ Crash Failure ] +crbug.com/591099 fast/forms/datetimelocal-multiple-fields/datetimelocal-multiple-fields-ax-value-changed-notification.html [ Crash Failure ] +crbug.com/591099 fast/forms/datetimelocal-multiple-fields/datetimelocal-multiple-fields-blur-and-focus-events.html [ Crash Failure ] crbug.com/591099 fast/forms/datetimelocal-multiple-fields/datetimelocal-multiple-fields-change-layout-by-value.html [ Failure ] crbug.com/591099 fast/forms/datetimelocal-multiple-fields/datetimelocal-multiple-fields-choose-default-value-after-set-value.html [ Failure ] crbug.com/591099 fast/forms/datetimelocal-multiple-fields/datetimelocal-multiple-fields-clearbutton-change-and-input-events.html [ Crash Failure ] @@ -10589,12 +10597,12 @@ crbug.com/591099 fast/forms/datetimelocal-multiple-fields/datetimelocal-multiple-fields-mouse-events.html [ Crash Failure ] crbug.com/591099 fast/forms/datetimelocal-multiple-fields/datetimelocal-multiple-fields-preserve-value-after-history-back.html [ Crash Failure ] crbug.com/591099 fast/forms/datetimelocal-multiple-fields/datetimelocal-multiple-fields-readonly-subfield.html [ Failure ] -crbug.com/591099 fast/forms/datetimelocal-multiple-fields/datetimelocal-multiple-fields-reset-value-after-reloads.html [ Crash ] -crbug.com/591099 fast/forms/datetimelocal-multiple-fields/datetimelocal-multiple-fields-spinbutton-change-and-input-events.html [ Crash ] +crbug.com/591099 fast/forms/datetimelocal-multiple-fields/datetimelocal-multiple-fields-reset-value-after-reloads.html [ Crash Failure ] +crbug.com/591099 fast/forms/datetimelocal-multiple-fields/datetimelocal-multiple-fields-spinbutton-change-and-input-events.html [ Crash Failure ] crbug.com/591099 fast/forms/datetimelocal-multiple-fields/datetimelocal-multiple-fields-stepup-stepdown-from-renderer.html [ Crash Failure ] crbug.com/591099 fast/forms/datetimelocal-multiple-fields/datetimelocal-multiple-fields-validity-badinput.html [ Crash Failure ] crbug.com/591099 fast/forms/datetimelocal-multiple-fields/datetimelocal-multiple-fields-value-set-empty.html [ Failure ] -crbug.com/591099 fast/forms/datetimelocal-multiple-fields/datetimelocal-multiple-fields-wheel-event.html [ Crash ] +crbug.com/591099 fast/forms/datetimelocal-multiple-fields/datetimelocal-multiple-fields-wheel-event.html [ Crash Failure ] crbug.com/591099 fast/forms/datetimelocal/ValidityState-rangeOverflow-datetimelocal.html [ Failure ] crbug.com/591099 fast/forms/datetimelocal/ValidityState-rangeUnderflow-datetimelocal.html [ Failure ] crbug.com/591099 fast/forms/datetimelocal/ValidityState-stepMismatch-datetimelocal.html [ Failure ] @@ -10624,11 +10632,11 @@ crbug.com/591099 fast/forms/empty-get.html [ Failure ] crbug.com/591099 fast/forms/encoding-test.html [ Failure ] crbug.com/591099 fast/forms/enctype-attribute.html [ Failure ] -crbug.com/591099 fast/forms/enter-clicks-buttons.html [ Crash ] +crbug.com/591099 fast/forms/enter-clicks-buttons.html [ Crash Failure ] crbug.com/591099 fast/forms/fieldset/fieldset-align.html [ Failure ] crbug.com/591099 fast/forms/fieldset/fieldset-crash.html [ Failure ] crbug.com/591099 fast/forms/fieldset/fieldset-disabled.html [ Crash Failure ] -crbug.com/591099 fast/forms/fieldset/fieldset-elements.html [ Crash ] +crbug.com/591099 fast/forms/fieldset/fieldset-elements.html [ Crash Failure ] crbug.com/591099 fast/forms/fieldset/fieldset-form-collection-radionode-list.html [ Crash Failure ] crbug.com/591099 fast/forms/fieldset/fieldset-legend-padding-unclipped-fieldset-border.html [ Failure ] crbug.com/591099 fast/forms/fieldset/fieldset-name.html [ Failure ] @@ -10644,7 +10652,7 @@ crbug.com/591099 fast/forms/fieldset/legend-after-margin-with-before-border-horizontal-mode.html [ Failure ] crbug.com/591099 fast/forms/fieldset/legend-display-none.html [ Failure ] crbug.com/591099 fast/forms/fieldset/legend-form.html [ Failure ] -crbug.com/591099 fast/forms/file/file-cloneNode.html [ Crash ] +crbug.com/591099 fast/forms/file/file-cloneNode.html [ Crash Pass ] crbug.com/591099 fast/forms/file/file-input-capture.html [ Failure ] crbug.com/591099 fast/forms/file/file-input-change-event.html [ Crash Failure ] crbug.com/591099 fast/forms/file/file-input-direction.html [ Failure ] @@ -10657,7 +10665,7 @@ crbug.com/591099 fast/forms/file/get-file-upload.html [ Crash Failure ] crbug.com/591099 fast/forms/file/input-file-entries.html [ Crash Failure ] crbug.com/591099 fast/forms/file/input-file-label.html [ Crash Failure ] -crbug.com/591099 fast/forms/file/input-file-re-render.html [ Crash ] +crbug.com/591099 fast/forms/file/input-file-re-render.html [ Crash Failure ] crbug.com/591099 fast/forms/file/input-file-value-with-zoom.html [ Crash Failure ] crbug.com/591099 fast/forms/file/input-file-value.html [ Crash Failure ] crbug.com/591099 fast/forms/file/input-file-write-files.html [ Crash Failure ] @@ -10672,7 +10680,7 @@ crbug.com/591099 fast/forms/focus-style-pending.html [ Failure Pass ] crbug.com/591099 fast/forms/focus-with-display-block.html [ Failure ] crbug.com/591099 fast/forms/focus.html [ Crash Failure ] -crbug.com/591099 fast/forms/focus2.html [ Crash ] +crbug.com/591099 fast/forms/focus2.html [ Crash Failure ] crbug.com/591099 fast/forms/form-added-to-table.html [ Failure Pass ] crbug.com/591099 fast/forms/form-and-frame-interaction-retains-values.html [ Crash Failure ] crbug.com/591099 fast/forms/form-associated-element-crash.html [ Crash Failure ] @@ -10686,9 +10694,9 @@ crbug.com/591099 fast/forms/form-attribute-not-in-document.html [ Failure ] crbug.com/591099 fast/forms/form-attribute.html [ Crash Failure ] crbug.com/591099 fast/forms/form-collection-elements-order.html [ Crash Failure ] -crbug.com/591099 fast/forms/form-collection-elements.html [ Crash ] +crbug.com/591099 fast/forms/form-collection-elements.html [ Crash Failure ] crbug.com/591099 fast/forms/form-collection-lookup.html [ Failure ] -crbug.com/591099 fast/forms/form-collection-radio-node-list.html [ Crash ] +crbug.com/591099 fast/forms/form-collection-radio-node-list.html [ Crash Failure ] crbug.com/591099 fast/forms/form-data-encoding-normalization-overrun.html [ Failure ] crbug.com/591099 fast/forms/form-dirname-attribute.html [ Failure ] crbug.com/591099 fast/forms/form-element-geometry.html [ Crash Failure ] @@ -10700,7 +10708,7 @@ crbug.com/591099 fast/forms/form-radio-node-list.html [ Crash Failure ] crbug.com/591099 fast/forms/form-submission-cancelable.html [ Crash Failure ] crbug.com/591099 fast/forms/form-submit-in-image-document.html [ Failure ] -crbug.com/591099 fast/forms/form-submit-in-submit-event.html [ Crash ] +crbug.com/591099 fast/forms/form-submit-in-submit-event.html [ Crash Pass ] crbug.com/591099 fast/forms/formaction-attribute.html [ Failure ] crbug.com/591099 fast/forms/formmethod-attribute-button-html.html [ Failure ] crbug.com/591099 fast/forms/formmethod-attribute-input-2.html [ Failure ] @@ -10720,14 +10728,14 @@ crbug.com/591099 fast/forms/image-disconnected-during-parse.html [ Failure ] crbug.com/591099 fast/forms/image/002.html [ Crash Failure ] crbug.com/591099 fast/forms/image/005.html [ Failure ] -crbug.com/591099 fast/forms/image/fallback-reattach-crash.html [ Crash ] +crbug.com/591099 fast/forms/image/fallback-reattach-crash.html [ Crash Pass ] crbug.com/591099 fast/forms/image/image-error-event-modifies-type-crash.html [ Crash Failure ] crbug.com/591099 fast/forms/image/image-setrangetext.html [ Crash Failure ] crbug.com/591099 fast/forms/image/input-align-image.html [ Failure ] -crbug.com/591099 fast/forms/image/input-image-submit.html [ Crash ] +crbug.com/591099 fast/forms/image/input-image-submit.html [ Crash Pass ] crbug.com/591099 fast/forms/image/input-width-height-attributes-without-renderer-loaded-image.html [ Crash Pass ] crbug.com/591099 fast/forms/image/width-and-height-of-detached-input.html [ Failure ] -crbug.com/591099 fast/forms/implicit-submission.html [ Crash ] +crbug.com/591099 fast/forms/implicit-submission.html [ Crash Failure ] crbug.com/591099 fast/forms/incremental-dom-property.html [ Failure ] crbug.com/591099 fast/forms/indeterminate-input-types.html [ Crash Failure ] crbug.com/591099 fast/forms/indeterminate.html [ Failure ] @@ -10743,14 +10751,14 @@ crbug.com/591099 fast/forms/input-multiple.html [ Crash Failure ] crbug.com/591099 fast/forms/input-named-action-overrides-action-attribute.html [ Failure ] crbug.com/591099 fast/forms/input-pattern.html [ Failure ] -crbug.com/591099 fast/forms/input-readonly-select.html [ Crash ] +crbug.com/591099 fast/forms/input-readonly-select.html [ Crash Failure ] crbug.com/591099 fast/forms/input-select-api-support.html [ Crash Failure ] crbug.com/591099 fast/forms/input-step-as-double.html [ Crash Failure ] crbug.com/591099 fast/forms/input-stepup-stepdown.html [ Failure ] -crbug.com/591099 fast/forms/input-type-change-focusout.html [ Crash ] +crbug.com/591099 fast/forms/input-type-change-focusout.html [ Crash Failure ] crbug.com/591099 fast/forms/input-type-change-in-onfocus-keyboard.html [ Failure ] crbug.com/591099 fast/forms/input-type-change-in-onfocus-mouse.html [ Failure ] -crbug.com/591099 fast/forms/input-type-change.html [ Crash ] +crbug.com/591099 fast/forms/input-type-change.html [ Crash Failure ] crbug.com/591099 fast/forms/input-type-change3.html [ Failure ] crbug.com/591099 fast/forms/input-type-text-min-width.html [ Crash Failure ] crbug.com/591099 fast/forms/input-user-modify.html [ Failure ] @@ -10758,7 +10766,7 @@ crbug.com/591099 fast/forms/input-value.html [ Failure ] crbug.com/591099 fast/forms/input-valueasnumber-unsupported.html [ Crash Failure ] crbug.com/591099 fast/forms/input-width-height-attributes.html [ Failure ] -crbug.com/591099 fast/forms/input-widths.html [ Crash ] +crbug.com/591099 fast/forms/input-widths.html [ Crash Failure ] crbug.com/591099 fast/forms/input-zero-height-focus.html [ Failure ] crbug.com/591099 fast/forms/interactive-validation-assertion-by-validate-twice.html [ Failure ] crbug.com/591099 fast/forms/interactive-validation-cancel.html [ Failure ] @@ -10771,26 +10779,26 @@ crbug.com/591099 fast/forms/interactive-validation-required-checkbox.html [ Failure ] crbug.com/591099 fast/forms/interactive-validation-select-crash.html [ Failure ] crbug.com/591099 fast/forms/label/continous-click-on-label.html [ Failure ] -crbug.com/591099 fast/forms/label/hover-on-moving-mouse-checkbox-to-parent-label.html [ Failure ] -crbug.com/591099 fast/forms/label/label-contains-other-interactive-content.html [ Crash ] -crbug.com/591099 fast/forms/label/label-event-order.html [ Crash ] +crbug.com/591099 fast/forms/label/hover-on-moving-mouse-checkbox-to-parent-label.html [ Failure Pass ] +crbug.com/591099 fast/forms/label/label-contains-other-interactive-content.html [ Crash Pass ] +crbug.com/591099 fast/forms/label/label-event-order.html [ Crash Failure ] crbug.com/591099 fast/forms/label/label-selection-by-dragging.html [ Failure ] crbug.com/591099 fast/forms/label/label-selection-by-textSelection-and-click.html [ Failure ] crbug.com/591099 fast/forms/label/label-selection.html [ Failure ] -crbug.com/591099 fast/forms/label/labelable-elements.html [ Crash ] -crbug.com/591099 fast/forms/label/labels-add-htmlFor-label.html [ Crash ] -crbug.com/591099 fast/forms/label/labels-add-parent-label.html [ Crash ] -crbug.com/591099 fast/forms/label/labels-change-htmlFor-attribute.html [ Crash ] +crbug.com/591099 fast/forms/label/labelable-elements.html [ Crash Failure ] +crbug.com/591099 fast/forms/label/labels-add-htmlFor-label.html [ Crash Failure ] +crbug.com/591099 fast/forms/label/labels-add-parent-label.html [ Crash Failure ] +crbug.com/591099 fast/forms/label/labels-change-htmlFor-attribute.html [ Crash Failure ] crbug.com/591099 fast/forms/label/labels-contenteditable.html [ Failure ] crbug.com/591099 fast/forms/label/labels-custom-property.html [ Failure ] crbug.com/591099 fast/forms/label/labels-item-index.html [ Failure ] -crbug.com/591099 fast/forms/label/labels-multiple-sibling-labels.html [ Crash ] +crbug.com/591099 fast/forms/label/labels-multiple-sibling-labels.html [ Crash Failure ] crbug.com/591099 fast/forms/label/labels-owner-node-adopted.html [ Crash Failure ] -crbug.com/591099 fast/forms/label/labels-parent-and-sibling-labels.html [ Crash ] -crbug.com/591099 fast/forms/label/labels-remove-htmlFor-attribute.html [ Crash ] -crbug.com/591099 fast/forms/label/labels-remove-htmlFor-label.html [ Crash ] -crbug.com/591099 fast/forms/label/labels-remove-parent-label.html [ Crash ] -crbug.com/591099 fast/forms/label/labels-set-htmlFor-attribute.html [ Crash ] +crbug.com/591099 fast/forms/label/labels-parent-and-sibling-labels.html [ Crash Failure ] +crbug.com/591099 fast/forms/label/labels-remove-htmlFor-attribute.html [ Crash Failure ] +crbug.com/591099 fast/forms/label/labels-remove-htmlFor-label.html [ Crash Failure ] +crbug.com/591099 fast/forms/label/labels-remove-parent-label.html [ Crash Failure ] +crbug.com/591099 fast/forms/label/labels-set-htmlFor-attribute.html [ Crash Failure ] crbug.com/591099 fast/forms/label/selection-disabled-label.html [ Failure ] crbug.com/591099 fast/forms/large-parts.html [ Failure ] crbug.com/591099 fast/forms/lazy-event-listener-scope-chain.html [ Crash Failure ] @@ -10802,9 +10810,9 @@ crbug.com/591099 fast/forms/minWidthPercent.html [ Failure ] crbug.com/591099 fast/forms/misplaced-img-form-registration.html [ Failure ] crbug.com/591099 fast/forms/missing-action.html [ Failure ] -crbug.com/591099 fast/forms/month-multiple-fields/month-multiple-fields-ax-aria-attributes.html [ Crash ] -crbug.com/591099 fast/forms/month-multiple-fields/month-multiple-fields-ax-value-changed-notification.html [ Crash ] -crbug.com/591099 fast/forms/month-multiple-fields/month-multiple-fields-blur-and-focus-events.html [ Crash ] +crbug.com/591099 fast/forms/month-multiple-fields/month-multiple-fields-ax-aria-attributes.html [ Crash Failure ] +crbug.com/591099 fast/forms/month-multiple-fields/month-multiple-fields-ax-value-changed-notification.html [ Crash Failure ] +crbug.com/591099 fast/forms/month-multiple-fields/month-multiple-fields-blur-and-focus-events.html [ Crash Failure ] crbug.com/591099 fast/forms/month-multiple-fields/month-multiple-fields-change-layout-by-value.html [ Failure ] crbug.com/591099 fast/forms/month-multiple-fields/month-multiple-fields-choose-default-value-after-set-value.html [ Failure ] crbug.com/591099 fast/forms/month-multiple-fields/month-multiple-fields-clearbutton-change-and-input-events.html [ Crash Failure ] @@ -10813,12 +10821,12 @@ crbug.com/591099 fast/forms/month-multiple-fields/month-multiple-fields-mouse-events.html [ Crash Failure ] crbug.com/591099 fast/forms/month-multiple-fields/month-multiple-fields-preserve-value-after-history-back.html [ Failure ] crbug.com/591099 fast/forms/month-multiple-fields/month-multiple-fields-readonly-subfield.html [ Failure ] -crbug.com/591099 fast/forms/month-multiple-fields/month-multiple-fields-reset-value-after-reloads.html [ Crash ] -crbug.com/591099 fast/forms/month-multiple-fields/month-multiple-fields-spinbutton-change-and-input-events.html [ Crash ] +crbug.com/591099 fast/forms/month-multiple-fields/month-multiple-fields-reset-value-after-reloads.html [ Crash Failure ] +crbug.com/591099 fast/forms/month-multiple-fields/month-multiple-fields-spinbutton-change-and-input-events.html [ Crash Failure ] crbug.com/591099 fast/forms/month-multiple-fields/month-multiple-fields-stepup-stepdown-from-renderer.html [ Crash Failure ] crbug.com/591099 fast/forms/month-multiple-fields/month-multiple-fields-validity-badinput.html [ Failure ] crbug.com/591099 fast/forms/month-multiple-fields/month-multiple-fields-value-set-empty.html [ Failure ] -crbug.com/591099 fast/forms/month-multiple-fields/month-multiple-fields-wheel-event.html [ Crash ] +crbug.com/591099 fast/forms/month-multiple-fields/month-multiple-fields-wheel-event.html [ Crash Failure ] crbug.com/591099 fast/forms/month/ValidityState-rangeOverflow-month.html [ Failure ] crbug.com/591099 fast/forms/month/ValidityState-rangeUnderflow-month.html [ Failure ] crbug.com/591099 fast/forms/month/ValidityState-stepMismatch-month.html [ Failure ] @@ -10833,7 +10841,7 @@ crbug.com/591099 fast/forms/month/month-pseudo-classes.html [ Failure ] crbug.com/591099 fast/forms/month/month-setrangetext.html [ Failure ] crbug.com/591099 fast/forms/month/month-stepup-stepdown.html [ Failure ] -crbug.com/591099 fast/forms/mouseevent_disabled_form_control.html [ Crash ] +crbug.com/591099 fast/forms/mouseevent_disabled_form_control.html [ Crash Pass ] crbug.com/591099 fast/forms/multiple-selected-options-innerHTML.html [ Failure ] crbug.com/591099 fast/forms/mutation-event-recalc.html [ Failure ] crbug.com/591099 fast/forms/negativeLineHeight.html [ Crash Failure ] @@ -10846,31 +10854,31 @@ crbug.com/591099 fast/forms/number/number-change-event-by-readonly.html [ Failure ] crbug.com/591099 fast/forms/number/number-change-type-on-focus.html [ Crash Failure ] crbug.com/591099 fast/forms/number/number-commit-valid-only.html [ Crash Failure ] -crbug.com/591099 fast/forms/number/number-input-changeevent.html [ Crash ] +crbug.com/591099 fast/forms/number/number-input-changeevent.html [ Crash Failure ] crbug.com/591099 fast/forms/number/number-interactive-validation-required.html [ Crash Failure ] crbug.com/591099 fast/forms/number/number-keyoperation.html [ Crash Failure ] -crbug.com/591099 fast/forms/number/number-losing-renderer-on-click.html [ Crash ] -crbug.com/591099 fast/forms/number/number-outofrange.html [ Crash ] +crbug.com/591099 fast/forms/number/number-losing-renderer-on-click.html [ Crash Pass ] +crbug.com/591099 fast/forms/number/number-outofrange.html [ Crash Failure ] crbug.com/591099 fast/forms/number/number-setrangetext.html [ Failure ] crbug.com/591099 fast/forms/number/number-size.html [ Failure Timeout ] crbug.com/591099 fast/forms/number/number-skip-spaces-in-user-input.html [ Failure ] -crbug.com/591099 fast/forms/number/number-spinbutton-capturing.html [ Crash ] -crbug.com/591099 fast/forms/number/number-spinbutton-change-and-input-events.html [ Crash ] -crbug.com/591099 fast/forms/number/number-spinbutton-click-in-iframe.html [ Crash ] -crbug.com/591099 fast/forms/number/number-spinbutton-crash-on-detach.html [ Crash ] +crbug.com/591099 fast/forms/number/number-spinbutton-capturing.html [ Crash Failure ] +crbug.com/591099 fast/forms/number/number-spinbutton-change-and-input-events.html [ Crash Failure ] +crbug.com/591099 fast/forms/number/number-spinbutton-click-in-iframe.html [ Crash Failure ] +crbug.com/591099 fast/forms/number/number-spinbutton-crash-on-detach.html [ Crash Pass ] crbug.com/591099 fast/forms/number/number-spinbutton-gets-disabled-or-readonly.html [ Crash Failure ] crbug.com/591099 fast/forms/number/number-spinbutton-in-multi-column.html [ Failure ] -crbug.com/591099 fast/forms/number/number-spinbutton-state.html [ Crash ] +crbug.com/591099 fast/forms/number/number-spinbutton-state.html [ Crash Failure ] crbug.com/591099 fast/forms/number/number-stepup-stepdown-from-renderer.html [ Crash Failure Timeout ] crbug.com/591099 fast/forms/number/number-stepup-stepdown.html [ Failure ] crbug.com/591099 fast/forms/number/number-validation-message.html [ Crash Failure ] -crbug.com/591099 fast/forms/number/number-validity-badinput.html [ Crash ] +crbug.com/591099 fast/forms/number/number-validity-badinput.html [ Crash Failure ] crbug.com/591099 fast/forms/number/number-validity-rangeoverflow.html [ Failure ] crbug.com/591099 fast/forms/number/number-validity-rangeunderflow.html [ Failure ] crbug.com/591099 fast/forms/number/number-validity-stepmismatch.html [ Crash Failure ] crbug.com/591099 fast/forms/number/number-validity-typemismatch.html [ Failure ] crbug.com/591099 fast/forms/number/number-valueasnumber.html [ Failure ] -crbug.com/591099 fast/forms/number/number-wheel-event.html [ Crash ] +crbug.com/591099 fast/forms/number/number-wheel-event.html [ Crash Failure ] crbug.com/591099 fast/forms/numeric-input-name.html [ Failure ] crbug.com/591099 fast/forms/old-names.html [ Failure ] crbug.com/591099 fast/forms/onselect-textfield.html [ Failure ] @@ -10901,7 +10909,7 @@ crbug.com/591099 fast/forms/radio/radio-group-arrow-cycle-edge.html [ Failure ] crbug.com/591099 fast/forms/radio/radio-group-document-destruction.html [ Failure ] crbug.com/591099 fast/forms/radio/radio-group-in-detached-form.html [ Failure ] -crbug.com/591099 fast/forms/radio/radio-group-keyboard-change-event.html [ Crash ] +crbug.com/591099 fast/forms/radio/radio-group-keyboard-change-event.html [ Crash Pass ] crbug.com/591099 fast/forms/radio/radio-group-remove-required.html [ Failure ] crbug.com/591099 fast/forms/radio/radio-group.html [ Failure ] crbug.com/591099 fast/forms/radio/radio-indeterminate-pseudo-class.html [ Failure ] @@ -10912,7 +10920,7 @@ crbug.com/591099 fast/forms/radio/radio-remove-form-attr.html [ Failure ] crbug.com/591099 fast/forms/radio/radio-restore-preventDefault.html [ Failure ] crbug.com/591099 fast/forms/radio/radio_checked.html [ Failure ] -crbug.com/591099 fast/forms/radio/radio_checked_dynamic.html [ Crash ] +crbug.com/591099 fast/forms/radio/radio_checked_dynamic.html [ Crash Pass ] crbug.com/591099 fast/forms/radio/radio_checked_name.html [ Failure ] crbug.com/591099 fast/forms/radio/remove-radio-button-assert.html [ Failure ] crbug.com/591099 fast/forms/radio/state-restore-radio-group.html [ Crash Failure ] @@ -10940,11 +10948,11 @@ crbug.com/591099 fast/forms/range/range-thumb-height-percentage.html [ Failure ] crbug.com/591099 fast/forms/range/range-type-change-crash.html [ Failure ] crbug.com/591099 fast/forms/range/range-type-change-onchange-2.html [ Failure ] -crbug.com/591099 fast/forms/range/range-type-change-onchange.html [ Crash ] -crbug.com/591099 fast/forms/range/range-type-change-oninput.html [ Crash ] +crbug.com/591099 fast/forms/range/range-type-change-onchange.html [ Crash Failure ] +crbug.com/591099 fast/forms/range/range-type-change-oninput.html [ Crash Pass ] crbug.com/591099 fast/forms/range/range-value-rounding.html [ Failure Timeout ] crbug.com/591099 fast/forms/range/slider-appearance-crash.html [ Failure ] -crbug.com/591099 fast/forms/range/slider-delete-while-dragging-thumb.html [ Crash ] +crbug.com/591099 fast/forms/range/slider-delete-while-dragging-thumb.html [ Crash Failure ] crbug.com/591099 fast/forms/range/slider-hit-testing.html [ Failure ] crbug.com/591099 fast/forms/range/slider-in-multi-column.html [ Failure ] crbug.com/591099 fast/forms/range/slider-inline-crash.html [ Failure ] @@ -10956,31 +10964,31 @@ crbug.com/591099 fast/forms/range/thumbslider-crash.html [ Failure ] crbug.com/591099 fast/forms/range/thumbslider-no-parent-slider.html [ Failure ] crbug.com/591099 fast/forms/removed-image-as-property.html [ Crash Failure ] -crbug.com/591099 fast/forms/render-text-crash.html [ Crash ] +crbug.com/591099 fast/forms/render-text-crash.html [ Crash Failure ] crbug.com/591099 fast/forms/reparented-image-as-property.html [ Failure ] crbug.com/591099 fast/forms/reportValidity-cancel.html [ Failure ] -crbug.com/591099 fast/forms/reportValidity-handler-updates-dom.html [ Crash ] +crbug.com/591099 fast/forms/reportValidity-handler-updates-dom.html [ Crash Failure ] crbug.com/591099 fast/forms/reportValidity-invalid.html [ Crash Failure ] crbug.com/591099 fast/forms/reportValidity-valid.html [ Crash Failure ] crbug.com/591099 fast/forms/required-attribute-001.html [ Failure ] crbug.com/591099 fast/forms/required-attribute-002.html [ Failure ] crbug.com/591099 fast/forms/reset-autofilled.html [ Failure ] -crbug.com/591099 fast/forms/restore-selection-after-layout.html [ Crash ] -crbug.com/591099 fast/forms/search/abspos-cancel-button-crash.html [ Crash ] +crbug.com/591099 fast/forms/restore-selection-after-layout.html [ Crash Failure ] +crbug.com/591099 fast/forms/search/abspos-cancel-button-crash.html [ Crash Pass ] crbug.com/591099 fast/forms/search/input-search-press-escape-key.html [ Crash Failure ] crbug.com/591099 fast/forms/search/search-abs-pos-cancel-button.html [ Crash Failure ] crbug.com/591099 fast/forms/search/search-appearance-basic.html [ Crash Failure ] -crbug.com/591099 fast/forms/search/search-cancel-button-events.html [ Crash ] +crbug.com/591099 fast/forms/search/search-cancel-button-events.html [ Crash Failure ] crbug.com/591099 fast/forms/search/search-cancel-button-mouseup.html [ Crash Failure ] crbug.com/591099 fast/forms/search/search-cancel-button-style-sharing.html [ Crash Failure ] -crbug.com/591099 fast/forms/search/search-delete-while-cancel-button-clicked.html [ Crash ] +crbug.com/591099 fast/forms/search/search-delete-while-cancel-button-clicked.html [ Crash Failure ] crbug.com/591099 fast/forms/search/search-disabled-readonly.html [ Crash Failure ] crbug.com/591099 fast/forms/search/search-display-none-cancel-button.html [ Crash Failure ] crbug.com/591099 fast/forms/search/search-hide-cancel-on-cancel.html [ Crash Failure ] crbug.com/591099 fast/forms/search/search-rtl.html [ Crash Failure ] crbug.com/591099 fast/forms/search/search-setrangetext.html [ Crash Failure ] crbug.com/591099 fast/forms/search/search-transformed.html [ Crash Failure ] -crbug.com/591099 fast/forms/search/search-type-change-crash.html [ Crash ] +crbug.com/591099 fast/forms/search/search-type-change-crash.html [ Crash Pass ] crbug.com/591099 fast/forms/search/search-vertical-alignment.html [ Crash Failure ] crbug.com/591099 fast/forms/search/search-zoomed.html [ Crash Failure ] crbug.com/591099 fast/forms/search/searchfield-heights.html [ Crash Failure ] @@ -10998,10 +11006,10 @@ crbug.com/591099 fast/forms/select-popup/popup-menu-appearance-zoom110.html [ Failure ] crbug.com/591099 fast/forms/select-popup/popup-menu-appearance.html [ Failure ] crbug.com/591099 fast/forms/select-popup/popup-menu-ax.html [ Crash Failure ] -crbug.com/591099 fast/forms/select-popup/popup-menu-crash-on-cancel.html [ Crash ] +crbug.com/591099 fast/forms/select-popup/popup-menu-crash-on-cancel.html [ Crash Failure ] crbug.com/591099 fast/forms/select-popup/popup-menu-crash-on-close.html [ Failure ] crbug.com/591099 fast/forms/select-popup/popup-menu-crash-on-select.html [ Failure ] -crbug.com/591099 fast/forms/select-popup/popup-menu-crash-on-style-update.html [ Crash ] +crbug.com/591099 fast/forms/select-popup/popup-menu-crash-on-style-update.html [ Crash Pass ] crbug.com/591099 fast/forms/select-popup/popup-menu-mouse-operations.html [ Failure ] crbug.com/591099 fast/forms/select-popup/popup-menu-nested-style.html [ Failure ] crbug.com/591099 fast/forms/select-popup/popup-menu-touch-operations.html [ Failure Timeout ] @@ -11034,13 +11042,13 @@ crbug.com/591099 fast/forms/select/listbox-clip.html [ Failure ] crbug.com/591099 fast/forms/select/listbox-deselect-scroll.html [ Failure ] crbug.com/591099 fast/forms/select/listbox-disabled-scroll-no-onchange.html [ Failure ] -crbug.com/591099 fast/forms/select/listbox-drag-in-from-outside.html [ Crash ] +crbug.com/591099 fast/forms/select/listbox-drag-in-from-outside.html [ Crash Pass ] crbug.com/591099 fast/forms/select/listbox-drag-in-non-multiple.html [ Failure ] crbug.com/591099 fast/forms/select/listbox-focusable-items.html [ Failure ] crbug.com/591099 fast/forms/select/listbox-height-with-before.html [ Failure ] crbug.com/591099 fast/forms/select/listbox-hit-test-zoomed.html [ Failure ] crbug.com/591099 fast/forms/select/listbox-in-multi-column.html [ Failure ] -crbug.com/591099 fast/forms/select/listbox-no-force-layout.html [ Crash ] +crbug.com/591099 fast/forms/select/listbox-no-force-layout.html [ Crash Pass ] crbug.com/591099 fast/forms/select/listbox-onchange.html [ Failure ] crbug.com/591099 fast/forms/select/listbox-oninput-fired.html [ Failure ] crbug.com/591099 fast/forms/select/listbox-overlay-scrollbar.html [ Failure Pass ] @@ -11049,7 +11057,7 @@ crbug.com/591099 fast/forms/select/listbox-scrollbar-incremental-load.html [ Failure ] crbug.com/591099 fast/forms/select/listbox-select-reset.html [ Failure ] crbug.com/591099 fast/forms/select/listbox-selection-2.html [ Failure ] -crbug.com/591099 fast/forms/select/listbox-selection.html [ Crash ] +crbug.com/591099 fast/forms/select/listbox-selection.html [ Crash Failure ] crbug.com/591099 fast/forms/select/listbox-tap-input-change-event.html [ Failure ] crbug.com/591099 fast/forms/select/listbox-tap.html [ Failure ] crbug.com/591099 fast/forms/select/listbox-typeahead-cyrillic.html [ Crash Failure ] @@ -11061,7 +11069,7 @@ crbug.com/591099 fast/forms/select/menulist-appearance-basic.html [ Failure ] crbug.com/591099 fast/forms/select/menulist-appearance-none.html [ Failure ] crbug.com/591099 fast/forms/select/menulist-appearance-rtl.html [ Failure ] -crbug.com/591099 fast/forms/select/menulist-change-event-with-reset-blur.html [ Crash ] +crbug.com/591099 fast/forms/select/menulist-change-event-with-reset-blur.html [ Crash Pass ] crbug.com/591099 fast/forms/select/menulist-clip.html [ Failure ] crbug.com/591099 fast/forms/select/menulist-deselect-update.html [ Failure ] crbug.com/591099 fast/forms/select/menulist-disabled-selected-option.html [ Failure ] @@ -11069,14 +11077,14 @@ crbug.com/591099 fast/forms/select/menulist-narrow-width.html [ Failure ] crbug.com/591099 fast/forms/select/menulist-no-overflow.html [ Failure ] crbug.com/591099 fast/forms/select/menulist-no-renderer-for-unexpected-children.html [ Failure ] -crbug.com/591099 fast/forms/select/menulist-no-renderer-onmousedown.html [ Crash ] +crbug.com/591099 fast/forms/select/menulist-no-renderer-onmousedown.html [ Crash Failure ] crbug.com/591099 fast/forms/select/menulist-onchange-fired-with-key-up-down.html [ Failure ] crbug.com/591099 fast/forms/select/menulist-oninput-fired.html [ Failure ] crbug.com/591099 fast/forms/select/menulist-option-wrap.html [ Failure ] crbug.com/591099 fast/forms/select/menulist-popup-crash.html [ Failure ] crbug.com/591099 fast/forms/select/menulist-popup-item-style.html [ Failure ] crbug.com/591099 fast/forms/select/menulist-popup-open-hide-using-keyboard.html [ Failure ] -crbug.com/591099 fast/forms/select/menulist-remove-option-onchange.html [ Crash ] +crbug.com/591099 fast/forms/select/menulist-remove-option-onchange.html [ Crash Pass ] crbug.com/591099 fast/forms/select/menulist-restrict-line-height.html [ Failure ] crbug.com/591099 fast/forms/select/menulist-separator-painting.html [ Failure ] crbug.com/591099 fast/forms/select/menulist-style-color.html [ Failure ] @@ -11109,8 +11117,8 @@ crbug.com/591099 fast/forms/select/options-indexed-properties.html [ Failure ] crbug.com/591099 fast/forms/select/popup-closes-on-blur.html [ Failure ] crbug.com/591099 fast/forms/select/popup-with-display-none-optgroup.html [ Failure ] -crbug.com/591099 fast/forms/select/remove-element-from-within-focus-handler-crash.html [ Crash ] -crbug.com/591099 fast/forms/select/select-add-assertion.html [ Crash ] +crbug.com/591099 fast/forms/select/remove-element-from-within-focus-handler-crash.html [ Crash Failure ] +crbug.com/591099 fast/forms/select/select-add-assertion.html [ Crash Pass ] crbug.com/591099 fast/forms/select/select-add.html [ Failure ] crbug.com/591099 fast/forms/select/select-align.html [ Failure ] crbug.com/591099 fast/forms/select/select-assign-null.html [ Failure ] @@ -11119,12 +11127,12 @@ crbug.com/591099 fast/forms/select/select-baseline.html [ Failure ] crbug.com/591099 fast/forms/select/select-block-background.html [ Failure ] crbug.com/591099 fast/forms/select/select-change-listbox-size.html [ Failure ] -crbug.com/591099 fast/forms/select/select-change-listbox-to-popup-roundtrip.html [ Crash ] +crbug.com/591099 fast/forms/select/select-change-listbox-to-popup-roundtrip.html [ Crash Pass ] crbug.com/591099 fast/forms/select/select-change-listbox-to-popup.html [ Failure ] -crbug.com/591099 fast/forms/select/select-change-popup-to-listbox-in-event-handler.html [ Crash ] -crbug.com/591099 fast/forms/select/select-change-popup-to-listbox-roundtrip.html [ Crash ] +crbug.com/591099 fast/forms/select/select-change-popup-to-listbox-in-event-handler.html [ Crash Failure ] +crbug.com/591099 fast/forms/select/select-change-popup-to-listbox-roundtrip.html [ Crash Pass ] crbug.com/591099 fast/forms/select/select-change-popup-to-listbox.html [ Failure ] -crbug.com/591099 fast/forms/select/select-change-type-on-focus.html [ Crash ] +crbug.com/591099 fast/forms/select/select-change-type-on-focus.html [ Crash Failure ] crbug.com/591099 fast/forms/select/select-change-type-on-mousedown-focus.html [ Crash Failure ] crbug.com/591099 fast/forms/select/select-clientheight-large-size.html [ Failure ] crbug.com/591099 fast/forms/select/select-clientheight-with-multiple-attr.html [ Failure ] @@ -11142,7 +11150,7 @@ crbug.com/591099 fast/forms/select/select-item-background-clip.html [ Failure ] crbug.com/591099 fast/forms/select/select-list-box-mouse-focus.html [ Failure ] crbug.com/591099 fast/forms/select/select-list-box-with-height.html [ Failure ] -crbug.com/591099 fast/forms/select/select-listbox-focus-displaynone.html [ Crash Failure ] +crbug.com/591099 fast/forms/select/select-listbox-focus-displaynone.html [ Crash Failure Pass ] crbug.com/591099 fast/forms/select/select-listbox-multiple-no-focusring.html [ Failure ] crbug.com/591099 fast/forms/select/select-live-pseudo-selectors.html [ Crash Failure ] crbug.com/591099 fast/forms/select/select-max-length.html [ Failure ] @@ -11178,7 +11186,7 @@ crbug.com/591099 fast/forms/select/select-type-ahead-non-latin.html [ Failure ] crbug.com/591099 fast/forms/select/select-typeahead-crash.html [ Failure ] crbug.com/591099 fast/forms/select/select-typeahead-with-spacekey.html [ Failure ] -crbug.com/591099 fast/forms/select/select-value-null.html [ Crash ] +crbug.com/591099 fast/forms/select/select-value-null.html [ Crash Pass ] crbug.com/591099 fast/forms/select/select-visual-hebrew.html [ Failure ] crbug.com/591099 fast/forms/select/select-width-font-change.html [ Failure ] crbug.com/591099 fast/forms/select/select-with-display-none-options.html [ Failure ] @@ -11191,15 +11199,15 @@ crbug.com/591099 fast/forms/selection-direction.html [ Crash Timeout ] crbug.com/591099 fast/forms/selection-functions.html [ Crash Failure ] crbug.com/591099 fast/forms/selection-setSelectionRange-focusing.html [ Crash Failure ] -crbug.com/591099 fast/forms/selection-setSelectionRange-frameselection.html [ Crash ] +crbug.com/591099 fast/forms/selection-setSelectionRange-frameselection.html [ Crash Pass ] crbug.com/591099 fast/forms/selection-start-end-readonly.html [ Crash Failure ] crbug.com/591099 fast/forms/selection-wrongtype.html [ Crash Timeout ] crbug.com/591099 fast/forms/setCustomValidity-arguments.html [ Failure ] crbug.com/591099 fast/forms/setCustomValidity-existence.html [ Crash Failure ] crbug.com/591099 fast/forms/setCustomValidity.html [ Failure ] -crbug.com/591099 fast/forms/setrangetext-within-events.html [ Crash Failure ] +crbug.com/591099 fast/forms/setrangetext-within-events.html [ Crash Failure Pass ] crbug.com/591099 fast/forms/setrangetext.html [ Crash Failure ] -crbug.com/591099 fast/forms/shadow-tree-exposure.html [ Crash ] +crbug.com/591099 fast/forms/shadow-tree-exposure.html [ Crash Failure ] crbug.com/591099 fast/forms/slow-click.html [ Failure Pass ] crbug.com/591099 fast/forms/state-restore-broken-state.html [ Crash Failure ] crbug.com/591099 fast/forms/state-restore-empty-state.html [ Failure ] @@ -11221,21 +11229,21 @@ crbug.com/591099 fast/forms/submit-to-url-fragment.html [ Failure ] crbug.com/591099 fast/forms/submit-with-base.html [ Crash Failure ] crbug.com/591099 fast/forms/submit/submit-appearance-basic.html [ Failure ] -crbug.com/591099 fast/forms/suggested-value-after-setvalue.html [ Crash ] -crbug.com/591099 fast/forms/suggested-value.html [ Crash ] +crbug.com/591099 fast/forms/suggested-value-after-setvalue.html [ Crash Pass ] +crbug.com/591099 fast/forms/suggested-value.html [ Crash Pass ] crbug.com/591099 fast/forms/suggestion-picker/date-suggestion-picker-appearance-zoom125.html [ Crash Failure Timeout ] crbug.com/591099 fast/forms/suggestion-picker/date-suggestion-picker-appearance-zoom200.html [ Crash Failure ] crbug.com/591099 fast/forms/suggestion-picker/date-suggestion-picker-key-operations.html [ Crash Failure Timeout ] crbug.com/591099 fast/forms/suggestion-picker/date-suggestion-picker-min-max-attribute.html [ Crash Failure Timeout ] -crbug.com/591099 fast/forms/suggestion-picker/date-suggestion-picker-reset-value-after-reload.html [ Crash ] +crbug.com/591099 fast/forms/suggestion-picker/date-suggestion-picker-reset-value-after-reload.html [ Crash Failure ] crbug.com/591099 fast/forms/suggestion-picker/date-suggestion-picker-step-attribute.html [ Crash Failure ] crbug.com/591099 fast/forms/suggestion-picker/datetimelocal-suggestion-picker-appearance-locale-hebrew.html [ Crash Failure Timeout ] crbug.com/591099 fast/forms/suggestion-picker/datetimelocal-suggestion-picker-min-max-attribute.html [ Crash Failure ] -crbug.com/591099 fast/forms/suggestion-picker/datetimelocal-suggestion-picker-reset-value-after-reload.html [ Crash ] +crbug.com/591099 fast/forms/suggestion-picker/datetimelocal-suggestion-picker-reset-value-after-reload.html [ Crash Failure ] crbug.com/591099 fast/forms/suggestion-picker/datetimelocal-suggestion-picker-step-attribute.html [ Crash Failure ] crbug.com/591099 fast/forms/suggestion-picker/month-suggestion-picker-key-operations.html [ Crash Failure Timeout ] crbug.com/591099 fast/forms/suggestion-picker/month-suggestion-picker-min-max-attribute.html [ Crash Failure ] -crbug.com/591099 fast/forms/suggestion-picker/month-suggestion-picker-reset-value-after-reload.html [ Crash ] +crbug.com/591099 fast/forms/suggestion-picker/month-suggestion-picker-reset-value-after-reload.html [ Crash Failure ] crbug.com/591099 fast/forms/suggestion-picker/month-suggestion-picker-step-attribute.html [ Crash Failure ] crbug.com/591099 fast/forms/suggestion-picker/time-suggestion-picker-appearance-locale-hebrew.html [ Crash Failure ] crbug.com/591099 fast/forms/suggestion-picker/time-suggestion-picker-appearance-rtl.html [ Crash Failure ] @@ -11244,14 +11252,14 @@ crbug.com/591099 fast/forms/suggestion-picker/time-suggestion-picker-step-attribute.html [ Crash Failure ] crbug.com/591099 fast/forms/suggestion-picker/week-suggestion-picker-key-operations.html [ Crash Failure Timeout ] crbug.com/591099 fast/forms/suggestion-picker/week-suggestion-picker-min-max-attribute.html [ Crash Failure ] -crbug.com/591099 fast/forms/suggestion-picker/week-suggestion-picker-reset-value-after-reload.html [ Crash ] +crbug.com/591099 fast/forms/suggestion-picker/week-suggestion-picker-reset-value-after-reload.html [ Crash Failure ] crbug.com/591099 fast/forms/suggestion-picker/week-suggestion-picker-step-attribute.html [ Crash Failure ] crbug.com/591099 fast/forms/tabbing-input-iframe.html [ Crash Failure ] crbug.com/591099 fast/forms/tabs-with-modifiers.html [ Failure ] crbug.com/591099 fast/forms/targeted-frame-submission.html [ Failure ] crbug.com/591099 fast/forms/text-control-intrinsic-widths.html [ Timeout ] -crbug.com/591099 fast/forms/text-control-selection-after-blur.html [ Crash ] -crbug.com/591099 fast/forms/text-set-value-crash.html [ Crash ] +crbug.com/591099 fast/forms/text-control-selection-after-blur.html [ Crash Pass ] +crbug.com/591099 fast/forms/text-set-value-crash.html [ Crash Failure ] crbug.com/591099 fast/forms/text-style-color.html [ Crash Failure ] crbug.com/591099 fast/forms/text/input-appearance-bkcolor.html [ Crash Failure ] crbug.com/591099 fast/forms/text/input-appearance-default-bkcolor.html [ Crash Failure ] @@ -11283,7 +11291,7 @@ crbug.com/591099 fast/forms/text/input-readonly-autoscroll.html [ Crash Failure ] crbug.com/591099 fast/forms/text/input-readonly-dimmed.html [ Crash Failure ] crbug.com/591099 fast/forms/text/input-readonly-empty.html [ Failure ] -crbug.com/591099 fast/forms/text/input-readonly-focus.html [ Crash ] +crbug.com/591099 fast/forms/text/input-readonly-focus.html [ Crash Pass ] crbug.com/591099 fast/forms/text/input-select-on-click.html [ Crash Failure ] crbug.com/591099 fast/forms/text/input-selection-hidden.html [ Crash Failure ] crbug.com/591099 fast/forms/text/input-set-composition-scroll.html [ Failure ] @@ -11298,18 +11306,18 @@ crbug.com/591099 fast/forms/text/input-text-drag-down.html [ Crash Failure ] crbug.com/591099 fast/forms/text/input-text-enter.html [ Crash Failure ] crbug.com/591099 fast/forms/text/input-text-option-delete.html [ Crash Failure ] -crbug.com/591099 fast/forms/text/input-text-paste-maxlength.html [ Crash Timeout ] +crbug.com/591099 fast/forms/text/input-text-paste-maxlength.html [ Crash Pass Timeout ] crbug.com/591099 fast/forms/text/input-text-scroll-left-on-blur.html [ Crash Failure ] crbug.com/591099 fast/forms/text/input-text-self-emptying-click.html [ Crash Failure ] crbug.com/591099 fast/forms/text/input-text-word-wrap.html [ Crash Failure ] crbug.com/591099 fast/forms/text/input-width.html [ Failure ] -crbug.com/591099 fast/forms/text/placeholder-crash-with-scrollbar-corner.html [ Crash ] +crbug.com/591099 fast/forms/text/placeholder-crash-with-scrollbar-corner.html [ Crash Failure ] crbug.com/591099 fast/forms/text/placeholder-dom-property.html [ Failure ] crbug.com/591099 fast/forms/text/text-appearance-basic.html [ Crash Failure ] crbug.com/591099 fast/forms/text/text-appearance-datalist.html [ Failure ] -crbug.com/591099 fast/forms/text/text-change-event-after-clear-in-submit.html [ Crash ] -crbug.com/591099 fast/forms/text/text-change-event-after-updating-default.html [ Crash ] -crbug.com/591099 fast/forms/text/text-dir-auto-with-placeholder.html [ Crash ] +crbug.com/591099 fast/forms/text/text-change-event-after-clear-in-submit.html [ Crash Pass ] +crbug.com/591099 fast/forms/text/text-change-event-after-updating-default.html [ Crash Pass ] +crbug.com/591099 fast/forms/text/text-dir-auto-with-placeholder.html [ Crash Pass ] crbug.com/591099 fast/forms/text/text-field-setvalue-crash.html [ Failure ] crbug.com/591099 fast/forms/text/text-font-height-mismatch.html [ Crash Failure ] crbug.com/591099 fast/forms/text/text-inner-overflow.html [ Failure ] @@ -11317,13 +11325,13 @@ crbug.com/591099 fast/forms/text/text-reset-click-delete-text-change-event.html [ Crash Failure ] crbug.com/591099 fast/forms/text/text-select-disabled.html [ Crash Failure ] crbug.com/591099 fast/forms/text/text-select-invisible.html [ Crash Failure ] -crbug.com/591099 fast/forms/text/text-selection-after-type-change.html [ Crash ] -crbug.com/591099 fast/forms/text/text-set-selection-crash.html [ Crash ] +crbug.com/591099 fast/forms/text/text-selection-after-type-change.html [ Crash Pass ] +crbug.com/591099 fast/forms/text/text-set-selection-crash.html [ Crash Pass ] crbug.com/591099 fast/forms/text/text-update-datalist-while-focused.html [ Failure ] crbug.com/591099 fast/forms/text/text-window-lost-focus-change-event.html [ Failure Timeout ] -crbug.com/591099 fast/forms/text/textfield-focus-out.html [ Crash ] +crbug.com/591099 fast/forms/text/textfield-focus-out.html [ Crash Failure ] crbug.com/591099 fast/forms/text/textfield-focus-ring.html [ Failure ] -crbug.com/591099 fast/forms/text/textfield-onchange-deletion.html [ Crash ] +crbug.com/591099 fast/forms/text/textfield-onchange-deletion.html [ Crash Pass ] crbug.com/591099 fast/forms/text/textfield-outline.html [ Crash Failure ] crbug.com/591099 fast/forms/text/textfield-overflow-by-value-update.html [ Crash Failure ] crbug.com/591099 fast/forms/text/textfield-overflow.html [ Failure ] @@ -11332,8 +11340,8 @@ crbug.com/591099 fast/forms/textarea/basic-textareas.html [ Crash Failure ] crbug.com/591099 fast/forms/textarea/cols-attribute.html [ Failure ] crbug.com/591099 fast/forms/textarea/drag-into-textarea.html [ Crash Failure ] -crbug.com/591099 fast/forms/textarea/drag-out-of-textarea.html [ Crash Failure ] -crbug.com/591099 fast/forms/textarea/empty-textarea-toggle-disabled.html [ Crash ] +crbug.com/591099 fast/forms/textarea/drag-out-of-textarea.html [ Crash Failure Pass ] +crbug.com/591099 fast/forms/textarea/empty-textarea-toggle-disabled.html [ Crash Pass ] crbug.com/591099 fast/forms/textarea/linebox-overflow-in-textarea-padding.html [ Crash Failure ] crbug.com/591099 fast/forms/textarea/onselect-textarea.html [ Failure ] crbug.com/591099 fast/forms/textarea/paste-into-textarea.html [ Crash Failure ] @@ -11350,7 +11358,7 @@ crbug.com/591099 fast/forms/textarea/textarea-checkValidity-crash.html [ Failure ] crbug.com/591099 fast/forms/textarea/textarea-crlf.html [ Crash Failure ] crbug.com/591099 fast/forms/textarea/textarea-default-value-leading-newline.html [ Crash Failure ] -crbug.com/591099 fast/forms/textarea/textarea-dir-auto-with-placeholder.html [ Crash ] +crbug.com/591099 fast/forms/textarea/textarea-dir-auto-with-placeholder.html [ Crash Pass ] crbug.com/591099 fast/forms/textarea/textarea-initial-caret-position.html [ Crash Failure ] crbug.com/591099 fast/forms/textarea/textarea-input-event.html [ Crash Failure ] crbug.com/591099 fast/forms/textarea/textarea-inputmode.html [ Failure ] @@ -11361,18 +11369,18 @@ crbug.com/591099 fast/forms/textarea/textarea-minlength.html [ Failure ] crbug.com/591099 fast/forms/textarea/textarea-newline.html [ Crash Failure ] crbug.com/591099 fast/forms/textarea/textarea-no-scroll-on-blur.html [ Crash Failure ] -crbug.com/591099 fast/forms/textarea/textarea-node-removed-from-document-crash.html [ Crash ] +crbug.com/591099 fast/forms/textarea/textarea-node-removed-from-document-crash.html [ Crash Pass ] crbug.com/591099 fast/forms/textarea/textarea-placeholder-dom-property.html [ Failure ] crbug.com/591099 fast/forms/textarea/textarea-placeholder-paint-order.html [ Failure ] crbug.com/591099 fast/forms/textarea/textarea-placeholder-relayout-assertion.html [ Crash Failure ] crbug.com/591099 fast/forms/textarea/textarea-placeholder-visibility-1.html [ Failure ] crbug.com/591099 fast/forms/textarea/textarea-placeholder-visibility-2.html [ Crash Failure ] crbug.com/591099 fast/forms/textarea/textarea-placeholder-wrapping.html [ Crash Failure ] -crbug.com/591099 fast/forms/textarea/textarea-resize-above-min-size-and-below-initial-size.html [ Crash ] -crbug.com/591099 fast/forms/textarea/textarea-resize-below-min-intrinsic-size.html [ Crash Timeout ] -crbug.com/591099 fast/forms/textarea/textarea-resize-below-min-size-zoomed.html [ Crash Timeout ] -crbug.com/591099 fast/forms/textarea/textarea-resize-below-min-size.html [ Crash ] -crbug.com/591099 fast/forms/textarea/textarea-resize-orthogonal-containing-block.html [ Crash ] +crbug.com/591099 fast/forms/textarea/textarea-resize-above-min-size-and-below-initial-size.html [ Crash Pass ] +crbug.com/591099 fast/forms/textarea/textarea-resize-below-min-intrinsic-size.html [ Crash Pass Timeout ] +crbug.com/591099 fast/forms/textarea/textarea-resize-below-min-size-zoomed.html [ Crash Pass Timeout ] +crbug.com/591099 fast/forms/textarea/textarea-resize-below-min-size.html [ Crash Pass ] +crbug.com/591099 fast/forms/textarea/textarea-resize-orthogonal-containing-block.html [ Crash Failure ] crbug.com/591099 fast/forms/textarea/textarea-rows-cols.html [ Crash Failure ] crbug.com/591099 fast/forms/textarea/textarea-scroll-height.html [ Crash Failure ] crbug.com/591099 fast/forms/textarea/textarea-scrollbar-height.html [ Crash Failure ] @@ -11382,7 +11390,7 @@ crbug.com/591099 fast/forms/textarea/textarea-scrolled-type.html [ Crash Failure ] crbug.com/591099 fast/forms/textarea/textarea-select.html [ Crash Failure ] crbug.com/591099 fast/forms/textarea/textarea-selection-preservation.html [ Crash Failure ] -crbug.com/591099 fast/forms/textarea/textarea-set-defaultvalue-after-value.html [ Crash ] +crbug.com/591099 fast/forms/textarea/textarea-set-defaultvalue-after-value.html [ Crash Failure ] crbug.com/591099 fast/forms/textarea/textarea-setinnerhtml.html [ Crash Failure ] crbug.com/591099 fast/forms/textarea/textarea-setrangetext.html [ Crash Failure ] crbug.com/591099 fast/forms/textarea/textarea-setvalue-without-renderer.html [ Crash Failure ] @@ -11390,42 +11398,42 @@ crbug.com/591099 fast/forms/textarea/textarea-textlength.html [ Crash Failure ] crbug.com/591099 fast/forms/textarea/textarea-width.html [ Crash Failure ] crbug.com/591099 fast/forms/textarea/textarea-wrap-attribute.html [ Failure ] -crbug.com/591099 fast/forms/textfield-change-event.html [ Crash ] -crbug.com/591099 fast/forms/textfield-clone.html [ Crash ] +crbug.com/591099 fast/forms/textfield-change-event.html [ Crash Pass ] +crbug.com/591099 fast/forms/textfield-clone.html [ Crash Failure ] crbug.com/591099 fast/forms/textfield-to-password-on-focus.html [ Crash Failure ] -crbug.com/591099 fast/forms/time-multiple-fields/time-multiple-fields-ax-aria-attributes.html [ Crash ] -crbug.com/591099 fast/forms/time-multiple-fields/time-multiple-fields-ax-value-changed-notification.html [ Crash ] -crbug.com/591099 fast/forms/time-multiple-fields/time-multiple-fields-blur-and-focus-events.html [ Crash ] +crbug.com/591099 fast/forms/time-multiple-fields/time-multiple-fields-ax-aria-attributes.html [ Crash Failure ] +crbug.com/591099 fast/forms/time-multiple-fields/time-multiple-fields-ax-value-changed-notification.html [ Crash Failure ] +crbug.com/591099 fast/forms/time-multiple-fields/time-multiple-fields-blur-and-focus-events.html [ Crash Failure ] crbug.com/591099 fast/forms/time-multiple-fields/time-multiple-fields-change-layout-by-value.html [ Failure ] -crbug.com/591099 fast/forms/time-multiple-fields/time-multiple-fields-change-type-on-focus-2.html [ Crash ] -crbug.com/591099 fast/forms/time-multiple-fields/time-multiple-fields-change-type-on-focus-3.html [ Crash ] -crbug.com/591099 fast/forms/time-multiple-fields/time-multiple-fields-change-type-on-focus.html [ Crash ] +crbug.com/591099 fast/forms/time-multiple-fields/time-multiple-fields-change-type-on-focus-2.html [ Crash Failure ] +crbug.com/591099 fast/forms/time-multiple-fields/time-multiple-fields-change-type-on-focus-3.html [ Crash Pass ] +crbug.com/591099 fast/forms/time-multiple-fields/time-multiple-fields-change-type-on-focus.html [ Crash Failure ] crbug.com/591099 fast/forms/time-multiple-fields/time-multiple-fields-choose-default-value-after-set-value.html [ Failure ] crbug.com/591099 fast/forms/time-multiple-fields/time-multiple-fields-clearbutton-change-and-input-events.html [ Crash Failure ] -crbug.com/591099 fast/forms/time-multiple-fields/time-multiple-fields-crash-after-adoptnode.html [ Crash ] -crbug.com/591099 fast/forms/time-multiple-fields/time-multiple-fields-crash-by-focus-on-unload.html [ Crash ] +crbug.com/591099 fast/forms/time-multiple-fields/time-multiple-fields-crash-after-adoptnode.html [ Crash Failure ] +crbug.com/591099 fast/forms/time-multiple-fields/time-multiple-fields-crash-by-focus-on-unload.html [ Crash Pass ] crbug.com/591099 fast/forms/time-multiple-fields/time-multiple-fields-fallback-format.html [ Failure ] -crbug.com/591099 fast/forms/time-multiple-fields/time-multiple-fields-focus-style.html [ Crash ] +crbug.com/591099 fast/forms/time-multiple-fields/time-multiple-fields-focus-style.html [ Crash Failure ] crbug.com/591099 fast/forms/time-multiple-fields/time-multiple-fields-focus.html [ Failure ] crbug.com/591099 fast/forms/time-multiple-fields/time-multiple-fields-keyboard-events.html [ Crash Failure Timeout ] crbug.com/591099 fast/forms/time-multiple-fields/time-multiple-fields-localization.html [ Failure ] -crbug.com/591099 fast/forms/time-multiple-fields/time-multiple-fields-losing-renderer-on-click.html [ Crash ] +crbug.com/591099 fast/forms/time-multiple-fields/time-multiple-fields-losing-renderer-on-click.html [ Crash Pass ] crbug.com/591099 fast/forms/time-multiple-fields/time-multiple-fields-mouse-events.html [ Crash Failure ] crbug.com/591099 fast/forms/time-multiple-fields/time-multiple-fields-narrow-width-scroll.html [ Failure ] crbug.com/591099 fast/forms/time-multiple-fields/time-multiple-fields-open-picker-key-bindings.html [ Failure ] crbug.com/591099 fast/forms/time-multiple-fields/time-multiple-fields-preserve-value-after-history-back.html [ Crash Failure ] crbug.com/591099 fast/forms/time-multiple-fields/time-multiple-fields-readonly-subfield.html [ Failure ] -crbug.com/591099 fast/forms/time-multiple-fields/time-multiple-fields-reset-value-after-reload.html [ Crash ] -crbug.com/591099 fast/forms/time-multiple-fields/time-multiple-fields-spinbutton-change-and-input-events.html [ Crash ] -crbug.com/591099 fast/forms/time-multiple-fields/time-multiple-fields-spinbutton-click-in-iframe.html [ Crash ] +crbug.com/591099 fast/forms/time-multiple-fields/time-multiple-fields-reset-value-after-reload.html [ Crash Failure ] +crbug.com/591099 fast/forms/time-multiple-fields/time-multiple-fields-spinbutton-change-and-input-events.html [ Crash Failure ] +crbug.com/591099 fast/forms/time-multiple-fields/time-multiple-fields-spinbutton-click-in-iframe.html [ Crash Failure ] crbug.com/591099 fast/forms/time-multiple-fields/time-multiple-fields-state-change-on-focus-or-blur.html [ Failure ] -crbug.com/591099 fast/forms/time-multiple-fields/time-multiple-fields-static-relayout.html [ Crash ] -crbug.com/591099 fast/forms/time-multiple-fields/time-multiple-fields-step-attribute.html [ Crash ] -crbug.com/591099 fast/forms/time-multiple-fields/time-multiple-fields-stepup-stepdown-from-renderer-hour.html [ Crash ] +crbug.com/591099 fast/forms/time-multiple-fields/time-multiple-fields-static-relayout.html [ Crash Pass ] +crbug.com/591099 fast/forms/time-multiple-fields/time-multiple-fields-step-attribute.html [ Crash Failure ] +crbug.com/591099 fast/forms/time-multiple-fields/time-multiple-fields-stepup-stepdown-from-renderer-hour.html [ Crash Pass ] crbug.com/591099 fast/forms/time-multiple-fields/time-multiple-fields-stepup-stepdown-from-renderer.html [ Crash Timeout ] crbug.com/591099 fast/forms/time-multiple-fields/time-multiple-fields-validity-badinput.html [ Failure ] crbug.com/591099 fast/forms/time-multiple-fields/time-multiple-fields-value-set-empty.html [ Crash Failure ] -crbug.com/591099 fast/forms/time-multiple-fields/time-multiple-fields-wheel-event.html [ Crash ] +crbug.com/591099 fast/forms/time-multiple-fields/time-multiple-fields-wheel-event.html [ Crash Failure ] crbug.com/591099 fast/forms/time/time-appearance-basic.html [ Crash Failure ] crbug.com/591099 fast/forms/time/time-appearance-pseudo-elements.html [ Crash Failure ] crbug.com/591099 fast/forms/time/time-input-type.html [ Failure ] @@ -11440,16 +11448,16 @@ crbug.com/591099 fast/forms/time/time-valueasdate.html [ Failure ] crbug.com/591099 fast/forms/time/time-valueasnumber.html [ Failure ] crbug.com/591099 fast/forms/type-after-focus-rule-shrink-width.html [ Crash Failure ] -crbug.com/591099 fast/forms/ua-shadow-select-all-crash.html [ Crash ] +crbug.com/591099 fast/forms/ua-shadow-select-all-crash.html [ Crash Pass ] crbug.com/591099 fast/forms/update-form-attribute-element.html [ Failure ] -crbug.com/591099 fast/forms/url/url-sanitize-user-input.html [ Crash ] -crbug.com/591099 fast/forms/validationMessage.html [ Crash ] +crbug.com/591099 fast/forms/url/url-sanitize-user-input.html [ Crash Pass ] +crbug.com/591099 fast/forms/validationMessage.html [ Crash Failure ] crbug.com/591099 fast/forms/validity-property.html [ Crash Failure ] crbug.com/591099 fast/forms/var-name-conflict-in-form-event-handler.html [ Failure ] crbug.com/591099 fast/forms/visual-hebrew-text-field.html [ Crash Failure ] -crbug.com/591099 fast/forms/week-multiple-fields/week-multiple-fields-ax-aria-attributes.html [ Crash ] -crbug.com/591099 fast/forms/week-multiple-fields/week-multiple-fields-ax-value-changed-notification.html [ Crash ] -crbug.com/591099 fast/forms/week-multiple-fields/week-multiple-fields-blur-and-focus-events.html [ Crash ] +crbug.com/591099 fast/forms/week-multiple-fields/week-multiple-fields-ax-aria-attributes.html [ Crash Failure ] +crbug.com/591099 fast/forms/week-multiple-fields/week-multiple-fields-ax-value-changed-notification.html [ Crash Failure ] +crbug.com/591099 fast/forms/week-multiple-fields/week-multiple-fields-blur-and-focus-events.html [ Crash Failure ] crbug.com/591099 fast/forms/week-multiple-fields/week-multiple-fields-change-layout-by-value.html [ Failure ] crbug.com/591099 fast/forms/week-multiple-fields/week-multiple-fields-choose-default-value-after-set-value.html [ Failure ] crbug.com/591099 fast/forms/week-multiple-fields/week-multiple-fields-clearbutton-change-and-input-events.html [ Crash Failure ] @@ -11458,12 +11466,12 @@ crbug.com/591099 fast/forms/week-multiple-fields/week-multiple-fields-mouse-events.html [ Crash Failure ] crbug.com/591099 fast/forms/week-multiple-fields/week-multiple-fields-preserve-value-after-history-back.html [ Failure ] crbug.com/591099 fast/forms/week-multiple-fields/week-multiple-fields-readonly-subfield.html [ Failure ] -crbug.com/591099 fast/forms/week-multiple-fields/week-multiple-fields-reset-value-after-reloads.html [ Crash ] -crbug.com/591099 fast/forms/week-multiple-fields/week-multiple-fields-spinbutton-change-and-input-events.html [ Crash ] +crbug.com/591099 fast/forms/week-multiple-fields/week-multiple-fields-reset-value-after-reloads.html [ Crash Failure ] +crbug.com/591099 fast/forms/week-multiple-fields/week-multiple-fields-spinbutton-change-and-input-events.html [ Crash Failure ] crbug.com/591099 fast/forms/week-multiple-fields/week-multiple-fields-stepup-stepdown-from-renderer.html [ Crash Failure ] crbug.com/591099 fast/forms/week-multiple-fields/week-multiple-fields-validity-badinput.html [ Failure ] crbug.com/591099 fast/forms/week-multiple-fields/week-multiple-fields-value-set-empty.html [ Failure ] -crbug.com/591099 fast/forms/week-multiple-fields/week-multiple-fields-wheel-event.html [ Crash ] +crbug.com/591099 fast/forms/week-multiple-fields/week-multiple-fields-wheel-event.html [ Crash Failure ] crbug.com/591099 fast/forms/week/ValidityState-rangeOverflow-week.html [ Failure ] crbug.com/591099 fast/forms/week/ValidityState-rangeUnderflow-week.html [ Failure ] crbug.com/591099 fast/forms/week/ValidityState-stepMismatch-week.html [ Failure ] @@ -11477,10 +11485,10 @@ crbug.com/591099 fast/forms/week/week-pseudo-classes.html [ Failure ] crbug.com/591099 fast/forms/week/week-setrangetext.html [ Failure ] crbug.com/591099 fast/forms/week/week-stepup-stepdown.html [ Failure ] -crbug.com/591099 fast/forms/willvalidate.html [ Crash ] +crbug.com/591099 fast/forms/willvalidate.html [ Crash Failure ] crbug.com/591099 fast/frames/001.html [ Failure ] crbug.com/591099 fast/frames/002.html [ Failure ] -crbug.com/591099 fast/frames/cached-frame-counter.html [ Crash ] +crbug.com/591099 fast/frames/cached-frame-counter.html [ Crash Failure ] crbug.com/591099 fast/frames/calculate-fixed.html [ Failure ] crbug.com/591099 fast/frames/calculate-order.html [ Failure ] crbug.com/591099 fast/frames/calculate-percentage.html [ Failure ] @@ -11489,7 +11497,7 @@ crbug.com/591099 fast/frames/content-opacity-1.html [ Failure ] crbug.com/591099 fast/frames/content-opacity-2.html [ Failure ] crbug.com/591099 fast/frames/crash-removed-iframe.html [ Failure ] -crbug.com/591099 fast/frames/create-iframe-on-blur.html [ Crash ] +crbug.com/591099 fast/frames/create-iframe-on-blur.html [ Crash Failure ] crbug.com/591099 fast/frames/detach-during-initial-load.html [ Failure ] crbug.com/591099 fast/frames/detach-frame-from-child-detach-no-crash.html [ Failure ] crbug.com/591099 fast/frames/detach-frame-nested-no-crash.html [ Crash Failure ] @@ -11501,10 +11509,10 @@ crbug.com/591099 fast/frames/empty-cols-attribute.html [ Failure ] crbug.com/591099 fast/frames/empty-frame-document.html [ Failure ] crbug.com/591099 fast/frames/empty-frame-src.html [ Failure ] -crbug.com/591099 fast/frames/focus-controller-crash-change-event.html [ Crash Timeout ] -crbug.com/591099 fast/frames/form-submission-early-return-for-sandboxed-iframes.html [ Crash ] +crbug.com/591099 fast/frames/focus-controller-crash-change-event.html [ Crash Pass Timeout ] +crbug.com/591099 fast/frames/form-submission-early-return-for-sandboxed-iframes.html [ Crash Pass ] crbug.com/591099 fast/frames/frame-dimensions-before-parent-layout.html [ Failure ] -crbug.com/591099 fast/frames/frame-focus-no-focusout-event.html [ Crash ] +crbug.com/591099 fast/frames/frame-focus-no-focusout-event.html [ Crash Pass ] crbug.com/591099 fast/frames/frame-focus-send-blur.html [ Failure ] crbug.com/591099 fast/frames/frame-inherit-noresize-from-frameset.html [ Failure ] crbug.com/591099 fast/frames/frame-length-fractional.html [ Failure ] @@ -11529,13 +11537,13 @@ crbug.com/591099 fast/frames/frameElement-frame.html [ Failure ] crbug.com/591099 fast/frames/frameElement-iframe.html [ Failure ] crbug.com/591099 fast/frames/frames-with-frameborder-zero-can-be-resized.html [ Failure ] -crbug.com/591099 fast/frames/frameset-dynamic-resize.html [ Crash ] +crbug.com/591099 fast/frames/frameset-dynamic-resize.html [ Crash Pass ] crbug.com/591099 fast/frames/frameset-frameborder-boolean-values.html [ Failure ] crbug.com/591099 fast/frames/frameset-frameborder-inheritance.html [ Failure ] crbug.com/591099 fast/frames/frameset-frameborder-overrides-border.html [ Failure ] crbug.com/591099 fast/frames/frameset-style-recalc.html [ Failure ] -crbug.com/591099 fast/frames/hover-timer-crash.html [ Crash ] -crbug.com/591099 fast/frames/iframe-access-screen-of-deleted.html [ Crash ] +crbug.com/591099 fast/frames/hover-timer-crash.html [ Crash Failure ] +crbug.com/591099 fast/frames/iframe-access-screen-of-deleted.html [ Crash Pass ] crbug.com/591099 fast/frames/iframe-js-url-clientWidth.html [ Failure ] crbug.com/591099 fast/frames/iframe-name-and-id.html [ Failure ] crbug.com/591099 fast/frames/iframe-no-name.html [ Failure ] @@ -11544,9 +11552,9 @@ crbug.com/591099 fast/frames/iframe-onload-and-domnodeinserted.html [ Failure ] crbug.com/591099 fast/frames/iframe-onload-remove-self-no-crash.html [ Failure ] crbug.com/591099 fast/frames/iframe-option-crash.xhtml [ Failure ] -crbug.com/591099 fast/frames/iframe-plugin-load-remove-document-crash.html [ Crash ] +crbug.com/591099 fast/frames/iframe-plugin-load-remove-document-crash.html [ Crash Pass ] crbug.com/591099 fast/frames/iframe-remove-after-id-change.html [ Failure ] -crbug.com/591099 fast/frames/iframe-reparenting-unique-name.html [ Crash ] +crbug.com/591099 fast/frames/iframe-reparenting-unique-name.html [ Crash Failure ] crbug.com/591099 fast/frames/iframe-scale-applied-twice.html [ Failure ] crbug.com/591099 fast/frames/iframe-scaling-with-scroll.html [ Failure ] crbug.com/591099 fast/frames/iframe-scrolling-attribute-overflowscroll.html [ Failure ] @@ -11570,10 +11578,10 @@ crbug.com/591099 fast/frames/parser-append-subframe-count.html [ Failure ] crbug.com/591099 fast/frames/reattach-in-unload.html [ Failure ] crbug.com/591099 fast/frames/removal-before-attach-crash.html [ Failure ] -crbug.com/591099 fast/frames/remove-frame-during-load-event.html [ Crash ] -crbug.com/591099 fast/frames/remove-frame-with-scrollbars-crash.html [ Crash ] -crbug.com/591099 fast/frames/repaint-display-none-crash.html [ Crash ] -crbug.com/591099 fast/frames/reparented-iframe-cleared-contentWindow.html [ Crash ] +crbug.com/591099 fast/frames/remove-frame-during-load-event.html [ Crash Pass ] +crbug.com/591099 fast/frames/remove-frame-with-scrollbars-crash.html [ Crash Failure ] +crbug.com/591099 fast/frames/repaint-display-none-crash.html [ Crash Failure ] +crbug.com/591099 fast/frames/reparented-iframe-cleared-contentWindow.html [ Crash Pass ] crbug.com/591099 fast/frames/sandboxed-iframe-about-blank.html [ Failure ] crbug.com/591099 fast/frames/sandboxed-iframe-attribute-parsing-01.html [ Failure ] crbug.com/591099 fast/frames/sandboxed-iframe-attribute-parsing-02.html [ Failure ] @@ -11611,17 +11619,17 @@ crbug.com/591099 fast/frames/set-iframe-src-in-pagehide-crash.html [ Failure ] crbug.com/591099 fast/frames/set-parent-src-synchronously-html.html [ Failure Pass ] crbug.com/591099 fast/frames/set-parent-src-synchronously-xhtml.xhtml [ Failure Pass ] -crbug.com/591099 fast/frames/srcdoc/removing-srcdoc-loads-src.html [ Crash ] +crbug.com/591099 fast/frames/srcdoc/removing-srcdoc-loads-src.html [ Crash Pass ] crbug.com/591099 fast/frames/srcdoc/setting-src-does-nothing.html [ Failure ] crbug.com/591099 fast/frames/srcdoc/setting-srcdoc-reloads-document.html [ Failure ] -crbug.com/591099 fast/frames/srcdoc/srcdoc-deep-nested-frames.html [ Crash ] -crbug.com/591099 fast/frames/subframe-load-crash-main.html [ Crash ] -crbug.com/591099 fast/frames/take-focus-from-iframe.html [ Crash ] +crbug.com/591099 fast/frames/srcdoc/srcdoc-deep-nested-frames.html [ Crash Pass ] +crbug.com/591099 fast/frames/subframe-load-crash-main.html [ Crash Pass ] +crbug.com/591099 fast/frames/take-focus-from-iframe.html [ Crash Failure ] crbug.com/591099 fast/frames/unique-name-all-subframes-have-same-name.html [ Failure ] crbug.com/591099 fast/frames/unique-name-ancestor-concatenation-conflict.html [ Failure ] crbug.com/591099 fast/frames/unique-name-remove-add-child.html [ Failure ] -crbug.com/591099 fast/frames/unload-reparent-sibling-frame.html [ Crash ] -crbug.com/591099 fast/frames/url-selected-crash.html [ Crash ] +crbug.com/591099 fast/frames/unload-reparent-sibling-frame.html [ Crash Failure ] +crbug.com/591099 fast/frames/url-selected-crash.html [ Crash Pass ] crbug.com/591099 fast/frames/valid.html [ Failure ] crbug.com/591099 fast/gradients/background-clipped.html [ Failure ] crbug.com/591099 fast/gradients/border-image-gradient-sides-and-corners.html [ Failure ] @@ -11679,10 +11687,10 @@ crbug.com/591099 fast/harness/perftests/perf-runner-compute-statistics.html [ Failure ] crbug.com/591099 fast/harness/perftests/runs-per-second-iterations.html [ Failure ] crbug.com/591099 fast/harness/perftests/runs-per-second-log.html [ Failure ] -crbug.com/591099 fast/harness/results.html [ Crash ] +crbug.com/591099 fast/harness/results.html [ Crash Pass ] crbug.com/591099 fast/harness/should-be-now.html [ Failure ] crbug.com/591099 fast/harness/user-preferred-language.html [ Crash Failure ] -crbug.com/591099 fast/hidpi/broken-image-icon-hidpi.html [ Crash Failure ] +crbug.com/591099 fast/hidpi/broken-image-icon-hidpi.html [ Crash Failure Pass ] crbug.com/591099 fast/hidpi/image-set-list-style-image.html [ Failure ] crbug.com/591099 fast/hidpi/image-set-shape-outside.html [ Failure ] crbug.com/591099 fast/hidpi/image-srcset-intrinsic-size.html [ Failure Pass ] @@ -11702,11 +11710,11 @@ crbug.com/591099 fast/history/multiple-classes-visited.html [ Failure ] crbug.com/591099 fast/history/nested-visited-test.html [ Failure ] crbug.com/591099 fast/history/redirect-via-iframe.html [ Failure ] -crbug.com/591099 fast/history/same-document-iframes-changing-fragment.html [ Crash ] -crbug.com/591099 fast/history/same-document-iframes-changing-pushstate.html [ Crash ] +crbug.com/591099 fast/history/same-document-iframes-changing-fragment.html [ Crash Failure ] +crbug.com/591099 fast/history/same-document-iframes-changing-pushstate.html [ Crash Failure ] crbug.com/591099 fast/history/saves-state-after-frame-nav.html [ Failure ] -crbug.com/591099 fast/history/scroll-restoration/scroll-restoration-fragment-navigation-crossdoc.html [ Crash ] -crbug.com/591099 fast/history/scroll-restoration/scroll-restoration-navigation.html [ Crash ] +crbug.com/591099 fast/history/scroll-restoration/scroll-restoration-fragment-navigation-crossdoc.html [ Crash Pass ] +crbug.com/591099 fast/history/scroll-restoration/scroll-restoration-navigation.html [ Crash Pass ] crbug.com/591099 fast/history/self-is-visited.html [ Failure ] crbug.com/591099 fast/history/sibling-visited-test.html [ Failure ] crbug.com/591099 fast/history/state-object-few-arguements-exception.html [ Failure ] @@ -11745,13 +11753,13 @@ crbug.com/591099 fast/html/input-type-change-crash.html [ Failure ] crbug.com/591099 fast/html/meter-user-modify.html [ Failure ] crbug.com/591099 fast/html/object-border.html [ Failure ] -crbug.com/591099 fast/html/object-image-nested-fallback.html [ Crash ] +crbug.com/591099 fast/html/object-image-nested-fallback.html [ Crash Pass ] crbug.com/591099 fast/html/progress-user-modify.html [ Failure ] crbug.com/591099 fast/html/script-allowed-types-languages.html [ Failure ] crbug.com/591099 fast/html/select-dropdown-consistent-background-color.html [ Failure Pass ] crbug.com/591099 fast/html/set-text-direction.html [ Crash Failure ] crbug.com/591099 fast/html/tab-order.html [ Crash Failure ] -crbug.com/591099 fast/html/tabindex-nonfocusable.html [ Crash ] +crbug.com/591099 fast/html/tabindex-nonfocusable.html [ Crash Pass ] crbug.com/591099 fast/html/unknown-tag.html [ Crash Failure ] crbug.com/591099 fast/inline-block/001.html [ Failure ] crbug.com/591099 fast/inline-block/002.html [ Failure ] @@ -11782,13 +11790,13 @@ crbug.com/591099 fast/inline/drawStyledEmptyInlinesWithWS.html [ Failure ] crbug.com/591099 fast/inline/empty-inline-before-collapsed-space.html [ Failure ] crbug.com/591099 fast/inline/emptyInlinesWithinLists.html [ Crash Failure ] -crbug.com/591099 fast/inline/fixed-pos-moves-with-abspos-inline-parent.html [ Crash ] +crbug.com/591099 fast/inline/fixed-pos-moves-with-abspos-inline-parent.html [ Crash Failure ] crbug.com/591099 fast/inline/fixed-pos-moves-with-abspos-parent-relative-ancestor.html [ Failure ] crbug.com/591099 fast/inline/fixed-pos-moves-with-abspos-parent.html [ Failure ] crbug.com/591099 fast/inline/fixed-pos-with-transform-container-moves-with-abspos-parent.html [ Failure ] crbug.com/591099 fast/inline/inline-body-with-inline-child.html [ Failure ] crbug.com/591099 fast/inline/inline-borders-with-bidi-override.html [ Failure ] -crbug.com/591099 fast/inline/inline-box-adjust-position-crash.html [ Crash ] +crbug.com/591099 fast/inline/inline-box-adjust-position-crash.html [ Crash Failure ] crbug.com/591099 fast/inline/inline-box-background-long-image.html [ Failure ] crbug.com/591099 fast/inline/inline-box-background-repeat-x.html [ Failure ] crbug.com/591099 fast/inline/inline-box-background-repeat-y.html [ Failure ] @@ -11817,7 +11825,7 @@ crbug.com/591099 fast/inline/positionedLifetime.html [ Failure Pass ] crbug.com/591099 fast/inline/reattach-inlines-in-anonymous-blocks-with-out-of-flow-siblings.html [ Failure ] crbug.com/591099 fast/inline/relative-positioned-overflow.html [ Failure ] -crbug.com/591099 fast/inline/reparent-inline-box.html [ Crash ] +crbug.com/591099 fast/inline/reparent-inline-box.html [ Crash Pass ] crbug.com/591099 fast/inline/styledEmptyInlinesWithBRs.html [ Failure ] crbug.com/591099 fast/innerHTML/004.xhtml [ Failure ] crbug.com/591099 fast/innerHTML/005.html [ Failure ] @@ -11859,7 +11867,7 @@ crbug.com/591099 fast/invalid/missing-font-end-tag.html [ Failure ] crbug.com/591099 fast/invalid/nestedh3s-rapidweaver.html [ Failure ] crbug.com/591099 fast/invalid/nestedh3s.html [ Failure ] -crbug.com/591099 fast/invalid/residual-style.html [ Crash ] +crbug.com/591099 fast/invalid/residual-style.html [ Crash Pass ] crbug.com/591099 fast/invalid/table-inside-stray-table-content.html [ Failure ] crbug.com/591099 fast/invalid/table-residual-style-crash.html [ Failure ] crbug.com/591099 fast/invalid/td-inside-object.html [ Failure ] @@ -11872,10 +11880,10 @@ crbug.com/591099 fast/js/activation-object-function-lifetime.html [ Failure ] crbug.com/591099 fast/js/activation-proto.html [ Failure ] crbug.com/591099 fast/js/add-to-primitive.html [ Failure ] -crbug.com/591099 fast/js/array-foreach.html [ Crash ] +crbug.com/591099 fast/js/array-foreach.html [ Crash Pass ] crbug.com/591099 fast/js/array-indexof.html [ Failure ] crbug.com/591099 fast/js/array-join-bug-11524.html [ Failure ] -crbug.com/591099 fast/js/array-some.html [ Crash ] +crbug.com/591099 fast/js/array-some.html [ Crash Pass ] crbug.com/591099 fast/js/array-sort-exception.html [ Failure ] crbug.com/591099 fast/js/assign.html [ Failure ] crbug.com/591099 fast/js/bom-in-file-retains-correct-offset.html [ Failure ] @@ -12136,7 +12144,7 @@ crbug.com/591099 fast/layers/self-painting-outline.html [ Failure ] crbug.com/591099 fast/layers/zindex-inherit.html [ Failure ] crbug.com/591099 fast/layers/zindex-ridonkulous.html [ Failure ] -crbug.com/591099 fast/layout/scroll-anchoring/anchor-inside-iframe.html [ Crash ] +crbug.com/591099 fast/layout/scroll-anchoring/anchor-inside-iframe.html [ Crash Pass ] crbug.com/591099 fast/leaks/001.html [ Failure ] crbug.com/591099 fast/leaks/002.html [ Crash Failure ] crbug.com/591099 fast/lists/001-vertical.html [ Crash Failure ] @@ -12210,7 +12218,7 @@ crbug.com/591099 fast/lists/list-marker-remove-crash.html [ Crash Pass ] crbug.com/591099 fast/lists/list-marker-with-line-height.html [ Crash Failure ] crbug.com/591099 fast/lists/list-style-none-crash.html [ Failure ] -crbug.com/591099 fast/lists/list-style-position-inside.html [ Crash ] +crbug.com/591099 fast/lists/list-style-position-inside.html [ Crash Pass ] crbug.com/591099 fast/lists/list-style-type-dynamic-change.html [ Crash Failure ] crbug.com/591099 fast/lists/marker-before-empty-inline.html [ Crash Failure ] crbug.com/591099 fast/lists/marker-image-error.html [ Crash Failure ] @@ -12233,7 +12241,7 @@ crbug.com/591099 fast/lists/ol-start-parsing.html [ Failure ] crbug.com/591099 fast/lists/olstart.html [ Failure ] crbug.com/591099 fast/lists/ordered-list-with-no-ol-tag.html [ Crash Failure ] -crbug.com/591099 fast/lists/remove-listmarker-and-make-anonblock-empty-2.html [ Crash ] +crbug.com/591099 fast/lists/remove-listmarker-and-make-anonblock-empty-2.html [ Crash Pass ] crbug.com/591099 fast/lists/w3-css3-list-styles-alphabetic.html [ Crash Failure Timeout ] crbug.com/591099 fast/lists/w3-css3-list-styles-deprecated.html [ Failure ] crbug.com/591099 fast/lists/w3-css3-list-styles-fallback-style.html [ Crash Failure ] @@ -12245,11 +12253,11 @@ crbug.com/591099 fast/loader/about-blank-hash-kept.html [ Failure ] crbug.com/591099 fast/loader/charset-parse.html [ Failure ] crbug.com/591099 fast/loader/child-frame-add-after-back-forward.html [ Failure Timeout ] -crbug.com/591099 fast/loader/crash-focus-in-unload.html [ Crash ] -crbug.com/591099 fast/loader/data-url-encoding-html-2.html [ Crash ] +crbug.com/591099 fast/loader/crash-focus-in-unload.html [ Crash Pass ] +crbug.com/591099 fast/loader/data-url-encoding-html-2.html [ Crash Pass ] crbug.com/591099 fast/loader/data-url-encoding-html.html [ Failure ] crbug.com/591099 fast/loader/data-url-encoding-svg.html [ Failure ] -crbug.com/591099 fast/loader/document-destruction-within-unload.html [ Crash ] +crbug.com/591099 fast/loader/document-destruction-within-unload.html [ Crash Pass ] crbug.com/591099 fast/loader/empty-embed-src-attribute.html [ Failure ] crbug.com/591099 fast/loader/font-face-empty.html [ Failure ] crbug.com/591099 fast/loader/fragment-anchor-cleared-after-load-when-hidden.html [ Failure ] @@ -12277,9 +12285,9 @@ crbug.com/591099 fast/loader/onload-bad-scheme-for-frame.html [ Failure Timeout ] crbug.com/591099 fast/loader/onload-policy-ignore-for-frame.html [ Failure ] crbug.com/591099 fast/loader/opaque-base-url.html [ Crash Failure ] -crbug.com/591099 fast/loader/open-in-srcdoc-unload.html [ Crash ] -crbug.com/591099 fast/loader/remove-iframe-during-history-navigation-different.html [ Crash ] -crbug.com/591099 fast/loader/remove-iframe-during-history-navigation-same.html [ Crash ] +crbug.com/591099 fast/loader/open-in-srcdoc-unload.html [ Crash Pass ] +crbug.com/591099 fast/loader/remove-iframe-during-history-navigation-different.html [ Crash Pass ] +crbug.com/591099 fast/loader/remove-iframe-during-history-navigation-same.html [ Crash Pass ] crbug.com/591099 fast/loader/scroll-position-restoration-for-history-api.html [ Failure ] crbug.com/591099 fast/loader/scroll-position-restoration-without-premature-clamping.html [ Failure ] crbug.com/591099 fast/loader/scroll-position-restored-on-back-at-load-event.html [ Failure ] @@ -12326,7 +12334,7 @@ crbug.com/591099 fast/media/viewport-media-query-synchronous.html [ Failure ] crbug.com/591099 fast/mediacapturefromelement/CanvasCaptureMediaStream-2d-events.html [ Failure ] crbug.com/591099 fast/mediacapturefromelement/CanvasCaptureMediaStream-framerate-0.html [ Failure ] -crbug.com/591099 fast/mediacapturefromelement/CanvasCaptureMediaStream-imagebitmaprenderingcontext.html [ Crash ] +crbug.com/591099 fast/mediacapturefromelement/CanvasCaptureMediaStream-imagebitmaprenderingcontext.html [ Crash Pass ] crbug.com/591099 fast/mediacapturefromelement/CanvasCaptureMediaStream-request-frame-events.html [ Failure ] crbug.com/591099 fast/mediacapturefromelement/CanvasCaptureMediaStream-webgl-events.html [ Failure ] crbug.com/591099 fast/mediastream/MediaStream-add-remove-tracks.html [ Failure ] @@ -12334,7 +12342,7 @@ crbug.com/591099 fast/mediastream/MediaStream-onactive-oninactive.html [ Failure ] crbug.com/591099 fast/mediastream/MediaStream-stop.html [ Failure ] crbug.com/591099 fast/mediastream/MediaStreamConstructor.html [ Failure ] -crbug.com/591099 fast/mediastream/MediaStreamTrack-contentHint.html [ Crash ] +crbug.com/591099 fast/mediastream/MediaStreamTrack-contentHint.html [ Crash Pass ] crbug.com/591099 fast/mediastream/MediaStreamTrack-gc-no-crash.html [ Failure ] crbug.com/591099 fast/mediastream/MediaStreamTrack-observer-iterate-no-crash.html [ Failure ] crbug.com/591099 fast/mediastream/MediaStreamTrack.html [ Failure ] @@ -12738,7 +12746,7 @@ crbug.com/591099 fast/overflow/overflow-with-local-background-attachment.html [ Crash Failure ] crbug.com/591099 fast/overflow/overflow-x-y.html [ Crash Failure ] crbug.com/591099 fast/overflow/overflow-y-scroll.html [ Failure ] -crbug.com/591099 fast/overflow/replaced-child-100percent-height-inside-fixed-container-with-overflow-auto.html [ Crash ] +crbug.com/591099 fast/overflow/replaced-child-100percent-height-inside-fixed-container-with-overflow-auto.html [ Crash Failure ] crbug.com/591099 fast/overflow/resize-inherit.html [ Failure ] crbug.com/591099 fast/overflow/scroll-div-hide-show.html [ Failure ] crbug.com/591099 fast/overflow/scroll-html-hidden-body.html [ Failure Pass ] @@ -12805,10 +12813,10 @@ crbug.com/591099 fast/parser/comment-in-textarea.html [ Crash Failure ] crbug.com/591099 fast/parser/comments.html [ Failure ] crbug.com/591099 fast/parser/crash-HTMLParser-createHead.html [ Failure ] -crbug.com/591099 fast/parser/disable-frameset-ok-flag-inside-template.html [ Crash ] +crbug.com/591099 fast/parser/disable-frameset-ok-flag-inside-template.html [ Crash Pass ] crbug.com/591099 fast/parser/document-open-in-unload.html [ Crash Failure ] crbug.com/591099 fast/parser/document-reload-with-failed-deferred-scripts.html [ Failure ] -crbug.com/591099 fast/parser/document-write-into-initial-document.html [ Crash ] +crbug.com/591099 fast/parser/document-write-into-initial-document.html [ Crash Pass ] crbug.com/591099 fast/parser/document-write-onload-nesting.html [ Failure ] crbug.com/591099 fast/parser/document-write-onload-ordering.html [ Failure ] crbug.com/591099 fast/parser/document-write-option.html [ Failure ] @@ -12844,13 +12852,13 @@ crbug.com/591099 fast/parser/inline-script-order.html [ Failure ] crbug.com/591099 fast/parser/innerhtml-with-prefixed-elements.xhtml [ Failure Pass ] crbug.com/591099 fast/parser/input-textarea-inside-select-element.html [ Failure ] -crbug.com/591099 fast/parser/inselect-tokenization.html [ Crash ] +crbug.com/591099 fast/parser/inselect-tokenization.html [ Crash Pass ] crbug.com/591099 fast/parser/invalid-entity-document-write.html [ Failure ] crbug.com/591099 fast/parser/move-during-parsing.html [ Failure ] crbug.com/591099 fast/parser/nofoo-tags-inside-paragraph.html [ Failure ] crbug.com/591099 fast/parser/non-script-endtag-in-textmode.html [ Failure ] crbug.com/591099 fast/parser/noscript-with-javascript-disabled.html [ Failure ] -crbug.com/591099 fast/parser/object-with-textarea-fallback.html [ Crash ] +crbug.com/591099 fast/parser/object-with-textarea-fallback.html [ Crash Pass ] crbug.com/591099 fast/parser/open-comment-in-style.html [ Failure ] crbug.com/591099 fast/parser/open-comment-in-textarea.html [ Crash Failure ] crbug.com/591099 fast/parser/p-in-scope-strict.html [ Failure ] @@ -12870,19 +12878,19 @@ crbug.com/591099 fast/parser/stray-end-tags-with-attributes-002-alt-quirks.html [ Failure ] crbug.com/591099 fast/parser/stray-end-tags-with-attributes-002-alt.html [ Failure ] crbug.com/591099 fast/parser/strict-img-in-map.html [ Crash Failure ] -crbug.com/591099 fast/parser/strip-script-attrs-on-input.html [ Crash ] +crbug.com/591099 fast/parser/strip-script-attrs-on-input.html [ Crash Pass ] crbug.com/591099 fast/parser/style-script-head-test.html [ Failure ] crbug.com/591099 fast/parser/tabindex-parsing.html [ Failure ] crbug.com/591099 fast/parser/tabs-in-scripts.html [ Failure ] crbug.com/591099 fast/parser/tag-with-exclamation-point.html [ Failure ] crbug.com/591099 fast/parser/title-error-test.html [ Failure ] crbug.com/591099 fast/parser/tokenizer-close-during-document-write.html [ Failure ] -crbug.com/591099 fast/parser/write-script-waiting-for-style-crash.html [ Crash ] +crbug.com/591099 fast/parser/write-script-waiting-for-style-crash.html [ Crash Pass ] crbug.com/591099 fast/parser/xhtml-alternate-entities.xml [ Crash Failure ] crbug.com/591099 fast/parser/xhtml-document-with-html-object.xhtml [ Failure ] -crbug.com/591099 fast/parser/xhtml-dom-character-data-modified-crash.html [ Crash ] +crbug.com/591099 fast/parser/xhtml-dom-character-data-modified-crash.html [ Crash Pass ] crbug.com/591099 fast/parser/xhtml-html-comment-in-style-block.xhtml [ Failure ] -crbug.com/591099 fast/parser/xhtml-synchronous-detach-crash.html [ Crash ] +crbug.com/591099 fast/parser/xhtml-synchronous-detach-crash.html [ Crash Pass ] crbug.com/591099 fast/parser/xml-colon-entity.html [ Failure ] crbug.com/591099 fast/parser/xml-declaration-missing-ending-mark.html [ Failure ] crbug.com/591099 fast/peerconnection/RTCPeerConnection-createAnswer.html [ Failure ] @@ -12905,9 +12913,9 @@ crbug.com/591099 fast/performance/performance-mark-exceptions.html [ Failure ] crbug.com/591099 fast/performance/performance-measure-exceptions.html [ Failure ] crbug.com/591099 fast/performance/performance-observer.html [ Failure ] -crbug.com/591099 fast/plugins/update-plugin-after-detachment-crash.html [ Crash ] -crbug.com/591099 fast/plugins/webview-plugin-updates-without-layout.html [ Crash ] -crbug.com/591099 fast/preloader/document-write-noscript.html [ Crash ] +crbug.com/591099 fast/plugins/update-plugin-after-detachment-crash.html [ Crash Pass ] +crbug.com/591099 fast/plugins/webview-plugin-updates-without-layout.html [ Crash Pass ] +crbug.com/591099 fast/preloader/document-write-noscript.html [ Crash Pass ] crbug.com/591099 fast/preloader/iframe-srcdoc.html [ Failure Pass ] crbug.com/591099 fast/reflections/abs-position-in-reflection.html [ Failure ] crbug.com/591099 fast/reflections/inline-crash.html [ Failure ] @@ -12947,8 +12955,8 @@ crbug.com/591099 fast/replaced/computed-image-width-with-percent-height-inside-table-cell-and-fixed-ancestor-vertical-lr.html [ Failure ] crbug.com/591099 fast/replaced/computed-image-width-with-percent-height-inside-table-cell-and-fixed-ancestor.html [ Failure ] crbug.com/591099 fast/replaced/container-width-zero.html [ Failure ] -crbug.com/591099 fast/replaced/frame-removed-during-resize-smaller.html [ Crash ] -crbug.com/591099 fast/replaced/frame-removed-during-resize.html [ Crash ] +crbug.com/591099 fast/replaced/frame-removed-during-resize-smaller.html [ Crash Failure ] +crbug.com/591099 fast/replaced/frame-removed-during-resize.html [ Crash Failure ] crbug.com/591099 fast/replaced/iframe-with-percentage-height-within-table-with-anonymous-table-cell.html [ Failure ] crbug.com/591099 fast/replaced/iframe-with-percentage-height-within-table-with-table-cell-ignore-height.html [ Failure ] crbug.com/591099 fast/replaced/image-map-2.html [ Failure ] @@ -12962,7 +12970,7 @@ crbug.com/591099 fast/replaced/image-resize-width.html [ Failure ] crbug.com/591099 fast/replaced/image-solid-color-with-alpha.html [ Failure ] crbug.com/591099 fast/replaced/inline-box-wrapper-handover.html [ Failure ] -crbug.com/591099 fast/replaced/invalid-object-with-fallback.html [ Crash ] +crbug.com/591099 fast/replaced/invalid-object-with-fallback.html [ Crash Failure ] crbug.com/591099 fast/replaced/max-width-percent.html [ Failure ] crbug.com/591099 fast/replaced/maxheight-percent.html [ Failure ] crbug.com/591099 fast/replaced/maxheight-pxs.html [ Failure ] @@ -12977,10 +12985,10 @@ crbug.com/591099 fast/replaced/no-focus-ring-object.html [ Failure Pass Timeout ] crbug.com/591099 fast/replaced/object-align-hspace-vspace.html [ Failure ] crbug.com/591099 fast/replaced/object-param-no-name.html [ Failure ] -crbug.com/591099 fast/replaced/object-with-non-empty-classid-triggers-fallback.html [ Crash ] +crbug.com/591099 fast/replaced/object-with-non-empty-classid-triggers-fallback.html [ Crash Failure ] crbug.com/591099 fast/replaced/outline-replaced-elements.html [ Failure Pass ] crbug.com/591099 fast/replaced/percent-height-in-anonymous-block-in-table.html [ Failure ] -crbug.com/591099 fast/replaced/percent-height-in-anonymous-block-widget.html [ Crash ] +crbug.com/591099 fast/replaced/percent-height-in-anonymous-block-widget.html [ Crash Failure ] crbug.com/591099 fast/replaced/percent-height-in-anonymous-block.html [ Failure ] crbug.com/591099 fast/replaced/percentage-height-with-dynamic-container-height.html [ Failure ] crbug.com/591099 fast/replaced/preferred-widths.html [ Failure ] @@ -13009,7 +13017,7 @@ crbug.com/591099 fast/ruby/base-shorter-than-text.html [ Crash Failure ] crbug.com/591099 fast/ruby/float-overhang-from-ruby-text.html [ Crash Failure ] crbug.com/591099 fast/ruby/floating-ruby-text.html [ Crash Failure ] -crbug.com/591099 fast/ruby/line-break-ruby.html [ Crash ] +crbug.com/591099 fast/ruby/line-break-ruby.html [ Crash Failure ] crbug.com/591099 fast/ruby/list-item-marker-in-block-ruby.html [ Crash Failure ] crbug.com/591099 fast/ruby/merge-adjacent-anonymous-blocks-inside-ruby-run.html [ Crash Failure ] crbug.com/591099 fast/ruby/nested-ruby.html [ Crash Failure ] @@ -13024,20 +13032,20 @@ crbug.com/591099 fast/ruby/percentage-height-child.html [ Crash Failure ] crbug.com/591099 fast/ruby/position-after.html [ Crash Failure ] crbug.com/591099 fast/ruby/positioned-ruby-text.html [ Crash Failure ] -crbug.com/591099 fast/ruby/ruby-base-merge-block-children-crash.html [ Crash ] +crbug.com/591099 fast/ruby/ruby-base-merge-block-children-crash.html [ Crash Failure ] crbug.com/591099 fast/ruby/ruby-block-style-not-updated.html [ Crash Failure ] crbug.com/591099 fast/ruby/ruby-empty-rt.html [ Crash Failure ] crbug.com/591099 fast/ruby/ruby-inline-style-not-updated.html [ Crash Failure ] crbug.com/591099 fast/ruby/ruby-inline-table.html [ Failure ] crbug.com/591099 fast/ruby/ruby-length.html [ Crash Failure ] crbug.com/591099 fast/ruby/ruby-line-height.html [ Crash Failure ] -crbug.com/591099 fast/ruby/ruby-overhang-crash.html [ Crash ] +crbug.com/591099 fast/ruby/ruby-overhang-crash.html [ Crash Pass ] crbug.com/591099 fast/ruby/ruby-run-break.html [ Crash Failure ] crbug.com/591099 fast/ruby/ruby-runs-spans.html [ Crash Failure ] crbug.com/591099 fast/ruby/ruby-runs.html [ Crash Failure ] crbug.com/591099 fast/ruby/ruby-simple-rp.html [ Crash Failure ] crbug.com/591099 fast/ruby/ruby-simple.html [ Crash Failure ] -crbug.com/591099 fast/ruby/ruby-svg-crash.html [ Crash ] +crbug.com/591099 fast/ruby/ruby-svg-crash.html [ Crash Pass ] crbug.com/591099 fast/ruby/ruby-text-before-after-content.html [ Crash Failure ] crbug.com/591099 fast/ruby/ruby-text-before-child-split.html [ Failure ] crbug.com/591099 fast/ruby/ruby-text-indent.html [ Crash Failure ] @@ -13065,14 +13073,14 @@ crbug.com/591099 fast/scroll-behavior/overflow-scroll-triggers-layout.html [ Failure ] crbug.com/591099 fast/scroll-behavior/parse-scroll-behavior.html [ Failure ] crbug.com/591099 fast/scroll-behavior/scroll-into-view-scrolls-layout-viewport.html [ Failure ] -crbug.com/591099 fast/scroll-behavior/scroll-over-resizer.html [ Crash ] +crbug.com/591099 fast/scroll-behavior/scroll-over-resizer.html [ Crash Pass ] crbug.com/591099 fast/scroll-behavior/smooth-scroll/keyboard-scroll.html [ Failure ] crbug.com/591099 fast/scroll-behavior/smooth-scroll/mousewheel-scroll.html [ Failure ] crbug.com/591099 fast/scroll-behavior/smooth-scroll/scroll-during-selection.html [ Failure ] crbug.com/591099 fast/scroll-behavior/smooth-scroll/track-scroll.html [ Failure ] crbug.com/591099 fast/scroll-behavior/subframe-interrupted-scroll.html [ Failure Pass ] crbug.com/591099 fast/scrolling/abspos-relayout-overflow-style-change.html [ Failure ] -crbug.com/591099 fast/scrolling/content-box-smaller-than-scrollbar.html [ Crash ] +crbug.com/591099 fast/scrolling/content-box-smaller-than-scrollbar.html [ Crash Failure ] crbug.com/591099 fast/scrolling/custom-scrollbar-style-applied.html [ Failure ] crbug.com/591099 fast/scrolling/editor-command-scroll-page-scale.html [ Failure ] crbug.com/591099 fast/scrolling/fractional-scroll-height-chaining.html [ Failure ] @@ -13086,7 +13094,7 @@ crbug.com/591099 fast/scrolling/scroll-clears-fragment-anchor.html [ Failure ] crbug.com/591099 fast/scrolling/scroll-element-into-view.html [ Failure ] crbug.com/591099 fast/scrolling/scroll-into-view-collapsed-div.html [ Failure ] -crbug.com/591099 fast/scrolling/scroll-into-view-small-size-ancestor.html [ Crash ] +crbug.com/591099 fast/scrolling/scroll-into-view-small-size-ancestor.html [ Crash Pass ] crbug.com/591099 fast/scrolling/scroll-max-value.html [ Crash Failure ] crbug.com/591099 fast/scrolling/scrollable-area-frame-overflow-hidden.html [ Crash Failure ] crbug.com/591099 fast/scrolling/scrollbar-mousedown-mouseup.html [ Failure ] @@ -13174,8 +13182,8 @@ crbug.com/591099 fast/selectors/adjacent-selectors-with-subselector.html [ Failure ] crbug.com/591099 fast/selectors/element-closest-general.html [ Failure ] crbug.com/591099 fast/selectors/element-closest-scope.html [ Failure ] -crbug.com/591099 fast/selectors/focus-within-iframe.html [ Crash ] -crbug.com/591099 fast/selectors/focus-within-window-inactive.html [ Crash ] +crbug.com/591099 fast/selectors/focus-within-iframe.html [ Crash Pass ] +crbug.com/591099 fast/selectors/focus-within-window-inactive.html [ Crash Pass ] crbug.com/591099 fast/selectors/lang-inheritance.html [ Failure Pass ] crbug.com/591099 fast/selectors/lang-inheritance2.html [ Failure Pass ] crbug.com/591099 fast/selectors/lang-vs-xml-lang-xhtml.xhtml [ Failure Pass ] @@ -13270,16 +13278,16 @@ crbug.com/591099 fast/spatial-navigation/snav-clipped-overflowed-content.html [ Failure ] crbug.com/591099 fast/spatial-navigation/snav-container-white-space.html [ Failure ] crbug.com/591099 fast/spatial-navigation/snav-date.html [ Failure ] -crbug.com/591099 fast/spatial-navigation/snav-div-scrollable-but-without-focusable-content.html [ Failure ] +crbug.com/591099 fast/spatial-navigation/snav-div-scrollable-but-without-focusable-content.html [ Failure Pass ] crbug.com/591099 fast/spatial-navigation/snav-fully-aligned-vertically.html [ Failure ] crbug.com/591099 fast/spatial-navigation/snav-hidden-focusable-element.html [ Failure ] crbug.com/591099 fast/spatial-navigation/snav-hidden-iframe-zero-size.html [ Failure ] crbug.com/591099 fast/spatial-navigation/snav-hidden-iframe.html [ Failure ] -crbug.com/591099 fast/spatial-navigation/snav-iframe-with-offscreen-focusable-element.html [ Failure ] -crbug.com/591099 fast/spatial-navigation/snav-imagemap-area-not-focusable.html [ Failure ] -crbug.com/591099 fast/spatial-navigation/snav-imagemap-area-without-image.html [ Failure ] -crbug.com/591099 fast/spatial-navigation/snav-imagemap-overlapped-areas.html [ Failure ] -crbug.com/591099 fast/spatial-navigation/snav-imagemap-simple.html [ Failure ] +crbug.com/591099 fast/spatial-navigation/snav-iframe-with-offscreen-focusable-element.html [ Failure Pass ] +crbug.com/591099 fast/spatial-navigation/snav-imagemap-area-not-focusable.html [ Failure Pass ] +crbug.com/591099 fast/spatial-navigation/snav-imagemap-area-without-image.html [ Failure Pass ] +crbug.com/591099 fast/spatial-navigation/snav-imagemap-overlapped-areas.html [ Failure Pass ] +crbug.com/591099 fast/spatial-navigation/snav-imagemap-simple.html [ Failure Pass ] crbug.com/591099 fast/spatial-navigation/snav-input.html [ Failure ] crbug.com/591099 fast/spatial-navigation/snav-media-elements.html [ Failure ] crbug.com/591099 fast/spatial-navigation/snav-multiple-select-focusring.html [ Failure ] @@ -13330,7 +13338,7 @@ crbug.com/591099 fast/sub-pixel/size-of-box-with-zoom.html [ Failure ] crbug.com/591099 fast/sub-pixel/size-of-span-with-different-positions.html [ Failure ] crbug.com/591099 fast/sub-pixel/sub-pixel-border-2.html [ Failure ] -crbug.com/591099 fast/sub-pixel/sub-pixel-border.html [ Crash ] +crbug.com/591099 fast/sub-pixel/sub-pixel-border.html [ Crash Pass ] crbug.com/591099 fast/sub-pixel/sub-pixel-precision-on-height-of-replaced-element.html [ Failure ] crbug.com/591099 fast/sub-pixel/table-rows-have-stable-height.html [ Failure ] crbug.com/591099 fast/table/003.html [ Failure ] @@ -13407,7 +13415,7 @@ crbug.com/591099 fast/table/crash-output-element-as-column-group.html [ Failure ] crbug.com/591099 fast/table/crash-section-logical-height-changed-needsCellRecalc.html [ Failure ] crbug.com/591099 fast/table/crash-split-table-section-no-cell-recalc.html [ Crash Pass ] -crbug.com/591099 fast/table/crash-splitColumn-2.html [ Crash ] +crbug.com/591099 fast/table/crash-splitColumn-2.html [ Crash Failure ] crbug.com/591099 fast/table/crash-splitColumn-3.html [ Failure ] crbug.com/591099 fast/table/crash-splitColumn.html [ Failure ] crbug.com/591099 fast/table/css-table-max-width.html [ Failure ] @@ -13454,7 +13462,7 @@ crbug.com/591099 fast/table/min-width-css-inline-table.html [ Failure Timeout ] crbug.com/591099 fast/table/min-width-html-block-table.html [ Failure Timeout ] crbug.com/591099 fast/table/min-width-html-inline-table.html [ Failure Timeout ] -crbug.com/591099 fast/table/multiple-captions-crash3.html [ Crash ] +crbug.com/591099 fast/table/multiple-captions-crash3.html [ Crash Pass ] crbug.com/591099 fast/table/nested-percent-height-table.html [ Failure ] crbug.com/591099 fast/table/overallocating-auto-cells.html [ Failure ] crbug.com/591099 fast/table/percent-height-border-box-content-in-cell-2.html [ Failure ] @@ -13478,7 +13486,7 @@ crbug.com/591099 fast/table/percent-widths-stretch-vertical.html [ Failure ] crbug.com/591099 fast/table/percent-widths-total-less-than-one.html [ Failure ] crbug.com/591099 fast/table/prepend-in-anonymous-table.html [ Failure ] -crbug.com/591099 fast/table/quirks-mode-ignore-display-inline-table.html [ Crash ] +crbug.com/591099 fast/table/quirks-mode-ignore-display-inline-table.html [ Crash Pass ] crbug.com/591099 fast/table/recalc-section-first-body-crash-main.html [ Failure ] crbug.com/591099 fast/table/remove-anonymous-cell.html [ Failure ] crbug.com/591099 fast/table/remove-cell-with-large-border-width.html [ Failure ] @@ -13500,7 +13508,7 @@ crbug.com/591099 fast/table/table-all-rowspans-height-distribution-in-rows-except-overlapped.html [ Failure ] crbug.com/591099 fast/table/table-all-rowspans-height-distribution-in-rows.html [ Failure ] crbug.com/591099 fast/table/table-before-child-in-table.html [ Failure Pass ] -crbug.com/591099 fast/table/table-caption-moved-crash.html [ Crash ] +crbug.com/591099 fast/table/table-caption-moved-crash.html [ Crash Pass ] crbug.com/591099 fast/table/table-cell-negative-start-margin-align-center.html [ Failure ] crbug.com/591099 fast/table/table-colgroup-present-after-table-row.html [ Failure ] crbug.com/591099 fast/table/table-different-overflow-values-2.html [ Failure ] @@ -13569,7 +13577,7 @@ crbug.com/591099 fast/text-autosizing/header-links-autosizing-different-fontsize.html [ Failure ] crbug.com/591099 fast/text-autosizing/header-links-autosizing.html [ Failure ] crbug.com/591099 fast/text-autosizing/inherited-multiplier.html [ Failure ] -crbug.com/591099 fast/text-autosizing/inline-block-em-width-hover.html [ Crash ] +crbug.com/591099 fast/text-autosizing/inline-block-em-width-hover.html [ Crash Pass ] crbug.com/591099 fast/text-autosizing/inline-float.html [ Failure ] crbug.com/591099 fast/text-autosizing/layout-after-append.html [ Failure ] crbug.com/591099 fast/text-autosizing/list-item-above-dbcat.html [ Failure ] @@ -13645,7 +13653,7 @@ crbug.com/591099 fast/text/decorations-with-text-combine.html [ Failure ] crbug.com/591099 fast/text/delete-hard-break-character.html [ Failure ] crbug.com/591099 fast/text/drawBidiText.html [ Failure ] -crbug.com/591099 fast/text/editing-text-crash.html [ Crash ] +crbug.com/591099 fast/text/editing-text-crash.html [ Crash Pass ] crbug.com/591099 fast/text/ellipsis-at-edge-of-ltr-text-in-rtl-flow.html [ Failure ] crbug.com/591099 fast/text/ellipsis-at-edge-of-rtl-text-in-ltr-flow.html [ Failure ] crbug.com/591099 fast/text/ellipsis-ltr-text-in-ltr-flow-underline-composition.html [ Failure ] @@ -13678,11 +13686,11 @@ crbug.com/591099 fast/text/find-kana.html [ Timeout ] crbug.com/591099 fast/text/find-russian.html [ Failure ] crbug.com/591099 fast/text/find-soft-hyphen.html [ Failure ] -crbug.com/591099 fast/text/first-letter-bad-line-boxes-crash.html [ Crash ] +crbug.com/591099 fast/text/first-letter-bad-line-boxes-crash.html [ Crash Pass ] crbug.com/591099 fast/text/firstline/001.html [ Failure ] crbug.com/591099 fast/text/firstline/002.html [ Failure ] crbug.com/591099 fast/text/firstline/003.html [ Failure ] -crbug.com/591099 fast/text/fit-content-with-element-boundaries.html [ Crash ] +crbug.com/591099 fast/text/fit-content-with-element-boundaries.html [ Crash Pass ] crbug.com/591099 fast/text/font-ascent-mac.html [ Failure ] crbug.com/591099 fast/text/font-fallback-synthetic-italics.html [ Failure ] crbug.com/591099 fast/text/font-initial.html [ Failure ] @@ -13696,7 +13704,7 @@ crbug.com/591099 fast/text/hyphenate-character.html [ Failure ] crbug.com/591099 fast/text/hyphens/hyphens-none.html [ Failure ] crbug.com/591099 fast/text/in-rendered-text-rtl.html [ Failure ] -crbug.com/591099 fast/text/insert-text-crash.html [ Crash ] +crbug.com/591099 fast/text/insert-text-crash.html [ Crash Pass ] crbug.com/591099 fast/text/international/arabic-justify.html [ Failure ] crbug.com/591099 fast/text/international/arabic-vertical-offset.html [ Failure ] crbug.com/591099 fast/text/international/bidi-AN-after-empty-run.html [ Failure ] @@ -13727,7 +13735,7 @@ crbug.com/591099 fast/text/international/hebrew-vowels.html [ Failure ] crbug.com/591099 fast/text/international/hindi-whitespace.html [ Failure ] crbug.com/591099 fast/text/international/iso-8859-8.html [ Failure ] -crbug.com/591099 fast/text/international/listbox-width-rtl.html [ Crash ] +crbug.com/591099 fast/text/international/listbox-width-rtl.html [ Crash Failure ] crbug.com/591099 fast/text/international/plane2.html [ Failure ] crbug.com/591099 fast/text/international/rtl-caret.html [ Failure ] crbug.com/591099 fast/text/international/rtl-negative-letter-spacing.html [ Failure ] @@ -13739,8 +13747,8 @@ crbug.com/591099 fast/text/international/text-spliced-font.html [ Failure ] crbug.com/591099 fast/text/international/thai-cursor-position.html [ Crash Failure ] crbug.com/591099 fast/text/international/thai-offsetForPosition-inside-character.html [ Failure ] -crbug.com/591099 fast/text/international/unicode-bidi-isolate-nested-with-removes-not-adjacent.html [ Crash ] -crbug.com/591099 fast/text/international/unicode-bidi-isolate-nested-with-removes.html [ Crash ] +crbug.com/591099 fast/text/international/unicode-bidi-isolate-nested-with-removes-not-adjacent.html [ Crash Pass ] +crbug.com/591099 fast/text/international/unicode-bidi-isolate-nested-with-removes.html [ Crash Pass ] crbug.com/591099 fast/text/international/unicode-bidi-plaintext.html [ Failure ] crbug.com/591099 fast/text/international/vertical-text-glyph-test.html [ Failure ] crbug.com/591099 fast/text/international/vertical-text-metrics-test.html [ Crash Failure ] @@ -13820,16 +13828,16 @@ crbug.com/591099 fast/text/soft-hyphen-min-preferred-width.html [ Failure ] crbug.com/591099 fast/text/soft-hyphen-overflow.html [ Failure ] crbug.com/591099 fast/text/stale-TextLayout-from-first-line.html [ Failure ] -crbug.com/591099 fast/text/sub-pixel/text-scaling-ltr.html [ Crash ] +crbug.com/591099 fast/text/sub-pixel/text-scaling-ltr.html [ Crash Pass ] crbug.com/591099 fast/text/sub-pixel/text-scaling-pixel.html [ Failure Timeout ] -crbug.com/591099 fast/text/sub-pixel/text-scaling-rtl.html [ Crash Failure Timeout ] -crbug.com/591099 fast/text/sub-pixel/text-scaling-vertical.html [ Crash Failure Timeout ] -crbug.com/591099 fast/text/sub-pixel/text-scaling-webfont.html [ Crash Failure Timeout ] +crbug.com/591099 fast/text/sub-pixel/text-scaling-rtl.html [ Crash Failure Pass Timeout ] +crbug.com/591099 fast/text/sub-pixel/text-scaling-vertical.html [ Crash Failure Pass Timeout ] +crbug.com/591099 fast/text/sub-pixel/text-scaling-webfont.html [ Crash Failure Pass Timeout ] crbug.com/591099 fast/text/tab-min-size.html [ Failure ] crbug.com/591099 fast/text/text-between-two-brs-in-nowrap-overflow.html [ Failure ] crbug.com/591099 fast/text/text-combine-shrink-to-fit.html [ Failure ] crbug.com/591099 fast/text/text-container-bounding-rect.html [ Crash Failure ] -crbug.com/591099 fast/text/text-iterator-crash.html [ Crash ] +crbug.com/591099 fast/text/text-iterator-crash.html [ Crash Failure ] crbug.com/591099 fast/text/text-large-negative-letter-spacing-with-opacity.html [ Failure ] crbug.com/591099 fast/text/text-letter-spacing.html [ Failure ] crbug.com/591099 fast/text/text-shadow-no-default-color.html [ Failure ] @@ -13936,7 +13944,7 @@ crbug.com/591099 fast/url/standard-url.html [ Failure ] crbug.com/591099 fast/url/trivial-segments.html [ Failure ] crbug.com/591099 fast/url/trivial.html [ Failure ] -crbug.com/591099 fast/workers/close-context-messageport-crash.html [ Crash ] +crbug.com/591099 fast/workers/close-context-messageport-crash.html [ Crash Pass ] crbug.com/591099 fast/workers/constructor-proto.html [ Failure ] crbug.com/591099 fast/workers/dedicated-worker-lifecycle.html [ Failure ] crbug.com/591099 fast/workers/shared-worker-console-log.html [ Failure ] @@ -13946,7 +13954,7 @@ crbug.com/591099 fast/workers/shared-worker-exception.html [ Failure ] crbug.com/591099 fast/workers/shared-worker-gc.html [ Failure ] crbug.com/591099 fast/workers/shared-worker-in-iframe.html [ Failure ] -crbug.com/591099 fast/workers/shared-worker-lifecycle.html [ Crash ] +crbug.com/591099 fast/workers/shared-worker-lifecycle.html [ Crash Failure ] crbug.com/591099 fast/workers/shared-worker-load-error.html [ Failure ] crbug.com/591099 fast/workers/shared-worker-location.html [ Failure ] crbug.com/591099 fast/workers/shared-worker-messageevent-source.html [ Failure ] @@ -14046,7 +14054,7 @@ crbug.com/591099 fast/writing-mode/margin-collapse.html [ Failure ] crbug.com/591099 fast/writing-mode/margins.html [ Failure ] crbug.com/591099 fast/writing-mode/orthogonal-writing-modes-available-width-absolute-crash.html [ Failure ] -crbug.com/591099 fast/writing-mode/orthogonal-writing-modes-floats-crash-3.html [ Crash ] +crbug.com/591099 fast/writing-mode/orthogonal-writing-modes-floats-crash-3.html [ Crash Pass ] crbug.com/591099 fast/writing-mode/orthogonal-writing-modes-scrollbarpart-crash.html [ Failure ] crbug.com/591099 fast/writing-mode/percentage-height-orthogonal-writing-modes-quirks.html [ Failure ] crbug.com/591099 fast/writing-mode/percentage-height-orthogonal-writing-modes.html [ Failure ] @@ -14055,14 +14063,14 @@ crbug.com/591099 fast/writing-mode/table-hit-test.html [ Failure ] crbug.com/591099 fast/writing-mode/table-percent-width-quirk.html [ Crash Failure ] crbug.com/591099 fast/writing-mode/table-vertical-child-width.html [ Failure ] -crbug.com/591099 fast/writing-mode/text-combine-compress.html [ Crash ] +crbug.com/591099 fast/writing-mode/text-combine-compress.html [ Crash Failure ] crbug.com/591099 fast/writing-mode/text-combine-justify.html [ Failure ] crbug.com/591099 fast/writing-mode/text-combine-line-break.html [ Failure ] crbug.com/591099 fast/writing-mode/text-combine-various-fonts.html [ Failure ] crbug.com/591099 fast/writing-mode/text-orientation-basic.html [ Failure ] crbug.com/591099 fast/writing-mode/vertical-baseline-alignment.html [ Failure ] crbug.com/591099 fast/writing-mode/vertical-font-fallback.html [ Failure ] -crbug.com/591099 fast/writing-mode/vertical-inline-block-hittest.html [ Crash ] +crbug.com/591099 fast/writing-mode/vertical-inline-block-hittest.html [ Crash Failure ] crbug.com/591099 fast/writing-mode/vertical-lr-replaced-selection.html [ Failure ] crbug.com/591099 fast/writing-mode/vorg-glyph-zero-crash.html [ Failure ] crbug.com/591099 fast/xmlhttprequest/instanceof-XMLHttpRequest.html [ Failure ] @@ -14074,7 +14082,7 @@ crbug.com/591099 fast/xmlhttprequest/xmlhttprequest-html-response-encoding.html [ Crash Failure ] crbug.com/591099 fast/xmlhttprequest/xmlhttprequest-missing-file-exception.html [ Failure ] crbug.com/591099 fast/xmlhttprequest/xmlhttprequest-nonexistent-file.html [ Failure ] -crbug.com/591099 fast/xmlhttprequest/xmlhttprequest-open-after-iframe-onload-remove-self.html [ Crash ] +crbug.com/591099 fast/xmlhttprequest/xmlhttprequest-open-after-iframe-onload-remove-self.html [ Crash Failure ] crbug.com/591099 fast/xmlhttprequest/xmlhttprequest-open-exceptions.html [ Failure ] crbug.com/591099 fast/xmlhttprequest/xmlhttprequest-recursive-sync-event.html [ Failure ] crbug.com/591099 fast/xmlhttprequest/xmlhttprequest-responseXML-html-document-responsetype-quirks.html [ Failure ] @@ -14214,7 +14222,7 @@ crbug.com/591099 fragmentation/tbody-before-thead.html [ Failure ] crbug.com/591099 fragmentation/unbreakable-tall-float-before-block.html [ Failure ] crbug.com/591099 fragmentation/unbreakable-tall-float-before-line.html [ Failure Pass ] -crbug.com/591099 fullscreen/anonymous-block-merge-crash.html [ Crash ] +crbug.com/591099 fullscreen/anonymous-block-merge-crash.html [ Crash Pass ] crbug.com/591099 fullscreen/compositor-touch-hit-rects-fullscreen-video-controls.html [ Failure ] crbug.com/591099 fullscreen/exit-full-screen-iframe.html [ Crash Failure ] crbug.com/591099 fullscreen/full-screen-cancel-nested.html [ Crash Failure ] @@ -14223,7 +14231,7 @@ crbug.com/591099 fullscreen/full-screen-element-stack.html [ Failure ] crbug.com/591099 fullscreen/full-screen-frameset.html [ Failure ] crbug.com/591099 fullscreen/full-screen-iframe-allowed-nested.html [ Timeout ] -crbug.com/591099 fullscreen/full-screen-iframe-allowed.html [ Crash ] +crbug.com/591099 fullscreen/full-screen-iframe-allowed.html [ Crash Failure ] crbug.com/591099 fullscreen/full-screen-iframe-legacy.html [ Failure ] crbug.com/591099 fullscreen/full-screen-iframe-not-allowed.html [ Failure ] crbug.com/591099 fullscreen/full-screen-iframe-without-allow-attribute-allowed-from-parent.html [ Failure ] @@ -14231,8 +14239,8 @@ crbug.com/591099 fullscreen/full-screen-request-removed.html [ Failure ] crbug.com/591099 fullscreen/full-screen-table-section.html [ Failure ] crbug.com/591099 fullscreen/full-screen-with-css-reference-filter.html [ Failure ] -crbug.com/591099 fullscreen/full-screen-with-flex-item.html [ Crash ] -crbug.com/591099 fullscreen/model/fully-exit-fullscreen-nested-iframe.html [ Crash ] +crbug.com/591099 fullscreen/full-screen-with-flex-item.html [ Crash Failure ] +crbug.com/591099 fullscreen/model/fully-exit-fullscreen-nested-iframe.html [ Crash Pass ] crbug.com/591099 fullscreen/video-controls-override.html [ Failure ] crbug.com/591099 fullscreen/video-controls-timeline.html [ Failure ] crbug.com/591099 fullscreen/video-fail-to-enter-full-screen.html [ Failure ] @@ -14272,7 +14280,7 @@ crbug.com/591099 geolocation-api/reentrant-error.html [ Failure ] crbug.com/591099 geolocation-api/reentrant-permission-denied.html [ Failure ] crbug.com/591099 geolocation-api/reentrant-success.html [ Failure ] -crbug.com/591099 geolocation-api/remove-remote-context-in-error-callback-crash.html [ Crash ] +crbug.com/591099 geolocation-api/remove-remote-context-in-error-callback-crash.html [ Crash Failure ] crbug.com/591099 geolocation-api/success-clear-watch.html [ Failure ] crbug.com/591099 geolocation-api/success.html [ Failure ] crbug.com/591099 geolocation-api/timeout-clear-watch.html [ Failure ] @@ -14286,19 +14294,19 @@ crbug.com/591099 geolocation-api/watchPosition-unique.html [ Failure ] crbug.com/591099 geolocation-api/window-close-crash.html [ Failure ] crbug.com/591099 hittesting/border-hittest-inlineFlowBox.html [ Failure ] -crbug.com/591099 hittesting/border-hittest-with-image-fallback.html [ Crash ] +crbug.com/591099 hittesting/border-hittest-with-image-fallback.html [ Crash Failure ] crbug.com/591099 hittesting/border-hittest.html [ Failure ] crbug.com/591099 hittesting/border-radius-hittest.html [ Failure ] crbug.com/591099 hittesting/culled-inline-crash.html [ Failure ] crbug.com/591099 hittesting/culled-inline.html [ Failure ] -crbug.com/591099 hittesting/hittest-child-of-inlineblock.html [ Crash ] +crbug.com/591099 hittesting/hittest-child-of-inlineblock.html [ Crash Failure ] crbug.com/591099 hittesting/hittest-overlapping-floats.html [ Failure ] crbug.com/591099 hittesting/image-with-border-radius.html [ Failure ] crbug.com/591099 hittesting/image-with-clip-path.html [ Failure ] crbug.com/591099 hittesting/inline-with-clip-path.html [ Failure ] crbug.com/591099 hittesting/inner-border-radius-hittest.html [ Failure ] crbug.com/591099 hittesting/paint-containment-hittest.html [ Failure ] -crbug.com/591099 hittesting/subframe_active_crash.html [ Crash ] +crbug.com/591099 hittesting/subframe_active_crash.html [ Crash Pass ] crbug.com/591099 hittesting/text-overflow-inline-image.html [ Timeout ] crbug.com/591099 html/details_summary/details-add-child-1.html [ Crash Failure ] crbug.com/591099 html/details_summary/details-add-child-2.html [ Crash Failure ] @@ -14326,7 +14334,7 @@ crbug.com/591099 html/details_summary/details-add-summary-9.html [ Crash Failure ] crbug.com/591099 html/details_summary/details-add-summary-child-1.html [ Crash Failure ] crbug.com/591099 html/details_summary/details-add-summary-child-2.html [ Crash Failure ] -crbug.com/591099 html/details_summary/details-click-controls.html [ Crash ] +crbug.com/591099 html/details_summary/details-click-controls.html [ Crash Pass ] crbug.com/591099 html/details_summary/details-clone.html [ Crash Failure ] crbug.com/591099 html/details_summary/details-keyboard-show-hide.html [ Crash Failure ] crbug.com/591099 html/details_summary/details-marker-style.html [ Crash Failure ] @@ -14338,7 +14346,7 @@ crbug.com/591099 html/details_summary/details-no-summary3.html [ Crash Failure ] crbug.com/591099 html/details_summary/details-no-summary4.html [ Crash Failure ] crbug.com/591099 html/details_summary/details-open-javascript.html [ Crash Failure ] -crbug.com/591099 html/details_summary/details-open-toggle-event.html [ Crash ] +crbug.com/591099 html/details_summary/details-open-toggle-event.html [ Crash Failure ] crbug.com/591099 html/details_summary/details-open1.html [ Crash Failure ] crbug.com/591099 html/details_summary/details-open2.html [ Crash Failure ] crbug.com/591099 html/details_summary/details-open3.html [ Crash Failure ] @@ -14372,8 +14380,8 @@ crbug.com/591099 html/details_summary/summary-display-inline-flex.html [ Failure ] crbug.com/591099 html/dialog/abspos-dialog-layout.html [ Failure ] crbug.com/591099 html/dialog/closed-dialog-does-not-block-mouse-events.html [ Failure ] -crbug.com/591099 html/dialog/dialog-autofocus-multiple-times.html [ Crash ] -crbug.com/591099 html/dialog/dialog-autofocus.html [ Crash ] +crbug.com/591099 html/dialog/dialog-autofocus-multiple-times.html [ Crash Failure ] +crbug.com/591099 html/dialog/dialog-autofocus.html [ Crash Failure ] crbug.com/591099 html/dialog/dialog-canceling.html [ Failure ] crbug.com/591099 html/dialog/dialog-close-event.html [ Failure ] crbug.com/591099 html/dialog/dialog-enabled.html [ Failure ] @@ -14381,9 +14389,9 @@ crbug.com/591099 html/dialog/dialog-return-value.html [ Failure ] crbug.com/591099 html/dialog/dialog-show-modal.html [ Failure ] crbug.com/591099 html/dialog/fixpos-dialog-layout.html [ Failure ] -crbug.com/591099 html/dialog/form-method-dialog.html [ Crash ] +crbug.com/591099 html/dialog/form-method-dialog.html [ Crash Failure ] crbug.com/591099 html/dialog/inert-does-not-match-disabled-selector.html [ Failure ] -crbug.com/591099 html/dialog/inert-focus-in-frames.html [ Crash ] +crbug.com/591099 html/dialog/inert-focus-in-frames.html [ Crash Failure ] crbug.com/591099 html/dialog/inert-inlines.html [ Failure ] crbug.com/591099 html/dialog/inert-label-focus.html [ Failure ] crbug.com/591099 html/dialog/inert-node-is-uneditable.html [ Crash Failure ] @@ -14398,15 +14406,15 @@ crbug.com/591099 html/dialog/non-modal-dialog-does-not-block-mouse-events.html [ Failure ] crbug.com/591099 html/dialog/non-modal-dialog-layout.html [ Failure ] crbug.com/591099 html/dialog/scrollable-after-close.html [ Failure ] -crbug.com/591099 html/dialog/shadowdom-in-dialog.html [ Crash ] -crbug.com/591099 html/dialog/show-modal-focusing-steps.html [ Crash ] +crbug.com/591099 html/dialog/shadowdom-in-dialog.html [ Crash Pass ] +crbug.com/591099 html/dialog/show-modal-focusing-steps.html [ Crash Failure ] crbug.com/591099 html/dialog/simulated-click-inert.html [ Failure ] -crbug.com/591099 html/dialog/submit-dialog-close-event.html [ Crash ] +crbug.com/591099 html/dialog/submit-dialog-close-event.html [ Crash Failure ] crbug.com/591099 html/dialog/synthetic-click-inert.html [ Failure ] crbug.com/591099 html/dialog/top-layer-position-relative.html [ Failure ] crbug.com/591099 html/dialog/top-layer-position-static.html [ Failure ] crbug.com/591099 html/document_metadata/base-multiple.html [ Failure ] -crbug.com/591099 html/document_metadata/head-check.html [ Crash ] +crbug.com/591099 html/document_metadata/head-check.html [ Crash Failure ] crbug.com/591099 html/document_metadata/head-has-text-1.html [ Failure ] crbug.com/591099 html/document_metadata/head-has-text-2.html [ Failure ] crbug.com/591099 html/document_metadata/head-has-text-3.html [ Failure ] @@ -14423,7 +14431,7 @@ crbug.com/591099 html/marquee/marquee-element.html [ Crash Failure ] crbug.com/591099 html/marquee/marquee-scroll.html [ Crash Failure ] crbug.com/591099 html/marquee/marquee-scrollamount.html [ Crash Failure ] -crbug.com/591099 html/marquee/marquee-shadow-root-no-access.html [ Crash ] +crbug.com/591099 html/marquee/marquee-shadow-root-no-access.html [ Crash Pass ] crbug.com/591099 html/sections/article-element.html [ Failure ] crbug.com/591099 html/sections/aside-element.html [ Failure ] crbug.com/591099 html/sections/body-quirk-client-size.html [ Failure ] @@ -14476,9 +14484,9 @@ crbug.com/591099 http/tests/appcache/access-via-redirect.php [ Failure ] crbug.com/591099 http/tests/appcache/credential-url.html [ Failure Timeout ] crbug.com/591099 http/tests/appcache/cyrillic-uri.html [ Crash Failure ] -crbug.com/591099 http/tests/appcache/deferred-events-delete-while-raising-timer.html [ Crash ] -crbug.com/591099 http/tests/appcache/deferred-events-delete-while-raising.html [ Crash ] -crbug.com/591099 http/tests/appcache/destroyed-frame.html [ Crash ] +crbug.com/591099 http/tests/appcache/deferred-events-delete-while-raising-timer.html [ Crash Failure ] +crbug.com/591099 http/tests/appcache/deferred-events-delete-while-raising.html [ Crash Failure ] +crbug.com/591099 http/tests/appcache/destroyed-frame.html [ Crash Failure ] crbug.com/591099 http/tests/appcache/detached-iframe.html [ Crash Failure ] crbug.com/591099 http/tests/appcache/different-https-origin-resource-main.html [ Failure ] crbug.com/591099 http/tests/appcache/different-origin-manifest.html [ Failure ] @@ -14509,7 +14517,7 @@ crbug.com/591099 http/tests/appcache/top-frame-3.html [ Failure ] crbug.com/591099 http/tests/appcache/top-frame-4.html [ Failure ] crbug.com/591099 http/tests/appcache/update-cache.html [ Failure ] -crbug.com/591099 http/tests/appcache/video.html [ Crash ] +crbug.com/591099 http/tests/appcache/video.html [ Crash Pass ] crbug.com/591099 http/tests/appcache/whitelist-wildcard.html [ Failure ] crbug.com/591099 http/tests/appcache/wrong-content-type.html [ Failure ] crbug.com/591099 http/tests/appcache/wrong-signature-2.html [ Failure ] @@ -14519,7 +14527,7 @@ crbug.com/591099 http/tests/cache/history-only-cached-subresource-loads-max-age-https.html [ Failure ] crbug.com/591099 http/tests/cache/history-only-cached-subresource-loads.html [ Failure ] crbug.com/591099 http/tests/cache/network-error-during-revalidation.html [ Failure ] -crbug.com/591099 http/tests/cache/subresource-fragment-identifier.html [ Crash ] +crbug.com/591099 http/tests/cache/subresource-fragment-identifier.html [ Crash Failure ] crbug.com/591099 http/tests/cache/subresource-multiple-instances.html [ Failure ] crbug.com/591099 http/tests/cache/subresource-revalidation-referrer.html [ Failure ] crbug.com/591099 http/tests/cache/x-frame-options-304.html [ Failure ] @@ -14537,13 +14545,13 @@ crbug.com/591099 http/tests/cookies/simple-cookies-expired.html [ Failure ] crbug.com/591099 http/tests/cookies/simple-cookies-max-age.html [ Failure ] crbug.com/591099 http/tests/cookies/single-quoted-value.html [ Failure ] -crbug.com/591099 http/tests/credentialmanager/credentialscontainer-frame-errors.html [ Crash ] +crbug.com/591099 http/tests/credentialmanager/credentialscontainer-frame-errors.html [ Crash Pass ] crbug.com/591099 http/tests/css/border-image-loading.html [ Failure ] crbug.com/591099 http/tests/css/css-image-loading.html [ Crash Failure ] crbug.com/591099 http/tests/css/css-image-valued-shape.html [ Failure ] crbug.com/591099 http/tests/css/css-non-blocking.html [ Failure ] crbug.com/591099 http/tests/css/font-face-src-loading.html [ Failure ] -crbug.com/591099 http/tests/css/image-value-cached.html [ Crash ] +crbug.com/591099 http/tests/css/image-value-cached.html [ Crash Pass ] crbug.com/591099 http/tests/css/mask-image-loading.html [ Failure ] crbug.com/591099 http/tests/css/pending-stylesheet-offset-width.html [ Failure ] crbug.com/591099 http/tests/css/performance-info-with-cached-sheet.html [ Failure ] @@ -14555,8 +14563,8 @@ crbug.com/591099 http/tests/csspaint/invalidation-background-image.html [ Timeout ] crbug.com/591099 http/tests/csspaint/invalidation-border-image.html [ Timeout ] crbug.com/591099 http/tests/csspaint/invalidation-content-image.html [ Timeout ] -crbug.com/591099 http/tests/dom/EventListener-incumbent-global-1.html [ Crash ] -crbug.com/591099 http/tests/dom/EventListener-incumbent-global-2.html [ Crash ] +crbug.com/591099 http/tests/dom/EventListener-incumbent-global-1.html [ Crash Pass ] +crbug.com/591099 http/tests/dom/EventListener-incumbent-global-2.html [ Crash Pass ] crbug.com/591099 http/tests/dom/create-contextual-fragment-from-bodyless-svg-document-range.html [ Failure ] crbug.com/591099 http/tests/dom/create-contextual-fragment-from-svg-document-range.html [ Failure ] crbug.com/591099 http/tests/dom/location-stringify.html [ Crash Failure ] @@ -14581,8 +14589,8 @@ crbug.com/591099 http/tests/eventsource/eventsource-retry-precision.html [ Failure ] crbug.com/591099 http/tests/eventsource/eventsource-status-code-states.html [ Failure ] crbug.com/591099 http/tests/eventsource/eventsource-url-attribute.html [ Failure ] -crbug.com/591099 http/tests/eventsource/existent-eventsource-status-error-iframe-crash.html [ Crash ] -crbug.com/591099 http/tests/eventsource/non-existent-eventsource-status-error-iframe-crash.html [ Crash ] +crbug.com/591099 http/tests/eventsource/existent-eventsource-status-error-iframe-crash.html [ Crash Pass ] +crbug.com/591099 http/tests/eventsource/non-existent-eventsource-status-error-iframe-crash.html [ Crash Pass ] crbug.com/591099 http/tests/eventsource/workers/eventsource-bad-mime-type.html [ Failure ] crbug.com/591099 http/tests/eventsource/workers/eventsource-content-type-charset.html [ Failure ] crbug.com/591099 http/tests/eventsource/workers/eventsource-cors-basic.html [ Failure ] @@ -14605,16 +14613,16 @@ crbug.com/591099 http/tests/feature-policy-experimental-features/vibrate-disabled.php [ Timeout ] crbug.com/591099 http/tests/feature-policy-experimental-features/vibrate-enabledforall.php [ Timeout ] crbug.com/591099 http/tests/feature-policy-experimental-features/vibrate-enabledforself.php [ Timeout ] -crbug.com/591099 http/tests/feature-policy/fullscreen-allowed-by-container-policy-relocate.html [ Crash ] -crbug.com/591099 http/tests/feature-policy/fullscreen-allowed-by-container-policy.html [ Crash ] -crbug.com/591099 http/tests/feature-policy/fullscreen-disabled.php [ Crash ] -crbug.com/591099 http/tests/feature-policy/fullscreen-enabledforall.php [ Crash ] -crbug.com/591099 http/tests/feature-policy/fullscreen-enabledforself.php [ Crash ] -crbug.com/591099 http/tests/feature-policy/payment-allowed-by-container-policy-relocate.html [ Crash ] -crbug.com/591099 http/tests/feature-policy/payment-allowed-by-container-policy.html [ Crash ] -crbug.com/591099 http/tests/feature-policy/payment-disabled.php [ Crash ] -crbug.com/591099 http/tests/feature-policy/payment-enabledforall.php [ Crash ] -crbug.com/591099 http/tests/feature-policy/payment-enabledforself.php [ Crash ] +crbug.com/591099 http/tests/feature-policy/fullscreen-allowed-by-container-policy-relocate.html [ Crash Pass ] +crbug.com/591099 http/tests/feature-policy/fullscreen-allowed-by-container-policy.html [ Crash Pass ] +crbug.com/591099 http/tests/feature-policy/fullscreen-disabled.php [ Crash Pass ] +crbug.com/591099 http/tests/feature-policy/fullscreen-enabledforall.php [ Crash Pass ] +crbug.com/591099 http/tests/feature-policy/fullscreen-enabledforself.php [ Crash Pass ] +crbug.com/591099 http/tests/feature-policy/payment-allowed-by-container-policy-relocate.html [ Crash Pass ] +crbug.com/591099 http/tests/feature-policy/payment-allowed-by-container-policy.html [ Crash Pass ] +crbug.com/591099 http/tests/feature-policy/payment-disabled.php [ Crash Failure ] +crbug.com/591099 http/tests/feature-policy/payment-enabledforall.php [ Crash Failure ] +crbug.com/591099 http/tests/feature-policy/payment-enabledforself.php [ Crash Pass ] crbug.com/591099 http/tests/fetch/chromium/discarded-window.html [ Crash Pass ] crbug.com/591099 http/tests/fetch/window/pageimportancesignals.html [ Failure ] crbug.com/591099 http/tests/fileapi/blob-url-in-subframe.html [ Failure ] @@ -14659,13 +14667,13 @@ crbug.com/591099 http/tests/htmlimports/encoding.html [ Failure ] crbug.com/591099 http/tests/htmlimports/import-script-block-crossorigin-dynamic.html [ Failure ] crbug.com/591099 http/tests/images/drag-image-to-desktop.html [ Timeout ] -crbug.com/591099 http/tests/images/force-reload-image-document.html [ Crash ] -crbug.com/591099 http/tests/images/force-reload.html [ Crash ] -crbug.com/591099 http/tests/images/image-currentsrc-broken.html [ Crash ] -crbug.com/591099 http/tests/images/image-currentsrc-error.html [ Crash ] -crbug.com/591099 http/tests/images/image-currentsrc-invalid.html [ Crash ] -crbug.com/591099 http/tests/images/image-error-event-not-firing.html [ Crash ] -crbug.com/591099 http/tests/images/image-with-dpr-natural-dimensions.html [ Crash ] +crbug.com/591099 http/tests/images/force-reload-image-document.html [ Crash Pass ] +crbug.com/591099 http/tests/images/force-reload.html [ Crash Pass ] +crbug.com/591099 http/tests/images/image-currentsrc-broken.html [ Crash Pass ] +crbug.com/591099 http/tests/images/image-currentsrc-error.html [ Crash Pass ] +crbug.com/591099 http/tests/images/image-currentsrc-invalid.html [ Crash Pass ] +crbug.com/591099 http/tests/images/image-error-event-not-firing.html [ Crash Pass ] +crbug.com/591099 http/tests/images/image-with-dpr-natural-dimensions.html [ Crash Pass ] crbug.com/591099 http/tests/images/image-with-origin-header.html [ Failure ] crbug.com/591099 http/tests/images/png-partial-load-as-document.html [ Failure Pass ] crbug.com/591099 http/tests/images/restyle-decode-error.html [ Failure Pass ] @@ -14687,11 +14695,11 @@ crbug.com/591099 http/tests/inspector-enabled/dom-storage-open.html [ Failure ] crbug.com/591099 http/tests/inspector-enabled/dynamic-scripts.html [ Crash Failure Timeout ] crbug.com/591099 http/tests/inspector-enabled/injected-script-discard.html [ Failure ] -crbug.com/591099 http/tests/inspector-enabled/reattach-after-editing-styles.html [ Crash ] +crbug.com/591099 http/tests/inspector-enabled/reattach-after-editing-styles.html [ Crash Failure ] crbug.com/591099 http/tests/inspector-enabled/resource-tree/main-resource-content.html [ Failure ] crbug.com/591099 http/tests/inspector-enabled/resource-tree/resource-tree-mimetype.html [ Failure ] -crbug.com/591099 http/tests/inspector-enabled/shadow-dom-rules-restart.html [ Crash ] -crbug.com/591099 http/tests/inspector-enabled/shadow-dom-rules.html [ Crash ] +crbug.com/591099 http/tests/inspector-enabled/shadow-dom-rules-restart.html [ Crash Failure ] +crbug.com/591099 http/tests/inspector-enabled/shadow-dom-rules.html [ Crash Failure ] crbug.com/591099 http/tests/inspector-protocol/access-inspected-object.html [ Failure Timeout ] crbug.com/591099 http/tests/inspector-protocol/cookies-protocol-test.html [ Failure Timeout ] crbug.com/591099 http/tests/inspector-protocol/network-data-length.html [ Failure Timeout ] @@ -14720,7 +14728,7 @@ crbug.com/591099 http/tests/inspector-protocol/websocket/websocket-user-agent-override.html [ Failure ] crbug.com/591099 http/tests/inspector-unit/viewport-datagrid-items-attached-to-dom.js [ Failure ] crbug.com/591099 http/tests/inspector-unit/viewport-datagrid-items-expandable-attached-to-dom.js [ Failure ] -crbug.com/591099 http/tests/inspector/appcache/appcache-iframe-manifests.html [ Crash Timeout ] +crbug.com/591099 http/tests/inspector/appcache/appcache-iframe-manifests.html [ Crash Failure Timeout ] crbug.com/591099 http/tests/inspector/appcache/appcache-manifest-with-non-existing-file.html [ Failure Timeout ] crbug.com/591099 http/tests/inspector/appcache/appcache-swap.html [ Failure Timeout ] crbug.com/591099 http/tests/inspector/application-panel/resources-panel-on-navigation.html [ Failure Timeout ] @@ -14730,27 +14738,27 @@ crbug.com/591099 http/tests/inspector/bindings/bindings-frame-attach-detach.html [ Crash Failure Timeout ] crbug.com/591099 http/tests/inspector/bindings/bindings-frame-navigate.html [ Failure Timeout ] crbug.com/591099 http/tests/inspector/bindings/bindings-main-frame-navigated.html [ Failure ] -crbug.com/591099 http/tests/inspector/bindings/bindings-multiple-frames.html [ Crash ] -crbug.com/591099 http/tests/inspector/bindings/contentscripts-bindings-multiple-frames.html [ Crash ] -crbug.com/591099 http/tests/inspector/bindings/contentscripts-navigator-multiple-frames.html [ Crash ] +crbug.com/591099 http/tests/inspector/bindings/bindings-multiple-frames.html [ Crash Failure ] +crbug.com/591099 http/tests/inspector/bindings/contentscripts-bindings-multiple-frames.html [ Crash Failure ] +crbug.com/591099 http/tests/inspector/bindings/contentscripts-navigator-multiple-frames.html [ Crash Failure Timeout ] crbug.com/591099 http/tests/inspector/bindings/dynamic-bindings-frame-attach-detach.html [ Failure ] crbug.com/591099 http/tests/inspector/bindings/dynamic-navigator-frame-attach-detach.html [ Failure Timeout ] crbug.com/591099 http/tests/inspector/bindings/livelocation-main-frame-navigated.html [ Failure ] crbug.com/591099 http/tests/inspector/bindings/navigator-frame-attach-detach.html [ Failure Timeout ] crbug.com/591099 http/tests/inspector/bindings/navigator-frame-navigate.html [ Failure Timeout ] crbug.com/591099 http/tests/inspector/bindings/navigator-main-frame-navigated.html [ Failure Timeout ] -crbug.com/591099 http/tests/inspector/bindings/navigator-multiple-frames.html [ Crash Timeout ] +crbug.com/591099 http/tests/inspector/bindings/navigator-multiple-frames.html [ Crash Failure Timeout ] crbug.com/591099 http/tests/inspector/bindings/shadowdom-bindings.html [ Failure Timeout ] crbug.com/591099 http/tests/inspector/bindings/shadowdom-navigator.html [ Failure Timeout ] -crbug.com/591099 http/tests/inspector/bindings/sourcemap-bindings-multiple-frames.html [ Crash Timeout ] -crbug.com/591099 http/tests/inspector/bindings/sourcemap-navigator-multiple-frames.html [ Crash Timeout ] -crbug.com/591099 http/tests/inspector/bindings/suspendtarget-bindings.html [ Crash Timeout ] -crbug.com/591099 http/tests/inspector/bindings/suspendtarget-navigator.html [ Crash ] +crbug.com/591099 http/tests/inspector/bindings/sourcemap-bindings-multiple-frames.html [ Crash Failure Timeout ] +crbug.com/591099 http/tests/inspector/bindings/sourcemap-navigator-multiple-frames.html [ Crash Failure Timeout ] +crbug.com/591099 http/tests/inspector/bindings/suspendtarget-bindings.html [ Crash Failure Timeout ] +crbug.com/591099 http/tests/inspector/bindings/suspendtarget-navigator.html [ Crash Failure ] crbug.com/591099 http/tests/inspector/cache-storage/cache-data.html [ Failure Timeout ] crbug.com/591099 http/tests/inspector/cache-storage/cache-deletion.html [ Failure ] crbug.com/591099 http/tests/inspector/cache-storage/cache-entry-deletion.html [ Failure Timeout ] crbug.com/591099 http/tests/inspector/cache-storage/cache-names.html [ Failure ] -crbug.com/591099 http/tests/inspector/change-iframe-src.html [ Crash ] +crbug.com/591099 http/tests/inspector/change-iframe-src.html [ Crash Pass ] crbug.com/591099 http/tests/inspector/command-line-api-inspect.html [ Crash Failure ] crbug.com/591099 http/tests/inspector/compiler-script-mapping.html [ Crash Failure ] crbug.com/591099 http/tests/inspector/compiler-source-mapping-debug.html [ Crash Failure ] @@ -14766,52 +14774,52 @@ crbug.com/591099 http/tests/inspector/console/console-links-on-messages-before-inspection.html [ Failure ] crbug.com/591099 http/tests/inspector/console/console-on-paint-worklet.html [ Failure ] crbug.com/591099 http/tests/inspector/debugger/fetch-breakpoints.html [ Crash Failure Timeout ] -crbug.com/591099 http/tests/inspector/elements/elements-linkify-attributes.html [ Crash ] -crbug.com/591099 http/tests/inspector/elements/event-listeners-framework-with-service-worker.html [ Crash ] -crbug.com/591099 http/tests/inspector/elements/html-link-import.html [ Crash ] -crbug.com/591099 http/tests/inspector/elements/styles/edit-css-with-source-url.html [ Crash ] -crbug.com/591099 http/tests/inspector/elements/styles/import-added-through-js-crash.html [ Crash ] +crbug.com/591099 http/tests/inspector/elements/elements-linkify-attributes.html [ Crash Failure ] +crbug.com/591099 http/tests/inspector/elements/event-listeners-framework-with-service-worker.html [ Crash Failure ] +crbug.com/591099 http/tests/inspector/elements/html-link-import.html [ Crash Failure ] +crbug.com/591099 http/tests/inspector/elements/styles/edit-css-with-source-url.html [ Crash Failure ] +crbug.com/591099 http/tests/inspector/elements/styles/import-added-through-js-crash.html [ Crash Failure ] crbug.com/591099 http/tests/inspector/elements/styles/inline-stylesheet-sourceurl-and-sourcemapurl.html [ Crash Failure ] -crbug.com/591099 http/tests/inspector/elements/styles/selector-line-deprecated.html [ Crash ] +crbug.com/591099 http/tests/inspector/elements/styles/selector-line-deprecated.html [ Crash Failure ] crbug.com/591099 http/tests/inspector/elements/styles/selector-line-sourcemap-header-deprecated.html [ Crash Failure ] -crbug.com/591099 http/tests/inspector/elements/styles/selector-line-sourcemap-header.html [ Crash ] -crbug.com/591099 http/tests/inspector/elements/styles/selector-line.html [ Crash ] +crbug.com/591099 http/tests/inspector/elements/styles/selector-line-sourcemap-header.html [ Crash Failure ] +crbug.com/591099 http/tests/inspector/elements/styles/selector-line.html [ Crash Failure ] crbug.com/591099 http/tests/inspector/elements/styles/styles-do-not-add-inline-stylesheets-in-navigator.html [ Failure Timeout ] -crbug.com/591099 http/tests/inspector/elements/styles/styles-redirected-css.html [ Crash ] +crbug.com/591099 http/tests/inspector/elements/styles/styles-redirected-css.html [ Crash Failure ] crbug.com/591099 http/tests/inspector/elements/styles/stylesheet-tracking.html [ Crash Failure Timeout ] -crbug.com/591099 http/tests/inspector/elements/styles/xsl-transformed.xml [ Crash ] +crbug.com/591099 http/tests/inspector/elements/styles/xsl-transformed.xml [ Crash Failure ] crbug.com/591099 http/tests/inspector/extensions-headers.html [ Crash Failure ] crbug.com/591099 http/tests/inspector/extensions-iframe-eval.html [ Crash Failure ] crbug.com/591099 http/tests/inspector/extensions-ignore-cache.html [ Crash Failure ] crbug.com/591099 http/tests/inspector/extensions-network-redirect.html [ Crash Failure ] -crbug.com/591099 http/tests/inspector/extensions-useragent.html [ Crash ] +crbug.com/591099 http/tests/inspector/extensions-useragent.html [ Crash Failure ] crbug.com/591099 http/tests/inspector/extensions/extensions-api.html [ Failure ] crbug.com/591099 http/tests/inspector/extensions/extensions-audits-api.html [ Crash Failure ] crbug.com/591099 http/tests/inspector/extensions/extensions-audits-content-script.html [ Crash Failure ] crbug.com/591099 http/tests/inspector/extensions/extensions-audits.html [ Crash Failure ] crbug.com/591099 http/tests/inspector/extensions/extensions-eval-content-script.html [ Failure ] crbug.com/591099 http/tests/inspector/extensions/extensions-eval.html [ Crash Failure ] -crbug.com/591099 http/tests/inspector/extensions/extensions-events.html [ Crash ] +crbug.com/591099 http/tests/inspector/extensions/extensions-events.html [ Crash Failure ] crbug.com/591099 http/tests/inspector/extensions/extensions-network.html [ Crash Failure ] -crbug.com/591099 http/tests/inspector/extensions/extensions-panel.html [ Crash ] +crbug.com/591099 http/tests/inspector/extensions/extensions-panel.html [ Crash Failure ] crbug.com/591099 http/tests/inspector/extensions/extensions-reload.html [ Failure ] crbug.com/591099 http/tests/inspector/extensions/extensions-resources.html [ Crash Failure ] -crbug.com/591099 http/tests/inspector/extensions/extensions-sidebar.html [ Crash ] -crbug.com/591099 http/tests/inspector/extensions/extensions-timeline-api.html [ Crash ] +crbug.com/591099 http/tests/inspector/extensions/extensions-sidebar.html [ Crash Failure ] +crbug.com/591099 http/tests/inspector/extensions/extensions-timeline-api.html [ Crash Failure ] crbug.com/591099 http/tests/inspector/extensions/multiple-extensions.html [ Failure ] -crbug.com/591099 http/tests/inspector/forced-layout-in-microtask.html [ Crash ] +crbug.com/591099 http/tests/inspector/forced-layout-in-microtask.html [ Crash Failure ] crbug.com/591099 http/tests/inspector/fragment.html [ Crash Failure ] crbug.com/591099 http/tests/inspector/indexeddb/database-data.html [ Failure ] crbug.com/591099 http/tests/inspector/indexeddb/database-names.html [ Failure ] -crbug.com/591099 http/tests/inspector/indexeddb/database-refresh-view.html [ Crash ] +crbug.com/591099 http/tests/inspector/indexeddb/database-refresh-view.html [ Crash Failure ] crbug.com/591099 http/tests/inspector/indexeddb/database-structure.html [ Failure ] crbug.com/591099 http/tests/inspector/indexeddb/resources-panel.html [ Failure ] crbug.com/591099 http/tests/inspector/indexeddb/transaction-promise-console.html [ Failure ] crbug.com/591099 http/tests/inspector/indexeddb/upgrade-events.html [ Failure ] crbug.com/591099 http/tests/inspector/inline-source-map-loading.html [ Crash Failure ] -crbug.com/591099 http/tests/inspector/inspect-element.html [ Crash ] -crbug.com/591099 http/tests/inspector/inspect-iframe-from-different-domain.html [ Crash ] -crbug.com/591099 http/tests/inspector/modify-cross-domain-rule.html [ Crash ] +crbug.com/591099 http/tests/inspector/inspect-element.html [ Crash Failure ] +crbug.com/591099 http/tests/inspector/inspect-iframe-from-different-domain.html [ Crash Failure ] +crbug.com/591099 http/tests/inspector/modify-cross-domain-rule.html [ Crash Failure ] crbug.com/591099 http/tests/inspector/network-preflight-options.html [ Crash Failure ] crbug.com/591099 http/tests/inspector/network/async-xhr-json-mime-type.html [ Crash Failure Timeout ] crbug.com/591099 http/tests/inspector/network/cached-resource-destroyed-moved-to-storage.html [ Crash Failure ] @@ -14865,7 +14873,7 @@ crbug.com/591099 http/tests/inspector/network/network-xsl-content.html [ Failure ] crbug.com/591099 http/tests/inspector/network/ping-response.html [ Crash Failure ] crbug.com/591099 http/tests/inspector/network/ping.html [ Failure ] -crbug.com/591099 http/tests/inspector/network/preview-searchable.html [ Crash ] +crbug.com/591099 http/tests/inspector/network/preview-searchable.html [ Crash Failure ] crbug.com/591099 http/tests/inspector/network/request-name-path.html [ Crash Failure ] crbug.com/591099 http/tests/inspector/network/request-parameters-decoding.html [ Crash Failure ] crbug.com/591099 http/tests/inspector/network/resource-priority.html [ Crash Failure ] @@ -14924,10 +14932,10 @@ crbug.com/591099 http/tests/inspector/search/search-in-resource.html [ Failure ] crbug.com/591099 http/tests/inspector/search/search-in-script.html [ Failure ] crbug.com/591099 http/tests/inspector/search/search-in-static.html [ Failure ] -crbug.com/591099 http/tests/inspector/search/source-frame-replace-1.html [ Crash ] -crbug.com/591099 http/tests/inspector/search/source-frame-replace-2.html [ Crash ] -crbug.com/591099 http/tests/inspector/search/source-frame-replace-3.html [ Crash ] -crbug.com/591099 http/tests/inspector/search/source-frame-replace-4.html [ Crash ] +crbug.com/591099 http/tests/inspector/search/source-frame-replace-1.html [ Crash Failure ] +crbug.com/591099 http/tests/inspector/search/source-frame-replace-2.html [ Crash Failure ] +crbug.com/591099 http/tests/inspector/search/source-frame-replace-3.html [ Crash Failure ] +crbug.com/591099 http/tests/inspector/search/source-frame-replace-4.html [ Crash Failure ] crbug.com/591099 http/tests/inspector/search/source-frame-search.html [ Failure ] crbug.com/591099 http/tests/inspector/search/sources-search-scope-in-files.html [ Failure ] crbug.com/591099 http/tests/inspector/search/sources-search-scope-many-projects.html [ Failure ] @@ -14960,19 +14968,19 @@ crbug.com/591099 http/tests/inspector/service-workers/service-workers-bypass-for-network-redirect.html [ Failure ] crbug.com/591099 http/tests/inspector/service-workers/service-workers-force-update-on-page-load.html [ Failure ] crbug.com/591099 http/tests/inspector/service-workers/service-workers-navigation-preload.html [ Failure ] -crbug.com/591099 http/tests/inspector/service-workers/service-workers-redundant.html [ Crash ] -crbug.com/591099 http/tests/inspector/service-workers/service-workers-view.html [ Crash ] +crbug.com/591099 http/tests/inspector/service-workers/service-workers-redundant.html [ Crash Failure ] +crbug.com/591099 http/tests/inspector/service-workers/service-workers-view.html [ Crash Failure ] crbug.com/591099 http/tests/inspector/service-workers/user-agent-override.html [ Failure Timeout ] crbug.com/591099 http/tests/inspector/sources/css-sourcemaps-toggle-enabled.html [ Failure ] crbug.com/591099 http/tests/inspector/sources/debugger/async-callstack-fetch.html [ Failure ] crbug.com/591099 http/tests/inspector/sources/debugger/async-callstack-network-initiator-image.html [ Failure ] crbug.com/591099 http/tests/inspector/sources/debugger/async-callstack-network-initiator.html [ Failure Timeout ] -crbug.com/591099 http/tests/inspector/sources/debugger/pause-in-removed-frame.html [ Crash ] +crbug.com/591099 http/tests/inspector/sources/debugger/pause-in-removed-frame.html [ Crash Failure ] crbug.com/591099 http/tests/inspector/sources/debugger/source-map-http-header.html [ Failure ] crbug.com/591099 http/tests/inspector/sources/debugger/worker-debugging-script-mapping.html [ Failure ] crbug.com/591099 http/tests/inspector/sources/debugger/worker-debugging.html [ Failure ] crbug.com/591099 http/tests/inspector/sources/event-listener-breakpoints-script-fst-stmt-for-module.html [ Failure Timeout ] -crbug.com/591099 http/tests/inspector/sources/inline-module-export-error.html [ Crash ] +crbug.com/591099 http/tests/inspector/sources/inline-module-export-error.html [ Crash Failure ] crbug.com/591099 http/tests/inspector/sources/js-sourcemaps-toggle-enabled.html [ Failure ] crbug.com/591099 http/tests/inspector/sources/navigator-view-content-scripts.html [ Failure ] crbug.com/591099 http/tests/inspector/sources/ui-source-code-highlight.php [ Failure ] @@ -14983,28 +14991,28 @@ crbug.com/591099 http/tests/inspector/stylesheet-source-mapping.html [ Crash Failure ] crbug.com/591099 http/tests/inspector/template-content-inspect-crash.html [ Crash Failure ] crbug.com/591099 http/tests/inspector/text-source-map.html [ Crash Failure ] -crbug.com/591099 http/tests/inspector/tracing/timeline-network-received-data.html [ Crash ] -crbug.com/591099 http/tests/inspector/tracing/timeline-receive-response-event.html [ Crash ] -crbug.com/591099 http/tests/inspector/tracing/timeline-script-parse.html [ Crash ] -crbug.com/591099 http/tests/inspector/tracing/timeline-xhr-event.html [ Crash ] -crbug.com/591099 http/tests/inspector/tracing/timeline-xhr-response-type-blob-event.html [ Crash Timeout ] -crbug.com/591099 http/tests/inspector/tracing/websocket/timeline-websocket-event.html [ Crash ] +crbug.com/591099 http/tests/inspector/tracing/timeline-network-received-data.html [ Crash Failure ] +crbug.com/591099 http/tests/inspector/tracing/timeline-receive-response-event.html [ Crash Failure ] +crbug.com/591099 http/tests/inspector/tracing/timeline-script-parse.html [ Crash Failure ] +crbug.com/591099 http/tests/inspector/tracing/timeline-xhr-event.html [ Crash Failure ] +crbug.com/591099 http/tests/inspector/tracing/timeline-xhr-response-type-blob-event.html [ Crash Failure Timeout ] +crbug.com/591099 http/tests/inspector/tracing/websocket/timeline-websocket-event.html [ Crash Failure ] crbug.com/591099 http/tests/inspector/websocket/network-preserve-selection-on-frame-receive.html [ Failure ] crbug.com/591099 http/tests/inspector/websocket/websocket-frame-error.html [ Failure ] crbug.com/591099 http/tests/inspector/websocket/websocket-frame.html [ Crash Failure ] crbug.com/591099 http/tests/inspector/websocket/websocket-handshake.html [ Failure ] crbug.com/591099 http/tests/inspector/workers-on-navigation.html [ Failure ] -crbug.com/591099 http/tests/intersection-observer/cross-origin-iframe-with-nesting.html [ Crash ] -crbug.com/591099 http/tests/intersection-observer/root-bounds.html [ Crash ] -crbug.com/591099 http/tests/linkHeader/link-preload-in-iframe.html [ Crash ] -crbug.com/591099 http/tests/loading/empty-content-disposition-type.html [ Crash ] +crbug.com/591099 http/tests/intersection-observer/cross-origin-iframe-with-nesting.html [ Crash Pass ] +crbug.com/591099 http/tests/intersection-observer/root-bounds.html [ Crash Pass ] +crbug.com/591099 http/tests/linkHeader/link-preload-in-iframe.html [ Crash Pass ] +crbug.com/591099 http/tests/loading/empty-content-disposition-type.html [ Crash Pass ] crbug.com/591099 http/tests/loading/fire-error-event-empty-404-script.html [ Failure ] crbug.com/591099 http/tests/loading/fire-error-event-script-no-content-type.html [ Failure ] -crbug.com/591099 http/tests/loading/image-picture-download-after-shrink.html [ Crash ] -crbug.com/591099 http/tests/loading/image-picture-no-download-after-picture-removal.html [ Crash ] -crbug.com/591099 http/tests/loading/image-picture-no-download-after-removal.html [ Crash ] -crbug.com/591099 http/tests/loading/image-picture-no-download-after-source-removal.html [ Crash ] -crbug.com/591099 http/tests/loading/nested_bad_objects.php [ Crash ] +crbug.com/591099 http/tests/loading/image-picture-download-after-shrink.html [ Crash Pass ] +crbug.com/591099 http/tests/loading/image-picture-no-download-after-picture-removal.html [ Crash Pass ] +crbug.com/591099 http/tests/loading/image-picture-no-download-after-removal.html [ Crash Pass ] +crbug.com/591099 http/tests/loading/image-picture-no-download-after-source-removal.html [ Crash Pass ] +crbug.com/591099 http/tests/loading/nested_bad_objects.php [ Crash Pass ] crbug.com/591099 http/tests/loading/preload-css-test.html [ Failure ] crbug.com/591099 http/tests/loading/preload-img-test.html [ Crash Failure ] crbug.com/591099 http/tests/loading/preload-picture-invalid.html [ Crash Failure ] @@ -15023,109 +15031,109 @@ crbug.com/591099 http/tests/local/fileapi/send-sliced-dragged-file.html [ Crash Failure ] crbug.com/591099 http/tests/local/formdata/send-form-data-with-bad-string.html [ Failure ] crbug.com/591099 http/tests/local/formdata/send-form-data-with-empty-blob-filename.html [ Failure ] -crbug.com/591099 http/tests/local/formdata/send-form-data-with-empty-file-filename.html [ Crash ] +crbug.com/591099 http/tests/local/formdata/send-form-data-with-empty-file-filename.html [ Crash Failure ] crbug.com/591099 http/tests/local/formdata/send-form-data-with-empty-name.html [ Failure ] -crbug.com/591099 http/tests/local/formdata/send-form-data-with-filename.html [ Crash Timeout ] +crbug.com/591099 http/tests/local/formdata/send-form-data-with-filename.html [ Crash Failure Timeout ] crbug.com/591099 http/tests/local/formdata/send-form-data-with-null-string.html [ Failure ] -crbug.com/591099 http/tests/local/formdata/send-form-data-with-sliced-file.html [ Crash ] +crbug.com/591099 http/tests/local/formdata/send-form-data-with-sliced-file.html [ Crash Failure ] crbug.com/591099 http/tests/local/formdata/send-form-data-with-string-containing-null.html [ Failure ] crbug.com/591099 http/tests/local/formdata/send-form-data.html [ Crash Failure ] -crbug.com/591099 http/tests/local/formdata/upload-events.html [ Crash ] +crbug.com/591099 http/tests/local/formdata/upload-events.html [ Crash Failure ] crbug.com/591099 http/tests/local/link-stylesheet-preferred.html [ Failure ] -crbug.com/591099 http/tests/local/serviceworker/fetch-request-body-file.html [ Crash ] +crbug.com/591099 http/tests/local/serviceworker/fetch-request-body-file.html [ Crash Pass ] crbug.com/591099 http/tests/local/stylesheet-and-script-load-order-http.html [ Failure ] crbug.com/591099 http/tests/local/stylesheet-and-script-load-order-media-print.html [ Failure ] crbug.com/591099 http/tests/local/stylesheet-and-script-load-order.html [ Failure ] -crbug.com/591099 http/tests/media/autoplay-crossorigin.html [ Crash ] -crbug.com/591099 http/tests/media/controls/controls-list-add-hide.html [ Crash ] -crbug.com/591099 http/tests/media/controls/controls-list-remove-show.html [ Crash ] -crbug.com/591099 http/tests/media/controls/video-controls-overflow-menu-correct-ordering.html [ Crash ] -crbug.com/591099 http/tests/media/controls/video-controls-overflow-menu-updates-appropriately.html [ Crash ] -crbug.com/591099 http/tests/media/encrypted-media/encrypted-media-encrypted-event-different-origin.html [ Crash ] -crbug.com/591099 http/tests/media/encrypted-media/encrypted-media-encrypted-event-same-origin.html [ Crash ] -crbug.com/591099 http/tests/media/media-source/mediasource-addsourcebuffer.html [ Crash ] -crbug.com/591099 http/tests/media/media-source/mediasource-append-buffer.html [ Crash ] -crbug.com/591099 http/tests/media/media-source/mediasource-appendwindow.html [ Crash ] -crbug.com/591099 http/tests/media/media-source/mediasource-avtracks.html [ Crash ] -crbug.com/591099 http/tests/media/media-source/mediasource-buffered.html [ Crash ] -crbug.com/591099 http/tests/media/media-source/mediasource-closed.html [ Crash ] -crbug.com/591099 http/tests/media/media-source/mediasource-config-change-mp4-a-bitrate.html [ Crash ] -crbug.com/591099 http/tests/media/media-source/mediasource-config-change-mp4-av-audio-bitrate.html [ Crash ] -crbug.com/591099 http/tests/media/media-source/mediasource-config-change-mp4-av-framesize.html [ Crash ] -crbug.com/591099 http/tests/media/media-source/mediasource-config-change-mp4-av-video-bitrate.html [ Crash ] -crbug.com/591099 http/tests/media/media-source/mediasource-config-change-mp4-v-bitrate.html [ Crash ] -crbug.com/591099 http/tests/media/media-source/mediasource-config-change-mp4-v-framerate.html [ Crash ] -crbug.com/591099 http/tests/media/media-source/mediasource-config-change-mp4-v-framesize.html [ Crash ] -crbug.com/591099 http/tests/media/media-source/mediasource-config-change-webm-a-bitrate.html [ Crash ] -crbug.com/591099 http/tests/media/media-source/mediasource-config-change-webm-av-audio-bitrate.html [ Crash ] -crbug.com/591099 http/tests/media/media-source/mediasource-config-change-webm-av-framesize.html [ Crash ] -crbug.com/591099 http/tests/media/media-source/mediasource-config-change-webm-av-video-bitrate.html [ Crash ] -crbug.com/591099 http/tests/media/media-source/mediasource-config-change-webm-v-bitrate.html [ Crash ] -crbug.com/591099 http/tests/media/media-source/mediasource-config-change-webm-v-framerate.html [ Crash ] -crbug.com/591099 http/tests/media/media-source/mediasource-config-change-webm-v-framesize.html [ Crash ] -crbug.com/591099 http/tests/media/media-source/mediasource-detach.html [ Crash ] -crbug.com/591099 http/tests/media/media-source/mediasource-duration-boundaryconditions.html [ Crash ] -crbug.com/591099 http/tests/media/media-source/mediasource-duration.html [ Crash ] -crbug.com/591099 http/tests/media/media-source/mediasource-endofstream-invaliderror.html [ Crash ] -crbug.com/591099 http/tests/media/media-source/mediasource-errors.html [ Crash ] -crbug.com/591099 http/tests/media/media-source/mediasource-garbage-collection-before-sourceopen.html [ Crash ] -crbug.com/591099 http/tests/media/media-source/mediasource-gc-after-decode-error-crash.html [ Crash ] -crbug.com/591099 http/tests/media/media-source/mediasource-getvideoplaybackquality.html [ Crash ] -crbug.com/591099 http/tests/media/media-source/mediasource-initsegmentreceived-alg.html [ Crash ] -crbug.com/591099 http/tests/media/media-source/mediasource-multiple-attach.html [ Crash ] -crbug.com/591099 http/tests/media/media-source/mediasource-play-then-seek-back.html [ Crash ] -crbug.com/591099 http/tests/media/media-source/mediasource-play.html [ Crash ] -crbug.com/591099 http/tests/media/media-source/mediasource-precise-duration.html [ Crash ] -crbug.com/591099 http/tests/media/media-source/mediasource-preload.html [ Crash ] -crbug.com/591099 http/tests/media/media-source/mediasource-redundant-seek.html [ Crash ] -crbug.com/591099 http/tests/media/media-source/mediasource-remove.html [ Crash ] -crbug.com/591099 http/tests/media/media-source/mediasource-removesourcebuffer.html [ Crash ] -crbug.com/591099 http/tests/media/media-source/mediasource-seek-beyond-duration.html [ Crash ] -crbug.com/591099 http/tests/media/media-source/mediasource-seek-during-pending-seek.html [ Crash ] -crbug.com/591099 http/tests/media/media-source/mediasource-seekable.html [ Crash ] -crbug.com/591099 http/tests/media/media-source/mediasource-sequencemode-append-buffer.html [ Crash ] -crbug.com/591099 http/tests/media/media-source/mediasource-sequencemode-crbug-616565.html [ Crash ] -crbug.com/591099 http/tests/media/media-source/mediasource-sourcebuffer-mode.html [ Crash ] -crbug.com/591099 http/tests/media/media-source/mediasource-sourcebuffer-trackdefaults.html [ Crash ] -crbug.com/591099 http/tests/media/media-source/mediasource-sourcebufferlist-crash.html [ Crash ] -crbug.com/591099 http/tests/media/media-source/mediasource-sourcebufferlist.html [ Crash ] -crbug.com/591099 http/tests/media/media-source/mediasource-timestamp-offset.html [ Crash ] -crbug.com/591099 http/tests/media/media-source/stream_memory_tests/mediasource-appendbuffer-quota-exceeded-default-buffers.html [ Crash ] -crbug.com/591099 http/tests/media/pdf-served-as-pdf.html [ Crash ] -crbug.com/591099 http/tests/media/progress-events-generated-correctly.html [ Crash ] -crbug.com/591099 http/tests/media/reload-after-dialog.html [ Crash ] -crbug.com/591099 http/tests/media/remove-while-loading.html [ Crash ] -crbug.com/591099 http/tests/media/text-served-as-text.html [ Crash ] +crbug.com/591099 http/tests/media/autoplay-crossorigin.html [ Crash Pass ] +crbug.com/591099 http/tests/media/controls/controls-list-add-hide.html [ Crash Pass ] +crbug.com/591099 http/tests/media/controls/controls-list-remove-show.html [ Crash Pass ] +crbug.com/591099 http/tests/media/controls/video-controls-overflow-menu-correct-ordering.html [ Crash Pass ] +crbug.com/591099 http/tests/media/controls/video-controls-overflow-menu-updates-appropriately.html [ Crash Pass ] +crbug.com/591099 http/tests/media/encrypted-media/encrypted-media-encrypted-event-different-origin.html [ Crash Pass ] +crbug.com/591099 http/tests/media/encrypted-media/encrypted-media-encrypted-event-same-origin.html [ Crash Pass ] +crbug.com/591099 http/tests/media/media-source/mediasource-addsourcebuffer.html [ Crash Pass ] +crbug.com/591099 http/tests/media/media-source/mediasource-append-buffer.html [ Crash Pass ] +crbug.com/591099 http/tests/media/media-source/mediasource-appendwindow.html [ Crash Pass ] +crbug.com/591099 http/tests/media/media-source/mediasource-avtracks.html [ Crash Pass ] +crbug.com/591099 http/tests/media/media-source/mediasource-buffered.html [ Crash Pass ] +crbug.com/591099 http/tests/media/media-source/mediasource-closed.html [ Crash Pass ] +crbug.com/591099 http/tests/media/media-source/mediasource-config-change-mp4-a-bitrate.html [ Crash Pass ] +crbug.com/591099 http/tests/media/media-source/mediasource-config-change-mp4-av-audio-bitrate.html [ Crash Pass ] +crbug.com/591099 http/tests/media/media-source/mediasource-config-change-mp4-av-framesize.html [ Crash Pass ] +crbug.com/591099 http/tests/media/media-source/mediasource-config-change-mp4-av-video-bitrate.html [ Crash Pass ] +crbug.com/591099 http/tests/media/media-source/mediasource-config-change-mp4-v-bitrate.html [ Crash Pass ] +crbug.com/591099 http/tests/media/media-source/mediasource-config-change-mp4-v-framerate.html [ Crash Pass ] +crbug.com/591099 http/tests/media/media-source/mediasource-config-change-mp4-v-framesize.html [ Crash Pass ] +crbug.com/591099 http/tests/media/media-source/mediasource-config-change-webm-a-bitrate.html [ Crash Pass ] +crbug.com/591099 http/tests/media/media-source/mediasource-config-change-webm-av-audio-bitrate.html [ Crash Pass ] +crbug.com/591099 http/tests/media/media-source/mediasource-config-change-webm-av-framesize.html [ Crash Pass ] +crbug.com/591099 http/tests/media/media-source/mediasource-config-change-webm-av-video-bitrate.html [ Crash Pass ] +crbug.com/591099 http/tests/media/media-source/mediasource-config-change-webm-v-bitrate.html [ Crash Pass ] +crbug.com/591099 http/tests/media/media-source/mediasource-config-change-webm-v-framerate.html [ Crash Pass ] +crbug.com/591099 http/tests/media/media-source/mediasource-config-change-webm-v-framesize.html [ Crash Pass ] +crbug.com/591099 http/tests/media/media-source/mediasource-detach.html [ Crash Pass ] +crbug.com/591099 http/tests/media/media-source/mediasource-duration-boundaryconditions.html [ Crash Pass ] +crbug.com/591099 http/tests/media/media-source/mediasource-duration.html [ Crash Pass ] +crbug.com/591099 http/tests/media/media-source/mediasource-endofstream-invaliderror.html [ Crash Pass ] +crbug.com/591099 http/tests/media/media-source/mediasource-errors.html [ Crash Pass ] +crbug.com/591099 http/tests/media/media-source/mediasource-garbage-collection-before-sourceopen.html [ Crash Pass ] +crbug.com/591099 http/tests/media/media-source/mediasource-gc-after-decode-error-crash.html [ Crash Pass ] +crbug.com/591099 http/tests/media/media-source/mediasource-getvideoplaybackquality.html [ Crash Pass ] +crbug.com/591099 http/tests/media/media-source/mediasource-initsegmentreceived-alg.html [ Crash Pass ] +crbug.com/591099 http/tests/media/media-source/mediasource-multiple-attach.html [ Crash Pass ] +crbug.com/591099 http/tests/media/media-source/mediasource-play-then-seek-back.html [ Crash Pass ] +crbug.com/591099 http/tests/media/media-source/mediasource-play.html [ Crash Pass ] +crbug.com/591099 http/tests/media/media-source/mediasource-precise-duration.html [ Crash Pass ] +crbug.com/591099 http/tests/media/media-source/mediasource-preload.html [ Crash Pass ] +crbug.com/591099 http/tests/media/media-source/mediasource-redundant-seek.html [ Crash Pass ] +crbug.com/591099 http/tests/media/media-source/mediasource-remove.html [ Crash Pass ] +crbug.com/591099 http/tests/media/media-source/mediasource-removesourcebuffer.html [ Crash Pass ] +crbug.com/591099 http/tests/media/media-source/mediasource-seek-beyond-duration.html [ Crash Pass ] +crbug.com/591099 http/tests/media/media-source/mediasource-seek-during-pending-seek.html [ Crash Pass ] +crbug.com/591099 http/tests/media/media-source/mediasource-seekable.html [ Crash Pass ] +crbug.com/591099 http/tests/media/media-source/mediasource-sequencemode-append-buffer.html [ Crash Pass ] +crbug.com/591099 http/tests/media/media-source/mediasource-sequencemode-crbug-616565.html [ Crash Pass ] +crbug.com/591099 http/tests/media/media-source/mediasource-sourcebuffer-mode.html [ Crash Pass ] +crbug.com/591099 http/tests/media/media-source/mediasource-sourcebuffer-trackdefaults.html [ Crash Pass ] +crbug.com/591099 http/tests/media/media-source/mediasource-sourcebufferlist-crash.html [ Crash Pass ] +crbug.com/591099 http/tests/media/media-source/mediasource-sourcebufferlist.html [ Crash Pass ] +crbug.com/591099 http/tests/media/media-source/mediasource-timestamp-offset.html [ Crash Pass ] +crbug.com/591099 http/tests/media/media-source/stream_memory_tests/mediasource-appendbuffer-quota-exceeded-default-buffers.html [ Crash Pass ] +crbug.com/591099 http/tests/media/pdf-served-as-pdf.html [ Crash Pass ] +crbug.com/591099 http/tests/media/progress-events-generated-correctly.html [ Crash Pass ] +crbug.com/591099 http/tests/media/reload-after-dialog.html [ Crash Pass ] +crbug.com/591099 http/tests/media/remove-while-loading.html [ Crash Pass ] +crbug.com/591099 http/tests/media/text-served-as-text.html [ Crash Pass ] crbug.com/591099 http/tests/media/video-buffered-range-contains-currentTime.html [ Failure Pass ] -crbug.com/591099 http/tests/media/video-buffered.html [ Crash ] -crbug.com/591099 http/tests/media/video-controls-download-button-displayed.html [ Crash ] -crbug.com/591099 http/tests/media/video-controls-download-button-not-displayed-hide-download-ui.html [ Crash ] -crbug.com/591099 http/tests/media/video-controls-download-button-not-displayed-mediastream.html [ Crash ] -crbug.com/591099 http/tests/media/video-controls-download-button-not-displayed-mse.html [ Crash ] -crbug.com/591099 http/tests/media/video-cookie.html [ Crash ] -crbug.com/591099 http/tests/media/video-error-abort.html [ Crash ] +crbug.com/591099 http/tests/media/video-buffered.html [ Crash Pass ] +crbug.com/591099 http/tests/media/video-controls-download-button-displayed.html [ Crash Pass ] +crbug.com/591099 http/tests/media/video-controls-download-button-not-displayed-hide-download-ui.html [ Crash Pass ] +crbug.com/591099 http/tests/media/video-controls-download-button-not-displayed-mediastream.html [ Crash Pass ] +crbug.com/591099 http/tests/media/video-controls-download-button-not-displayed-mse.html [ Crash Pass ] +crbug.com/591099 http/tests/media/video-cookie.html [ Crash Pass ] +crbug.com/591099 http/tests/media/video-error-abort.html [ Crash Pass ] crbug.com/591099 http/tests/media/video-in-iframe-crash.html [ Crash Pass ] -crbug.com/591099 http/tests/media/video-load-metadata-decode-error.html [ Crash ] -crbug.com/591099 http/tests/media/video-load-suspend.html [ Crash ] -crbug.com/591099 http/tests/media/video-load-with-userpass.html [ Crash ] -crbug.com/591099 http/tests/media/video-play-progress.html [ Crash ] -crbug.com/591099 http/tests/media/video-play-stall-before-meta-data.html [ Crash ] +crbug.com/591099 http/tests/media/video-load-metadata-decode-error.html [ Crash Pass ] +crbug.com/591099 http/tests/media/video-load-suspend.html [ Crash Pass ] +crbug.com/591099 http/tests/media/video-load-with-userpass.html [ Crash Pass ] +crbug.com/591099 http/tests/media/video-play-progress.html [ Crash Pass ] +crbug.com/591099 http/tests/media/video-play-stall-before-meta-data.html [ Crash Pass ] crbug.com/591099 http/tests/media/video-play-stall.html [ Crash Timeout ] -crbug.com/591099 http/tests/media/video-query-url.html [ Crash ] -crbug.com/591099 http/tests/media/video-referer.html [ Crash ] -crbug.com/591099 http/tests/media/video-seek-to-duration.html [ Crash ] -crbug.com/591099 http/tests/media/video-seek-to-middle.html [ Crash ] -crbug.com/591099 http/tests/media/video-served-as-text.html [ Crash ] -crbug.com/591099 http/tests/media/video-throttled-load-metadata.html [ Crash ] -crbug.com/591099 http/tests/media/video-useragent.html [ Crash ] +crbug.com/591099 http/tests/media/video-query-url.html [ Crash Pass ] +crbug.com/591099 http/tests/media/video-referer.html [ Crash Pass ] +crbug.com/591099 http/tests/media/video-seek-to-duration.html [ Crash Pass ] +crbug.com/591099 http/tests/media/video-seek-to-middle.html [ Crash Pass ] +crbug.com/591099 http/tests/media/video-served-as-text.html [ Crash Pass ] +crbug.com/591099 http/tests/media/video-throttled-load-metadata.html [ Crash Pass ] +crbug.com/591099 http/tests/media/video-useragent.html [ Crash Pass ] crbug.com/591099 http/tests/mime/quoted-charset.php [ Failure ] -crbug.com/591099 http/tests/mime/reload-subresource-when-type-changes.html [ Crash ] +crbug.com/591099 http/tests/mime/reload-subresource-when-type-changes.html [ Crash Pass ] crbug.com/591099 http/tests/misc/BOM-override-script.html [ Failure ] crbug.com/591099 http/tests/misc/DOMContentLoaded-event.html [ Crash Failure ] -crbug.com/591099 http/tests/misc/acid2-pixel.html [ Crash ] -crbug.com/591099 http/tests/misc/acid2.html [ Crash ] +crbug.com/591099 http/tests/misc/acid2-pixel.html [ Crash Failure ] +crbug.com/591099 http/tests/misc/acid2.html [ Crash Failure ] crbug.com/591099 http/tests/misc/acid3.html [ Crash Failure ] -crbug.com/591099 http/tests/misc/adopt-iframe-src-attr-after-remove.html [ Crash ] +crbug.com/591099 http/tests/misc/adopt-iframe-src-attr-after-remove.html [ Crash Pass ] crbug.com/591099 http/tests/misc/async-script-removed.html [ Failure ] crbug.com/591099 http/tests/misc/async-script.html [ Failure ] crbug.com/591099 http/tests/misc/bad-charset-alias.html [ Failure ] @@ -15140,23 +15148,23 @@ crbug.com/591099 http/tests/misc/char-encoding-in-hidden-charset-field-with-one-field.html [ Failure ] crbug.com/591099 http/tests/misc/char-encoding-in-text-charset-field-with-value.html [ Crash Failure ] crbug.com/591099 http/tests/misc/char-encoding-without-charset-field.html [ Crash Failure ] -crbug.com/591099 http/tests/misc/client-hint-accept-on-subresource.html [ Crash ] -crbug.com/591099 http/tests/misc/client-hints-accept-iframe.html [ Crash ] -crbug.com/591099 http/tests/misc/client-hints-accept-meta.html [ Crash ] -crbug.com/591099 http/tests/misc/client-hints-accept-parent.php [ Crash ] -crbug.com/591099 http/tests/misc/client-hints-accept.php [ Crash ] -crbug.com/591099 http/tests/misc/client-hints-dynamic-rw-sizes.html [ Crash ] -crbug.com/591099 http/tests/misc/client-hints-invalid-accept.php [ Crash ] -crbug.com/591099 http/tests/misc/client-hints-no-accept.html [ Crash ] -crbug.com/591099 http/tests/misc/client-hints-picture-source-removal.html [ Crash ] -crbug.com/591099 http/tests/misc/client-hints-picture.html [ Crash ] -crbug.com/591099 http/tests/misc/client-hints-preload-rw-sizes.html [ Crash ] +crbug.com/591099 http/tests/misc/client-hint-accept-on-subresource.html [ Crash Pass ] +crbug.com/591099 http/tests/misc/client-hints-accept-iframe.html [ Crash Pass ] +crbug.com/591099 http/tests/misc/client-hints-accept-meta.html [ Crash Pass ] +crbug.com/591099 http/tests/misc/client-hints-accept-parent.php [ Crash Pass ] +crbug.com/591099 http/tests/misc/client-hints-accept.php [ Crash Pass ] +crbug.com/591099 http/tests/misc/client-hints-dynamic-rw-sizes.html [ Crash Pass ] +crbug.com/591099 http/tests/misc/client-hints-invalid-accept.php [ Crash Pass ] +crbug.com/591099 http/tests/misc/client-hints-no-accept.html [ Crash Pass ] +crbug.com/591099 http/tests/misc/client-hints-picture-source-removal.html [ Crash Pass ] +crbug.com/591099 http/tests/misc/client-hints-picture.html [ Crash Pass ] +crbug.com/591099 http/tests/misc/client-hints-preload-rw-sizes.html [ Crash Pass ] crbug.com/591099 http/tests/misc/copy-resolves-urls.html [ Failure ] crbug.com/591099 http/tests/misc/crash-multiple-family-fontface.html [ Failure ] crbug.com/591099 http/tests/misc/css-reject-any-type-in-strict-mode.html [ Failure ] -crbug.com/591099 http/tests/misc/delete-frame-during-readystatechange-with-gc-after-video-removal.html [ Crash ] -crbug.com/591099 http/tests/misc/delete-frame-during-readystatechange.html [ Crash ] -crbug.com/591099 http/tests/misc/detach-during-notifyDone.html [ Crash ] +crbug.com/591099 http/tests/misc/delete-frame-during-readystatechange-with-gc-after-video-removal.html [ Crash Pass ] +crbug.com/591099 http/tests/misc/delete-frame-during-readystatechange.html [ Crash Pass ] +crbug.com/591099 http/tests/misc/detach-during-notifyDone.html [ Crash Pass ] crbug.com/591099 http/tests/misc/dns-prefetch-control.html [ Crash Failure ] crbug.com/591099 http/tests/misc/drag-over-iframe-invalid-source-crash.html [ Crash Failure ] crbug.com/591099 http/tests/misc/embed-image-load-outlives-gc-without-crashing.html [ Crash Pass ] @@ -15170,13 +15178,13 @@ crbug.com/591099 http/tests/misc/extract-http-content-language.php [ Failure ] crbug.com/591099 http/tests/misc/favicon-as-image.html [ Failure ] crbug.com/591099 http/tests/misc/font-face-in-multiple-segmented-faces.html [ Crash Failure ] -crbug.com/591099 http/tests/misc/form-action-using-replaceChild.html [ Crash ] +crbug.com/591099 http/tests/misc/form-action-using-replaceChild.html [ Crash Pass ] crbug.com/591099 http/tests/misc/form-post-textplain.html [ Failure ] crbug.com/591099 http/tests/misc/frame-access-during-load.html [ Failure ] crbug.com/591099 http/tests/misc/generated-content-inside-table.html [ Failure ] crbug.com/591099 http/tests/misc/gmail-assert-on-load.html [ Failure ] crbug.com/591099 http/tests/misc/iframe-reparenting-id-collision.html [ Failure ] -crbug.com/591099 http/tests/misc/iframe404.html [ Crash ] +crbug.com/591099 http/tests/misc/iframe404.html [ Crash Failure ] crbug.com/591099 http/tests/misc/image-blocked-src-change.html [ Crash Failure ] crbug.com/591099 http/tests/misc/image-blocked-src-no-change.html [ Crash Failure ] crbug.com/591099 http/tests/misc/image-input-type-outlives-gc-without-crashing.html [ Crash Pass ] @@ -15190,13 +15198,13 @@ crbug.com/591099 http/tests/misc/object-image-error-with-onload.html [ Crash Failure ] crbug.com/591099 http/tests/misc/object-image-error.html [ Crash Failure ] crbug.com/591099 http/tests/misc/object-image-load-outlives-gc-without-crashing.html [ Crash Pass ] -crbug.com/591099 http/tests/misc/onload-remove-iframe-crash-2.html [ Crash ] +crbug.com/591099 http/tests/misc/onload-remove-iframe-crash-2.html [ Crash Pass ] crbug.com/591099 http/tests/misc/percent-sign-in-form-field-name.html [ Crash Failure ] -crbug.com/591099 http/tests/misc/plugin-array-detach.html [ Crash ] +crbug.com/591099 http/tests/misc/plugin-array-detach.html [ Crash Pass ] crbug.com/591099 http/tests/misc/refresh-headers.php [ Failure ] crbug.com/591099 http/tests/misc/resource-timing-iframe-restored-from-history.html [ Failure ] -crbug.com/591099 http/tests/misc/resource-timing-sizes-multipart.html [ Crash ] -crbug.com/591099 http/tests/misc/resource-timing-sizes-tags.html [ Crash ] +crbug.com/591099 http/tests/misc/resource-timing-sizes-multipart.html [ Crash Pass ] +crbug.com/591099 http/tests/misc/resource-timing-sizes-tags.html [ Crash Pass ] crbug.com/591099 http/tests/misc/script-after-slow-stylesheet-removed.html [ Crash Failure ] crbug.com/591099 http/tests/misc/script-defer-after-slow-stylesheet.html [ Failure ] crbug.com/591099 http/tests/misc/script-sync-slow-scripts-onerror.html [ Failure ] @@ -15223,11 +15231,11 @@ crbug.com/591099 http/tests/misc/webtiming-resolution.html [ Failure ] crbug.com/591099 http/tests/misc/webtiming-slow-load.php [ Failure ] crbug.com/591099 http/tests/misc/webtiming-two-redirects.php [ Failure ] -crbug.com/591099 http/tests/misc/xslt-bad-import.html [ Crash ] +crbug.com/591099 http/tests/misc/xslt-bad-import.html [ Crash Pass ] crbug.com/591099 http/tests/multipart/stop-crash.html [ Failure ] -crbug.com/591099 http/tests/multipart/stop-loading-after-onload1.html [ Crash ] -crbug.com/591099 http/tests/multipart/stop-loading-after-onload2.html [ Crash ] -crbug.com/591099 http/tests/multipart/stop-loading.html [ Crash ] +crbug.com/591099 http/tests/multipart/stop-loading-after-onload1.html [ Crash Pass ] +crbug.com/591099 http/tests/multipart/stop-loading-after-onload2.html [ Crash Pass ] +crbug.com/591099 http/tests/multipart/stop-loading.html [ Crash Pass ] crbug.com/591099 http/tests/navigation/anchor-basic.html [ Crash Failure ] crbug.com/591099 http/tests/navigation/anchor-frames-cross-origin.html [ Failure ] crbug.com/591099 http/tests/navigation/anchor-frames-gbk.html [ Failure ] @@ -15236,20 +15244,20 @@ crbug.com/591099 http/tests/navigation/anchor-goback.html [ Crash Failure ] crbug.com/591099 http/tests/navigation/back-to-slow-frame.html [ Failure ] crbug.com/591099 http/tests/navigation/cross-origin-fragment-navigation-is-async.html [ Failure ] -crbug.com/591099 http/tests/navigation/fallback-anchor-reload.html [ Crash ] +crbug.com/591099 http/tests/navigation/fallback-anchor-reload.html [ Crash Pass ] crbug.com/591099 http/tests/navigation/form-targets-cross-site-frame-get.html [ Crash Failure ] crbug.com/591099 http/tests/navigation/form-targets-cross-site-frame-no-referrer.html [ Crash Failure ] crbug.com/591099 http/tests/navigation/form-targets-cross-site-frame-post.html [ Crash Failure ] crbug.com/591099 http/tests/navigation/form-with-enctype-targets-cross-site-frame.html [ Crash Failure ] crbug.com/591099 http/tests/navigation/forward-to-fragment-fires-onload.html [ Crash Failure ] crbug.com/591099 http/tests/navigation/history-back-across-form-submission-to-fragment.html [ Failure ] -crbug.com/591099 http/tests/navigation/image-load-in-subframe-unload-handler.html [ Crash ] +crbug.com/591099 http/tests/navigation/image-load-in-subframe-unload-handler.html [ Crash Pass ] crbug.com/591099 http/tests/navigation/javascriptlink-basic.html [ Crash Failure Timeout ] crbug.com/591099 http/tests/navigation/javascriptlink-goback.html [ Crash Failure Timeout ] crbug.com/591099 http/tests/navigation/lockedhistory-iframe.html [ Failure ] crbug.com/591099 http/tests/navigation/metaredirect-basic.html [ Crash Failure ] crbug.com/591099 http/tests/navigation/metaredirect-goback.html [ Crash Failure ] -crbug.com/591099 http/tests/navigation/navigate-during-commit.html [ Crash ] +crbug.com/591099 http/tests/navigation/navigate-during-commit.html [ Crash Pass ] crbug.com/591099 http/tests/navigation/navigation-with-detached-origin-document.html [ Crash Pass ] crbug.com/591099 http/tests/navigation/no-referrer-reset.html [ Failure Timeout ] crbug.com/591099 http/tests/navigation/onload-navigation-iframe-2.html [ Failure ] @@ -15282,7 +15290,7 @@ crbug.com/591099 http/tests/navigation/success200-goback.html [ Crash Failure ] crbug.com/591099 http/tests/navigation/success200-loadsame.html [ Crash Failure ] crbug.com/591099 http/tests/navigation/success200-reload.html [ Crash Failure ] -crbug.com/591099 http/tests/navigation/targeted-navigation-in-unload-handler.html [ Crash ] +crbug.com/591099 http/tests/navigation/targeted-navigation-in-unload-handler.html [ Crash Pass ] crbug.com/591099 http/tests/navigation/timerredirect-basic.html [ Crash Failure ] crbug.com/591099 http/tests/navigation/timerredirect-goback.html [ Crash Failure ] crbug.com/591099 http/tests/navigation/useragent.php [ Failure ] @@ -15290,7 +15298,7 @@ crbug.com/591099 http/tests/navigatorcontentutils/register-protocol-handler.html [ Failure ] crbug.com/591099 http/tests/navigatorcontentutils/unregister-protocol-handler.html [ Failure ] crbug.com/591099 http/tests/notifications/notification-sandbox-permission.html [ Failure ] -crbug.com/591099 http/tests/performance-timing/paint-timing/first-contentful-canvas.html [ Crash ] +crbug.com/591099 http/tests/performance-timing/paint-timing/first-contentful-canvas.html [ Crash Pass ] crbug.com/591099 http/tests/permissionclient/image-permissions.html [ Failure ] crbug.com/591099 http/tests/plugins/navigator-plugins-in-cross-origin-frame.html [ Failure Pass ] crbug.com/591099 http/tests/pointer-lock/iframe-sandboxed-allow-pointer-lock.html [ Failure ] @@ -15301,14 +15309,14 @@ crbug.com/591099 http/tests/pointer-lock/pointerlockelement-same-origin.html [ Failure ] crbug.com/591099 http/tests/pointer-lock/requestPointerLock-can-not-transfer-between-documents.html [ Failure ] crbug.com/591099 http/tests/preload/dynamic_remove_preload_href.html [ Failure Pass ] -crbug.com/591099 http/tests/preload/multiple-meta-csp.html [ Crash ] -crbug.com/591099 http/tests/preload/preload-video-cors.html [ Crash ] +crbug.com/591099 http/tests/preload/multiple-meta-csp.html [ Crash Pass ] +crbug.com/591099 http/tests/preload/preload-video-cors.html [ Crash Pass ] crbug.com/591099 http/tests/previews/client-lofi-sprite.html [ Failure ] crbug.com/591099 http/tests/security/MessagePort/event-listener-context.html [ Failure ] crbug.com/591099 http/tests/security/XFrameOptions/x-frame-options-cached.html [ Failure ] -crbug.com/591099 http/tests/security/XFrameOptions/x-frame-options-deny-delete-frame-in-load-event.html [ Crash ] -crbug.com/591099 http/tests/security/aboutBlank/security-context-alias.html [ Crash ] -crbug.com/591099 http/tests/security/aboutBlank/security-context-grandchildren-alias.html [ Crash ] +crbug.com/591099 http/tests/security/XFrameOptions/x-frame-options-deny-delete-frame-in-load-event.html [ Crash Pass ] +crbug.com/591099 http/tests/security/aboutBlank/security-context-alias.html [ Crash Pass ] +crbug.com/591099 http/tests/security/aboutBlank/security-context-grandchildren-alias.html [ Crash Pass ] crbug.com/591099 http/tests/security/anchor-download-allow-blob.html [ Failure ] crbug.com/591099 http/tests/security/anchor-download-allow-data.html [ Failure ] crbug.com/591099 http/tests/security/anchor-download-allow-sameorigin.html [ Failure ] @@ -15316,13 +15324,13 @@ crbug.com/591099 http/tests/security/cannot-read-cssrules-redirect.html [ Failure ] crbug.com/591099 http/tests/security/cannot-read-cssrules.html [ Failure ] crbug.com/591099 http/tests/security/canvas-remote-read-redirect-to-remote-image.html [ Failure ] -crbug.com/591099 http/tests/security/canvas-remote-read-remote-svg-image.html [ Crash ] +crbug.com/591099 http/tests/security/canvas-remote-read-remote-svg-image.html [ Crash Pass ] crbug.com/591099 http/tests/security/clipboard/clipboard-file-access.html [ Failure Timeout ] crbug.com/591099 http/tests/security/contentSecurityPolicy/1.1/form-action-blocked-when-target-blank.html [ Crash Failure ] crbug.com/591099 http/tests/security/contentSecurityPolicy/1.1/form-action-blocked-when-target-cross-site-window.html [ Crash Failure ] crbug.com/591099 http/tests/security/contentSecurityPolicy/1.1/form-action-leak-path-on-redirect.html [ Crash Failure ] -crbug.com/591099 http/tests/security/contentSecurityPolicy/1.1/form-action-resubmission-iframe-reload-from-child.html [ Crash ] -crbug.com/591099 http/tests/security/contentSecurityPolicy/1.1/form-action-resubmission-iframe-reload-from-parent.html [ Crash ] +crbug.com/591099 http/tests/security/contentSecurityPolicy/1.1/form-action-resubmission-iframe-reload-from-child.html [ Crash Pass ] +crbug.com/591099 http/tests/security/contentSecurityPolicy/1.1/form-action-resubmission-iframe-reload-from-parent.html [ Crash Pass ] crbug.com/591099 http/tests/security/contentSecurityPolicy/1.1/form-action-src-allowed-with-redirect.html [ Crash Failure ] crbug.com/591099 http/tests/security/contentSecurityPolicy/1.1/form-action-src-allowed.html [ Crash Failure ] crbug.com/591099 http/tests/security/contentSecurityPolicy/1.1/form-action-src-blocked.html [ Crash Failure ] @@ -15333,7 +15341,7 @@ crbug.com/591099 http/tests/security/contentSecurityPolicy/1.1/form-action-src-get-blocked-with-redirect.html [ Crash Failure ] crbug.com/591099 http/tests/security/contentSecurityPolicy/1.1/form-action-src-get-blocked.html [ Crash Failure ] crbug.com/591099 http/tests/security/contentSecurityPolicy/1.1/form-action-src-javascript-blocked.html [ Crash Failure ] -crbug.com/591099 http/tests/security/contentSecurityPolicy/1.1/form-action-src-redirect-blocked-in-new-window.html [ Crash ] +crbug.com/591099 http/tests/security/contentSecurityPolicy/1.1/form-action-src-redirect-blocked-in-new-window.html [ Crash Pass ] crbug.com/591099 http/tests/security/contentSecurityPolicy/1.1/form-action-src-redirect-blocked.html [ Crash Failure ] crbug.com/591099 http/tests/security/contentSecurityPolicy/1.1/plugintypes-affects-child.html [ Failure ] crbug.com/591099 http/tests/security/contentSecurityPolicy/1.1/plugintypes-affects-cross-site-child-allowed.html [ Failure ] @@ -15346,13 +15354,13 @@ crbug.com/591099 http/tests/security/contentSecurityPolicy/1.1/plugintypes-nourl-allowed.html [ Failure Pass ] crbug.com/591099 http/tests/security/contentSecurityPolicy/1.1/plugintypes-url-01.html [ Failure ] crbug.com/591099 http/tests/security/contentSecurityPolicy/1.1/plugintypes-url-02.html [ Failure ] -crbug.com/591099 http/tests/security/contentSecurityPolicy/1.1/scripthash-handler-allowed.html [ Crash ] -crbug.com/591099 http/tests/security/contentSecurityPolicy/1.1/scripthash-handler-blocked.html [ Crash ] +crbug.com/591099 http/tests/security/contentSecurityPolicy/1.1/scripthash-handler-allowed.html [ Crash Pass ] +crbug.com/591099 http/tests/security/contentSecurityPolicy/1.1/scripthash-handler-blocked.html [ Crash Pass ] crbug.com/591099 http/tests/security/contentSecurityPolicy/cached-frame-csp.html [ Crash Failure ] -crbug.com/591099 http/tests/security/contentSecurityPolicy/cascade/cross-origin-with-own-policy.html [ Crash ] -crbug.com/591099 http/tests/security/contentSecurityPolicy/cascade/cross-origin.html [ Crash ] -crbug.com/591099 http/tests/security/contentSecurityPolicy/cascade/same-origin-with-own-policy.html [ Crash ] -crbug.com/591099 http/tests/security/contentSecurityPolicy/cascade/same-origin.html [ Crash ] +crbug.com/591099 http/tests/security/contentSecurityPolicy/cascade/cross-origin-with-own-policy.html [ Crash Pass ] +crbug.com/591099 http/tests/security/contentSecurityPolicy/cascade/cross-origin.html [ Crash Pass ] +crbug.com/591099 http/tests/security/contentSecurityPolicy/cascade/same-origin-with-own-policy.html [ Crash Pass ] +crbug.com/591099 http/tests/security/contentSecurityPolicy/cascade/same-origin.html [ Crash Pass ] crbug.com/591099 http/tests/security/contentSecurityPolicy/directive-parsing-01.html [ Failure ] crbug.com/591099 http/tests/security/contentSecurityPolicy/directive-parsing-02.html [ Failure ] crbug.com/591099 http/tests/security/contentSecurityPolicy/directive-parsing-03.html [ Failure ] @@ -15374,11 +15382,11 @@ crbug.com/591099 http/tests/security/contentSecurityPolicy/object-src-param-url-blocked.html [ Failure ] crbug.com/591099 http/tests/security/contentSecurityPolicy/object-src-url-allowed.html [ Failure Pass ] crbug.com/591099 http/tests/security/contentSecurityPolicy/plugin-in-iframe-with-csp.html [ Failure ] -crbug.com/591099 http/tests/security/contentSecurityPolicy/redirect-does-not-match-paths.html [ Crash ] -crbug.com/591099 http/tests/security/contentSecurityPolicy/redirect-with-delay.html [ Crash ] +crbug.com/591099 http/tests/security/contentSecurityPolicy/redirect-does-not-match-paths.html [ Crash Pass ] +crbug.com/591099 http/tests/security/contentSecurityPolicy/redirect-with-delay.html [ Crash Pass ] crbug.com/591099 http/tests/security/contentSecurityPolicy/register-bypassing-scheme-partial.html [ Crash Failure ] crbug.com/591099 http/tests/security/contentSecurityPolicy/report-multiple-violations-01.php [ Crash Failure ] -crbug.com/591099 http/tests/security/contentSecurityPolicy/require-sri-for/require-sri-for-svg-script-blocked.php [ Crash ] +crbug.com/591099 http/tests/security/contentSecurityPolicy/require-sri-for/require-sri-for-svg-script-blocked.php [ Crash Pass ] crbug.com/591099 http/tests/security/contentSecurityPolicy/script-src-in-iframe.html [ Failure ] crbug.com/591099 http/tests/security/contentSecurityPolicy/script-src-none-inline-event.html [ Failure ] crbug.com/591099 http/tests/security/contentSecurityPolicy/script-src-none.html [ Failure ] @@ -15405,16 +15413,16 @@ crbug.com/591099 http/tests/security/contentTypeOptions/nosniff-script-allowed.html [ Failure ] crbug.com/591099 http/tests/security/contentTypeOptions/nosniff-script-blocked.html [ Failure ] crbug.com/591099 http/tests/security/contentTypeOptions/nosniff-script-without-content-type-blocked.html [ Failure ] -crbug.com/591099 http/tests/security/cookies/third-party-cookie-blocking-worker.html [ Crash ] -crbug.com/591099 http/tests/security/cookies/websocket/third-party-cookie-blocked-on-cross-origin-websocket.html [ Crash ] -crbug.com/591099 http/tests/security/cookies/websocket/third-party-cookie-blocked-on-same-origin-websocket.html [ Crash ] -crbug.com/591099 http/tests/security/cors-rfc1918/addressspace-document-appcache.html [ Crash ] -crbug.com/591099 http/tests/security/cors-rfc1918/addressspace-document-basic.html [ Crash ] -crbug.com/591099 http/tests/security/cors-rfc1918/addressspace-document-csp-appcache.html [ Crash ] -crbug.com/591099 http/tests/security/cors-rfc1918/addressspace-document-csp.html [ Crash ] -crbug.com/591099 http/tests/security/cors-rfc1918/addressspace-serviceworker-basic.html [ Crash ] -crbug.com/591099 http/tests/security/cors-rfc1918/addressspace-sharedworker-basic.html [ Crash ] -crbug.com/591099 http/tests/security/cors-rfc1918/addressspace-worker-basic.html [ Crash ] +crbug.com/591099 http/tests/security/cookies/third-party-cookie-blocking-worker.html [ Crash Pass ] +crbug.com/591099 http/tests/security/cookies/websocket/third-party-cookie-blocked-on-cross-origin-websocket.html [ Crash Pass ] +crbug.com/591099 http/tests/security/cookies/websocket/third-party-cookie-blocked-on-same-origin-websocket.html [ Crash Pass ] +crbug.com/591099 http/tests/security/cors-rfc1918/addressspace-document-appcache.html [ Crash Failure ] +crbug.com/591099 http/tests/security/cors-rfc1918/addressspace-document-basic.html [ Crash Pass ] +crbug.com/591099 http/tests/security/cors-rfc1918/addressspace-document-csp-appcache.html [ Crash Pass ] +crbug.com/591099 http/tests/security/cors-rfc1918/addressspace-document-csp.html [ Crash Pass ] +crbug.com/591099 http/tests/security/cors-rfc1918/addressspace-serviceworker-basic.html [ Crash Pass ] +crbug.com/591099 http/tests/security/cors-rfc1918/addressspace-sharedworker-basic.html [ Crash Pass ] +crbug.com/591099 http/tests/security/cors-rfc1918/addressspace-worker-basic.html [ Crash Pass ] crbug.com/591099 http/tests/security/cross-frame-access-call.html [ Crash Failure ] crbug.com/591099 http/tests/security/cross-frame-access-callback-explicit-domain-ALLOW.html [ Failure ] crbug.com/591099 http/tests/security/cross-frame-access-callback-explicit-domain-DENY.html [ Failure ] @@ -15431,12 +15439,12 @@ crbug.com/591099 http/tests/security/cross-frame-access-protocol-explicit-domain.html [ Failure ] crbug.com/591099 http/tests/security/cross-frame-access-put.html [ Failure Timeout ] crbug.com/591099 http/tests/security/cross-frame-access-set-window-properties.html [ Failure ] -crbug.com/591099 http/tests/security/cross-frame-mouse-source-capabilities.html [ Crash Timeout ] +crbug.com/591099 http/tests/security/cross-frame-mouse-source-capabilities.html [ Crash Pass Timeout ] crbug.com/591099 http/tests/security/cross-origin-OffscreenCanvas2D-createPattern.html [ Failure ] crbug.com/591099 http/tests/security/cross-origin-OffscreenCanvas2D-transferToImageBitmap.html [ Failure ] -crbug.com/591099 http/tests/security/cross-origin-OffscreenCanvasWebGL-texImage2D.html [ Crash ] +crbug.com/591099 http/tests/security/cross-origin-OffscreenCanvasWebGL-texImage2D.html [ Crash Pass ] crbug.com/591099 http/tests/security/cross-origin-access-over-property-descriptor.html [ Failure ] -crbug.com/591099 http/tests/security/cross-origin-appcache-allowed.html [ Crash ] +crbug.com/591099 http/tests/security/cross-origin-appcache-allowed.html [ Crash Failure ] crbug.com/591099 http/tests/security/cross-origin-createImageBitmap.html [ Failure ] crbug.com/591099 http/tests/security/cross-origin-getMatchedCSSRules.html [ Failure ] crbug.com/591099 http/tests/security/cross-origin-indexeddb-allowed.html [ Failure ] @@ -15449,8 +15457,8 @@ crbug.com/591099 http/tests/security/cross-origin-window-event-exception.html [ Failure ] crbug.com/591099 http/tests/security/cross-origin-window-open-exception.html [ Failure ] crbug.com/591099 http/tests/security/cross-origin-worker-indexeddb-allowed.html [ Failure ] -crbug.com/591099 http/tests/security/dangling-markup/option.html [ Crash ] -crbug.com/591099 http/tests/security/dangling-markup/textarea.html [ Crash ] +crbug.com/591099 http/tests/security/dangling-markup/option.html [ Crash Pass ] +crbug.com/591099 http/tests/security/dangling-markup/textarea.html [ Crash Pass ] crbug.com/591099 http/tests/security/data-url-inline.css.html [ Failure ] crbug.com/591099 http/tests/security/dataTransfer-set-data-file-url.html [ Timeout ] crbug.com/591099 http/tests/security/dataURL/xss-DENIED-from-data-url-in-foreign-domain-subframe.html [ Failure ] @@ -15465,9 +15473,9 @@ crbug.com/591099 http/tests/security/dataURL/xss-DENIED-to-data-url-sub-frame-2-level.html [ Failure ] crbug.com/591099 http/tests/security/dataURL/xss-DENIED-to-data-url-sub-frame-uppercase.html [ Failure ] crbug.com/591099 http/tests/security/dataURL/xss-DENIED-to-data-url-sub-frame.html [ Failure ] -crbug.com/591099 http/tests/security/deprecated-subresource-requests.html [ Crash ] -crbug.com/591099 http/tests/security/detached-sandboxed-frame-access.html [ Crash ] -crbug.com/591099 http/tests/security/document-origin.html [ Crash ] +crbug.com/591099 http/tests/security/deprecated-subresource-requests.html [ Crash Pass ] +crbug.com/591099 http/tests/security/detached-sandboxed-frame-access.html [ Crash Pass ] +crbug.com/591099 http/tests/security/document-origin.html [ Crash Pass ] crbug.com/591099 http/tests/security/drag-drop-same-unique-origin.html [ Failure ] crbug.com/591099 http/tests/security/drag-over-remote-content-iframe.html [ Failure ] crbug.com/591099 http/tests/security/escape-form-data-field-names.html [ Crash Failure ] @@ -15482,15 +15490,15 @@ crbug.com/591099 http/tests/security/frameNavigation/xss-DENIED-top-navigation-user-gesture-in-parent.html [ Failure ] crbug.com/591099 http/tests/security/frameNavigation/xss-DENIED-top-navigation-without-user-gesture.html [ Failure ] crbug.com/591099 http/tests/security/host-compare-case-insensitive.html [ Failure ] -crbug.com/591099 http/tests/security/img-crossorigin-cookies.html [ Crash ] +crbug.com/591099 http/tests/security/img-crossorigin-cookies.html [ Crash Pass ] crbug.com/591099 http/tests/security/img-crossorigin-no-credentials-prompt.html [ Crash Failure ] crbug.com/591099 http/tests/security/img-crossorigin-redirect-anonymous.html [ Crash Failure ] -crbug.com/591099 http/tests/security/img-crossorigin-redirect-credentials.html [ Crash ] +crbug.com/591099 http/tests/security/img-crossorigin-redirect-credentials.html [ Crash Pass ] crbug.com/591099 http/tests/security/img-crossorigin-redirect-no-cors.html [ Crash Failure ] -crbug.com/591099 http/tests/security/img-redirect-to-crossorigin-credentials.html [ Crash ] +crbug.com/591099 http/tests/security/img-redirect-to-crossorigin-credentials.html [ Crash Pass ] crbug.com/591099 http/tests/security/img-with-failed-cors-check-fails-to-load.html [ Crash Pass ] crbug.com/591099 http/tests/security/isolatedWorld/bypass-main-world-csp-for-inline-script.html [ Failure ] -crbug.com/591099 http/tests/security/isolatedWorld/bypass-main-world-csp.html [ Crash ] +crbug.com/591099 http/tests/security/isolatedWorld/bypass-main-world-csp.html [ Crash Pass ] crbug.com/591099 http/tests/security/isolatedWorld/cross-origin-xhr.html [ Failure ] crbug.com/591099 http/tests/security/isolatedWorld/no-bypass-main-world-csp-for-delayed-execution.html [ Failure ] crbug.com/591099 http/tests/security/isolatedWorld/sandboxed-iframe.html [ Failure ] @@ -15512,7 +15520,7 @@ crbug.com/591099 http/tests/security/javascriptURL/xss-DENIED-from-javascript-url-in-foreign-domain-subframe.html [ Failure ] crbug.com/591099 http/tests/security/javascriptURL/xss-DENIED-from-javascript-url-in-foreign-domain-window-open.html [ Failure ] crbug.com/591099 http/tests/security/javascriptURL/xss-DENIED-to-javascript-url-in-foreign-domain-subframe.html [ Failure ] -crbug.com/591099 http/tests/security/lenient-this-issue569043.html [ Crash ] +crbug.com/591099 http/tests/security/lenient-this-issue569043.html [ Crash Pass ] crbug.com/591099 http/tests/security/link-crossorigin-stylesheet-anonymous.html [ Failure ] crbug.com/591099 http/tests/security/link-crossorigin-stylesheet-import-anonymous.html [ Failure ] crbug.com/591099 http/tests/security/link-crossorigin-stylesheet-import-credentials.html [ Failure ] @@ -15554,16 +15562,16 @@ crbug.com/591099 http/tests/security/mime-type-execute-as-html-15.html [ Failure ] crbug.com/591099 http/tests/security/mime-type-execute-as-html-16.html [ Failure ] crbug.com/591099 http/tests/security/mixedContent/active-subresource-in-iframe-blocked.https.html [ Failure ] -crbug.com/591099 http/tests/security/mixedContent/blob-url-script-in-data-iframe.https.html [ Crash ] -crbug.com/591099 http/tests/security/mixedContent/blob-url-script-in-sandboxed-iframe.https.html [ Crash ] -crbug.com/591099 http/tests/security/mixedContent/blocked-blob-url-script-in-data-iframe.https.html [ Crash ] -crbug.com/591099 http/tests/security/mixedContent/data-url-script-in-data-iframe.https.html [ Crash ] +crbug.com/591099 http/tests/security/mixedContent/blob-url-script-in-data-iframe.https.html [ Crash Pass ] +crbug.com/591099 http/tests/security/mixedContent/blob-url-script-in-sandboxed-iframe.https.html [ Crash Pass ] +crbug.com/591099 http/tests/security/mixedContent/blocked-blob-url-script-in-data-iframe.https.html [ Crash Pass ] +crbug.com/591099 http/tests/security/mixedContent/data-url-script-in-data-iframe.https.html [ Crash Pass ] crbug.com/591099 http/tests/security/mixedContent/data-url-script-in-iframe.html [ Failure ] crbug.com/591099 http/tests/security/mixedContent/empty-url-plugin-in-frame.html [ Failure ] crbug.com/591099 http/tests/security/mixedContent/insecure-css-in-iframe.html [ Failure ] crbug.com/591099 http/tests/security/mixedContent/insecure-iframe-in-iframe.html [ Failure ] crbug.com/591099 http/tests/security/mixedContent/insecure-image-in-iframe.html [ Failure ] -crbug.com/591099 http/tests/security/mixedContent/insecure-picture-in-main-frame-blocked.https.html [ Crash ] +crbug.com/591099 http/tests/security/mixedContent/insecure-picture-in-main-frame-blocked.https.html [ Crash Pass ] crbug.com/591099 http/tests/security/mixedContent/insecure-plugin-in-iframe.html [ Failure ] crbug.com/591099 http/tests/security/mixedContent/insecure-script-in-iframe.html [ Failure ] crbug.com/591099 http/tests/security/mixedContent/nonwebby-scheme-in-iframe-allowed.https.html [ Failure ] @@ -15577,14 +15585,14 @@ crbug.com/591099 http/tests/security/popup-allowed-by-sandbox-is-sandboxed-control.html [ Failure ] crbug.com/591099 http/tests/security/popup-allowed-by-sandbox-is-sandboxed.html [ Failure ] crbug.com/591099 http/tests/security/popup-allowed-by-sandbox-when-allowed.html [ Failure ] -crbug.com/591099 http/tests/security/postMessage/origin-unaffected-by-document-domain.html [ Crash ] -crbug.com/591099 http/tests/security/powerfulFeatureRestrictions/geolocation-on-sandboxed-insecure-origin.html [ Crash ] -crbug.com/591099 http/tests/security/powerfulFeatureRestrictions/geolocation-on-secure-origin-in-insecure-origin.html [ Crash ] -crbug.com/591099 http/tests/security/powerfulFeatureRestrictions/geolocation-on-secure-origin-in-secure-origin.html [ Crash ] +crbug.com/591099 http/tests/security/postMessage/origin-unaffected-by-document-domain.html [ Crash Pass ] +crbug.com/591099 http/tests/security/powerfulFeatureRestrictions/geolocation-on-sandboxed-insecure-origin.html [ Crash Pass ] +crbug.com/591099 http/tests/security/powerfulFeatureRestrictions/geolocation-on-secure-origin-in-insecure-origin.html [ Crash Pass ] +crbug.com/591099 http/tests/security/powerfulFeatureRestrictions/geolocation-on-secure-origin-in-secure-origin.html [ Crash Pass ] crbug.com/591099 http/tests/security/preload-script-crossorigin-fails-cross-origin.html [ Failure ] -crbug.com/591099 http/tests/security/promise-realm.html [ Crash ] +crbug.com/591099 http/tests/security/promise-realm.html [ Crash Pass ] crbug.com/591099 http/tests/security/protocol-compare-case-insensitive.html [ Failure ] -crbug.com/591099 http/tests/security/referrer-on-client-reload.html [ Crash ] +crbug.com/591099 http/tests/security/referrer-on-client-reload.html [ Crash Pass ] crbug.com/591099 http/tests/security/referrer-policy-always.html [ Failure ] crbug.com/591099 http/tests/security/referrer-policy-default.html [ Failure ] crbug.com/591099 http/tests/security/referrer-policy-https-always.html [ Failure ] @@ -15605,32 +15613,32 @@ crbug.com/591099 http/tests/security/referrer-policy-redirect-link.html [ Timeout ] crbug.com/591099 http/tests/security/referrer-policy-redirect.html [ Failure ] crbug.com/591099 http/tests/security/referrer-policy-rel-noreferrer.html [ Timeout ] -crbug.com/591099 http/tests/security/referrer-policy-srcdoc-dynamic-policy.html [ Crash ] -crbug.com/591099 http/tests/security/referrer-policy-srcdoc.html [ Crash ] +crbug.com/591099 http/tests/security/referrer-policy-srcdoc-dynamic-policy.html [ Crash Pass ] +crbug.com/591099 http/tests/security/referrer-policy-srcdoc.html [ Crash Pass ] crbug.com/591099 http/tests/security/referrer-policy-window-open.html [ Failure ] -crbug.com/591099 http/tests/security/referrerPolicyHeader/basic-header-cross-origin-with-origin-when-cross-origin.php [ Crash ] -crbug.com/591099 http/tests/security/referrerPolicyHeader/basic-header-cross-origin-with-origin.php [ Crash ] -crbug.com/591099 http/tests/security/referrerPolicyHeader/basic-header-downgrade-with-no-referrer-when-downgrade.https.php [ Crash ] -crbug.com/591099 http/tests/security/referrerPolicyHeader/basic-header-no-downgrade-with-no-referrer-when-downgrade.https.php [ Crash ] -crbug.com/591099 http/tests/security/referrerPolicyHeader/basic-header-no-referrer.php [ Crash ] -crbug.com/591099 http/tests/security/referrerPolicyHeader/basic-header-same-origin-with-origin-when-cross-origin.php [ Crash ] -crbug.com/591099 http/tests/security/referrerPolicyHeader/basic-header-same-origin-with-origin.php [ Crash ] -crbug.com/591099 http/tests/security/referrerPolicyHeader/basic-header-unsafe-url.https.php [ Crash ] -crbug.com/591099 http/tests/security/referrerPolicyHeader/legacy-always.php [ Crash ] -crbug.com/591099 http/tests/security/referrerPolicyHeader/legacy-default.php [ Crash ] -crbug.com/591099 http/tests/security/referrerPolicyHeader/legacy-never.php [ Crash ] -crbug.com/591099 http/tests/security/referrerPolicyHeader/legacy-origin-when-crossorigin.php [ Crash ] -crbug.com/591099 http/tests/security/referrerPolicyHeader/referrer-policy-header-then-meta.php [ Crash ] -crbug.com/591099 http/tests/security/referrerPolicyHeader/referrer-policy-redirect.php [ Crash ] -crbug.com/591099 http/tests/security/sandbox-iframe-blocks-top-navigation-to-javascript.html [ Crash ] -crbug.com/591099 http/tests/security/sandbox-iframe-blocks-top-navigation.html [ Crash ] +crbug.com/591099 http/tests/security/referrerPolicyHeader/basic-header-cross-origin-with-origin-when-cross-origin.php [ Crash Pass ] +crbug.com/591099 http/tests/security/referrerPolicyHeader/basic-header-cross-origin-with-origin.php [ Crash Pass ] +crbug.com/591099 http/tests/security/referrerPolicyHeader/basic-header-downgrade-with-no-referrer-when-downgrade.https.php [ Crash Pass ] +crbug.com/591099 http/tests/security/referrerPolicyHeader/basic-header-no-downgrade-with-no-referrer-when-downgrade.https.php [ Crash Pass ] +crbug.com/591099 http/tests/security/referrerPolicyHeader/basic-header-no-referrer.php [ Crash Pass ] +crbug.com/591099 http/tests/security/referrerPolicyHeader/basic-header-same-origin-with-origin-when-cross-origin.php [ Crash Pass ] +crbug.com/591099 http/tests/security/referrerPolicyHeader/basic-header-same-origin-with-origin.php [ Crash Pass ] +crbug.com/591099 http/tests/security/referrerPolicyHeader/basic-header-unsafe-url.https.php [ Crash Pass ] +crbug.com/591099 http/tests/security/referrerPolicyHeader/legacy-always.php [ Crash Pass ] +crbug.com/591099 http/tests/security/referrerPolicyHeader/legacy-default.php [ Crash Pass ] +crbug.com/591099 http/tests/security/referrerPolicyHeader/legacy-never.php [ Crash Pass ] +crbug.com/591099 http/tests/security/referrerPolicyHeader/legacy-origin-when-crossorigin.php [ Crash Pass ] +crbug.com/591099 http/tests/security/referrerPolicyHeader/referrer-policy-header-then-meta.php [ Crash Pass ] +crbug.com/591099 http/tests/security/referrerPolicyHeader/referrer-policy-redirect.php [ Crash Pass ] +crbug.com/591099 http/tests/security/sandbox-iframe-blocks-top-navigation-to-javascript.html [ Crash Pass ] +crbug.com/591099 http/tests/security/sandbox-iframe-blocks-top-navigation.html [ Crash Pass ] crbug.com/591099 http/tests/security/sandbox-inherit-to-initial-document-2.html [ Failure ] crbug.com/591099 http/tests/security/sandbox-inherit-to-initial-document.html [ Failure ] crbug.com/591099 http/tests/security/sandboxed-iframe-blocks-access-from-parent.html [ Failure ] crbug.com/591099 http/tests/security/sandboxed-iframe-document-cookie.html [ Failure ] crbug.com/591099 http/tests/security/sandboxed-iframe-form-top.html [ Failure ] crbug.com/591099 http/tests/security/sandboxed-iframe-invalid.html [ Failure ] -crbug.com/591099 http/tests/security/sandboxed-iframe-javascript-url.html [ Crash ] +crbug.com/591099 http/tests/security/sandboxed-iframe-javascript-url.html [ Crash Pass ] crbug.com/591099 http/tests/security/sandboxed-iframe-meta-refresh.html [ Failure ] crbug.com/591099 http/tests/security/sandboxed-iframe-modify-self.html [ Crash Failure ] crbug.com/591099 http/tests/security/sandboxed-iframe-origin-add.html [ Failure ] @@ -15656,51 +15664,51 @@ crbug.com/591099 http/tests/security/script-onerror-no-crossorigin-cors.html [ Failure ] crbug.com/591099 http/tests/security/script-onerror-no-crossorigin-no-cors.html [ Failure ] crbug.com/591099 http/tests/security/script-with-failed-cors-check-fails-to-load.html [ Failure ] -crbug.com/591099 http/tests/security/secureContexts/authenticated.html [ Crash ] -crbug.com/591099 http/tests/security/secureContexts/authenticated_sandbox.html [ Crash ] -crbug.com/591099 http/tests/security/secureContexts/authenticated_srcdoc.html [ Crash ] -crbug.com/591099 http/tests/security/secureContexts/unauthenticated.html [ Crash ] -crbug.com/591099 http/tests/security/secureContexts/unauthenticated_sandbox.html [ Crash ] -crbug.com/591099 http/tests/security/secureContexts/unauthenticated_srcdoc.html [ Crash ] +crbug.com/591099 http/tests/security/secureContexts/authenticated.html [ Crash Pass ] +crbug.com/591099 http/tests/security/secureContexts/authenticated_sandbox.html [ Crash Pass ] +crbug.com/591099 http/tests/security/secureContexts/authenticated_srcdoc.html [ Crash Pass ] +crbug.com/591099 http/tests/security/secureContexts/unauthenticated.html [ Crash Pass ] +crbug.com/591099 http/tests/security/secureContexts/unauthenticated_sandbox.html [ Crash Pass ] +crbug.com/591099 http/tests/security/secureContexts/unauthenticated_srcdoc.html [ Crash Pass ] crbug.com/591099 http/tests/security/shape-image-cors-allow-origin.html [ Failure ] crbug.com/591099 http/tests/security/shape-image-cors-data-url.html [ Failure ] crbug.com/591099 http/tests/security/shape-image-cors-same-origin.html [ Failure ] -crbug.com/591099 http/tests/security/suborigins/crossorigin/suborigin-cross-origin-window-event-exception.php [ Crash ] -crbug.com/591099 http/tests/security/suborigins/crossorigin/suborigin-cross-origin-window-open-exception.php [ Crash ] -crbug.com/591099 http/tests/security/suborigins/suborigin-allow-same-suborigin-access.html [ Crash ] -crbug.com/591099 http/tests/security/suborigins/suborigin-blocked-different-suborigins.html [ Crash ] -crbug.com/591099 http/tests/security/suborigins/suborigin-blocked-not-in-suborigin-to-suborigin.php [ Crash ] -crbug.com/591099 http/tests/security/suborigins/suborigin-change-document-domain.html [ Crash ] -crbug.com/591099 http/tests/security/suborigins/suborigin-cookies.php [ Crash ] -crbug.com/591099 http/tests/security/suborigins/suborigin-in-meta-disallowed.html [ Crash ] -crbug.com/591099 http/tests/security/suborigins/suborigin-invalid-names.html [ Crash ] -crbug.com/591099 http/tests/security/suborigins/suborigin-invalid-options.html [ Crash ] -crbug.com/591099 http/tests/security/suborigins/suborigin-meta-set-cookie-disabled.php [ Crash ] -crbug.com/591099 http/tests/security/suborigins/suborigin-multiple-suborigins-disallowed.php [ Crash ] -crbug.com/591099 http/tests/security/suborigins/suborigin-postmessage.html [ Crash ] -crbug.com/591099 http/tests/security/suborigins/suborigin-service-worker-fetch-event.html [ Crash ] -crbug.com/591099 http/tests/security/suborigins/suborigin-service-worker-no-xorigin-caching.html [ Crash ] -crbug.com/591099 http/tests/security/suborigins/suborigin-storage-dom-access.php [ Crash ] -crbug.com/591099 http/tests/security/suborigins/suborigin-unsafe-cookies.php [ Crash ] -crbug.com/591099 http/tests/security/suborigins/suborigin-unsafe-postmessage-receive.php [ Crash ] -crbug.com/591099 http/tests/security/suborigins/suborigin-unsafe-postmessage-send.html [ Crash ] -crbug.com/591099 http/tests/security/suborigins/suborigin-valid-names.html [ Crash ] -crbug.com/591099 http/tests/security/suborigins/suborigin-valid-options.html [ Crash ] +crbug.com/591099 http/tests/security/suborigins/crossorigin/suborigin-cross-origin-window-event-exception.php [ Crash Pass ] +crbug.com/591099 http/tests/security/suborigins/crossorigin/suborigin-cross-origin-window-open-exception.php [ Crash Pass ] +crbug.com/591099 http/tests/security/suborigins/suborigin-allow-same-suborigin-access.html [ Crash Pass ] +crbug.com/591099 http/tests/security/suborigins/suborigin-blocked-different-suborigins.html [ Crash Pass ] +crbug.com/591099 http/tests/security/suborigins/suborigin-blocked-not-in-suborigin-to-suborigin.php [ Crash Pass ] +crbug.com/591099 http/tests/security/suborigins/suborigin-change-document-domain.html [ Crash Pass ] +crbug.com/591099 http/tests/security/suborigins/suborigin-cookies.php [ Crash Pass ] +crbug.com/591099 http/tests/security/suborigins/suborigin-in-meta-disallowed.html [ Crash Pass ] +crbug.com/591099 http/tests/security/suborigins/suborigin-invalid-names.html [ Crash Pass ] +crbug.com/591099 http/tests/security/suborigins/suborigin-invalid-options.html [ Crash Pass ] +crbug.com/591099 http/tests/security/suborigins/suborigin-meta-set-cookie-disabled.php [ Crash Pass ] +crbug.com/591099 http/tests/security/suborigins/suborigin-multiple-suborigins-disallowed.php [ Crash Pass ] +crbug.com/591099 http/tests/security/suborigins/suborigin-postmessage.html [ Crash Pass ] +crbug.com/591099 http/tests/security/suborigins/suborigin-service-worker-fetch-event.html [ Crash Pass ] +crbug.com/591099 http/tests/security/suborigins/suborigin-service-worker-no-xorigin-caching.html [ Crash Pass ] +crbug.com/591099 http/tests/security/suborigins/suborigin-storage-dom-access.php [ Crash Pass ] +crbug.com/591099 http/tests/security/suborigins/suborigin-unsafe-cookies.php [ Crash Pass ] +crbug.com/591099 http/tests/security/suborigins/suborigin-unsafe-postmessage-receive.php [ Crash Pass ] +crbug.com/591099 http/tests/security/suborigins/suborigin-unsafe-postmessage-send.html [ Crash Pass ] +crbug.com/591099 http/tests/security/suborigins/suborigin-valid-names.html [ Crash Pass ] +crbug.com/591099 http/tests/security/suborigins/suborigin-valid-options.html [ Crash Pass ] crbug.com/591099 http/tests/security/subresourceIntegrity/integrity-attribute.html [ Failure ] -crbug.com/591099 http/tests/security/subresourceIntegrity/subresource-integrity-not-enforced.html [ Crash ] +crbug.com/591099 http/tests/security/subresourceIntegrity/subresource-integrity-not-enforced.html [ Crash Pass ] crbug.com/591099 http/tests/security/subresourceIntegrity/subresource-integrity-style-allowed.html [ Failure ] crbug.com/591099 http/tests/security/subresourceIntegrity/subresource-integrity-style-blocked.html [ Failure ] -crbug.com/591099 http/tests/security/svg-image-with-cached-remote-image.html [ Crash ] +crbug.com/591099 http/tests/security/svg-image-with-cached-remote-image.html [ Crash Pass ] crbug.com/591099 http/tests/security/synchronous-frame-load-in-javascript-url-inherits-correct-origin.html [ Failure ] crbug.com/591099 http/tests/security/text-track-crossorigin.html [ Failure ] -crbug.com/591099 http/tests/security/upgrade-insecure-requests/form-upgrade.html [ Crash ] -crbug.com/591099 http/tests/security/upgrade-insecure-requests/https-header-nested.html [ Crash ] -crbug.com/591099 http/tests/security/upgrade-insecure-requests/iframe-upgrade.https.html [ Crash ] +crbug.com/591099 http/tests/security/upgrade-insecure-requests/form-upgrade.html [ Crash Pass ] +crbug.com/591099 http/tests/security/upgrade-insecure-requests/https-header-nested.html [ Crash Pass ] +crbug.com/591099 http/tests/security/upgrade-insecure-requests/iframe-upgrade.https.html [ Crash Pass ] crbug.com/591099 http/tests/security/vibration/vibrate-in-cross-origin-iframe-with-user-gesture-allowed.html [ Failure ] crbug.com/591099 http/tests/security/vibration/vibrate-in-same-origin-iframe-with-user-gesture-allowed.html [ Failure ] -crbug.com/591099 http/tests/security/vibration/vibrate-on-top-page-before-during-after-user-gesture.html [ Crash ] -crbug.com/591099 http/tests/security/video-cross-origin-readback.html [ Crash ] -crbug.com/591099 http/tests/security/video-cross-origin-via-dom.html [ Crash ] +crbug.com/591099 http/tests/security/vibration/vibrate-on-top-page-before-during-after-user-gesture.html [ Crash Pass ] +crbug.com/591099 http/tests/security/video-cross-origin-readback.html [ Crash Pass ] +crbug.com/591099 http/tests/security/video-cross-origin-via-dom.html [ Crash Pass ] crbug.com/591099 http/tests/security/video-poster-cross-origin-crash2.html [ Crash Failure ] crbug.com/591099 http/tests/security/webgl-cross-origin-ImageBitmap-blocked.html [ Failure ] crbug.com/591099 http/tests/security/window-onerror-exception-in-iframe.html [ Failure ] @@ -15773,34 +15781,34 @@ crbug.com/591099 http/tests/sendbeacon/beacon-detached-no-crash.html [ Failure ] crbug.com/591099 http/tests/sendbeacon/beacon-same-origin.html [ Failure ] crbug.com/591099 http/tests/serviceworker/ServiceWorkerGlobalScope/registration-attribute.html [ Failure Pass ] -crbug.com/591099 http/tests/serviceworker/chromium/frame-detached-by-navigation.html [ Crash ] +crbug.com/591099 http/tests/serviceworker/chromium/frame-detached-by-navigation.html [ Crash Failure ] crbug.com/591099 http/tests/serviceworker/chromium/resolve-after-window-close.html [ Crash Failure ] crbug.com/591099 http/tests/serviceworker/chromium/service-worker-gc.html [ Failure ] crbug.com/591099 http/tests/serviceworker/chromium/window-close-during-registration.html [ Failure ] crbug.com/591099 http/tests/serviceworker/webexposed/global-interface-listing-service-worker.html [ Pass Timeout ] crbug.com/591099 http/tests/shapes/shape-outside-image-shape-margin.html [ Failure ] crbug.com/591099 http/tests/shapes/shape-outside-svg-image-shape-margin.html [ Failure ] -crbug.com/591099 http/tests/subresource_filter/image-disallowed-after-redirect.html [ Crash ] -crbug.com/591099 http/tests/subresource_filter/image-disallowed.html [ Crash ] -crbug.com/591099 http/tests/subresource_filter/picture-disallowed.html [ Crash ] -crbug.com/591099 http/tests/svg/svg-in-object-in-sandboxed-iframe.html [ Crash ] -crbug.com/591099 http/tests/svg/use-contenttype-blocked.html [ Crash ] -crbug.com/591099 http/tests/svg/use-no-contenttype-blocked.html [ Crash ] +crbug.com/591099 http/tests/subresource_filter/image-disallowed-after-redirect.html [ Crash Pass ] +crbug.com/591099 http/tests/subresource_filter/image-disallowed.html [ Crash Pass ] +crbug.com/591099 http/tests/subresource_filter/picture-disallowed.html [ Crash Pass ] +crbug.com/591099 http/tests/svg/svg-in-object-in-sandboxed-iframe.html [ Crash Pass ] +crbug.com/591099 http/tests/svg/use-contenttype-blocked.html [ Crash Pass ] +crbug.com/591099 http/tests/svg/use-no-contenttype-blocked.html [ Crash Pass ] crbug.com/591099 http/tests/text-autosizing/narrow-iframe.html [ Failure ] crbug.com/591099 http/tests/text-autosizing/wide-iframe.html [ Failure ] crbug.com/591099 http/tests/uri/css-href.php [ Failure ] crbug.com/591099 http/tests/uri/escaped-entity.html [ Failure ] crbug.com/591099 http/tests/uri/resolve-encoding-relative.html [ Failure ] crbug.com/591099 http/tests/uri/utf8-path.html [ Failure ] -crbug.com/591099 http/tests/w3c/webperf/approved/navigation-timing/html/test_performance_attributes_exist_in_object.html [ Crash ] +crbug.com/591099 http/tests/w3c/webperf/approved/navigation-timing/html/test_performance_attributes_exist_in_object.html [ Crash Pass ] crbug.com/591099 http/tests/w3c/webperf/submission/Google/resource-timing/html/test_resource_ignore_failures.html [ Crash Pass ] -crbug.com/591099 http/tests/w3c/webperf/submission/Intel/resource-timing/test_resource_timing_cross_origin_redirect.html [ Crash ] -crbug.com/591099 http/tests/w3c/webperf/submission/Intel/resource-timing/test_resource_timing_cross_origin_redirect_chain.html [ Crash ] -crbug.com/591099 http/tests/w3c/webperf/submission/Intel/resource-timing/test_resource_timing_cross_origin_redirect_chain_allow_timing.html [ Crash ] -crbug.com/591099 http/tests/w3c/webperf/submission/Intel/resource-timing/test_resource_timing_cross_origin_redirect_with_timing_allow_origin.html [ Crash ] -crbug.com/591099 http/tests/w3c/webperf/submission/Intel/resource-timing/test_resource_timing_cross_origin_resource_request.html [ Crash ] -crbug.com/591099 http/tests/w3c/webperf/submission/Intel/resource-timing/test_resource_timing_same_origin_redirect.html [ Crash ] -crbug.com/591099 http/tests/w3c/webperf/submission/Intel/resource-timing/test_resource_timing_timing_allow_cross_origin_resource_request.html [ Crash ] +crbug.com/591099 http/tests/w3c/webperf/submission/Intel/resource-timing/test_resource_timing_cross_origin_redirect.html [ Crash Pass ] +crbug.com/591099 http/tests/w3c/webperf/submission/Intel/resource-timing/test_resource_timing_cross_origin_redirect_chain.html [ Crash Pass ] +crbug.com/591099 http/tests/w3c/webperf/submission/Intel/resource-timing/test_resource_timing_cross_origin_redirect_chain_allow_timing.html [ Crash Pass ] +crbug.com/591099 http/tests/w3c/webperf/submission/Intel/resource-timing/test_resource_timing_cross_origin_redirect_with_timing_allow_origin.html [ Crash Pass ] +crbug.com/591099 http/tests/w3c/webperf/submission/Intel/resource-timing/test_resource_timing_cross_origin_resource_request.html [ Crash Pass ] +crbug.com/591099 http/tests/w3c/webperf/submission/Intel/resource-timing/test_resource_timing_same_origin_redirect.html [ Crash Pass ] +crbug.com/591099 http/tests/w3c/webperf/submission/Intel/resource-timing/test_resource_timing_timing_allow_cross_origin_resource_request.html [ Crash Pass ] crbug.com/591099 http/tests/webaudio/autoplay-crossorigin.html [ Timeout ] crbug.com/591099 http/tests/webfont/fallback-font-while-loading.html [ Failure ] crbug.com/591099 http/tests/webfont/popup-menu-load-webfont-after-open.html [ Failure ] @@ -15835,7 +15843,7 @@ crbug.com/591099 http/tests/websocket/connect-error-by-no-websocket-server-closeonerror.html [ Failure ] crbug.com/591099 http/tests/websocket/connect-error-by-no-websocket-server-noclose.html [ Failure ] crbug.com/591099 http/tests/websocket/connection-throttling.html [ Failure ] -crbug.com/591099 http/tests/websocket/construct-in-detached-frame.html [ Crash ] +crbug.com/591099 http/tests/websocket/construct-in-detached-frame.html [ Crash Failure ] crbug.com/591099 http/tests/websocket/cookie-http-to-ws.pl [ Failure ] crbug.com/591099 http/tests/websocket/cookie-ws-to-ws.html [ Failure ] crbug.com/591099 http/tests/websocket/cross-origin.html [ Failure ] @@ -15956,7 +15964,7 @@ crbug.com/591099 http/tests/workers/worker-invalid-url.html [ Failure ] crbug.com/591099 http/tests/workers/worker-redirect.html [ Failure ] crbug.com/591099 http/tests/workers/worker-workerScriptNotThere.html [ Failure ] -crbug.com/591099 http/tests/worklet/chromium/import-on-detached-iframe.html [ Crash ] +crbug.com/591099 http/tests/worklet/chromium/import-on-detached-iframe.html [ Crash Pass ] crbug.com/591099 http/tests/xmlhttprequest/XMLHttpRequestException.html [ Failure ] crbug.com/591099 http/tests/xmlhttprequest/abort-should-destroy-responseText.html [ Failure ] crbug.com/591099 http/tests/xmlhttprequest/access-control-allow-lists-starting-with-comma.html [ Failure ] @@ -15976,7 +15984,7 @@ crbug.com/591099 http/tests/xmlhttprequest/access-control-preflight-request-invalid-status-301.html [ Failure ] crbug.com/591099 http/tests/xmlhttprequest/access-control-preflight-request-invalid-status-400.html [ Failure ] crbug.com/591099 http/tests/xmlhttprequest/access-control-preflight-request-invalid-status-501.html [ Failure ] -crbug.com/591099 http/tests/xmlhttprequest/access-control-preflight-request-must-not-contain-cookie.html [ Crash ] +crbug.com/591099 http/tests/xmlhttprequest/access-control-preflight-request-must-not-contain-cookie.html [ Crash Pass ] crbug.com/591099 http/tests/xmlhttprequest/access-control-response-with-body-sync.html [ Failure ] crbug.com/591099 http/tests/xmlhttprequest/access-control-response-with-body.html [ Failure ] crbug.com/591099 http/tests/xmlhttprequest/access-control-response-with-expose-headers.html [ Failure ] @@ -15998,9 +16006,9 @@ crbug.com/591099 http/tests/xmlhttprequest/cross-origin-preflight-get-response-type-blob.html [ Failure ] crbug.com/591099 http/tests/xmlhttprequest/cross-origin-preflight-get.html [ Failure ] crbug.com/591099 http/tests/xmlhttprequest/cross-origin-unsupported-url.html [ Failure ] -crbug.com/591099 http/tests/xmlhttprequest/destroy-context-in-onloadstart.html [ Crash ] +crbug.com/591099 http/tests/xmlhttprequest/destroy-context-in-onloadstart.html [ Crash Pass ] crbug.com/591099 http/tests/xmlhttprequest/detaching-frame-2.html [ Failure ] -crbug.com/591099 http/tests/xmlhttprequest/detaching-frame.html [ Crash ] +crbug.com/591099 http/tests/xmlhttprequest/detaching-frame.html [ Crash Failure ] crbug.com/591099 http/tests/xmlhttprequest/docLoaderFrame.html [ Failure ] crbug.com/591099 http/tests/xmlhttprequest/duplicate-revalidation-reload.html [ Failure ] crbug.com/591099 http/tests/xmlhttprequest/encode-request-url-2.html [ Crash Failure ] @@ -16013,7 +16021,7 @@ crbug.com/591099 http/tests/xmlhttprequest/failed-auth.html [ Crash Failure ] crbug.com/591099 http/tests/xmlhttprequest/filename-encoding.html [ Failure ] crbug.com/591099 http/tests/xmlhttprequest/frame-load-cancelled-abort.html [ Crash Failure ] -crbug.com/591099 http/tests/xmlhttprequest/frame-unload-abort-crash.html [ Crash ] +crbug.com/591099 http/tests/xmlhttprequest/frame-unload-abort-crash.html [ Crash Failure ] crbug.com/591099 http/tests/xmlhttprequest/get-dangerous-headers.html [ Failure ] crbug.com/591099 http/tests/xmlhttprequest/getAllResponseHeaders.html [ Failure ] crbug.com/591099 http/tests/xmlhttprequest/getResponseHeader.html [ Failure ] @@ -16025,7 +16033,7 @@ crbug.com/591099 http/tests/xmlhttprequest/methods-async.html [ Crash Failure ] crbug.com/591099 http/tests/xmlhttprequest/methods-lower-case.html [ Crash Failure ] crbug.com/591099 http/tests/xmlhttprequest/methods.html [ Crash Failure ] -crbug.com/591099 http/tests/xmlhttprequest/navigation-abort-detaches-frame.html [ Crash Timeout ] +crbug.com/591099 http/tests/xmlhttprequest/navigation-abort-detaches-frame.html [ Crash Pass Timeout ] crbug.com/591099 http/tests/xmlhttprequest/newline-in-request-uri.html [ Failure ] crbug.com/591099 http/tests/xmlhttprequest/null-auth.php [ Failure ] crbug.com/591099 http/tests/xmlhttprequest/onabort-event.html [ Failure ] @@ -16115,7 +16123,7 @@ crbug.com/591099 http/tests/xmlhttprequest/request-encoding.html [ Failure ] crbug.com/591099 http/tests/xmlhttprequest/request-encoding2.html [ Failure ] crbug.com/591099 http/tests/xmlhttprequest/request-encoding3.html [ Failure ] -crbug.com/591099 http/tests/xmlhttprequest/request-encoding4.html [ Crash ] +crbug.com/591099 http/tests/xmlhttprequest/request-encoding4.html [ Crash Failure ] crbug.com/591099 http/tests/xmlhttprequest/request-from-popup.html [ Failure ] crbug.com/591099 http/tests/xmlhttprequest/response-array-buffer-abort-in-loading-state.html [ Failure ] crbug.com/591099 http/tests/xmlhttprequest/response-blob-abort-in-loading-state.html [ Failure ] @@ -16321,7 +16329,7 @@ crbug.com/591099 images/cross-fade-svg-size-diff.html [ Failure Pass ] crbug.com/591099 images/cross-fade-svg-size.html [ Failure Pass ] crbug.com/591099 images/cross-fade-tiled.html [ Failure ] -crbug.com/591099 images/destroyed-image-load-event.html [ Crash ] +crbug.com/591099 images/destroyed-image-load-event.html [ Crash Failure ] crbug.com/591099 images/drag-svg-image.html [ Failure ] crbug.com/591099 images/embed-does-not-propagate-dimensions-to-object-ancestor.html [ Failure Pass ] crbug.com/591099 images/exif-orientation-css.html [ Crash Failure ] @@ -16337,7 +16345,7 @@ crbug.com/591099 images/icon-0colors.html [ Failure ] crbug.com/591099 images/icon-decoding.html [ Failure ] crbug.com/591099 images/image-change-src.html [ Crash Pass ] -crbug.com/591099 images/image-change-without-resize-shouldnt-layout.html [ Crash ] +crbug.com/591099 images/image-change-without-resize-shouldnt-layout.html [ Crash Pass ] crbug.com/591099 images/image-click-scale-restore-zoomed-image.html [ Failure ] crbug.com/591099 images/image-css3-content-data.html [ Failure ] crbug.com/591099 images/image-document-write-assert.html [ Failure ] @@ -16352,7 +16360,7 @@ crbug.com/591099 images/image-map-zoom-alt-content.html [ Crash Failure ] crbug.com/591099 images/image-map-zoom.html [ Failure ] crbug.com/591099 images/image-page-injected-script-crash.html [ Crash Failure ] -crbug.com/591099 images/image-use-counters.html [ Crash ] +crbug.com/591099 images/image-use-counters.html [ Crash Pass ] crbug.com/591099 images/image-zoom-to-25.html [ Failure ] crbug.com/591099 images/image-zoom-to-500.html [ Failure ] crbug.com/591099 images/imagemap-circle-focus-ring.html [ Failure ] @@ -16368,17 +16376,17 @@ crbug.com/591099 images/imagemap-overflowing-circle-focus-ring.html [ Failure ] crbug.com/591099 images/imagemap-overflowing-polygon-focus-ring.html [ Failure ] crbug.com/591099 images/imagemap-polygon-focus-ring.html [ Failure ] -crbug.com/591099 images/imagemap-scroll.html [ Crash ] -crbug.com/591099 images/img-dimensions-styled.html [ Crash ] -crbug.com/591099 images/invalid-image-url-crash.html [ Crash ] +crbug.com/591099 images/imagemap-scroll.html [ Crash Failure ] +crbug.com/591099 images/img-dimensions-styled.html [ Crash Pass ] +crbug.com/591099 images/invalid-image-url-crash.html [ Crash Pass ] crbug.com/591099 images/jpeg-yuv-image-decoding.html [ Failure Pass ] crbug.com/591099 images/jpeg-yuv-progressive-canvas.html [ Failure Pass ] crbug.com/591099 images/jpeg-yuv-progressive-image.html [ Failure Pass ] crbug.com/591099 images/link-body-content-imageDimensionChanged-crash.html [ Failure ] crbug.com/591099 images/load-img-with-empty-src.html [ Failure ] crbug.com/591099 images/motion-jpeg-single-frame.html [ Failure ] -crbug.com/591099 images/move-image-to-new-document.html [ Crash ] -crbug.com/591099 images/multiple-inflight-error-event-crash.html [ Crash ] +crbug.com/591099 images/move-image-to-new-document.html [ Crash Pass ] +crbug.com/591099 images/multiple-inflight-error-event-crash.html [ Crash Pass ] crbug.com/591099 images/pdf-as-background.html [ Failure ] crbug.com/591099 images/pdf-as-tiled-background.html [ Failure ] crbug.com/591099 images/percent-height-image.html [ Failure ] @@ -16397,15 +16405,15 @@ crbug.com/591099 images/script-counter-imageDimensionChanged-crash.html [ Failure ] crbug.com/591099 images/sprite-no-bleed.html [ Failure ] crbug.com/591099 images/style-access-during-imageChanged-crash.html [ Crash Failure ] -crbug.com/591099 images/style-access-during-imageChanged-style-freeze.html [ Crash ] +crbug.com/591099 images/style-access-during-imageChanged-style-freeze.html [ Crash Pass ] crbug.com/591099 images/text-content-crash-2.html [ Failure ] crbug.com/591099 images/text-content-crash.html [ Failure ] -crbug.com/591099 images/update-alt-text.html [ Crash ] +crbug.com/591099 images/update-alt-text.html [ Crash Pass ] crbug.com/591099 images/viewport-in-standalone-image-document.html [ Failure ] -crbug.com/591099 images/webgl-teximage2d.html [ Crash ] +crbug.com/591099 images/webgl-teximage2d.html [ Crash Pass ] crbug.com/591099 images/webp-flip.html [ Failure ] crbug.com/591099 images/zoomed-img-size.html [ Failure ] -crbug.com/591099 images/zoomed-offset-size.html [ Crash ] +crbug.com/591099 images/zoomed-offset-size.html [ Crash Pass ] crbug.com/591099 inspector-enabled/console/console-uncaught-promise-no-inspector.html [ Failure ] crbug.com/591099 inspector-enabled/sources/debugger/linkifier.html [ Failure ] crbug.com/591099 inspector-enabled/sources/debugger/script-formatter-breakpoints-1.html [ Failure ] @@ -16447,14 +16455,14 @@ crbug.com/591099 inspector-protocol/layers/paint-profiler.js [ Failure ] crbug.com/591099 inspector-protocol/layout-fonts/languages-emoji-rare-glyphs.html [ Failure ] crbug.com/591099 inspector/agents-enable-disable.html [ Failure ] -crbug.com/591099 inspector/animation/animation-KeyframeEffectReadOnly-crash.html [ Crash ] +crbug.com/591099 inspector/animation/animation-KeyframeEffectReadOnly-crash.html [ Crash Failure ] crbug.com/591099 inspector/animation/animation-empty-web-animations.html [ Crash Failure ] -crbug.com/591099 inspector/animation/animation-group-matching-animations.html [ Crash ] -crbug.com/591099 inspector/animation/animation-group-matching-transitions.html [ Crash ] -crbug.com/591099 inspector/animation/animation-group-matching.html [ Crash ] -crbug.com/591099 inspector/animation/animation-timeline.html [ Crash ] +crbug.com/591099 inspector/animation/animation-group-matching-animations.html [ Crash Failure ] +crbug.com/591099 inspector/animation/animation-group-matching-transitions.html [ Crash Failure ] +crbug.com/591099 inspector/animation/animation-group-matching.html [ Crash Failure ] +crbug.com/591099 inspector/animation/animation-timeline.html [ Crash Failure ] crbug.com/591099 inspector/animation/animation-transition-setTiming-crash.html [ Crash Failure ] -crbug.com/591099 inspector/animation/animation-web-anim-negative-start-time.html [ Crash ] +crbug.com/591099 inspector/animation/animation-web-anim-negative-start-time.html [ Crash Failure ] crbug.com/591099 inspector/audits/audits-empty-stylesheet.html [ Crash Failure ] crbug.com/591099 inspector/audits/audits-panel-functional.html [ Crash Failure ] crbug.com/591099 inspector/changes/changes-highlighter.html [ Crash Failure Timeout ] @@ -16484,9 +16492,9 @@ crbug.com/591099 inspector/components/widget-events.html [ Failure ] crbug.com/591099 inspector/components/widget-focus.html [ Failure ] crbug.com/591099 inspector/console-document-write-from-external-script-logging.html [ Failure ] -crbug.com/591099 inspector/console/alert-toString-exception.html [ Crash ] +crbug.com/591099 inspector/console/alert-toString-exception.html [ Crash Failure ] crbug.com/591099 inspector/console/command-line-api-getEventListeners.html [ Crash Failure ] -crbug.com/591099 inspector/console/command-line-api.html [ Crash ] +crbug.com/591099 inspector/console/command-line-api.html [ Crash Failure ] crbug.com/591099 inspector/console/console-Object-overwritten.html [ Failure ] crbug.com/591099 inspector/console/console-api-on-call-frame.html [ Crash Failure ] crbug.com/591099 inspector/console/console-assert.html [ Failure ] @@ -16500,7 +16508,7 @@ crbug.com/591099 inspector/console/console-context-selector.html [ Crash Failure ] crbug.com/591099 inspector/console/console-control-characters.html [ Failure ] crbug.com/591099 inspector/console/console-copy-treeoutline.html [ Failure ] -crbug.com/591099 inspector/console/console-copy-truncated-text.html [ Crash ] +crbug.com/591099 inspector/console/console-copy-truncated-text.html [ Crash Failure ] crbug.com/591099 inspector/console/console-correct-suggestions.html [ Failure ] crbug.com/591099 inspector/console/console-custom-formatters.html [ Failure ] crbug.com/591099 inspector/console/console-dir-deprecated.html [ Failure ] @@ -16516,14 +16524,14 @@ crbug.com/591099 inspector/console/console-eval-fake.html [ Crash Failure ] crbug.com/591099 inspector/console/console-eval-global.html [ Failure ] crbug.com/591099 inspector/console/console-eval-object-literal.html [ Failure ] -crbug.com/591099 inspector/console/console-eval-scoped.html [ Crash ] +crbug.com/591099 inspector/console/console-eval-scoped.html [ Crash Failure ] crbug.com/591099 inspector/console/console-eval-syntax-error.html [ Failure ] -crbug.com/591099 inspector/console/console-eval-throw.html [ Crash ] +crbug.com/591099 inspector/console/console-eval-throw.html [ Crash Failure ] crbug.com/591099 inspector/console/console-eval-undefined-override.html [ Failure ] crbug.com/591099 inspector/console/console-eval.html [ Failure ] crbug.com/591099 inspector/console/console-export.html [ Failure ] crbug.com/591099 inspector/console/console-external-array.html [ Failure ] -crbug.com/591099 inspector/console/console-filter-level-test.html [ Crash ] +crbug.com/591099 inspector/console/console-filter-level-test.html [ Crash Failure ] crbug.com/591099 inspector/console/console-filter-test.html [ Failure ] crbug.com/591099 inspector/console/console-focus.html [ Failure ] crbug.com/591099 inspector/console/console-format-array-prototype.html [ Crash Failure ] @@ -16540,7 +16548,7 @@ crbug.com/591099 inspector/console/console-functions.html [ Failure ] crbug.com/591099 inspector/console/console-history-contains-requested-text.html [ Failure ] crbug.com/591099 inspector/console/console-last-result.html [ Failure ] -crbug.com/591099 inspector/console/console-link-to-snippet.html [ Crash ] +crbug.com/591099 inspector/console/console-link-to-snippet.html [ Crash Failure ] crbug.com/591099 inspector/console/console-linkify-message-location.html [ Failure ] crbug.com/591099 inspector/console/console-log-before-inspector-open.html [ Failure ] crbug.com/591099 inspector/console/console-log-custom-elements.html [ Failure ] @@ -16568,11 +16576,11 @@ crbug.com/591099 inspector/console/console-proxy.html [ Failure ] crbug.com/591099 inspector/console/console-repeat-count.html [ Failure ] crbug.com/591099 inspector/console/console-retain-autocomplete-on-typing.html [ Crash Failure ] -crbug.com/591099 inspector/console/console-revoke-error-in-worker.html [ Crash ] -crbug.com/591099 inspector/console/console-revoke-error.html [ Crash ] +crbug.com/591099 inspector/console/console-revoke-error-in-worker.html [ Crash Failure ] +crbug.com/591099 inspector/console/console-revoke-error.html [ Crash Failure ] crbug.com/591099 inspector/console/console-save-to-temp-var.html [ Failure ] crbug.com/591099 inspector/console/console-search-reveals-messages.html [ Failure ] -crbug.com/591099 inspector/console/console-search.html [ Crash ] +crbug.com/591099 inspector/console/console-search.html [ Crash Failure ] crbug.com/591099 inspector/console/console-smart-enter.html [ Failure ] crbug.com/591099 inspector/console/console-stack-overflow.html [ Failure ] crbug.com/591099 inspector/console/console-string-format.html [ Failure ] @@ -16600,18 +16608,18 @@ crbug.com/591099 inspector/console/function-name-in-console-message-stack.html [ Failure ] crbug.com/591099 inspector/console/inspect-html-all-collection.html [ Failure ] crbug.com/591099 inspector/console/paintworklet-console-selector.html [ Failure ] -crbug.com/591099 inspector/console/shadow-element.html [ Crash ] +crbug.com/591099 inspector/console/shadow-element.html [ Crash Failure ] crbug.com/591099 inspector/console/worker-eval-contains-stack.html [ Failure ] crbug.com/591099 inspector/cookie-resource-match.html [ Failure ] -crbug.com/591099 inspector/coverage/coverage-repeated.html [ Crash ] -crbug.com/591099 inspector/coverage/coverage-view-filter.html [ Crash ] -crbug.com/591099 inspector/coverage/coverage-view.html [ Crash ] -crbug.com/591099 inspector/coverage/decorations-after-script-formatter.html [ Crash ] +crbug.com/591099 inspector/coverage/coverage-repeated.html [ Crash Failure ] +crbug.com/591099 inspector/coverage/coverage-view-filter.html [ Crash Failure ] +crbug.com/591099 inspector/coverage/coverage-view.html [ Crash Failure ] +crbug.com/591099 inspector/coverage/decorations-after-script-formatter.html [ Crash Failure ] crbug.com/591099 inspector/coverage/gutter-css.html [ Crash Failure ] -crbug.com/591099 inspector/coverage/gutter-html.html [ Crash ] +crbug.com/591099 inspector/coverage/gutter-html.html [ Crash Failure ] crbug.com/591099 inspector/coverage/gutter-js.html [ Crash Failure ] -crbug.com/591099 inspector/coverage/multiple-instances-merge.html [ Crash ] -crbug.com/591099 inspector/coverage/reveal-autoformat.html [ Crash ] +crbug.com/591099 inspector/coverage/multiple-instances-merge.html [ Crash Failure ] +crbug.com/591099 inspector/coverage/reveal-autoformat.html [ Crash Failure ] crbug.com/591099 inspector/coverage/segments-merge.html [ Crash Failure ] crbug.com/591099 inspector/curl-command.html [ Failure ] crbug.com/591099 inspector/database-table-name-excaping.html [ Failure ] @@ -16639,224 +16647,224 @@ crbug.com/591099 inspector/editor/text-editor-smart-braces.html [ Crash Failure ] crbug.com/591099 inspector/editor/text-editor-token-at-position.html [ Crash Failure ] crbug.com/591099 inspector/editor/text-editor-word-jumps.html [ Crash Failure Timeout ] -crbug.com/591099 inspector/elements/accessibility/autocomplete-attribute.html [ Crash Timeout ] -crbug.com/591099 inspector/elements/accessibility/edit-aria-attributes.html [ Crash Timeout ] -crbug.com/591099 inspector/elements/attribute-modified-ns.html [ Crash ] -crbug.com/591099 inspector/elements/bidi-dom-tree.html [ Crash ] -crbug.com/591099 inspector/elements/breadcrumb-updates.html [ Crash ] -crbug.com/591099 inspector/elements/css-rule-hover-highlights-selectors.html [ Crash ] -crbug.com/591099 inspector/elements/dom-agent-query-selector.html [ Crash ] +crbug.com/591099 inspector/elements/accessibility/autocomplete-attribute.html [ Crash Failure Timeout ] +crbug.com/591099 inspector/elements/accessibility/edit-aria-attributes.html [ Crash Failure Timeout ] +crbug.com/591099 inspector/elements/attribute-modified-ns.html [ Crash Failure ] +crbug.com/591099 inspector/elements/bidi-dom-tree.html [ Crash Failure ] +crbug.com/591099 inspector/elements/breadcrumb-updates.html [ Crash Failure ] +crbug.com/591099 inspector/elements/css-rule-hover-highlights-selectors.html [ Crash Pass ] +crbug.com/591099 inspector/elements/dom-agent-query-selector.html [ Crash Failure ] crbug.com/591099 inspector/elements/dom-search-crash.html [ Crash Failure ] -crbug.com/591099 inspector/elements/edit/delete-from-document.html [ Crash ] -crbug.com/591099 inspector/elements/edit/edit-dom-actions-1.html [ Crash ] +crbug.com/591099 inspector/elements/edit/delete-from-document.html [ Crash Failure ] +crbug.com/591099 inspector/elements/edit/edit-dom-actions-1.html [ Crash Timeout ] crbug.com/591099 inspector/elements/edit/edit-dom-actions-2.html [ Crash Timeout ] -crbug.com/591099 inspector/elements/edit/edit-dom-actions-3.html [ Crash ] -crbug.com/591099 inspector/elements/edit/edit-dom-actions-4.html [ Crash ] -crbug.com/591099 inspector/elements/edit/edit-dom-actions-shadow-1.html [ Crash ] -crbug.com/591099 inspector/elements/edit/edit-dom-actions-shadow-2.html [ Crash ] -crbug.com/591099 inspector/elements/edit/edit-style-attribute.html [ Crash ] -crbug.com/591099 inspector/elements/edit/edit-trimmed-attribute-value.html [ Crash ] -crbug.com/591099 inspector/elements/edit/insert-node-collapsed.html [ Crash ] -crbug.com/591099 inspector/elements/edit/perform-undo-undo.html [ Crash ] -crbug.com/591099 inspector/elements/edit/remove-node.html [ Crash ] +crbug.com/591099 inspector/elements/edit/edit-dom-actions-3.html [ Crash Timeout ] +crbug.com/591099 inspector/elements/edit/edit-dom-actions-4.html [ Crash Timeout ] +crbug.com/591099 inspector/elements/edit/edit-dom-actions-shadow-1.html [ Crash Failure ] +crbug.com/591099 inspector/elements/edit/edit-dom-actions-shadow-2.html [ Crash Timeout ] +crbug.com/591099 inspector/elements/edit/edit-style-attribute.html [ Crash Failure ] +crbug.com/591099 inspector/elements/edit/edit-trimmed-attribute-value.html [ Crash Failure ] +crbug.com/591099 inspector/elements/edit/insert-node-collapsed.html [ Crash Failure ] +crbug.com/591099 inspector/elements/edit/perform-undo-undo.html [ Crash Failure ] +crbug.com/591099 inspector/elements/edit/remove-node.html [ Crash Failure Timeout ] crbug.com/591099 inspector/elements/edit/set-attribute-non-html.svg [ Crash Failure ] -crbug.com/591099 inspector/elements/edit/set-attribute.html [ Crash ] -crbug.com/591099 inspector/elements/edit/set-outer-html-2.html [ Crash ] -crbug.com/591099 inspector/elements/edit/set-outer-html-body.html [ Crash ] -crbug.com/591099 inspector/elements/edit/set-outer-html-for-xhtml.xhtml [ Crash ] -crbug.com/591099 inspector/elements/edit/set-outer-html.html [ Crash ] -crbug.com/591099 inspector/elements/edit/shadow-dom-modify-chardata.html [ Crash ] -crbug.com/591099 inspector/elements/edit/switch-panels-while-editing-as-html.html [ Crash ] -crbug.com/591099 inspector/elements/edit/undo-dom-edits-2.html [ Crash ] -crbug.com/591099 inspector/elements/edit/undo-dom-edits.html [ Crash ] -crbug.com/591099 inspector/elements/edit/undo-set-outer-html-2.html [ Crash ] -crbug.com/591099 inspector/elements/edit/undo-set-outer-html.html [ Crash ] -crbug.com/591099 inspector/elements/elements-css-path.html [ Crash ] -crbug.com/591099 inspector/elements/elements-delete-inline-style.html [ Crash ] -crbug.com/591099 inspector/elements/elements-hide-html-comments.html [ Crash ] -crbug.com/591099 inspector/elements/elements-img-tooltip.html [ Crash ] -crbug.com/591099 inspector/elements/elements-inspect-iframe-from-different-domain.html [ Crash ] -crbug.com/591099 inspector/elements/elements-panel-correct-case.html [ Crash ] -crbug.com/591099 inspector/elements/elements-panel-limited-children.html [ Crash ] -crbug.com/591099 inspector/elements/elements-panel-reload-assert.html [ Crash Timeout ] -crbug.com/591099 inspector/elements/elements-panel-restore-selection-when-node-comes-later.html [ Crash ] -crbug.com/591099 inspector/elements/elements-panel-rewrite-href.html [ Crash ] -crbug.com/591099 inspector/elements/elements-panel-search.html [ Crash ] -crbug.com/591099 inspector/elements/elements-panel-selection-after-delete.html [ Crash ] -crbug.com/591099 inspector/elements/elements-panel-selection-on-refresh.html [ Crash ] -crbug.com/591099 inspector/elements/elements-panel-structure.html [ Crash ] -crbug.com/591099 inspector/elements/elements-panel-styles.html [ Crash ] +crbug.com/591099 inspector/elements/edit/set-attribute.html [ Crash Failure ] +crbug.com/591099 inspector/elements/edit/set-outer-html-2.html [ Crash Failure ] +crbug.com/591099 inspector/elements/edit/set-outer-html-body.html [ Crash Failure ] +crbug.com/591099 inspector/elements/edit/set-outer-html-for-xhtml.xhtml [ Crash Failure ] +crbug.com/591099 inspector/elements/edit/set-outer-html.html [ Crash Failure ] +crbug.com/591099 inspector/elements/edit/shadow-dom-modify-chardata.html [ Crash Failure ] +crbug.com/591099 inspector/elements/edit/switch-panels-while-editing-as-html.html [ Crash Failure ] +crbug.com/591099 inspector/elements/edit/undo-dom-edits-2.html [ Crash Failure ] +crbug.com/591099 inspector/elements/edit/undo-dom-edits.html [ Crash Failure Timeout ] +crbug.com/591099 inspector/elements/edit/undo-set-outer-html-2.html [ Crash Failure ] +crbug.com/591099 inspector/elements/edit/undo-set-outer-html.html [ Crash Failure ] +crbug.com/591099 inspector/elements/elements-css-path.html [ Crash Failure ] +crbug.com/591099 inspector/elements/elements-delete-inline-style.html [ Crash Failure ] +crbug.com/591099 inspector/elements/elements-hide-html-comments.html [ Crash Pass ] +crbug.com/591099 inspector/elements/elements-img-tooltip.html [ Crash Failure ] +crbug.com/591099 inspector/elements/elements-inspect-iframe-from-different-domain.html [ Crash Failure ] +crbug.com/591099 inspector/elements/elements-panel-correct-case.html [ Crash Failure ] +crbug.com/591099 inspector/elements/elements-panel-limited-children.html [ Crash Failure ] +crbug.com/591099 inspector/elements/elements-panel-reload-assert.html [ Crash Failure Timeout ] +crbug.com/591099 inspector/elements/elements-panel-restore-selection-when-node-comes-later.html [ Crash Failure ] +crbug.com/591099 inspector/elements/elements-panel-rewrite-href.html [ Crash Failure ] +crbug.com/591099 inspector/elements/elements-panel-search.html [ Crash Failure ] +crbug.com/591099 inspector/elements/elements-panel-selection-after-delete.html [ Crash Failure ] +crbug.com/591099 inspector/elements/elements-panel-selection-on-refresh.html [ Crash Failure ] +crbug.com/591099 inspector/elements/elements-panel-structure.html [ Crash Failure ] +crbug.com/591099 inspector/elements/elements-panel-styles.html [ Crash Failure ] crbug.com/591099 inspector/elements/elements-tab-stops.html [ Crash Failure ] -crbug.com/591099 inspector/elements/elements-treeoutline-copy.html [ Crash ] -crbug.com/591099 inspector/elements/event-listener-sidebar-custom-framework.html [ Crash ] -crbug.com/591099 inspector/elements/event-listener-sidebar-jquery1.html [ Crash ] -crbug.com/591099 inspector/elements/event-listener-sidebar-jquery2.html [ Crash ] -crbug.com/591099 inspector/elements/event-listener-sidebar-remove.html [ Crash ] -crbug.com/591099 inspector/elements/event-listener-sidebar.html [ Crash ] -crbug.com/591099 inspector/elements/event-listeners-about-blank.html [ Crash ] -crbug.com/591099 inspector/elements/expand-recursively.html [ Crash ] -crbug.com/591099 inspector/elements/hide-shortcut.html [ Crash ] -crbug.com/591099 inspector/elements/highlight/highlight-css-shapes-outside-scroll.html [ Crash ] -crbug.com/591099 inspector/elements/highlight/highlight-css-shapes-outside.html [ Crash ] -crbug.com/591099 inspector/elements/highlight/highlight-dom-updates.html [ Crash ] -crbug.com/591099 inspector/elements/highlight/highlight-node-scaled-and-scrolled.html [ Crash ] -crbug.com/591099 inspector/elements/highlight/highlight-node-scaled.html [ Crash ] -crbug.com/591099 inspector/elements/highlight/highlight-node-scroll.html [ Crash ] -crbug.com/591099 inspector/elements/highlight/highlight-node-transformed.html [ Crash ] -crbug.com/591099 inspector/elements/highlight/highlight-node.html [ Crash ] -crbug.com/591099 inspector/elements/highlight/highlight-svg-content-inside-iframe.html [ Crash ] -crbug.com/591099 inspector/elements/highlight/highlight-svg-root-zoomed.html [ Crash ] -crbug.com/591099 inspector/elements/highlight/highlight-svg-root.html [ Crash ] -crbug.com/591099 inspector/elements/iframe-load-event.html [ Crash ] -crbug.com/591099 inspector/elements/inline-style-title.html [ Crash ] -crbug.com/591099 inspector/elements/insert-node.html [ Crash ] -crbug.com/591099 inspector/elements/inspect-mode-after-profiling.html [ Crash ] -crbug.com/591099 inspector/elements/inspect-mode-shadow-text.html [ Crash ] -crbug.com/591099 inspector/elements/inspect-pointer-events-none.html [ Crash ] -crbug.com/591099 inspector/elements/inspect-pseudo-element.html [ Crash Timeout ] -crbug.com/591099 inspector/elements/modify-chardata.html [ Crash ] -crbug.com/591099 inspector/elements/move-node.html [ Crash ] -crbug.com/591099 inspector/elements/node-reselect-on-append-child.html [ Crash ] +crbug.com/591099 inspector/elements/elements-treeoutline-copy.html [ Crash Failure ] +crbug.com/591099 inspector/elements/event-listener-sidebar-custom-framework.html [ Crash Failure ] +crbug.com/591099 inspector/elements/event-listener-sidebar-jquery1.html [ Crash Failure ] +crbug.com/591099 inspector/elements/event-listener-sidebar-jquery2.html [ Crash Failure ] +crbug.com/591099 inspector/elements/event-listener-sidebar-remove.html [ Crash Failure ] +crbug.com/591099 inspector/elements/event-listener-sidebar.html [ Crash Failure ] +crbug.com/591099 inspector/elements/event-listeners-about-blank.html [ Crash Failure ] +crbug.com/591099 inspector/elements/expand-recursively.html [ Crash Failure ] +crbug.com/591099 inspector/elements/hide-shortcut.html [ Crash Failure ] +crbug.com/591099 inspector/elements/highlight/highlight-css-shapes-outside-scroll.html [ Crash Failure ] +crbug.com/591099 inspector/elements/highlight/highlight-css-shapes-outside.html [ Crash Failure ] +crbug.com/591099 inspector/elements/highlight/highlight-dom-updates.html [ Crash Timeout ] +crbug.com/591099 inspector/elements/highlight/highlight-node-scaled-and-scrolled.html [ Crash Failure ] +crbug.com/591099 inspector/elements/highlight/highlight-node-scaled.html [ Crash Failure ] +crbug.com/591099 inspector/elements/highlight/highlight-node-scroll.html [ Crash Failure ] +crbug.com/591099 inspector/elements/highlight/highlight-node-transformed.html [ Crash Pass ] +crbug.com/591099 inspector/elements/highlight/highlight-node.html [ Crash Failure ] +crbug.com/591099 inspector/elements/highlight/highlight-svg-content-inside-iframe.html [ Crash Pass ] +crbug.com/591099 inspector/elements/highlight/highlight-svg-root-zoomed.html [ Crash Failure ] +crbug.com/591099 inspector/elements/highlight/highlight-svg-root.html [ Crash Failure ] +crbug.com/591099 inspector/elements/iframe-load-event.html [ Crash Failure ] +crbug.com/591099 inspector/elements/inline-style-title.html [ Crash Failure ] +crbug.com/591099 inspector/elements/insert-node.html [ Crash Failure ] +crbug.com/591099 inspector/elements/inspect-mode-after-profiling.html [ Crash Failure ] +crbug.com/591099 inspector/elements/inspect-mode-shadow-text.html [ Crash Failure ] +crbug.com/591099 inspector/elements/inspect-pointer-events-none.html [ Crash Timeout ] +crbug.com/591099 inspector/elements/inspect-pseudo-element.html [ Crash Pass Timeout ] +crbug.com/591099 inspector/elements/modify-chardata.html [ Crash Failure ] +crbug.com/591099 inspector/elements/move-node.html [ Crash Failure ] +crbug.com/591099 inspector/elements/node-reselect-on-append-child.html [ Crash Failure ] crbug.com/591099 inspector/elements/node-xpath.xhtml [ Crash Failure ] -crbug.com/591099 inspector/elements/resolve-alien-node.html [ Crash ] -crbug.com/591099 inspector/elements/resolve-node-blocked.html [ Crash ] -crbug.com/591099 inspector/elements/reveal-whitespace-text-node.html [ Crash ] -crbug.com/591099 inspector/elements/selected-element-changes-execution-context.html [ Crash ] -crbug.com/591099 inspector/elements/shadow/breadcrumb-shadow-roots.html [ Crash ] -crbug.com/591099 inspector/elements/shadow/create-shadow-root.html [ Crash Timeout ] -crbug.com/591099 inspector/elements/shadow/elements-panel-shadow-selection-on-refresh-1.html [ Crash ] -crbug.com/591099 inspector/elements/shadow/elements-panel-shadow-selection-on-refresh-2.html [ Crash ] -crbug.com/591099 inspector/elements/shadow/elements-panel-shadow-selection-on-refresh-3.html [ Crash ] -crbug.com/591099 inspector/elements/shadow/inspect-deep-shadow-element.html [ Crash ] -crbug.com/591099 inspector/elements/shadow/reveal-shadow-dom-node.html [ Crash ] -crbug.com/591099 inspector/elements/shadow/shadow-distribution.html [ Crash ] -crbug.com/591099 inspector/elements/shadow/shadow-host-display-modes.html [ Crash ] -crbug.com/591099 inspector/elements/shadow/shadow-root.html [ Crash ] -crbug.com/591099 inspector/elements/shadow/update-shadowdom.html [ Crash ] -crbug.com/591099 inspector/elements/styles-1/add-new-rule-inline-style-csp.html [ Crash ] -crbug.com/591099 inspector/elements/styles-1/add-new-rule-invalid-selector.html [ Crash ] -crbug.com/591099 inspector/elements/styles-1/add-new-rule-with-style-after-body.html [ Crash ] -crbug.com/591099 inspector/elements/styles-1/cached-sync-computed-styles.html [ Crash ] +crbug.com/591099 inspector/elements/resolve-alien-node.html [ Crash Failure ] +crbug.com/591099 inspector/elements/resolve-node-blocked.html [ Crash Failure ] +crbug.com/591099 inspector/elements/reveal-whitespace-text-node.html [ Crash Failure ] +crbug.com/591099 inspector/elements/selected-element-changes-execution-context.html [ Crash Failure ] +crbug.com/591099 inspector/elements/shadow/breadcrumb-shadow-roots.html [ Crash Failure ] +crbug.com/591099 inspector/elements/shadow/create-shadow-root.html [ Crash Failure Timeout ] +crbug.com/591099 inspector/elements/shadow/elements-panel-shadow-selection-on-refresh-1.html [ Crash Failure ] +crbug.com/591099 inspector/elements/shadow/elements-panel-shadow-selection-on-refresh-2.html [ Crash Failure ] +crbug.com/591099 inspector/elements/shadow/elements-panel-shadow-selection-on-refresh-3.html [ Crash Failure ] +crbug.com/591099 inspector/elements/shadow/inspect-deep-shadow-element.html [ Crash Failure ] +crbug.com/591099 inspector/elements/shadow/reveal-shadow-dom-node.html [ Crash Failure ] +crbug.com/591099 inspector/elements/shadow/shadow-distribution.html [ Crash Timeout ] +crbug.com/591099 inspector/elements/shadow/shadow-host-display-modes.html [ Crash Failure ] +crbug.com/591099 inspector/elements/shadow/shadow-root.html [ Crash Failure ] +crbug.com/591099 inspector/elements/shadow/update-shadowdom.html [ Crash Failure ] +crbug.com/591099 inspector/elements/styles-1/add-new-rule-inline-style-csp.html [ Crash Failure ] +crbug.com/591099 inspector/elements/styles-1/add-new-rule-invalid-selector.html [ Crash Failure ] +crbug.com/591099 inspector/elements/styles-1/add-new-rule-with-style-after-body.html [ Crash Failure ] +crbug.com/591099 inspector/elements/styles-1/cached-sync-computed-styles.html [ Crash Failure ] crbug.com/591099 inspector/elements/styles-1/case-sensitive-suggestions.html [ Crash Failure Timeout ] -crbug.com/591099 inspector/elements/styles-1/color-aware-property-value-edit.html [ Crash ] +crbug.com/591099 inspector/elements/styles-1/color-aware-property-value-edit.html [ Crash Failure ] crbug.com/591099 inspector/elements/styles-1/color-nicknames-lowercase.html [ Crash Failure ] -crbug.com/591099 inspector/elements/styles-1/color-swatch.html [ Crash ] -crbug.com/591099 inspector/elements/styles-1/commit-selector-mark-matching.html [ Crash ] -crbug.com/591099 inspector/elements/styles-1/commit-selector.html [ Crash ] -crbug.com/591099 inspector/elements/styles-1/css-live-edit.html [ Crash ] -crbug.com/591099 inspector/elements/styles-1/css-outline.html [ Crash ] -crbug.com/591099 inspector/elements/styles-1/cssom-media-insert-crash.html [ Crash ] -crbug.com/591099 inspector/elements/styles-1/disable-property-workingcopy-update.html [ Crash ] -crbug.com/591099 inspector/elements/styles-1/dynamic-style-tag.html [ Crash ] -crbug.com/591099 inspector/elements/styles-1/edit-inspector-stylesheet.html [ Crash ] -crbug.com/591099 inspector/elements/styles-1/edit-media-text.html [ Crash ] -crbug.com/591099 inspector/elements/styles-1/edit-name-with-trimmed-value.html [ Crash ] -crbug.com/591099 inspector/elements/styles-1/edit-resource-referred-by-multiple-styletags.html [ Crash ] -crbug.com/591099 inspector/elements/styles-1/edit-value-inside-property.html [ Crash ] -crbug.com/591099 inspector/elements/styles-1/edit-value-url-with-color.html [ Crash ] -crbug.com/591099 inspector/elements/styles-1/edit-value-with-trimmed-url.html [ Crash ] -crbug.com/591099 inspector/elements/styles-1/empty-background-url.html [ Crash ] -crbug.com/591099 inspector/elements/styles-1/filter-matched-styles.html [ Crash ] -crbug.com/591099 inspector/elements/styles-2/add-import-rule.html [ Crash ] -crbug.com/591099 inspector/elements/styles-2/cssom-shorthand-important.html [ Crash ] -crbug.com/591099 inspector/elements/styles-2/filter-matched-styles-hides-separators.html [ Crash ] -crbug.com/591099 inspector/elements/styles-2/force-pseudo-state.html [ Crash ] -crbug.com/591099 inspector/elements/styles-2/get-set-stylesheet-text.html [ Crash ] -crbug.com/591099 inspector/elements/styles-2/import-pseudoclass-crash.html [ Crash ] -crbug.com/591099 inspector/elements/styles-2/inactive-properties.html [ Crash ] -crbug.com/591099 inspector/elements/styles-2/inherited-mixed-case-properties.html [ Crash ] -crbug.com/591099 inspector/elements/styles-2/inject-stylesheet.html [ Crash ] -crbug.com/591099 inspector/elements/styles-2/keyframes-rules.html [ Crash ] -crbug.com/591099 inspector/elements/styles-2/lazy-computed-style.html [ Crash ] -crbug.com/591099 inspector/elements/styles-2/media-emulation.html [ Crash ] -crbug.com/591099 inspector/elements/styles-2/media-queries.html [ Crash ] -crbug.com/591099 inspector/elements/styles-2/media-using-same-url.html [ Crash ] +crbug.com/591099 inspector/elements/styles-1/color-swatch.html [ Crash Failure ] +crbug.com/591099 inspector/elements/styles-1/commit-selector-mark-matching.html [ Crash Failure ] +crbug.com/591099 inspector/elements/styles-1/commit-selector.html [ Crash Failure ] +crbug.com/591099 inspector/elements/styles-1/css-live-edit.html [ Crash Failure ] +crbug.com/591099 inspector/elements/styles-1/css-outline.html [ Crash Failure ] +crbug.com/591099 inspector/elements/styles-1/cssom-media-insert-crash.html [ Crash Pass ] +crbug.com/591099 inspector/elements/styles-1/disable-property-workingcopy-update.html [ Crash Failure ] +crbug.com/591099 inspector/elements/styles-1/dynamic-style-tag.html [ Crash Failure ] +crbug.com/591099 inspector/elements/styles-1/edit-inspector-stylesheet.html [ Crash Failure ] +crbug.com/591099 inspector/elements/styles-1/edit-media-text.html [ Crash Failure ] +crbug.com/591099 inspector/elements/styles-1/edit-name-with-trimmed-value.html [ Crash Failure ] +crbug.com/591099 inspector/elements/styles-1/edit-resource-referred-by-multiple-styletags.html [ Crash Failure ] +crbug.com/591099 inspector/elements/styles-1/edit-value-inside-property.html [ Crash Failure ] +crbug.com/591099 inspector/elements/styles-1/edit-value-url-with-color.html [ Crash Failure ] +crbug.com/591099 inspector/elements/styles-1/edit-value-with-trimmed-url.html [ Crash Failure Timeout ] +crbug.com/591099 inspector/elements/styles-1/empty-background-url.html [ Crash Failure ] +crbug.com/591099 inspector/elements/styles-1/filter-matched-styles.html [ Crash Failure ] +crbug.com/591099 inspector/elements/styles-2/add-import-rule.html [ Crash Pass ] +crbug.com/591099 inspector/elements/styles-2/cssom-shorthand-important.html [ Crash Failure ] +crbug.com/591099 inspector/elements/styles-2/filter-matched-styles-hides-separators.html [ Crash Failure ] +crbug.com/591099 inspector/elements/styles-2/force-pseudo-state.html [ Crash Failure ] +crbug.com/591099 inspector/elements/styles-2/get-set-stylesheet-text.html [ Crash Failure ] +crbug.com/591099 inspector/elements/styles-2/import-pseudoclass-crash.html [ Crash Failure ] +crbug.com/591099 inspector/elements/styles-2/inactive-properties.html [ Crash Failure ] +crbug.com/591099 inspector/elements/styles-2/inherited-mixed-case-properties.html [ Crash Failure ] +crbug.com/591099 inspector/elements/styles-2/inject-stylesheet.html [ Crash Failure ] +crbug.com/591099 inspector/elements/styles-2/keyframes-rules.html [ Crash Failure ] +crbug.com/591099 inspector/elements/styles-2/lazy-computed-style.html [ Crash Failure ] +crbug.com/591099 inspector/elements/styles-2/media-emulation.html [ Crash Failure ] +crbug.com/591099 inspector/elements/styles-2/media-queries.html [ Crash Failure ] +crbug.com/591099 inspector/elements/styles-2/media-using-same-url.html [ Crash Failure ] crbug.com/591099 inspector/elements/styles-2/mixed-case-color-aware-properties.html [ Failure ] -crbug.com/591099 inspector/elements/styles-2/multiple-imports-edit-crash.html [ Crash ] -crbug.com/591099 inspector/elements/styles-2/page-reload-update-sidebar.html [ Crash ] -crbug.com/591099 inspector/elements/styles-2/parse-comments.html [ Crash ] -crbug.com/591099 inspector/elements/styles-2/parse-declaration-unterminated-comment.html [ Crash ] -crbug.com/591099 inspector/elements/styles-2/parse-declaration-with-quote.html [ Crash ] -crbug.com/591099 inspector/elements/styles-2/parse-utf8-bom.html [ Crash ] -crbug.com/591099 inspector/elements/styles-2/paste-property.html [ Crash ] -crbug.com/591099 inspector/elements/styles-2/perform-undo-perform-of-mergable-action.html [ Crash ] -crbug.com/591099 inspector/elements/styles-2/property-ui-location.html [ Crash ] +crbug.com/591099 inspector/elements/styles-2/multiple-imports-edit-crash.html [ Crash Failure ] +crbug.com/591099 inspector/elements/styles-2/page-reload-update-sidebar.html [ Crash Failure ] +crbug.com/591099 inspector/elements/styles-2/parse-comments.html [ Crash Failure ] +crbug.com/591099 inspector/elements/styles-2/parse-declaration-unterminated-comment.html [ Crash Failure ] +crbug.com/591099 inspector/elements/styles-2/parse-declaration-with-quote.html [ Crash Failure ] +crbug.com/591099 inspector/elements/styles-2/parse-utf8-bom.html [ Crash Failure ] +crbug.com/591099 inspector/elements/styles-2/paste-property.html [ Crash Failure ] +crbug.com/591099 inspector/elements/styles-2/perform-undo-perform-of-mergable-action.html [ Crash Failure ] +crbug.com/591099 inspector/elements/styles-2/property-ui-location.html [ Crash Failure ] crbug.com/591099 inspector/elements/styles-2/pseudo-elements.html [ Crash Timeout ] -crbug.com/591099 inspector/elements/styles-2/region-style-crash.html [ Crash ] -crbug.com/591099 inspector/elements/styles-3/computed-properties-retain-expanded.html [ Crash ] -crbug.com/591099 inspector/elements/styles-3/remove-shadow-host.html [ Crash ] -crbug.com/591099 inspector/elements/styles-3/selector-list.html [ Crash ] -crbug.com/591099 inspector/elements/styles-3/selector-source-data.html [ Crash ] -crbug.com/591099 inspector/elements/styles-3/shadow-dom-rules.html [ Crash ] -crbug.com/591099 inspector/elements/styles-3/simple-selector.html [ Crash ] +crbug.com/591099 inspector/elements/styles-2/region-style-crash.html [ Crash Failure ] +crbug.com/591099 inspector/elements/styles-3/computed-properties-retain-expanded.html [ Crash Failure ] +crbug.com/591099 inspector/elements/styles-3/remove-shadow-host.html [ Crash Pass ] +crbug.com/591099 inspector/elements/styles-3/selector-list.html [ Crash Failure ] +crbug.com/591099 inspector/elements/styles-3/selector-source-data.html [ Crash Failure ] +crbug.com/591099 inspector/elements/styles-3/shadow-dom-rules.html [ Crash Failure ] +crbug.com/591099 inspector/elements/styles-3/simple-selector.html [ Crash Failure ] crbug.com/591099 inspector/elements/styles-3/spectrum.html [ Failure ] -crbug.com/591099 inspector/elements/styles-3/style-autocomplete.html [ Crash ] -crbug.com/591099 inspector/elements/styles-3/style-rule-from-imported-stylesheet.html [ Crash ] -crbug.com/591099 inspector/elements/styles-3/styles-add-blank-property.html [ Crash ] -crbug.com/591099 inspector/elements/styles-3/styles-add-invalid-property.html [ Crash ] -crbug.com/591099 inspector/elements/styles-3/styles-add-new-rule-colon.html [ Crash ] -crbug.com/591099 inspector/elements/styles-3/styles-add-new-rule-tab.html [ Crash ] -crbug.com/591099 inspector/elements/styles-3/styles-add-new-rule-to-stylesheet.html [ Crash ] -crbug.com/591099 inspector/elements/styles-3/styles-add-new-rule.html [ Crash ] -crbug.com/591099 inspector/elements/styles-3/styles-cancel-editing.html [ Crash ] -crbug.com/591099 inspector/elements/styles-3/styles-change-node-while-editing.html [ Crash ] -crbug.com/591099 inspector/elements/styles-3/styles-commit-editing.html [ Crash ] -crbug.com/591099 inspector/elements/styles-3/styles-computed-trace.html [ Crash ] -crbug.com/591099 inspector/elements/styles-3/styles-disable-inherited.html [ Crash ] -crbug.com/591099 inspector/elements/styles-3/styles-disable-property-after-selector-edit.html [ Crash ] -crbug.com/591099 inspector/elements/styles-3/styles-disable-then-change.html [ Crash ] -crbug.com/591099 inspector/elements/styles-3/styles-disable-then-delete.html [ Crash ] -crbug.com/591099 inspector/elements/styles-3/styles-disable-then-enable-overriden-ua.html [ Crash ] -crbug.com/591099 inspector/elements/styles-3/styles-disable-then-enable.html [ Crash ] -crbug.com/591099 inspector/elements/styles-3/styles-variables.html [ Crash ] -crbug.com/591099 inspector/elements/styles-4/disable-last-property-without-semicolon.html [ Crash ] -crbug.com/591099 inspector/elements/styles-4/do-not-rebuild-styles-on-every-change.html [ Crash ] -crbug.com/591099 inspector/elements/styles-4/inline-style-sourcemap.html [ Crash ] -crbug.com/591099 inspector/elements/styles-4/keyframes-source-offsets.html [ Crash ] -crbug.com/591099 inspector/elements/styles-4/style-update-during-selector-edit.html [ Crash ] -crbug.com/591099 inspector/elements/styles-4/styles-do-not-detach-sourcemap-on-edits.html [ Crash ] -crbug.com/591099 inspector/elements/styles-4/styles-edit-property-after-invalid-rule.html [ Crash ] -crbug.com/591099 inspector/elements/styles-4/styles-formatting.html [ Crash ] +crbug.com/591099 inspector/elements/styles-3/style-autocomplete.html [ Crash Failure ] +crbug.com/591099 inspector/elements/styles-3/style-rule-from-imported-stylesheet.html [ Crash Failure ] +crbug.com/591099 inspector/elements/styles-3/styles-add-blank-property.html [ Crash Failure ] +crbug.com/591099 inspector/elements/styles-3/styles-add-invalid-property.html [ Crash Failure ] +crbug.com/591099 inspector/elements/styles-3/styles-add-new-rule-colon.html [ Crash Failure ] +crbug.com/591099 inspector/elements/styles-3/styles-add-new-rule-tab.html [ Crash Failure ] +crbug.com/591099 inspector/elements/styles-3/styles-add-new-rule-to-stylesheet.html [ Crash Failure ] +crbug.com/591099 inspector/elements/styles-3/styles-add-new-rule.html [ Crash Failure ] +crbug.com/591099 inspector/elements/styles-3/styles-cancel-editing.html [ Crash Failure ] +crbug.com/591099 inspector/elements/styles-3/styles-change-node-while-editing.html [ Crash Failure ] +crbug.com/591099 inspector/elements/styles-3/styles-commit-editing.html [ Crash Failure ] +crbug.com/591099 inspector/elements/styles-3/styles-computed-trace.html [ Crash Failure ] +crbug.com/591099 inspector/elements/styles-3/styles-disable-inherited.html [ Crash Failure ] +crbug.com/591099 inspector/elements/styles-3/styles-disable-property-after-selector-edit.html [ Crash Failure ] +crbug.com/591099 inspector/elements/styles-3/styles-disable-then-change.html [ Crash Failure ] +crbug.com/591099 inspector/elements/styles-3/styles-disable-then-delete.html [ Crash Failure ] +crbug.com/591099 inspector/elements/styles-3/styles-disable-then-enable-overriden-ua.html [ Crash Failure ] +crbug.com/591099 inspector/elements/styles-3/styles-disable-then-enable.html [ Crash Failure ] +crbug.com/591099 inspector/elements/styles-3/styles-variables.html [ Crash Failure ] +crbug.com/591099 inspector/elements/styles-4/disable-last-property-without-semicolon.html [ Crash Failure ] +crbug.com/591099 inspector/elements/styles-4/do-not-rebuild-styles-on-every-change.html [ Crash Failure ] +crbug.com/591099 inspector/elements/styles-4/inline-style-sourcemap.html [ Crash Failure ] +crbug.com/591099 inspector/elements/styles-4/keyframes-source-offsets.html [ Crash Failure ] +crbug.com/591099 inspector/elements/styles-4/style-update-during-selector-edit.html [ Crash Failure ] +crbug.com/591099 inspector/elements/styles-4/styles-do-not-detach-sourcemap-on-edits.html [ Crash Failure ] +crbug.com/591099 inspector/elements/styles-4/styles-edit-property-after-invalid-rule.html [ Crash Failure ] +crbug.com/591099 inspector/elements/styles-4/styles-formatting.html [ Crash Failure ] crbug.com/591099 inspector/elements/styles-4/styles-history.html [ Crash ] -crbug.com/591099 inspector/elements/styles-4/styles-iframe.html [ Crash ] -crbug.com/591099 inspector/elements/styles-4/styles-inline-element-style-changes-should-not-force-style-recalc.html [ Crash ] +crbug.com/591099 inspector/elements/styles-4/styles-iframe.html [ Crash Failure ] +crbug.com/591099 inspector/elements/styles-4/styles-inline-element-style-changes-should-not-force-style-recalc.html [ Crash Failure ] crbug.com/591099 inspector/elements/styles-4/styles-invalid-color-values.html [ Crash Failure ] -crbug.com/591099 inspector/elements/styles-4/styles-keyframes-cssom-injected.html [ Crash ] -crbug.com/591099 inspector/elements/styles-4/styles-keyframes.html [ Crash ] -crbug.com/591099 inspector/elements/styles-4/styles-live-locations-leak.html [ Crash ] -crbug.com/591099 inspector/elements/styles-4/styles-new-API.html [ Crash ] -crbug.com/591099 inspector/elements/styles-4/styles-overriden-properties.html [ Crash ] -crbug.com/591099 inspector/elements/styles-4/styles-properties-overload.html [ Crash ] -crbug.com/591099 inspector/elements/styles-4/styles-rerequest-sourcemap-on-watchdog.html [ Crash ] -crbug.com/591099 inspector/elements/styles-4/styles-should-not-force-sync-style-recalc.html [ Crash ] -crbug.com/591099 inspector/elements/styles-4/styles-source-lines-inline.html [ Crash ] -crbug.com/591099 inspector/elements/styles-4/styles-source-lines-recovery.html [ Crash ] -crbug.com/591099 inspector/elements/styles-4/styles-source-lines.html [ Crash ] -crbug.com/591099 inspector/elements/styles-4/styles-source-offsets.html [ Crash ] -crbug.com/591099 inspector/elements/styles-4/styles-update-from-js.html [ Crash ] -crbug.com/591099 inspector/elements/styles-4/styles-update-links-1.html [ Crash Timeout ] -crbug.com/591099 inspector/elements/styles-4/styles-update-links-2.html [ Crash ] -crbug.com/591099 inspector/elements/styles-4/styles-update-links-3.html [ Crash ] -crbug.com/591099 inspector/elements/styles-4/styles-update-links-4.html [ Crash ] -crbug.com/591099 inspector/elements/styles-4/styles-url-linkify.html [ Crash ] -crbug.com/591099 inspector/elements/styles-4/styles-with-spaces-in-sourceURL.html [ Crash ] +crbug.com/591099 inspector/elements/styles-4/styles-keyframes-cssom-injected.html [ Crash Pass ] +crbug.com/591099 inspector/elements/styles-4/styles-keyframes.html [ Crash Failure ] +crbug.com/591099 inspector/elements/styles-4/styles-live-locations-leak.html [ Crash Failure ] +crbug.com/591099 inspector/elements/styles-4/styles-new-API.html [ Crash Failure ] +crbug.com/591099 inspector/elements/styles-4/styles-overriden-properties.html [ Crash Failure ] +crbug.com/591099 inspector/elements/styles-4/styles-properties-overload.html [ Crash Failure ] +crbug.com/591099 inspector/elements/styles-4/styles-rerequest-sourcemap-on-watchdog.html [ Crash Failure ] +crbug.com/591099 inspector/elements/styles-4/styles-should-not-force-sync-style-recalc.html [ Crash Failure ] +crbug.com/591099 inspector/elements/styles-4/styles-source-lines-inline.html [ Crash Failure ] +crbug.com/591099 inspector/elements/styles-4/styles-source-lines-recovery.html [ Crash Failure ] +crbug.com/591099 inspector/elements/styles-4/styles-source-lines.html [ Crash Failure ] +crbug.com/591099 inspector/elements/styles-4/styles-source-offsets.html [ Crash Failure ] +crbug.com/591099 inspector/elements/styles-4/styles-update-from-js.html [ Crash Failure ] +crbug.com/591099 inspector/elements/styles-4/styles-update-links-1.html [ Crash Failure Timeout ] +crbug.com/591099 inspector/elements/styles-4/styles-update-links-2.html [ Crash Failure ] +crbug.com/591099 inspector/elements/styles-4/styles-update-links-3.html [ Crash Failure ] +crbug.com/591099 inspector/elements/styles-4/styles-update-links-4.html [ Crash Failure ] +crbug.com/591099 inspector/elements/styles-4/styles-url-linkify.html [ Crash Failure ] +crbug.com/591099 inspector/elements/styles-4/styles-with-spaces-in-sourceURL.html [ Crash Failure ] crbug.com/591099 inspector/elements/styles-4/stylesheet-source-url-comment.html [ Crash Failure ] -crbug.com/591099 inspector/elements/styles-4/svg-style.xhtml [ Crash ] -crbug.com/591099 inspector/elements/styles-4/undo-add-new-rule.html [ Crash ] -crbug.com/591099 inspector/elements/styles-4/undo-add-property.html [ Crash ] -crbug.com/591099 inspector/elements/styles-4/undo-add-rule-crash.html [ Crash ] -crbug.com/591099 inspector/elements/styles/cancel-upon-invalid-property.html [ Crash ] -crbug.com/591099 inspector/elements/styles/original-content-provider.html [ Crash ] -crbug.com/591099 inspector/elements/styles/undo-after-cancelled-editing.html [ Crash ] -crbug.com/591099 inspector/elements/styles/undo-change-property.html [ Crash ] -crbug.com/591099 inspector/elements/styles/undo-property-toggle.html [ Crash ] -crbug.com/591099 inspector/elements/styles/undo-set-selector-text.html [ Crash Timeout ] -crbug.com/591099 inspector/elements/styles/up-down-numerics-and-colors.html [ Crash ] -crbug.com/591099 inspector/elements/styles/updates-during-dom-traversal.html [ Crash ] -crbug.com/591099 inspector/elements/styles/updates-throttled.html [ Crash ] -crbug.com/591099 inspector/elements/styles/url-color-swatch.html [ Crash ] -crbug.com/591099 inspector/elements/styles/url-multiple-collapsing.html [ Crash ] -crbug.com/591099 inspector/elements/user-properties.html [ Crash ] +crbug.com/591099 inspector/elements/styles-4/svg-style.xhtml [ Crash Failure ] +crbug.com/591099 inspector/elements/styles-4/undo-add-new-rule.html [ Crash Failure ] +crbug.com/591099 inspector/elements/styles-4/undo-add-property.html [ Crash Failure ] +crbug.com/591099 inspector/elements/styles-4/undo-add-rule-crash.html [ Crash Failure ] +crbug.com/591099 inspector/elements/styles/cancel-upon-invalid-property.html [ Crash Failure ] +crbug.com/591099 inspector/elements/styles/original-content-provider.html [ Crash Failure ] +crbug.com/591099 inspector/elements/styles/undo-after-cancelled-editing.html [ Crash Failure ] +crbug.com/591099 inspector/elements/styles/undo-change-property.html [ Crash Failure ] +crbug.com/591099 inspector/elements/styles/undo-property-toggle.html [ Crash Failure ] +crbug.com/591099 inspector/elements/styles/undo-set-selector-text.html [ Crash Failure Timeout ] +crbug.com/591099 inspector/elements/styles/up-down-numerics-and-colors.html [ Crash Failure ] +crbug.com/591099 inspector/elements/styles/updates-during-dom-traversal.html [ Crash Failure ] +crbug.com/591099 inspector/elements/styles/updates-throttled.html [ Crash Failure ] +crbug.com/591099 inspector/elements/styles/url-color-swatch.html [ Crash Failure ] +crbug.com/591099 inspector/elements/styles/url-multiple-collapsing.html [ Crash Failure ] +crbug.com/591099 inspector/elements/user-properties.html [ Crash Failure ] crbug.com/591099 inspector/evaluate-in-page.html [ Failure ] crbug.com/591099 inspector/file-reader-with-network-panel.html [ Failure ] crbug.com/591099 inspector/file-system-mapping.html [ Failure ] @@ -16864,7 +16872,7 @@ crbug.com/591099 inspector/filtered-item-selection-dialog-rendering.html [ Failure ] crbug.com/591099 inspector/geolocation-emulation-tests.html [ Failure ] crbug.com/591099 inspector/help/release-note-unit.html [ Crash Failure ] -crbug.com/591099 inspector/help/release-note.html [ Crash ] +crbug.com/591099 inspector/help/release-note.html [ Crash Failure ] crbug.com/591099 inspector/import-open-inspector.html [ Failure ] crbug.com/591099 inspector/initial-modules-load.html [ Failure ] crbug.com/591099 inspector/input-event-warning.html [ Failure ] @@ -16898,40 +16906,40 @@ crbug.com/591099 inspector/profiler/cpu-profiler-save-load.html [ Crash Failure ] crbug.com/591099 inspector/profiler/cpu-profiler-stopped-removed-race.html [ Crash Failure ] crbug.com/591099 inspector/profiler/heap-profiler-profiling.html [ Crash Failure ] -crbug.com/591099 inspector/profiler/heap-snapshot-comparison-dom-groups-change.html [ Crash ] -crbug.com/591099 inspector/profiler/heap-snapshot-comparison-expansion-preserved-when-sorting.html [ Crash ] -crbug.com/591099 inspector/profiler/heap-snapshot-comparison-show-all.html [ Crash ] -crbug.com/591099 inspector/profiler/heap-snapshot-comparison-show-next.html [ Crash ] -crbug.com/591099 inspector/profiler/heap-snapshot-comparison-shown-node-count-preserved-when-sorting.html [ Crash ] -crbug.com/591099 inspector/profiler/heap-snapshot-comparison-sorting.html [ Crash ] -crbug.com/591099 inspector/profiler/heap-snapshot-containment-expansion-preserved-when-sorting.html [ Crash ] -crbug.com/591099 inspector/profiler/heap-snapshot-containment-show-all.html [ Crash ] -crbug.com/591099 inspector/profiler/heap-snapshot-containment-show-next.html [ Crash ] -crbug.com/591099 inspector/profiler/heap-snapshot-containment-shown-node-count-preserved-when-sorting.html [ Crash ] -crbug.com/591099 inspector/profiler/heap-snapshot-containment-sorting.html [ Crash ] -crbug.com/591099 inspector/profiler/heap-snapshot-inspect-dom-wrapper.html [ Crash ] -crbug.com/591099 inspector/profiler/heap-snapshot-loader.html [ Crash ] -crbug.com/591099 inspector/profiler/heap-snapshot-orphan-nodes.html [ Crash ] -crbug.com/591099 inspector/profiler/heap-snapshot-statistics.html [ Crash ] -crbug.com/591099 inspector/profiler/heap-snapshot-summary-expansion-preserved-when-sorting.html [ Crash ] -crbug.com/591099 inspector/profiler/heap-snapshot-summary-retainers.html [ Crash ] -crbug.com/591099 inspector/profiler/heap-snapshot-summary-search-by-id.html [ Crash ] -crbug.com/591099 inspector/profiler/heap-snapshot-summary-search.html [ Crash ] -crbug.com/591099 inspector/profiler/heap-snapshot-summary-show-all.html [ Crash ] -crbug.com/591099 inspector/profiler/heap-snapshot-summary-show-next.html [ Crash ] -crbug.com/591099 inspector/profiler/heap-snapshot-summary-show-ranges.html [ Crash ] -crbug.com/591099 inspector/profiler/heap-snapshot-summary-shown-node-count-preserved-when-sorting.html [ Crash ] -crbug.com/591099 inspector/profiler/heap-snapshot-summary-sorting-fields.html [ Crash ] -crbug.com/591099 inspector/profiler/heap-snapshot-summary-sorting-instances.html [ Crash ] -crbug.com/591099 inspector/profiler/heap-snapshot-summary-sorting.html [ Crash ] -crbug.com/591099 inspector/profiler/heap-snapshot-weak-dominator.html [ Crash ] +crbug.com/591099 inspector/profiler/heap-snapshot-comparison-dom-groups-change.html [ Crash Failure ] +crbug.com/591099 inspector/profiler/heap-snapshot-comparison-expansion-preserved-when-sorting.html [ Crash Failure ] +crbug.com/591099 inspector/profiler/heap-snapshot-comparison-show-all.html [ Crash Failure ] +crbug.com/591099 inspector/profiler/heap-snapshot-comparison-show-next.html [ Crash Failure ] +crbug.com/591099 inspector/profiler/heap-snapshot-comparison-shown-node-count-preserved-when-sorting.html [ Crash Failure ] +crbug.com/591099 inspector/profiler/heap-snapshot-comparison-sorting.html [ Crash Failure ] +crbug.com/591099 inspector/profiler/heap-snapshot-containment-expansion-preserved-when-sorting.html [ Crash Failure ] +crbug.com/591099 inspector/profiler/heap-snapshot-containment-show-all.html [ Crash Failure ] +crbug.com/591099 inspector/profiler/heap-snapshot-containment-show-next.html [ Crash Failure ] +crbug.com/591099 inspector/profiler/heap-snapshot-containment-shown-node-count-preserved-when-sorting.html [ Crash Failure ] +crbug.com/591099 inspector/profiler/heap-snapshot-containment-sorting.html [ Crash Failure ] +crbug.com/591099 inspector/profiler/heap-snapshot-inspect-dom-wrapper.html [ Crash Failure ] +crbug.com/591099 inspector/profiler/heap-snapshot-loader.html [ Crash Failure ] +crbug.com/591099 inspector/profiler/heap-snapshot-orphan-nodes.html [ Crash Pass ] +crbug.com/591099 inspector/profiler/heap-snapshot-statistics.html [ Crash Failure ] +crbug.com/591099 inspector/profiler/heap-snapshot-summary-expansion-preserved-when-sorting.html [ Crash Failure ] +crbug.com/591099 inspector/profiler/heap-snapshot-summary-retainers.html [ Crash Pass ] +crbug.com/591099 inspector/profiler/heap-snapshot-summary-search-by-id.html [ Crash Timeout ] +crbug.com/591099 inspector/profiler/heap-snapshot-summary-search.html [ Crash Failure ] +crbug.com/591099 inspector/profiler/heap-snapshot-summary-show-all.html [ Crash Failure ] +crbug.com/591099 inspector/profiler/heap-snapshot-summary-show-next.html [ Crash Failure ] +crbug.com/591099 inspector/profiler/heap-snapshot-summary-show-ranges.html [ Crash Failure ] +crbug.com/591099 inspector/profiler/heap-snapshot-summary-shown-node-count-preserved-when-sorting.html [ Crash Failure ] +crbug.com/591099 inspector/profiler/heap-snapshot-summary-sorting-fields.html [ Crash Failure ] +crbug.com/591099 inspector/profiler/heap-snapshot-summary-sorting-instances.html [ Crash Failure ] +crbug.com/591099 inspector/profiler/heap-snapshot-summary-sorting.html [ Crash Failure ] +crbug.com/591099 inspector/profiler/heap-snapshot-weak-dominator.html [ Crash Pass ] crbug.com/591099 inspector/profiler/heap-snapshot.html [ Crash Failure ] crbug.com/591099 inspector/profiler/temp-storage-cleaner.html [ Crash Failure ] crbug.com/591099 inspector/quick-open/command-menu.html [ Crash Failure ] crbug.com/591099 inspector/remote-object.html [ Failure ] crbug.com/591099 inspector/report-API-errors.html [ Failure ] crbug.com/591099 inspector/report-protocol-errors.html [ Failure ] -crbug.com/591099 inspector/reveal-objects.html [ Crash ] +crbug.com/591099 inspector/reveal-objects.html [ Crash Failure ] crbug.com/591099 inspector/runtime.html [ Failure ] crbug.com/591099 inspector/runtime/runtime-callFunctionOn.html [ Crash Failure ] crbug.com/591099 inspector/runtime/runtime-es6-setSymbolPropertyValue.html [ Failure ] @@ -16939,32 +16947,32 @@ crbug.com/591099 inspector/runtime/runtime-getProperties.html [ Failure ] crbug.com/591099 inspector/runtime/runtime-localStorage-getProperties.html [ Crash Failure ] crbug.com/591099 inspector/runtime/runtime-setPropertyValue.html [ Crash Failure ] -crbug.com/591099 inspector/sass/test-ast-css-1.html [ Crash ] -crbug.com/591099 inspector/sass/test-ast-css-2.html [ Crash ] -crbug.com/591099 inspector/sass/test-ast-css-3.html [ Crash ] -crbug.com/591099 inspector/sass/test-ast-diff-1.html [ Crash ] -crbug.com/591099 inspector/sass/test-ast-editing-1.html [ Crash ] -crbug.com/591099 inspector/sass/test-ast-editing-2.html [ Crash ] -crbug.com/591099 inspector/sass/test-ast-scss-1.html [ Crash ] -crbug.com/591099 inspector/sass/test-ast-scss-2.html [ Crash ] -crbug.com/591099 inspector/sass/test-ast-scss-3.html [ Crash ] -crbug.com/591099 inspector/sass/test-ast-scss-4.html [ Crash ] -crbug.com/591099 inspector/sass/test-ast-scss-5.html [ Crash ] -crbug.com/591099 inspector/sass/test-ast-scss-6.html [ Crash ] -crbug.com/591099 inspector/sass/test-ast-scss-7.html [ Crash ] +crbug.com/591099 inspector/sass/test-ast-css-1.html [ Crash Failure ] +crbug.com/591099 inspector/sass/test-ast-css-2.html [ Crash Failure ] +crbug.com/591099 inspector/sass/test-ast-css-3.html [ Crash Failure ] +crbug.com/591099 inspector/sass/test-ast-diff-1.html [ Crash Failure ] +crbug.com/591099 inspector/sass/test-ast-editing-1.html [ Crash Failure ] +crbug.com/591099 inspector/sass/test-ast-editing-2.html [ Crash Failure ] +crbug.com/591099 inspector/sass/test-ast-scss-1.html [ Crash Failure ] +crbug.com/591099 inspector/sass/test-ast-scss-2.html [ Crash Failure ] +crbug.com/591099 inspector/sass/test-ast-scss-3.html [ Crash Failure ] +crbug.com/591099 inspector/sass/test-ast-scss-4.html [ Crash Failure ] +crbug.com/591099 inspector/sass/test-ast-scss-5.html [ Crash Failure ] +crbug.com/591099 inspector/sass/test-ast-scss-6.html [ Crash Failure ] +crbug.com/591099 inspector/sass/test-ast-scss-7.html [ Crash Failure ] crbug.com/591099 inspector/sass/test-edit-insert-property-empty-rule.html [ Failure ] crbug.com/591099 inspector/sass/test-edit-insert-property.html [ Failure ] crbug.com/591099 inspector/sass/test-edit-remove-property.html [ Failure ] crbug.com/591099 inspector/sass/test-edit-set-property-text.html [ Failure ] crbug.com/591099 inspector/sass/test-edit-toggle-property.html [ Crash Failure ] -crbug.com/591099 inspector/sass/test-find-node-for-position.html [ Crash ] +crbug.com/591099 inspector/sass/test-find-node-for-position.html [ Crash Failure ] crbug.com/591099 inspector/sass/test-mapping-bad.html [ Crash Failure ] crbug.com/591099 inspector/sass/test-mapping-good.html [ Failure ] crbug.com/591099 inspector/sass/test-mapping-many-scss.html [ Failure ] crbug.com/591099 inspector/sass/test-mapping-with-cache-busting-url.html [ Crash Failure ] -crbug.com/591099 inspector/sass/test-ssp-breaking-edits.html [ Crash ] -crbug.com/591099 inspector/sass/test-ssp-editing.html [ Crash ] -crbug.com/591099 inspector/sass/test-ssp-incremental-edit-invalid-value.html [ Crash ] +crbug.com/591099 inspector/sass/test-ssp-breaking-edits.html [ Crash Failure ] +crbug.com/591099 inspector/sass/test-ssp-editing.html [ Crash Failure ] +crbug.com/591099 inspector/sass/test-ssp-incremental-edit-invalid-value.html [ Crash Failure ] crbug.com/591099 inspector/schema-get-domains-matches-agents.html [ Failure ] crbug.com/591099 inspector/sources/autocomplete-css.html [ Crash Failure ] crbug.com/591099 inspector/sources/autocomplete-general.html [ Crash Failure ] @@ -17194,98 +17202,98 @@ crbug.com/591099 inspector/tracing-model-ids.html [ Failure ] crbug.com/591099 inspector/tracing-model-storage.html [ Failure ] crbug.com/591099 inspector/tracing-model.html [ Failure ] -crbug.com/591099 inspector/tracing-session-id.html [ Crash ] -crbug.com/591099 inspector/tracing/anonymous-image-object.html [ Crash ] +crbug.com/591099 inspector/tracing-session-id.html [ Crash Failure ] +crbug.com/591099 inspector/tracing/anonymous-image-object.html [ Crash Failure ] crbug.com/591099 inspector/tracing/buffer-usage.html [ Failure ] crbug.com/591099 inspector/tracing/category-filter.html [ Failure ] -crbug.com/591099 inspector/tracing/console-timeline.html [ Crash ] -crbug.com/591099 inspector/tracing/decode-resize.html [ Crash Timeout ] -crbug.com/591099 inspector/tracing/frame-model-instrumentation.html [ Crash ] +crbug.com/591099 inspector/tracing/console-timeline.html [ Crash Failure ] +crbug.com/591099 inspector/tracing/decode-resize.html [ Crash Failure Timeout ] +crbug.com/591099 inspector/tracing/frame-model-instrumentation.html [ Crash Pass ] crbug.com/591099 inspector/tracing/frame-model.html [ Crash Failure ] -crbug.com/591099 inspector/tracing/hit-test.html [ Crash ] -crbug.com/591099 inspector/tracing/scroll-invalidations.html [ Crash ] -crbug.com/591099 inspector/tracing/timeline-js/compile-script.html [ Crash ] -crbug.com/591099 inspector/tracing/timeline-js/timeline-gc-event.html [ Crash ] -crbug.com/591099 inspector/tracing/timeline-js/timeline-injected-script-eval.html [ Crash ] -crbug.com/591099 inspector/tracing/timeline-js/timeline-js-line-level-profile.html [ Crash ] -crbug.com/591099 inspector/tracing/timeline-js/timeline-microtasks.html [ Crash ] +crbug.com/591099 inspector/tracing/hit-test.html [ Crash Failure ] +crbug.com/591099 inspector/tracing/scroll-invalidations.html [ Crash Failure ] +crbug.com/591099 inspector/tracing/timeline-js/compile-script.html [ Crash Failure ] +crbug.com/591099 inspector/tracing/timeline-js/timeline-gc-event.html [ Crash Failure ] +crbug.com/591099 inspector/tracing/timeline-js/timeline-injected-script-eval.html [ Crash Pass ] +crbug.com/591099 inspector/tracing/timeline-js/timeline-js-line-level-profile.html [ Crash Pass ] +crbug.com/591099 inspector/tracing/timeline-js/timeline-microtasks.html [ Crash Failure ] crbug.com/591099 inspector/tracing/timeline-js/timeline-open-function-call.html [ Failure ] -crbug.com/591099 inspector/tracing/timeline-js/timeline-runtime-stats.html [ Crash ] -crbug.com/591099 inspector/tracing/timeline-js/timeline-script-id.html [ Crash ] -crbug.com/591099 inspector/tracing/timeline-js/timeline-script-tag-1.html [ Crash ] -crbug.com/591099 inspector/tracing/timeline-js/timeline-script-tag-2.html [ Crash ] -crbug.com/591099 inspector/tracing/timeline-layout/timeline-layout-reason.html [ Crash ] -crbug.com/591099 inspector/tracing/timeline-layout/timeline-layout-with-invalidations.html [ Crash ] -crbug.com/591099 inspector/tracing/timeline-layout/timeline-layout.html [ Crash ] -crbug.com/591099 inspector/tracing/timeline-misc/timeline-aggregated-details.html [ Crash ] -crbug.com/591099 inspector/tracing/timeline-misc/timeline-animation-frame.html [ Crash ] -crbug.com/591099 inspector/tracing/timeline-misc/timeline-bound-function.html [ Crash ] -crbug.com/591099 inspector/tracing/timeline-misc/timeline-event-causes.html [ Crash ] +crbug.com/591099 inspector/tracing/timeline-js/timeline-runtime-stats.html [ Crash Pass ] +crbug.com/591099 inspector/tracing/timeline-js/timeline-script-id.html [ Crash Failure ] +crbug.com/591099 inspector/tracing/timeline-js/timeline-script-tag-1.html [ Crash Failure ] +crbug.com/591099 inspector/tracing/timeline-js/timeline-script-tag-2.html [ Crash Failure ] +crbug.com/591099 inspector/tracing/timeline-layout/timeline-layout-reason.html [ Crash Failure ] +crbug.com/591099 inspector/tracing/timeline-layout/timeline-layout-with-invalidations.html [ Crash Failure ] +crbug.com/591099 inspector/tracing/timeline-layout/timeline-layout.html [ Crash Failure ] +crbug.com/591099 inspector/tracing/timeline-misc/timeline-aggregated-details.html [ Crash Pass ] +crbug.com/591099 inspector/tracing/timeline-misc/timeline-animation-frame.html [ Crash Failure ] +crbug.com/591099 inspector/tracing/timeline-misc/timeline-bound-function.html [ Crash Failure ] +crbug.com/591099 inspector/tracing/timeline-misc/timeline-event-causes.html [ Crash Failure ] crbug.com/591099 inspector/tracing/timeline-misc/timeline-event-details.html [ Crash Failure ] -crbug.com/591099 inspector/tracing/timeline-misc/timeline-event-dispatch.html [ Crash ] +crbug.com/591099 inspector/tracing/timeline-misc/timeline-event-dispatch.html [ Crash Failure ] crbug.com/591099 inspector/tracing/timeline-misc/timeline-filtering.html [ Crash Failure ] -crbug.com/591099 inspector/tracing/timeline-misc/timeline-flame-chart-automatically-size-window.html [ Crash ] -crbug.com/591099 inspector/tracing/timeline-misc/timeline-grouped-invalidations.html [ Crash ] -crbug.com/591099 inspector/tracing/timeline-misc/timeline-load-event.html [ Crash ] -crbug.com/591099 inspector/tracing/timeline-misc/timeline-mark-timeline.html [ Crash ] +crbug.com/591099 inspector/tracing/timeline-misc/timeline-flame-chart-automatically-size-window.html [ Crash Failure ] +crbug.com/591099 inspector/tracing/timeline-misc/timeline-grouped-invalidations.html [ Crash Failure ] +crbug.com/591099 inspector/tracing/timeline-misc/timeline-load-event.html [ Crash Failure ] +crbug.com/591099 inspector/tracing/timeline-misc/timeline-mark-timeline.html [ Crash Failure ] crbug.com/591099 inspector/tracing/timeline-misc/timeline-model.html [ Crash Failure ] -crbug.com/591099 inspector/tracing/timeline-misc/timeline-node-reference.html [ Crash ] -crbug.com/591099 inspector/tracing/timeline-misc/timeline-parse-html.html [ Crash ] +crbug.com/591099 inspector/tracing/timeline-misc/timeline-node-reference.html [ Crash Failure ] +crbug.com/591099 inspector/tracing/timeline-misc/timeline-parse-html.html [ Crash Failure ] crbug.com/591099 inspector/tracing/timeline-misc/timeline-range-stats.html [ Failure ] -crbug.com/591099 inspector/tracing/timeline-misc/timeline-record-reload.html [ Crash ] +crbug.com/591099 inspector/tracing/timeline-misc/timeline-record-reload.html [ Crash Failure ] crbug.com/591099 inspector/tracing/timeline-misc/timeline-search.html [ Failure ] crbug.com/591099 inspector/tracing/timeline-misc/timeline-tree-search.html [ Crash Failure ] -crbug.com/591099 inspector/tracing/timeline-misc/timeline-trivial.html [ Crash ] -crbug.com/591099 inspector/tracing/timeline-misc/timeline-window-filter.html [ Crash ] +crbug.com/591099 inspector/tracing/timeline-misc/timeline-trivial.html [ Crash Failure ] +crbug.com/591099 inspector/tracing/timeline-misc/timeline-window-filter.html [ Crash Failure ] crbug.com/591099 inspector/tracing/timeline-network/timeline-network-resource-details.html [ Failure ] crbug.com/591099 inspector/tracing/timeline-network/timeline-network-resource.html [ Failure ] -crbug.com/591099 inspector/tracing/timeline-paint/layer-tree.html [ Crash ] -crbug.com/591099 inspector/tracing/timeline-paint/paint-profiler-update.html [ Crash ] -crbug.com/591099 inspector/tracing/timeline-paint/timeline-paint-and-multiple-style-invalidations.html [ Crash ] -crbug.com/591099 inspector/tracing/timeline-paint/timeline-paint-with-layout-invalidations-on-deleted-node.html [ Crash ] -crbug.com/591099 inspector/tracing/timeline-paint/timeline-paint-with-layout-invalidations.html [ Crash ] -crbug.com/591099 inspector/tracing/timeline-paint/timeline-paint-with-style-recalc-invalidations.html [ Crash ] -crbug.com/591099 inspector/tracing/timeline-paint/timeline-paint.html [ Crash ] -crbug.com/591099 inspector/tracing/timeline-paint/update-layer-tree.html [ Crash ] -crbug.com/591099 inspector/tracing/timeline-style/parse-author-style-sheet.html [ Crash ] -crbug.com/591099 inspector/tracing/timeline-style/timeline-recalculate-styles.html [ Crash ] -crbug.com/591099 inspector/tracing/timeline-style/timeline-style-recalc-all-invalidator-types.html [ Crash ] -crbug.com/591099 inspector/tracing/timeline-style/timeline-style-recalc-with-invalidations.html [ Crash ] -crbug.com/591099 inspector/tracing/timeline-style/timeline-style-recalc-with-invalidator-invalidations.html [ Crash ] -crbug.com/591099 inspector/tracing/timeline-time/timeline-time-stamp.html [ Crash ] -crbug.com/591099 inspector/tracing/timeline-time/timeline-time.html [ Crash ] -crbug.com/591099 inspector/tracing/timeline-time/timeline-timer-fired-from-eval-call-site.html [ Crash ] -crbug.com/591099 inspector/tracing/timeline-time/timeline-timer.html [ Crash ] -crbug.com/591099 inspector/tracing/timeline-time/timeline-usertiming.html [ Crash ] +crbug.com/591099 inspector/tracing/timeline-paint/layer-tree.html [ Crash Pass ] +crbug.com/591099 inspector/tracing/timeline-paint/paint-profiler-update.html [ Crash Failure ] +crbug.com/591099 inspector/tracing/timeline-paint/timeline-paint-and-multiple-style-invalidations.html [ Crash Failure ] +crbug.com/591099 inspector/tracing/timeline-paint/timeline-paint-with-layout-invalidations-on-deleted-node.html [ Crash Failure ] +crbug.com/591099 inspector/tracing/timeline-paint/timeline-paint-with-layout-invalidations.html [ Crash Failure ] +crbug.com/591099 inspector/tracing/timeline-paint/timeline-paint-with-style-recalc-invalidations.html [ Crash Failure ] +crbug.com/591099 inspector/tracing/timeline-paint/timeline-paint.html [ Crash Failure ] +crbug.com/591099 inspector/tracing/timeline-paint/update-layer-tree.html [ Crash Failure ] +crbug.com/591099 inspector/tracing/timeline-style/parse-author-style-sheet.html [ Crash Failure ] +crbug.com/591099 inspector/tracing/timeline-style/timeline-recalculate-styles.html [ Crash Failure ] +crbug.com/591099 inspector/tracing/timeline-style/timeline-style-recalc-all-invalidator-types.html [ Crash Failure ] +crbug.com/591099 inspector/tracing/timeline-style/timeline-style-recalc-with-invalidations.html [ Crash Failure ] +crbug.com/591099 inspector/tracing/timeline-style/timeline-style-recalc-with-invalidator-invalidations.html [ Crash Failure ] +crbug.com/591099 inspector/tracing/timeline-time/timeline-time-stamp.html [ Crash Failure ] +crbug.com/591099 inspector/tracing/timeline-time/timeline-time.html [ Crash Failure ] +crbug.com/591099 inspector/tracing/timeline-time/timeline-timer-fired-from-eval-call-site.html [ Crash Failure ] +crbug.com/591099 inspector/tracing/timeline-time/timeline-timer.html [ Crash Failure ] +crbug.com/591099 inspector/tracing/timeline-time/timeline-usertiming.html [ Crash Failure ] crbug.com/591099 inspector/tracing/tracing-timeline-load.html [ Failure ] -crbug.com/591099 inspector/tracing/worker-events.html [ Crash ] -crbug.com/591099 inspector/tracing/worker-js-frames.html [ Crash ] +crbug.com/591099 inspector/tracing/worker-events.html [ Crash Failure ] +crbug.com/591099 inspector/tracing/worker-js-frames.html [ Crash Failure ] crbug.com/591099 inspector/uisourcecode-revisions.html [ Failure ] crbug.com/591099 inspector/user-metrics.html [ Failure ] crbug.com/591099 inspector/version-controller.html [ Failure ] crbug.com/591099 inspector/workspace-mapping.html [ Failure ] -crbug.com/591099 installedapp/getinstalledrelatedapps-iframe.html [ Crash ] -crbug.com/591099 intersection-observer/client-rect.html [ Crash ] -crbug.com/591099 intersection-observer/cross-origin-iframe.html [ Crash ] +crbug.com/591099 installedapp/getinstalledrelatedapps-iframe.html [ Crash Pass ] +crbug.com/591099 intersection-observer/client-rect.html [ Crash Pass ] +crbug.com/591099 intersection-observer/cross-origin-iframe.html [ Crash Pass ] crbug.com/591099 intersection-observer/edge-inclusive-intersection.html [ Failure ] -crbug.com/591099 intersection-observer/iframe-no-root.html [ Crash ] -crbug.com/591099 intersection-observer/observer-in-iframe.html [ Crash ] +crbug.com/591099 intersection-observer/iframe-no-root.html [ Crash Pass ] +crbug.com/591099 intersection-observer/observer-in-iframe.html [ Crash Pass ] crbug.com/591099 intersection-observer/remove-element.html [ Failure ] -crbug.com/591099 intersection-observer/root-margin.html [ Crash ] -crbug.com/591099 intersection-observer/same-document-root.html [ Crash ] -crbug.com/591099 jquery/attributes.html [ Crash ] -crbug.com/591099 jquery/core.html [ Crash ] -crbug.com/591099 jquery/css.html [ Crash ] -crbug.com/591099 jquery/data.html [ Crash ] -crbug.com/591099 jquery/deferred.html [ Crash ] -crbug.com/591099 jquery/dimensions.html [ Crash ] -crbug.com/591099 jquery/event.html [ Crash ] -crbug.com/591099 jquery/manipulation.html [ Crash ] -crbug.com/591099 jquery/offset.html [ Crash ] -crbug.com/591099 jquery/traversing.html [ Crash ] +crbug.com/591099 intersection-observer/root-margin.html [ Crash Pass ] +crbug.com/591099 intersection-observer/same-document-root.html [ Crash Failure ] +crbug.com/591099 jquery/attributes.html [ Crash Pass ] +crbug.com/591099 jquery/core.html [ Crash Pass ] +crbug.com/591099 jquery/css.html [ Crash Pass ] +crbug.com/591099 jquery/data.html [ Crash Pass ] +crbug.com/591099 jquery/deferred.html [ Crash Pass ] +crbug.com/591099 jquery/dimensions.html [ Crash Pass ] +crbug.com/591099 jquery/event.html [ Crash Pass ] +crbug.com/591099 jquery/manipulation.html [ Crash Pass ] +crbug.com/591099 jquery/offset.html [ Crash Failure ] +crbug.com/591099 jquery/traversing.html [ Crash Pass ] crbug.com/591099 loader/iframe-src-change-onload-crash.html [ Failure ] -crbug.com/591099 loader/iframe-sync-loads.html [ Crash ] -crbug.com/591099 loader/image-loader-base.html [ Crash ] +crbug.com/591099 loader/iframe-sync-loads.html [ Crash Pass ] +crbug.com/591099 loader/image-loader-base.html [ Crash Pass ] crbug.com/591099 media/W3C/audio/canPlayType/canPlayType_application_octet_stream.html [ Failure ] crbug.com/591099 media/W3C/audio/canPlayType/canPlayType_application_octet_stream_with_codecs_1.html [ Failure ] crbug.com/591099 media/W3C/audio/canPlayType/canPlayType_application_octet_stream_with_codecs_2.html [ Failure ] @@ -17418,327 +17426,327 @@ crbug.com/591099 media/W3C/video/src/src_reflects_attribute_not_source_elements.html [ Failure ] crbug.com/591099 media/W3C/video/src/src_reflects_no_value.html [ Failure ] crbug.com/591099 media/W3C/video/src/src_removal_does_not_trigger_loadstart.html [ Failure ] -crbug.com/591099 media/audio-controls-captions.html [ Crash ] -crbug.com/591099 media/audio-controls-do-not-fade-out.html [ Crash ] -crbug.com/591099 media/audio-delete-while-slider-thumb-clicked.html [ Crash ] +crbug.com/591099 media/audio-controls-captions.html [ Crash Pass ] +crbug.com/591099 media/audio-controls-do-not-fade-out.html [ Crash Pass ] +crbug.com/591099 media/audio-delete-while-slider-thumb-clicked.html [ Crash Pass ] crbug.com/591099 media/audio-only-video-intrinsic-size.html [ Failure ] -crbug.com/591099 media/auto-play-in-sandbox-with-allow-scripts.html [ Crash ] -crbug.com/591099 media/autoplay-document-move.html [ Crash ] -crbug.com/591099 media/autoplay-muted-conditions.html [ Crash ] -crbug.com/591099 media/autoplay-muted.html [ Crash Timeout ] -crbug.com/591099 media/autoplay-non-whitelisted-scope.html [ Crash ] -crbug.com/591099 media/autoplay-whitelisted-scope.html [ Crash ] +crbug.com/591099 media/auto-play-in-sandbox-with-allow-scripts.html [ Crash Pass ] +crbug.com/591099 media/autoplay-document-move.html [ Crash Pass ] +crbug.com/591099 media/autoplay-muted-conditions.html [ Crash Pass ] +crbug.com/591099 media/autoplay-muted.html [ Crash Pass Timeout ] +crbug.com/591099 media/autoplay-non-whitelisted-scope.html [ Crash Pass ] +crbug.com/591099 media/autoplay-whitelisted-scope.html [ Crash Pass ] crbug.com/591099 media/autoplay/document-user-activation.html [ Failure ] -crbug.com/591099 media/before-load-member-access.html [ Crash ] -crbug.com/591099 media/broken-video.html [ Crash ] +crbug.com/591099 media/before-load-member-access.html [ Crash Pass ] +crbug.com/591099 media/broken-video.html [ Crash Pass ] crbug.com/591099 media/color-profile-video-poster-image.html [ Failure Pass ] crbug.com/591099 media/color-profile-video-seek-filter.html [ Failure Pass ] crbug.com/591099 media/color-profile-video-seek-object-fit.html [ Failure Pass ] crbug.com/591099 media/color-profile-video-seek.html [ Failure Pass ] crbug.com/591099 media/color-profile-video.html [ Failure Pass ] -crbug.com/591099 media/constructors.html [ Crash ] -crbug.com/591099 media/controls-css-overload.html [ Crash ] -crbug.com/591099 media/controls-drag-timebar.html [ Crash ] -crbug.com/591099 media/controls-right-click-on-timebar.html [ Crash ] +crbug.com/591099 media/constructors.html [ Crash Pass ] +crbug.com/591099 media/controls-css-overload.html [ Crash Pass ] +crbug.com/591099 media/controls-drag-timebar.html [ Crash Pass ] +crbug.com/591099 media/controls-right-click-on-timebar.html [ Crash Pass ] crbug.com/591099 media/controls-slider-appearance-crash.html [ Failure ] -crbug.com/591099 media/controls-timeline.html [ Crash ] -crbug.com/591099 media/controls-volume-slider-keynav.html [ Crash ] -crbug.com/591099 media/controls-volume-slider.html [ Crash ] -crbug.com/591099 media/controls/closed-captions-dynamic-update.html [ Crash ] -crbug.com/591099 media/controls/closed-captions-on-off.html [ Crash ] -crbug.com/591099 media/controls/closed-captions-single-track.html [ Crash ] -crbug.com/591099 media/controls/closed-captions-switch-track.html [ Crash ] -crbug.com/591099 media/controls/controls-cast-button-narrow.html [ Crash ] -crbug.com/591099 media/controls/controls-cast-button.html [ Crash ] -crbug.com/591099 media/controls/controls-cast-do-not-fade-out.html [ Crash ] -crbug.com/591099 media/controls/controls-cast-overlay-slow-fade.html [ Crash ] -crbug.com/591099 media/controls/controls-overlay-cast-button.html [ Crash ] -crbug.com/591099 media/controls/controls-video-keynav-no-controls.html [ Crash ] -crbug.com/591099 media/controls/controls-video-keynav.html [ Crash ] -crbug.com/591099 media/controls/download-button-displays-with-preload-none.html [ Crash ] -crbug.com/591099 media/controls/overflow-fully-hidden.html [ Crash ] -crbug.com/591099 media/controls/overlay-play-button-document-move.html [ Crash ] -crbug.com/591099 media/controls/overlay-play-button-narrow.html [ Crash ] -crbug.com/591099 media/controls/settings-disable-controls.html [ Crash ] -crbug.com/591099 media/controls/video-controls-overflow-menu-hide-on-click-outside.html [ Crash ] -crbug.com/591099 media/controls/video-controls-overflow-menu-hide-on-click-panel.html [ Crash ] -crbug.com/591099 media/controls/video-controls-overflow-menu-hide-on-click.html [ Crash ] -crbug.com/591099 media/controls/video-controls-overflow-menu-hide-on-resize.html [ Crash ] -crbug.com/591099 media/controls/video-controls-overflow-menu-text.html [ Crash ] -crbug.com/591099 media/controls/video-controls-overflow-menu-visibility.html [ Crash ] +crbug.com/591099 media/controls-timeline.html [ Crash Pass ] +crbug.com/591099 media/controls-volume-slider-keynav.html [ Crash Pass ] +crbug.com/591099 media/controls-volume-slider.html [ Crash Pass ] +crbug.com/591099 media/controls/closed-captions-dynamic-update.html [ Crash Pass ] +crbug.com/591099 media/controls/closed-captions-on-off.html [ Crash Pass ] +crbug.com/591099 media/controls/closed-captions-single-track.html [ Crash Pass ] +crbug.com/591099 media/controls/closed-captions-switch-track.html [ Crash Pass ] +crbug.com/591099 media/controls/controls-cast-button-narrow.html [ Crash Pass ] +crbug.com/591099 media/controls/controls-cast-button.html [ Crash Pass ] +crbug.com/591099 media/controls/controls-cast-do-not-fade-out.html [ Crash Pass ] +crbug.com/591099 media/controls/controls-cast-overlay-slow-fade.html [ Crash Pass ] +crbug.com/591099 media/controls/controls-overlay-cast-button.html [ Crash Pass ] +crbug.com/591099 media/controls/controls-video-keynav-no-controls.html [ Crash Pass ] +crbug.com/591099 media/controls/controls-video-keynav.html [ Crash Pass ] +crbug.com/591099 media/controls/download-button-displays-with-preload-none.html [ Crash Pass ] +crbug.com/591099 media/controls/overflow-fully-hidden.html [ Crash Pass ] +crbug.com/591099 media/controls/overlay-play-button-document-move.html [ Crash Pass ] +crbug.com/591099 media/controls/overlay-play-button-narrow.html [ Crash Pass ] +crbug.com/591099 media/controls/settings-disable-controls.html [ Crash Pass ] +crbug.com/591099 media/controls/video-controls-overflow-menu-hide-on-click-outside.html [ Crash Pass ] +crbug.com/591099 media/controls/video-controls-overflow-menu-hide-on-click-panel.html [ Crash Pass ] +crbug.com/591099 media/controls/video-controls-overflow-menu-hide-on-click.html [ Crash Pass ] +crbug.com/591099 media/controls/video-controls-overflow-menu-hide-on-resize.html [ Crash Pass ] +crbug.com/591099 media/controls/video-controls-overflow-menu-text.html [ Crash Pass ] +crbug.com/591099 media/controls/video-controls-overflow-menu-visibility.html [ Crash Pass ] crbug.com/591099 media/controls/video-controls-with-cast-rendering.html [ Failure ] -crbug.com/591099 media/controls/video-enter-exit-fullscreen-while-hovering-shows-controls.html [ Crash ] -crbug.com/591099 media/controls/video-enter-exit-fullscreen-without-hovering-doesnt-show-controls.html [ Crash ] +crbug.com/591099 media/controls/video-enter-exit-fullscreen-while-hovering-shows-controls.html [ Crash Pass ] +crbug.com/591099 media/controls/video-enter-exit-fullscreen-without-hovering-doesnt-show-controls.html [ Crash Pass ] crbug.com/591099 media/controls/video-overlay-cast-dark-rendering.html [ Failure ] crbug.com/591099 media/controls/video-overlay-cast-light-rendering.html [ Failure ] -crbug.com/591099 media/controls/video-overlay-play-button.html [ Crash ] -crbug.com/591099 media/crash-in-media-moved-to-newdocument.html [ Crash ] -crbug.com/591099 media/csp-blocks-video.html [ Crash ] -crbug.com/591099 media/deprecated-css-selectors.html [ Crash ] -crbug.com/591099 media/encrypted-media/encrypted-media-lifetime-reload.html [ Crash ] -crbug.com/591099 media/encrypted-media/encrypted-media-onencrypted.html [ Crash ] -crbug.com/591099 media/encrypted-media/encrypted-media-playback-encrypted-and-clear-sources.html [ Crash ] -crbug.com/591099 media/encrypted-media/encrypted-media-playback-multiple-sessions.html [ Crash ] -crbug.com/591099 media/encrypted-media/encrypted-media-playback-setmediakeys-after-src.html [ Crash ] -crbug.com/591099 media/encrypted-media/encrypted-media-playback-setmediakeys-before-src.html [ Crash ] -crbug.com/591099 media/encrypted-media/encrypted-media-playback-two-videos.html [ Crash ] -crbug.com/591099 media/encrypted-media/encrypted-media-reset-src-after-setmediakeys.html [ Crash ] -crbug.com/591099 media/encrypted-media/encrypted-media-reset-src-during-setmediakeys.html [ Crash ] -crbug.com/591099 media/encrypted-media/encrypted-media-setmediakeys-again-after-playback.html [ Crash ] -crbug.com/591099 media/encrypted-media/encrypted-media-setmediakeys-again-after-resetting-src.html [ Crash ] -crbug.com/591099 media/encrypted-media/encrypted-media-setmediakeys-at-same-time.html [ Crash ] -crbug.com/591099 media/encrypted-media/encrypted-media-setmediakeys-multiple-times-with-different-mediakeys.html [ Crash ] -crbug.com/591099 media/encrypted-media/encrypted-media-setmediakeys-multiple-times-with-the-same-mediakeys.html [ Crash ] -crbug.com/591099 media/encrypted-media/encrypted-media-setmediakeys-to-multiple-video-elements.html [ Crash ] -crbug.com/591099 media/encrypted-media/encrypted-media-setmediakeys.html [ Crash ] -crbug.com/591099 media/encrypted-media/encrypted-media-waiting-for-a-key.html [ Crash ] -crbug.com/591099 media/event-attributes.html [ Crash ] +crbug.com/591099 media/controls/video-overlay-play-button.html [ Crash Pass ] +crbug.com/591099 media/crash-in-media-moved-to-newdocument.html [ Crash Pass ] +crbug.com/591099 media/csp-blocks-video.html [ Crash Pass ] +crbug.com/591099 media/deprecated-css-selectors.html [ Crash Pass ] +crbug.com/591099 media/encrypted-media/encrypted-media-lifetime-reload.html [ Crash Pass ] +crbug.com/591099 media/encrypted-media/encrypted-media-onencrypted.html [ Crash Pass ] +crbug.com/591099 media/encrypted-media/encrypted-media-playback-encrypted-and-clear-sources.html [ Crash Pass ] +crbug.com/591099 media/encrypted-media/encrypted-media-playback-multiple-sessions.html [ Crash Pass ] +crbug.com/591099 media/encrypted-media/encrypted-media-playback-setmediakeys-after-src.html [ Crash Pass ] +crbug.com/591099 media/encrypted-media/encrypted-media-playback-setmediakeys-before-src.html [ Crash Pass ] +crbug.com/591099 media/encrypted-media/encrypted-media-playback-two-videos.html [ Crash Pass ] +crbug.com/591099 media/encrypted-media/encrypted-media-reset-src-after-setmediakeys.html [ Crash Pass ] +crbug.com/591099 media/encrypted-media/encrypted-media-reset-src-during-setmediakeys.html [ Crash Pass ] +crbug.com/591099 media/encrypted-media/encrypted-media-setmediakeys-again-after-playback.html [ Crash Pass ] +crbug.com/591099 media/encrypted-media/encrypted-media-setmediakeys-again-after-resetting-src.html [ Crash Pass ] +crbug.com/591099 media/encrypted-media/encrypted-media-setmediakeys-at-same-time.html [ Crash Pass ] +crbug.com/591099 media/encrypted-media/encrypted-media-setmediakeys-multiple-times-with-different-mediakeys.html [ Crash Pass ] +crbug.com/591099 media/encrypted-media/encrypted-media-setmediakeys-multiple-times-with-the-same-mediakeys.html [ Crash Pass ] +crbug.com/591099 media/encrypted-media/encrypted-media-setmediakeys-to-multiple-video-elements.html [ Crash Pass ] +crbug.com/591099 media/encrypted-media/encrypted-media-setmediakeys.html [ Crash Pass ] +crbug.com/591099 media/encrypted-media/encrypted-media-waiting-for-a-key.html [ Crash Pass ] +crbug.com/591099 media/event-attributes.html [ Crash Pass ] crbug.com/591099 media/fallback.html [ Failure ] -crbug.com/591099 media/fullscreen-controls-visible-last.html [ Crash ] -crbug.com/591099 media/media-can-play-mpeg4-video.html [ Crash ] -crbug.com/591099 media/media-can-play-ogg.html [ Crash ] -crbug.com/591099 media/media-can-play-type.html [ Crash ] -crbug.com/591099 media/media-can-play-webm.html [ Crash ] -crbug.com/591099 media/media-captions-no-controls.html [ Crash ] -crbug.com/591099 media/media-controls-fit-properly-while-zoomed.html [ Crash ] -crbug.com/591099 media/media-controls-hide-menu-stoppropagation-iframe.html [ Crash ] -crbug.com/591099 media/media-controls-hide-menu-stoppropagation.html [ Crash ] -crbug.com/591099 media/media-controls-invalid-url.html [ Crash ] -crbug.com/591099 media/media-controls-overflow-hidden.html [ Crash ] -crbug.com/591099 media/media-controls-overflow-visible.html [ Crash ] -crbug.com/591099 media/media-controls-tap-show-controls-without-activating.html [ Crash ] +crbug.com/591099 media/fullscreen-controls-visible-last.html [ Crash Pass ] +crbug.com/591099 media/media-can-play-mpeg4-video.html [ Crash Pass ] +crbug.com/591099 media/media-can-play-ogg.html [ Crash Pass ] +crbug.com/591099 media/media-can-play-type.html [ Crash Pass ] +crbug.com/591099 media/media-can-play-webm.html [ Crash Pass ] +crbug.com/591099 media/media-captions-no-controls.html [ Crash Pass ] +crbug.com/591099 media/media-controls-fit-properly-while-zoomed.html [ Crash Pass ] +crbug.com/591099 media/media-controls-hide-menu-stoppropagation-iframe.html [ Crash Pass ] +crbug.com/591099 media/media-controls-hide-menu-stoppropagation.html [ Crash Pass ] +crbug.com/591099 media/media-controls-invalid-url.html [ Crash Pass ] +crbug.com/591099 media/media-controls-overflow-hidden.html [ Crash Pass ] +crbug.com/591099 media/media-controls-overflow-visible.html [ Crash Pass ] +crbug.com/591099 media/media-controls-tap-show-controls-without-activating.html [ Crash Pass ] crbug.com/591099 media/media-document-audio-size.html [ Failure ] -crbug.com/591099 media/media-extension-with-fragment.html [ Crash ] +crbug.com/591099 media/media-extension-with-fragment.html [ Crash Pass ] crbug.com/591099 media/network-no-source-const-shadow.html [ Failure ] -crbug.com/591099 media/no-autoplay-with-user-gesture-requirement.html [ Crash ] -crbug.com/591099 media/remoteplayback/availability-callback-gc.html [ Crash ] -crbug.com/591099 media/remoteplayback/prompt-twice-throws.html [ Crash ] -crbug.com/591099 media/remoteplayback/watch-availability-throws-low-end-device.html [ Crash ] -crbug.com/591099 media/remove-from-document-before-load.html [ Crash ] +crbug.com/591099 media/no-autoplay-with-user-gesture-requirement.html [ Crash Pass ] +crbug.com/591099 media/remoteplayback/availability-callback-gc.html [ Crash Pass ] +crbug.com/591099 media/remoteplayback/prompt-twice-throws.html [ Crash Pass ] +crbug.com/591099 media/remoteplayback/watch-availability-throws-low-end-device.html [ Crash Pass ] +crbug.com/591099 media/remove-from-document-before-load.html [ Crash Pass ] crbug.com/591099 media/remove-from-document-config-controls-no-crash.html [ Crash Failure ] -crbug.com/591099 media/remove-from-document.html [ Crash ] +crbug.com/591099 media/remove-from-document.html [ Crash Pass ] crbug.com/591099 media/svg-as-image-with-media-blocked.html [ Failure ] -crbug.com/591099 media/track/cue-style-invalidation.html [ Crash ] -crbug.com/591099 media/track/media-element-enqueue-event-crash.html [ Crash ] +crbug.com/591099 media/track/cue-style-invalidation.html [ Crash Pass ] +crbug.com/591099 media/track/media-element-enqueue-event-crash.html [ Crash Pass ] crbug.com/591099 media/track/media-element-move-to-new-document-assert.html [ Failure ] -crbug.com/591099 media/track/opera/track/webvtt/parsing/001.html [ Crash ] -crbug.com/591099 media/track/regions-webvtt/vtt-region-display.html [ Crash ] +crbug.com/591099 media/track/opera/track/webvtt/parsing/001.html [ Crash Pass ] +crbug.com/591099 media/track/regions-webvtt/vtt-region-display.html [ Crash Pass ] crbug.com/591099 media/track/text-track-cue-exceptions.html [ Failure ] -crbug.com/591099 media/track/text-track-selection-menu-add-track.html [ Crash ] -crbug.com/591099 media/track/track-css-all-cues.html [ Crash ] -crbug.com/591099 media/track/track-css-cue-lifetime.html [ Crash ] -crbug.com/591099 media/track/track-css-matching-default.html [ Crash ] -crbug.com/591099 media/track/track-css-matching-lang.html [ Crash ] -crbug.com/591099 media/track/track-css-matching-timestamps.html [ Crash ] -crbug.com/591099 media/track/track-css-matching.html [ Crash ] -crbug.com/591099 media/track/track-css-property-whitelist.html [ Crash ] -crbug.com/591099 media/track/track-css-user-settings-override-author-settings.html [ Crash ] -crbug.com/591099 media/track/track-css-user-settings-override-internal-settings.html [ Crash ] -crbug.com/591099 media/track/track-cue-container-rendering-position.html [ Crash ] -crbug.com/591099 media/track/track-cue-gc-wrapper.html [ Crash ] -crbug.com/591099 media/track/track-cue-inline-assertion-crash.html [ Crash ] -crbug.com/591099 media/track/track-cue-mutable-fragment.html [ Crash ] -crbug.com/591099 media/track/track-cue-mutable-text.html [ Crash ] -crbug.com/591099 media/track/track-cue-mutable.html [ Crash ] -crbug.com/591099 media/track/track-cue-negative-timestamp.html [ Crash ] -crbug.com/591099 media/track/track-cue-nothing-to-render.html [ Crash ] +crbug.com/591099 media/track/text-track-selection-menu-add-track.html [ Crash Pass ] +crbug.com/591099 media/track/track-css-all-cues.html [ Crash Pass ] +crbug.com/591099 media/track/track-css-cue-lifetime.html [ Crash Pass ] +crbug.com/591099 media/track/track-css-matching-default.html [ Crash Pass ] +crbug.com/591099 media/track/track-css-matching-lang.html [ Crash Pass ] +crbug.com/591099 media/track/track-css-matching-timestamps.html [ Crash Pass ] +crbug.com/591099 media/track/track-css-matching.html [ Crash Pass ] +crbug.com/591099 media/track/track-css-property-whitelist.html [ Crash Pass ] +crbug.com/591099 media/track/track-css-user-settings-override-author-settings.html [ Crash Pass ] +crbug.com/591099 media/track/track-css-user-settings-override-internal-settings.html [ Crash Pass ] +crbug.com/591099 media/track/track-cue-container-rendering-position.html [ Crash Pass ] +crbug.com/591099 media/track/track-cue-gc-wrapper.html [ Crash Pass ] +crbug.com/591099 media/track/track-cue-inline-assertion-crash.html [ Crash Pass ] +crbug.com/591099 media/track/track-cue-mutable-fragment.html [ Crash Pass ] +crbug.com/591099 media/track/track-cue-mutable-text.html [ Crash Pass ] +crbug.com/591099 media/track/track-cue-mutable.html [ Crash Pass ] +crbug.com/591099 media/track/track-cue-negative-timestamp.html [ Crash Pass ] +crbug.com/591099 media/track/track-cue-nothing-to-render.html [ Crash Pass ] crbug.com/591099 media/track/track-cue-rendering-horizontal.html [ Failure Pass ] -crbug.com/591099 media/track/track-cue-rendering-on-resize.html [ Crash ] -crbug.com/591099 media/track/track-cue-rendering-overscan.html [ Crash ] -crbug.com/591099 media/track/track-cue-rendering-rtl.html [ Crash ] -crbug.com/591099 media/track/track-cue-rendering-snap-to-lines-not-set.html [ Crash ] -crbug.com/591099 media/track/track-cue-rendering-tree-is-removed-properly.html [ Crash ] +crbug.com/591099 media/track/track-cue-rendering-on-resize.html [ Crash Pass ] +crbug.com/591099 media/track/track-cue-rendering-overscan.html [ Crash Pass ] +crbug.com/591099 media/track/track-cue-rendering-rtl.html [ Crash Pass ] +crbug.com/591099 media/track/track-cue-rendering-snap-to-lines-not-set.html [ Crash Pass ] +crbug.com/591099 media/track/track-cue-rendering-tree-is-removed-properly.html [ Crash Failure ] crbug.com/591099 media/track/track-cue-rendering-vertical.html [ Failure Pass ] -crbug.com/591099 media/track/track-cue-rendering-wider-than-controls.html [ Crash ] -crbug.com/591099 media/track/track-cue-rendering-with-padding.html [ Crash ] -crbug.com/591099 media/track/track-cue-rendering.html [ Crash ] -crbug.com/591099 media/track/track-cues-cuechange.html [ Crash ] -crbug.com/591099 media/track/track-cues-enter-exit.html [ Crash ] -crbug.com/591099 media/track/track-cues-missed.html [ Crash ] -crbug.com/591099 media/track/track-cues-pause-on-exit.html [ Crash ] -crbug.com/591099 media/track/track-cues-seeking.html [ Crash ] -crbug.com/591099 media/track/track-cues-sorted-before-dispatch.html [ Crash ] -crbug.com/591099 media/track/track-default-attribute.html [ Crash Timeout ] -crbug.com/591099 media/track/track-delete-during-setup.html [ Crash ] -crbug.com/591099 media/track/track-disabled.html [ Crash ] -crbug.com/591099 media/track/track-element-load-event.html [ Crash ] -crbug.com/591099 media/track/track-id.html [ Crash ] -crbug.com/591099 media/track/track-kind-user-preference.html [ Crash ] -crbug.com/591099 media/track/track-kind.html [ Crash Timeout ] -crbug.com/591099 media/track/track-language-preference.html [ Crash ] -crbug.com/591099 media/track/track-large-timestamp.html [ Crash ] -crbug.com/591099 media/track/track-load-error-readyState.html [ Crash Timeout ] -crbug.com/591099 media/track/track-load-from-element-readyState.html [ Crash Timeout ] -crbug.com/591099 media/track/track-load-from-src-readyState.html [ Crash ] -crbug.com/591099 media/track/track-mode-disabled-crash.html [ Crash ] -crbug.com/591099 media/track/track-mode-not-changed-by-new-track.html [ Crash ] -crbug.com/591099 media/track/track-mode-triggers-loading.html [ Crash ] -crbug.com/591099 media/track/track-mode.html [ Crash ] -crbug.com/591099 media/track/track-removal-crash.html [ Crash ] -crbug.com/591099 media/track/track-remove-active-cue-crash.html [ Crash ] -crbug.com/591099 media/track/track-remove-by-setting-innerHTML.html [ Crash ] -crbug.com/591099 media/track/track-selection-metadata.html [ Crash ] -crbug.com/591099 media/track/track-text-track-cue-list.html [ Crash ] -crbug.com/591099 media/track/track-texttracks.html [ Crash ] -crbug.com/591099 media/track/track-webvtt-tc000-empty.html [ Crash Timeout ] -crbug.com/591099 media/track/track-webvtt-tc001-utf8.html [ Crash ] -crbug.com/591099 media/track/track-webvtt-tc002-bom.html [ Crash ] -crbug.com/591099 media/track/track-webvtt-tc003-newlines.html [ Crash ] -crbug.com/591099 media/track/track-webvtt-tc004-magic-header.html [ Crash ] -crbug.com/591099 media/track/track-webvtt-tc005-header-comment.html [ Crash ] -crbug.com/591099 media/track/track-webvtt-tc008-timings-no-hours.html [ Crash ] -crbug.com/591099 media/track/track-webvtt-tc009-timings-hour.html [ Crash ] -crbug.com/591099 media/track/track-webvtt-tc010-no-timings.html [ Crash ] -crbug.com/591099 media/track/track-webvtt-tc016-align-positioning.html [ Crash ] -crbug.com/591099 media/track/track-webvtt-tc017-line-position.html [ Crash ] -crbug.com/591099 media/track/track-webvtt-tc018-align-text-line-position.html [ Crash ] -crbug.com/591099 media/track/track-word-breaking.html [ Crash ] +crbug.com/591099 media/track/track-cue-rendering-wider-than-controls.html [ Crash Pass ] +crbug.com/591099 media/track/track-cue-rendering-with-padding.html [ Crash Pass ] +crbug.com/591099 media/track/track-cue-rendering.html [ Crash Pass ] +crbug.com/591099 media/track/track-cues-cuechange.html [ Crash Pass ] +crbug.com/591099 media/track/track-cues-enter-exit.html [ Crash Pass ] +crbug.com/591099 media/track/track-cues-missed.html [ Crash Pass ] +crbug.com/591099 media/track/track-cues-pause-on-exit.html [ Crash Pass ] +crbug.com/591099 media/track/track-cues-seeking.html [ Crash Pass ] +crbug.com/591099 media/track/track-cues-sorted-before-dispatch.html [ Crash Pass ] +crbug.com/591099 media/track/track-default-attribute.html [ Crash Failure Timeout ] +crbug.com/591099 media/track/track-delete-during-setup.html [ Crash Pass ] +crbug.com/591099 media/track/track-disabled.html [ Crash Pass ] +crbug.com/591099 media/track/track-element-load-event.html [ Crash Pass ] +crbug.com/591099 media/track/track-id.html [ Crash Pass ] +crbug.com/591099 media/track/track-kind-user-preference.html [ Crash Pass ] +crbug.com/591099 media/track/track-kind.html [ Crash Pass Timeout ] +crbug.com/591099 media/track/track-language-preference.html [ Crash Pass ] +crbug.com/591099 media/track/track-large-timestamp.html [ Crash Pass ] +crbug.com/591099 media/track/track-load-error-readyState.html [ Crash Pass Timeout ] +crbug.com/591099 media/track/track-load-from-element-readyState.html [ Crash Pass Timeout ] +crbug.com/591099 media/track/track-load-from-src-readyState.html [ Crash Pass ] +crbug.com/591099 media/track/track-mode-disabled-crash.html [ Crash Pass ] +crbug.com/591099 media/track/track-mode-not-changed-by-new-track.html [ Crash Pass ] +crbug.com/591099 media/track/track-mode-triggers-loading.html [ Crash Pass ] +crbug.com/591099 media/track/track-mode.html [ Crash Pass ] +crbug.com/591099 media/track/track-removal-crash.html [ Crash Pass ] +crbug.com/591099 media/track/track-remove-active-cue-crash.html [ Crash Pass ] +crbug.com/591099 media/track/track-remove-by-setting-innerHTML.html [ Crash Pass ] +crbug.com/591099 media/track/track-selection-metadata.html [ Crash Pass ] +crbug.com/591099 media/track/track-text-track-cue-list.html [ Crash Pass ] +crbug.com/591099 media/track/track-texttracks.html [ Crash Pass ] +crbug.com/591099 media/track/track-webvtt-tc000-empty.html [ Crash Pass Timeout ] +crbug.com/591099 media/track/track-webvtt-tc001-utf8.html [ Crash Pass ] +crbug.com/591099 media/track/track-webvtt-tc002-bom.html [ Crash Pass ] +crbug.com/591099 media/track/track-webvtt-tc003-newlines.html [ Crash Pass ] +crbug.com/591099 media/track/track-webvtt-tc004-magic-header.html [ Crash Pass ] +crbug.com/591099 media/track/track-webvtt-tc005-header-comment.html [ Crash Pass ] +crbug.com/591099 media/track/track-webvtt-tc008-timings-no-hours.html [ Crash Pass ] +crbug.com/591099 media/track/track-webvtt-tc009-timings-hour.html [ Crash Pass ] +crbug.com/591099 media/track/track-webvtt-tc010-no-timings.html [ Crash Pass ] +crbug.com/591099 media/track/track-webvtt-tc016-align-positioning.html [ Crash Pass ] +crbug.com/591099 media/track/track-webvtt-tc017-line-position.html [ Crash Pass ] +crbug.com/591099 media/track/track-webvtt-tc018-align-text-line-position.html [ Crash Pass ] +crbug.com/591099 media/track/track-word-breaking.html [ Crash Pass ] crbug.com/591099 media/track/vtt-cue-exceptions.html [ Failure ] -crbug.com/591099 media/unsupported-rtsp.html [ Crash ] -crbug.com/591099 media/unsupported-tracks.html [ Crash ] -crbug.com/591099 media/video-append-source.html [ Crash ] +crbug.com/591099 media/unsupported-rtsp.html [ Crash Pass ] +crbug.com/591099 media/unsupported-tracks.html [ Crash Pass ] +crbug.com/591099 media/video-append-source.html [ Crash Pass ] crbug.com/591099 media/video-aspect-ratio.html [ Failure ] -crbug.com/591099 media/video-autoplay.html [ Crash ] -crbug.com/591099 media/video-black-bg-in-media-document.html [ Crash ] +crbug.com/591099 media/video-autoplay.html [ Crash Pass ] +crbug.com/591099 media/video-black-bg-in-media-document.html [ Crash Pass ] crbug.com/591099 media/video-buffered-too-few-arguments.html [ Failure ] -crbug.com/591099 media/video-buffered-unknown-duration.html [ Crash ] -crbug.com/591099 media/video-buffered.html [ Crash ] +crbug.com/591099 media/video-buffered-unknown-duration.html [ Crash Pass ] +crbug.com/591099 media/video-buffered.html [ Crash Pass ] crbug.com/591099 media/video-canvas-alpha.html [ Failure ] -crbug.com/591099 media/video-canvas-source.html [ Crash ] -crbug.com/591099 media/video-canvas.html [ Crash ] -crbug.com/591099 media/video-capture-canvas.html [ Crash ] -crbug.com/591099 media/video-capture-preview.html [ Crash ] +crbug.com/591099 media/video-canvas-source.html [ Crash Pass ] +crbug.com/591099 media/video-canvas.html [ Crash Pass ] +crbug.com/591099 media/video-capture-canvas.html [ Crash Pass ] +crbug.com/591099 media/video-capture-preview.html [ Crash Pass ] crbug.com/591099 media/video-colorspace-yuv420.html [ Failure ] crbug.com/591099 media/video-colorspace-yuv422.html [ Failure ] -crbug.com/591099 media/video-controls-always-visible-when-control-hovered.html [ Crash ] -crbug.com/591099 media/video-controls-auto-hide-after-play-by-touch.html [ Crash ] -crbug.com/591099 media/video-controls-dont-show-on-focus-when-disabled.html [ Crash ] -crbug.com/591099 media/video-controls-download-button-not-displayed-local.html [ Crash ] -crbug.com/591099 media/video-controls-focus-movement-on-hide.html [ Crash ] -crbug.com/591099 media/video-controls-fullscreen-iframe-allowed.html [ Crash ] -crbug.com/591099 media/video-controls-fullscreen-iframe-not-allowed.html [ Crash ] -crbug.com/591099 media/video-controls-fullscreen-not-supported.html [ Crash ] -crbug.com/591099 media/video-controls-fullscreen.html [ Crash ] -crbug.com/591099 media/video-controls-hidden-audio.html [ Crash ] -crbug.com/591099 media/video-controls-hide-after-touch-on-control.html [ Crash ] -crbug.com/591099 media/video-controls-hide-on-move-outside-controls.html [ Crash ] -crbug.com/591099 media/video-controls-in-media-document.html [ Crash ] -crbug.com/591099 media/video-controls-labels.html [ Crash ] -crbug.com/591099 media/video-controls-mouse-events-captured.html [ Crash ] -crbug.com/591099 media/video-controls-muted-video-can-unmute.html [ Crash ] -crbug.com/591099 media/video-controls-no-scripting.html [ Crash ] -crbug.com/591099 media/video-controls-overflow-menu-closed-captions-button.html [ Crash ] -crbug.com/591099 media/video-controls-overflow-menu-closed-captions-list-hide-on-click-outside.html [ Crash ] -crbug.com/591099 media/video-controls-overflow-menu-last-button-visible.html [ Crash ] -crbug.com/591099 media/video-controls-overflow-menu-mute-button.html [ Crash ] -crbug.com/591099 media/video-controls-overflow-menu-play-button.html [ Crash ] -crbug.com/591099 media/video-controls-show-on-focus.html [ Crash ] +crbug.com/591099 media/video-controls-always-visible-when-control-hovered.html [ Crash Pass ] +crbug.com/591099 media/video-controls-auto-hide-after-play-by-touch.html [ Crash Pass ] +crbug.com/591099 media/video-controls-dont-show-on-focus-when-disabled.html [ Crash Pass ] +crbug.com/591099 media/video-controls-download-button-not-displayed-local.html [ Crash Pass ] +crbug.com/591099 media/video-controls-focus-movement-on-hide.html [ Crash Pass ] +crbug.com/591099 media/video-controls-fullscreen-iframe-allowed.html [ Crash Pass ] +crbug.com/591099 media/video-controls-fullscreen-iframe-not-allowed.html [ Crash Pass ] +crbug.com/591099 media/video-controls-fullscreen-not-supported.html [ Crash Pass ] +crbug.com/591099 media/video-controls-fullscreen.html [ Crash Pass ] +crbug.com/591099 media/video-controls-hidden-audio.html [ Crash Pass ] +crbug.com/591099 media/video-controls-hide-after-touch-on-control.html [ Crash Pass ] +crbug.com/591099 media/video-controls-hide-on-move-outside-controls.html [ Crash Pass ] +crbug.com/591099 media/video-controls-in-media-document.html [ Crash Pass ] +crbug.com/591099 media/video-controls-labels.html [ Crash Pass ] +crbug.com/591099 media/video-controls-mouse-events-captured.html [ Crash Pass ] +crbug.com/591099 media/video-controls-muted-video-can-unmute.html [ Crash Pass ] +crbug.com/591099 media/video-controls-no-scripting.html [ Crash Pass ] +crbug.com/591099 media/video-controls-overflow-menu-closed-captions-button.html [ Crash Pass ] +crbug.com/591099 media/video-controls-overflow-menu-closed-captions-list-hide-on-click-outside.html [ Crash Pass ] +crbug.com/591099 media/video-controls-overflow-menu-last-button-visible.html [ Crash Pass ] +crbug.com/591099 media/video-controls-overflow-menu-mute-button.html [ Crash Pass ] +crbug.com/591099 media/video-controls-overflow-menu-play-button.html [ Crash Pass ] +crbug.com/591099 media/video-controls-show-on-focus.html [ Crash Pass ] crbug.com/591099 media/video-controls-start-selection.html [ Failure ] -crbug.com/591099 media/video-controls-toggling.html [ Crash ] -crbug.com/591099 media/video-controls-touch-events-captured.html [ Crash ] -crbug.com/591099 media/video-controls-track-selection-menu.html [ Crash ] -crbug.com/591099 media/video-controls-transformed.html [ Crash ] -crbug.com/591099 media/video-controls-visibility-multimodal-mouse-after-touch.html [ Crash ] -crbug.com/591099 media/video-controls-visibility-multimodal-touch-after-mouse.html [ Crash ] +crbug.com/591099 media/video-controls-toggling.html [ Crash Pass ] +crbug.com/591099 media/video-controls-touch-events-captured.html [ Crash Pass ] +crbug.com/591099 media/video-controls-track-selection-menu.html [ Crash Pass ] +crbug.com/591099 media/video-controls-transformed.html [ Crash Pass ] +crbug.com/591099 media/video-controls-visibility-multimodal-mouse-after-touch.html [ Crash Pass ] +crbug.com/591099 media/video-controls-visibility-multimodal-touch-after-mouse.html [ Crash Pass ] crbug.com/591099 media/video-controls-visible-audio-only.html [ Failure ] crbug.com/591099 media/video-controls-with-mutation-event-handler.html [ Failure ] -crbug.com/591099 media/video-controls-zoomed.html [ Crash ] -crbug.com/591099 media/video-controls.html [ Crash ] -crbug.com/591099 media/video-currentTime-before-have-metadata-media-fragment-uri.html [ Crash ] -crbug.com/591099 media/video-currentTime-before-have-metadata.html [ Crash ] -crbug.com/591099 media/video-currentTime-delay.html [ Crash ] -crbug.com/591099 media/video-currentTime-set.html [ Crash ] -crbug.com/591099 media/video-currentTime-set2.html [ Crash ] -crbug.com/591099 media/video-currentTime.html [ Crash ] -crbug.com/591099 media/video-delay-load-event.html [ Crash ] -crbug.com/591099 media/video-display-aspect-ratio.html [ Crash ] -crbug.com/591099 media/video-dom-autoplay.html [ Crash ] -crbug.com/591099 media/video-dom-src.html [ Crash ] -crbug.com/591099 media/video-double-seek-currentTime.html [ Crash ] -crbug.com/591099 media/video-duration-known-after-eos.html [ Crash ] -crbug.com/591099 media/video-enter-fullscreen-without-user-gesture.html [ Crash ] -crbug.com/591099 media/video-error-does-not-exist.html [ Crash ] -crbug.com/591099 media/video-force-preload-none-to-metadata-on-load.html [ Crash ] -crbug.com/591099 media/video-force-preload-none-to-metadata-on-play.html [ Crash ] -crbug.com/591099 media/video-intrinsic-width-height.html [ Crash ] +crbug.com/591099 media/video-controls-zoomed.html [ Crash Pass ] +crbug.com/591099 media/video-controls.html [ Crash Pass ] +crbug.com/591099 media/video-currentTime-before-have-metadata-media-fragment-uri.html [ Crash Pass ] +crbug.com/591099 media/video-currentTime-before-have-metadata.html [ Crash Pass ] +crbug.com/591099 media/video-currentTime-delay.html [ Crash Pass ] +crbug.com/591099 media/video-currentTime-set.html [ Crash Pass ] +crbug.com/591099 media/video-currentTime-set2.html [ Crash Pass ] +crbug.com/591099 media/video-currentTime.html [ Crash Pass ] +crbug.com/591099 media/video-delay-load-event.html [ Crash Pass ] +crbug.com/591099 media/video-display-aspect-ratio.html [ Crash Pass ] +crbug.com/591099 media/video-dom-autoplay.html [ Crash Pass ] +crbug.com/591099 media/video-dom-src.html [ Crash Pass ] +crbug.com/591099 media/video-double-seek-currentTime.html [ Crash Pass ] +crbug.com/591099 media/video-duration-known-after-eos.html [ Crash Pass ] +crbug.com/591099 media/video-enter-fullscreen-without-user-gesture.html [ Crash Pass ] +crbug.com/591099 media/video-error-does-not-exist.html [ Crash Pass ] +crbug.com/591099 media/video-force-preload-none-to-metadata-on-load.html [ Crash Pass ] +crbug.com/591099 media/video-force-preload-none-to-metadata-on-play.html [ Crash Pass ] +crbug.com/591099 media/video-intrinsic-width-height.html [ Crash Pass ] crbug.com/591099 media/video-layer-crash.html [ Failure ] -crbug.com/591099 media/video-load-networkState.html [ Crash ] -crbug.com/591099 media/video-load-preload-none.html [ Crash ] -crbug.com/591099 media/video-load-readyState.html [ Crash ] -crbug.com/591099 media/video-loop-from-ended.html [ Crash ] -crbug.com/591099 media/video-loop.html [ Crash ] -crbug.com/591099 media/video-mouse-focus.html [ Crash ] -crbug.com/591099 media/video-move-to-new-document-srcobject.html [ Crash ] -crbug.com/591099 media/video-move-to-new-document.html [ Crash ] -crbug.com/591099 media/video-muted.html [ Crash ] -crbug.com/591099 media/video-no-autoplay.html [ Crash ] -crbug.com/591099 media/video-no-controls-events-not-absorbed.html [ Crash ] -crbug.com/591099 media/video-no-timeupdate-before-playback.html [ Crash ] -crbug.com/591099 media/video-not-paused-while-looping.html [ Crash ] -crbug.com/591099 media/video-pause-empty-events.html [ Crash ] -crbug.com/591099 media/video-pause-immediately.html [ Crash ] -crbug.com/591099 media/video-persistence.html [ Crash ] -crbug.com/591099 media/video-play-empty-events.html [ Crash ] -crbug.com/591099 media/video-play-pause-events.html [ Crash ] -crbug.com/591099 media/video-play-pause-exception.html [ Crash ] -crbug.com/591099 media/video-play-require-user-gesture.html [ Crash ] -crbug.com/591099 media/video-playbackrate.html [ Crash ] -crbug.com/591099 media/video-played-collapse.html [ Crash ] -crbug.com/591099 media/video-played-ranges-1.html [ Crash ] -crbug.com/591099 media/video-played-reset.html [ Crash ] -crbug.com/591099 media/video-playing-and-pause.html [ Crash ] +crbug.com/591099 media/video-load-networkState.html [ Crash Pass ] +crbug.com/591099 media/video-load-preload-none.html [ Crash Pass ] +crbug.com/591099 media/video-load-readyState.html [ Crash Pass ] +crbug.com/591099 media/video-loop-from-ended.html [ Crash Pass ] +crbug.com/591099 media/video-loop.html [ Crash Pass ] +crbug.com/591099 media/video-mouse-focus.html [ Crash Pass ] +crbug.com/591099 media/video-move-to-new-document-srcobject.html [ Crash Pass ] +crbug.com/591099 media/video-move-to-new-document.html [ Crash Pass ] +crbug.com/591099 media/video-muted.html [ Crash Pass ] +crbug.com/591099 media/video-no-autoplay.html [ Crash Pass ] +crbug.com/591099 media/video-no-controls-events-not-absorbed.html [ Crash Pass ] +crbug.com/591099 media/video-no-timeupdate-before-playback.html [ Crash Pass ] +crbug.com/591099 media/video-not-paused-while-looping.html [ Crash Pass ] +crbug.com/591099 media/video-pause-empty-events.html [ Crash Pass ] +crbug.com/591099 media/video-pause-immediately.html [ Crash Pass ] +crbug.com/591099 media/video-persistence.html [ Crash Pass ] +crbug.com/591099 media/video-play-empty-events.html [ Crash Pass ] +crbug.com/591099 media/video-play-pause-events.html [ Crash Pass ] +crbug.com/591099 media/video-play-pause-exception.html [ Crash Pass ] +crbug.com/591099 media/video-play-require-user-gesture.html [ Crash Pass ] +crbug.com/591099 media/video-playbackrate.html [ Crash Pass ] +crbug.com/591099 media/video-played-collapse.html [ Crash Pass ] +crbug.com/591099 media/video-played-ranges-1.html [ Crash Pass ] +crbug.com/591099 media/video-played-reset.html [ Crash Pass ] +crbug.com/591099 media/video-playing-and-pause.html [ Crash Pass ] crbug.com/591099 media/video-plays-past-end-of-test.html [ Failure ] -crbug.com/591099 media/video-positive-start-time-seek-after-start-time.html [ Crash ] -crbug.com/591099 media/video-positive-start-time-seek-before-start-time.html [ Crash ] -crbug.com/591099 media/video-positive-start-time.html [ Crash ] -crbug.com/591099 media/video-poster-delayed.html [ Crash ] +crbug.com/591099 media/video-positive-start-time-seek-after-start-time.html [ Crash Pass ] +crbug.com/591099 media/video-positive-start-time-seek-before-start-time.html [ Crash Pass ] +crbug.com/591099 media/video-positive-start-time.html [ Crash Pass ] +crbug.com/591099 media/video-poster-delayed.html [ Crash Pass ] crbug.com/591099 media/video-poster-scale.html [ Failure ] -crbug.com/591099 media/video-poster.html [ Crash ] -crbug.com/591099 media/video-prefixed-fullscreen.html [ Crash ] -crbug.com/591099 media/video-preload-none-no-stalled-event.html [ Crash ] -crbug.com/591099 media/video-remove-insert-repaints.html [ Crash ] +crbug.com/591099 media/video-poster.html [ Crash Pass ] +crbug.com/591099 media/video-prefixed-fullscreen.html [ Crash Pass ] +crbug.com/591099 media/video-preload-none-no-stalled-event.html [ Crash Pass ] +crbug.com/591099 media/video-remove-insert-repaints.html [ Crash Failure ] crbug.com/591099 media/video-replaces-poster.html [ Failure ] -crbug.com/591099 media/video-scales-in-media-document.html [ Crash ] -crbug.com/591099 media/video-seek-by-small-increment.html [ Crash ] -crbug.com/591099 media/video-seek-no-src.html [ Crash ] -crbug.com/591099 media/video-seek-past-end-paused.html [ Crash ] -crbug.com/591099 media/video-seek-past-end-playing.html [ Crash ] -crbug.com/591099 media/video-seek-to-duration-with-playbackrate-zero.html [ Crash ] -crbug.com/591099 media/video-seekable.html [ Crash ] -crbug.com/591099 media/video-seeking.html [ Crash ] -crbug.com/591099 media/video-set-rate-from-pause.html [ Crash ] -crbug.com/591099 media/video-single-valid-source.html [ Crash ] -crbug.com/591099 media/video-size.html [ Crash ] -crbug.com/591099 media/video-source-add-after-remove.html [ Crash ] -crbug.com/591099 media/video-source-error-no-candidate.html [ Crash ] -crbug.com/591099 media/video-source-error.html [ Crash ] -crbug.com/591099 media/video-source-inserted.html [ Crash ] -crbug.com/591099 media/video-source-load.html [ Crash ] -crbug.com/591099 media/video-source-media.html [ Crash ] -crbug.com/591099 media/video-source-none-supported.html [ Crash ] -crbug.com/591099 media/video-source-type-params.html [ Crash ] -crbug.com/591099 media/video-source-type.html [ Crash ] -crbug.com/591099 media/video-source.html [ Crash ] -crbug.com/591099 media/video-src-blob.html [ Crash ] -crbug.com/591099 media/video-src-change.html [ Crash ] -crbug.com/591099 media/video-src-empty.html [ Crash ] -crbug.com/591099 media/video-src-invalid-poster.html [ Crash ] -crbug.com/591099 media/video-src-invalid-remove.html [ Crash ] -crbug.com/591099 media/video-src-none.html [ Crash ] -crbug.com/591099 media/video-src-plus-source.html [ Crash ] -crbug.com/591099 media/video-src-remove.html [ Crash ] -crbug.com/591099 media/video-src-set.html [ Crash ] -crbug.com/591099 media/video-src-source.html [ Crash ] -crbug.com/591099 media/video-src.html [ Crash ] -crbug.com/591099 media/video-srcobject-mediastream-src-file.html [ Crash ] -crbug.com/591099 media/video-srcobject-mediastream.html [ Crash ] -crbug.com/591099 media/video-timeupdate-during-playback.html [ Crash ] +crbug.com/591099 media/video-scales-in-media-document.html [ Crash Failure ] +crbug.com/591099 media/video-seek-by-small-increment.html [ Crash Pass ] +crbug.com/591099 media/video-seek-no-src.html [ Crash Pass ] +crbug.com/591099 media/video-seek-past-end-paused.html [ Crash Pass ] +crbug.com/591099 media/video-seek-past-end-playing.html [ Crash Pass ] +crbug.com/591099 media/video-seek-to-duration-with-playbackrate-zero.html [ Crash Pass ] +crbug.com/591099 media/video-seekable.html [ Crash Pass ] +crbug.com/591099 media/video-seeking.html [ Crash Pass ] +crbug.com/591099 media/video-set-rate-from-pause.html [ Crash Pass ] +crbug.com/591099 media/video-single-valid-source.html [ Crash Pass ] +crbug.com/591099 media/video-size.html [ Crash Pass ] +crbug.com/591099 media/video-source-add-after-remove.html [ Crash Pass ] +crbug.com/591099 media/video-source-error-no-candidate.html [ Crash Pass ] +crbug.com/591099 media/video-source-error.html [ Crash Pass ] +crbug.com/591099 media/video-source-inserted.html [ Crash Pass ] +crbug.com/591099 media/video-source-load.html [ Crash Pass ] +crbug.com/591099 media/video-source-media.html [ Crash Pass ] +crbug.com/591099 media/video-source-none-supported.html [ Crash Pass ] +crbug.com/591099 media/video-source-type-params.html [ Crash Pass ] +crbug.com/591099 media/video-source-type.html [ Crash Pass ] +crbug.com/591099 media/video-source.html [ Crash Pass ] +crbug.com/591099 media/video-src-blob.html [ Crash Pass ] +crbug.com/591099 media/video-src-change.html [ Crash Pass ] +crbug.com/591099 media/video-src-empty.html [ Crash Pass ] +crbug.com/591099 media/video-src-invalid-poster.html [ Crash Pass ] +crbug.com/591099 media/video-src-invalid-remove.html [ Crash Pass ] +crbug.com/591099 media/video-src-none.html [ Crash Pass ] +crbug.com/591099 media/video-src-plus-source.html [ Crash Pass ] +crbug.com/591099 media/video-src-remove.html [ Crash Pass ] +crbug.com/591099 media/video-src-set.html [ Crash Pass ] +crbug.com/591099 media/video-src-source.html [ Crash Pass ] +crbug.com/591099 media/video-src.html [ Crash Pass ] +crbug.com/591099 media/video-srcobject-mediastream-src-file.html [ Crash Pass ] +crbug.com/591099 media/video-srcobject-mediastream.html [ Crash Pass ] +crbug.com/591099 media/video-timeupdate-during-playback.html [ Crash Pass ] crbug.com/591099 media/video-transformed.html [ Failure ] -crbug.com/591099 media/video-volume.html [ Crash ] -crbug.com/591099 media/video-width-height.html [ Crash ] +crbug.com/591099 media/video-volume.html [ Crash Pass ] +crbug.com/591099 media/video-width-height.html [ Crash Pass ] crbug.com/591099 media/video-zoom-controls.html [ Failure ] crbug.com/591099 media/video-zoom.html [ Failure ] -crbug.com/591099 media/viewport-in-standalone-media-document.html [ Crash ] +crbug.com/591099 media/viewport-in-standalone-media-document.html [ Crash Pass ] crbug.com/591099 mhtml/data-uri-font.mht [ Failure ] crbug.com/591099 mhtml/image_document.mht [ Failure ] crbug.com/591099 mhtml/invalid-bad-boundary2.mht [ Failure ] @@ -17769,7 +17777,7 @@ crbug.com/591099 paint/frames/frameset-with-stacking-context-and-not-stacking-context-children.html [ Failure ] crbug.com/591099 paint/frames/frameset-with-stacking-contexts.html [ Failure ] crbug.com/591099 paint/high-contrast-mode/image-filter-all/text-on-backgrounds.html [ Failure ] -crbug.com/591099 paint/images/animated-gif-last-frame-crash.html [ Crash ] +crbug.com/591099 paint/images/animated-gif-last-frame-crash.html [ Crash Pass ] crbug.com/591099 paint/inline/focus-ring-under-absolute-with-relative-continuation.html [ Failure ] crbug.com/591099 paint/inline/outline-offset.html [ Failure ] crbug.com/591099 paint/invalidation/4774354.html [ Failure ] @@ -17889,7 +17897,7 @@ crbug.com/591099 paint/invalidation/compositing/overflow-into-content.html [ Failure ] crbug.com/591099 paint/invalidation/compositing/overlap-test-with-filter.html [ Failure ] crbug.com/591099 paint/invalidation/compositing/page-scale-repaint.html [ Failure ] -crbug.com/591099 paint/invalidation/compositing/remove-squashed-layer-plus-move.html [ Crash ] +crbug.com/591099 paint/invalidation/compositing/remove-squashed-layer-plus-move.html [ Crash Failure ] crbug.com/591099 paint/invalidation/compositing/repaint-overflow-scrolled-squashed-content.html [ Failure ] crbug.com/591099 paint/invalidation/compositing/repaint-squashed-layer-in-rect.html [ Failure ] crbug.com/591099 paint/invalidation/compositing/repaint-via-layout-offset.html [ Failure Pass ] @@ -17992,7 +18000,7 @@ crbug.com/591099 paint/invalidation/fixed.html [ Failure ] crbug.com/591099 paint/invalidation/flexbox/repaint-column-reverse.html [ Failure ] crbug.com/591099 paint/invalidation/flexbox/repaint-during-resize-no-flex.html [ Failure ] -crbug.com/591099 paint/invalidation/flexbox/repaint-on-layout.html [ Crash ] +crbug.com/591099 paint/invalidation/flexbox/repaint-on-layout.html [ Crash Failure ] crbug.com/591099 paint/invalidation/flexbox/repaint-on-margin-change.html [ Failure ] crbug.com/591099 paint/invalidation/flexbox/repaint-opacity-change.html [ Failure ] crbug.com/591099 paint/invalidation/flexbox/repaint-rtl-column.html [ Failure ] @@ -18029,6 +18037,7 @@ crbug.com/591099 paint/invalidation/inline-block-overflow-repaint.html [ Failure Pass ] crbug.com/591099 paint/invalidation/inline-block-overflow.html [ Failure ] crbug.com/591099 paint/invalidation/inline-block-resize.html [ Failure ] +crbug.com/591099 paint/invalidation/inline-box-overflow-repaint.html [ Failure ] crbug.com/591099 paint/invalidation/inline-focus.html [ Failure ] crbug.com/591099 paint/invalidation/inline-outline-repaint-2.html [ Failure ] crbug.com/591099 paint/invalidation/inline-outline-repaint.html [ Failure ] @@ -18097,7 +18106,7 @@ crbug.com/591099 paint/invalidation/make-children-non-inline.html [ Failure ] crbug.com/591099 paint/invalidation/margin.html [ Failure Pass ] crbug.com/591099 paint/invalidation/mask-clip-change-stacking-child.html [ Failure ] -crbug.com/591099 paint/invalidation/media-audio-no-spurious-repaints.html [ Crash ] +crbug.com/591099 paint/invalidation/media-audio-no-spurious-repaints.html [ Crash Pass ] crbug.com/591099 paint/invalidation/mix-blend-mode-separate-stacking-context.html [ Failure ] crbug.com/591099 paint/invalidation/multi-subsequence-composited.html [ Failure ] crbug.com/591099 paint/invalidation/multi-subsequence-scrolled.html [ Failure ] @@ -18179,7 +18188,7 @@ crbug.com/591099 paint/invalidation/relayout-fixed-position-after-scale.html [ Failure ] crbug.com/591099 paint/invalidation/remove-block-after-layout.html [ Failure ] crbug.com/591099 paint/invalidation/remove-inline-after-layout.html [ Failure ] -crbug.com/591099 paint/invalidation/remove-inline-block-descendant-of-flex.html [ Crash ] +crbug.com/591099 paint/invalidation/remove-inline-block-descendant-of-flex.html [ Crash Failure ] crbug.com/591099 paint/invalidation/remove-inline-layer-after-layout.html [ Failure ] crbug.com/591099 paint/invalidation/renderer-destruction-by-invalidateSelection-crash.html [ Failure ] crbug.com/591099 paint/invalidation/repaint-across-writing-mode-boundary.html [ Failure ] @@ -18229,6 +18238,7 @@ crbug.com/591099 paint/invalidation/selection-after-delete.html [ Failure ] crbug.com/591099 paint/invalidation/selection-after-remove.html [ Failure ] crbug.com/591099 paint/invalidation/selection-change-in-iframe-with-relative-parent.html [ Failure ] +crbug.com/591099 paint/invalidation/selection-clear-after-move.html [ Failure ] crbug.com/591099 paint/invalidation/selection-clear.html [ Failure ] crbug.com/591099 paint/invalidation/selection-partial-invalidation-between-blocks.html [ Failure Pass ] crbug.com/591099 paint/invalidation/selection-rl.html [ Failure ] @@ -18245,7 +18255,7 @@ crbug.com/591099 paint/invalidation/shadow-box-resize.html [ Failure ] crbug.com/591099 paint/invalidation/shadow-multiple.html [ Failure ] crbug.com/591099 paint/invalidation/shift-relative-positioned-container-with-image-addition.html [ Failure ] -crbug.com/591099 paint/invalidation/shift-relative-positioned-container-with-image-removal.html [ Crash ] +crbug.com/591099 paint/invalidation/shift-relative-positioned-container-with-image-removal.html [ Crash Failure ] crbug.com/591099 paint/invalidation/slider-thumb-drag-release.html [ Failure ] crbug.com/591099 paint/invalidation/slider-thumb-float.html [ Failure ] crbug.com/591099 paint/invalidation/stacked-diacritics.html [ Failure ] @@ -18290,7 +18300,7 @@ crbug.com/591099 paint/invalidation/svg/remove-background-property-on-root.html [ Failure Pass ] crbug.com/591099 paint/invalidation/svg/remove-outline-property-on-root.html [ Failure Pass ] crbug.com/591099 paint/invalidation/svg/repaint-moving-svg-and-div.xhtml [ Failure Pass ] -crbug.com/591099 paint/invalidation/svg/resize-svg-invalidate-children.html [ Crash ] +crbug.com/591099 paint/invalidation/svg/resize-svg-invalidate-children.html [ Crash Failure ] crbug.com/591099 paint/invalidation/svg/scroll-hit-test.xhtml [ Failure ] crbug.com/591099 paint/invalidation/svg/scrolling-embedded-svg-file-image-repaint-problem.html [ Failure ] crbug.com/591099 paint/invalidation/svg/svg-background-partial-redraw.html [ Failure ] @@ -18372,7 +18382,7 @@ crbug.com/591099 paint/printing/print-box-shadow.html [ Failure ] crbug.com/591099 paint/roundedrects/circle-with-shadow.html [ Failure Pass ] crbug.com/591099 paint/roundedrects/input-with-rounded-rect-and-shadow.html [ Failure ] -crbug.com/591099 paint/selection/drag-caret.html [ Crash Timeout ] +crbug.com/591099 paint/selection/drag-caret.html [ Crash Pass Timeout ] crbug.com/591099 paint/selection/text-selection-editing-crash.html [ Failure ] crbug.com/591099 paint/selection/text-selection-inline-block-rtl.html [ Failure ] crbug.com/591099 paint/selection/text-selection-inline-block.html [ Failure ] @@ -18406,22 +18416,22 @@ crbug.com/591099 paint/theme/adjust-progress-bar-size.html [ Failure Pass ] crbug.com/591099 paint/transforms/percentage-transform-fractional-box-size.html [ Failure ] crbug.com/591099 paint/transparency/compositing-alpha-fold-crash.html [ Failure ] -crbug.com/591099 payments/payment-request-in-iframe-allowed.html [ Crash ] -crbug.com/591099 payments/payment-request-in-iframe-nested-allowed.html [ Crash ] -crbug.com/591099 payments/payment-request-in-iframe-nested-not-allowed.html [ Crash ] -crbug.com/591099 payments/payment-request-in-iframe.html [ Crash ] +crbug.com/591099 payments/payment-request-in-iframe-allowed.html [ Crash Pass ] +crbug.com/591099 payments/payment-request-in-iframe-nested-allowed.html [ Crash Pass ] +crbug.com/591099 payments/payment-request-in-iframe-nested-not-allowed.html [ Crash Failure ] +crbug.com/591099 payments/payment-request-in-iframe.html [ Crash Failure ] crbug.com/591099 permissionclient/image-permissions.html [ Crash Failure ] crbug.com/591099 permissionclient/storage-permission-detached.html [ Crash Failure ] -crbug.com/591099 plugins/change-widget-and-click-crash.html [ Crash ] +crbug.com/591099 plugins/change-widget-and-click-crash.html [ Crash Failure ] crbug.com/591099 plugins/createScriptableObject-before-start.html [ Failure ] -crbug.com/591099 plugins/embed-attributes-active.html [ Crash ] +crbug.com/591099 plugins/embed-attributes-active.html [ Crash Pass ] crbug.com/591099 plugins/embed-attributes-style.html [ Failure ] -crbug.com/591099 plugins/empty-per-context-data.html [ Crash ] +crbug.com/591099 plugins/empty-per-context-data.html [ Crash Failure ] crbug.com/591099 plugins/focus-change-1-no-change.html [ Failure ] crbug.com/591099 plugins/focus-change-2-change-focus.html [ Failure ] crbug.com/591099 plugins/focus-change-3-change-blur.html [ Failure ] crbug.com/591099 plugins/focus-change-4-change-focus-and-blur.html [ Failure ] -crbug.com/591099 plugins/focus.html [ Crash ] +crbug.com/591099 plugins/focus.html [ Crash Failure ] crbug.com/591099 plugins/fullscreen-plugins-dont-reload.html [ Failure ] crbug.com/591099 plugins/hidden-iframe-with-swf-plugin.html [ Failure ] crbug.com/591099 plugins/iframe-plugin-bgcolor.html [ Failure ] @@ -18431,32 +18441,32 @@ crbug.com/591099 plugins/mouse-click-plugin-clears-selection.html [ Crash Failure ] crbug.com/591099 plugins/mouse-events-fixedpos.html [ Failure ] crbug.com/591099 plugins/mouse-events.html [ Failure ] -crbug.com/591099 plugins/multiple-plugins.html [ Crash ] +crbug.com/591099 plugins/multiple-plugins.html [ Crash Failure ] crbug.com/591099 plugins/navigator-mimeTypes-length.html [ Failure ] crbug.com/591099 plugins/navigator-plugins.html [ Failure ] -crbug.com/591099 plugins/nested-plugin-objects.html [ Crash ] -crbug.com/591099 plugins/object-onerror-placeholder.html [ Crash ] -crbug.com/591099 plugins/object-onfocus-mutation-crash.html [ Crash ] -crbug.com/591099 plugins/object-onload-placeholder.html [ Crash ] +crbug.com/591099 plugins/nested-plugin-objects.html [ Crash Pass ] +crbug.com/591099 plugins/object-onerror-placeholder.html [ Crash Pass ] +crbug.com/591099 plugins/object-onfocus-mutation-crash.html [ Crash Pass ] +crbug.com/591099 plugins/object-onload-placeholder.html [ Crash Pass ] crbug.com/591099 plugins/overlay-scrollbar-mouse-capture.html [ Failure ] crbug.com/591099 plugins/override-node-method.html [ Failure ] -crbug.com/591099 plugins/page-scale-does-not-affect-plugin-height.html [ Crash ] -crbug.com/591099 plugins/plugin-destroyed-enumerate.html [ Crash ] +crbug.com/591099 plugins/page-scale-does-not-affect-plugin-height.html [ Crash Pass ] +crbug.com/591099 plugins/plugin-destroyed-enumerate.html [ Crash Failure ] crbug.com/591099 plugins/plugin-initiate-popup-window.html [ Timeout ] crbug.com/591099 plugins/plugin-javascript-access.html [ Failure ] crbug.com/591099 plugins/plugin-paint-test.html [ Failure ] -crbug.com/591099 plugins/plugin-remove-readystatechange.html [ Crash ] -crbug.com/591099 plugins/plugin-remove-subframe.html [ Crash ] +crbug.com/591099 plugins/plugin-remove-readystatechange.html [ Crash Pass ] +crbug.com/591099 plugins/plugin-remove-subframe.html [ Crash Failure ] crbug.com/591099 plugins/plugin-scriptable.html [ Failure ] crbug.com/591099 plugins/plugin-synthetic-event-crash.html [ Failure ] -crbug.com/591099 plugins/re-request-touch-events-crash.html [ Crash ] +crbug.com/591099 plugins/re-request-touch-events-crash.html [ Crash Failure ] crbug.com/591099 plugins/refcount-leaks.html [ Failure ] crbug.com/591099 plugins/release-frame-content-window.html [ Failure ] -crbug.com/591099 plugins/request-low-latency-touch.html [ Crash ] +crbug.com/591099 plugins/request-low-latency-touch.html [ Crash Pass ] crbug.com/591099 plugins/sequential-focus.html [ Failure ] -crbug.com/591099 plugins/simple-expando.html [ Crash ] -crbug.com/591099 plugins/tabindex.html [ Crash ] -crbug.com/591099 plugins/type-case.html [ Crash ] +crbug.com/591099 plugins/simple-expando.html [ Crash Pass ] +crbug.com/591099 plugins/tabindex.html [ Crash Failure ] +crbug.com/591099 plugins/type-case.html [ Crash Pass ] crbug.com/591099 plugins/webview-plugin-lifecycle.html [ Failure Pass ] crbug.com/591099 plugins/webview-plugin-nested-iframe-scroll.html [ Failure ] crbug.com/591099 plugins/webview-plugin-scroll.html [ Failure Pass ] @@ -18464,7 +18474,7 @@ crbug.com/591099 pointer-lock/bug90391-move-then-window-open-crash.html [ Failure ] crbug.com/591099 pointer-lock/lock-already-locked.html [ Failure ] crbug.com/591099 pointer-lock/lock-element-not-in-dom.html [ Failure ] -crbug.com/591099 pointer-lock/locked-element-iframe-removed-from-dom.html [ Crash ] +crbug.com/591099 pointer-lock/locked-element-iframe-removed-from-dom.html [ Crash Failure ] crbug.com/591099 pointer-lock/locked-element-removed-from-dom.html [ Failure ] crbug.com/591099 pointer-lock/mouse-event-delivery.html [ Failure ] crbug.com/591099 pointer-lock/pointer-lock-api.html [ Failure ] @@ -18473,18 +18483,18 @@ crbug.com/591099 pointer-lock/pointerlockchange-pointerlockerror-events.html [ Failure ] crbug.com/591099 pointer-lock/pointerlockelement-null-when-pending.html [ Failure ] crbug.com/591099 presentation/presentation-controller-close-connection.html [ Crash Timeout ] -crbug.com/591099 presentation/presentation-controller-connection-closed-by-receiver.html [ Crash Timeout ] -crbug.com/591099 presentation/presentation-controller-terminate-connection.html [ Crash Timeout ] -crbug.com/591099 presentation/presentation-navigation-multipleurls.html [ Crash ] -crbug.com/591099 presentation/presentation-navigation.html [ Crash ] -crbug.com/591099 presentation/presentation-receiver-terminate-connection.html [ Crash Timeout ] +crbug.com/591099 presentation/presentation-controller-connection-closed-by-receiver.html [ Crash Pass Timeout ] +crbug.com/591099 presentation/presentation-controller-terminate-connection.html [ Crash Pass Timeout ] +crbug.com/591099 presentation/presentation-navigation-multipleurls.html [ Crash Pass ] +crbug.com/591099 presentation/presentation-navigation.html [ Crash Pass ] +crbug.com/591099 presentation/presentation-receiver-terminate-connection.html [ Crash Pass Timeout ] crbug.com/591099 presentation/presentation-reconnect.html [ Crash Timeout ] -crbug.com/591099 presentation/presentation-request-iframe-default-success.html [ Crash ] -crbug.com/591099 presentation/presentation-request-iframe-sandbox-error.html [ Crash ] -crbug.com/591099 presentation/presentation-request-iframe-sandbox-success.html [ Crash ] -crbug.com/591099 presentation/presentation-start-error.html [ Crash Timeout ] +crbug.com/591099 presentation/presentation-request-iframe-default-success.html [ Crash Pass ] +crbug.com/591099 presentation/presentation-request-iframe-sandbox-error.html [ Crash Pass ] +crbug.com/591099 presentation/presentation-request-iframe-sandbox-success.html [ Crash Pass ] +crbug.com/591099 presentation/presentation-start-error.html [ Crash Pass Timeout ] crbug.com/591099 presentation/presentation-start.html [ Crash Timeout ] -crbug.com/591099 presentation/presentationconnectionavailableevent-ctor-mock.html [ Crash Timeout ] +crbug.com/591099 presentation/presentationconnectionavailableevent-ctor-mock.html [ Crash Pass Timeout ] crbug.com/591099 printing/absolute-position-headers-and-footers.html [ Failure ] crbug.com/591099 printing/absolute-positioned.html [ Failure ] crbug.com/591099 printing/allowed-page-breaks.html [ Failure ] @@ -18540,28 +18550,28 @@ crbug.com/591099 printing/thead-repeats-at-top-of-each-page-multiple-tables.html [ Failure ] crbug.com/591099 printing/thead-repeats-at-top-of-each-page.html [ Failure ] crbug.com/591099 printing/viewport-size-dependant-iframe-with-multicol-crash.html [ Failure ] -crbug.com/591099 resize-observer/observe.html [ Crash ] -crbug.com/591099 screen_orientation/page-visibility.html [ Crash ] -crbug.com/591099 screen_orientation/screenorientation-detached-notify-no-crash.html [ Crash ] -crbug.com/591099 screen_orientation/screenorientation-unsupported-no-crash.html [ Crash ] +crbug.com/591099 resize-observer/observe.html [ Crash Pass ] +crbug.com/591099 screen_orientation/page-visibility.html [ Crash Pass ] +crbug.com/591099 screen_orientation/screenorientation-detached-notify-no-crash.html [ Crash Pass ] +crbug.com/591099 screen_orientation/screenorientation-unsupported-no-crash.html [ Crash Pass ] crbug.com/591099 scrollbars/auto-scrollbar-fit-content.html [ Failure ] crbug.com/591099 scrollbars/basic-scrollbar.html [ Failure ] crbug.com/591099 scrollbars/border-box-rect-clips-scrollbars.html [ Failure Pass ] crbug.com/591099 scrollbars/custom-scrollbar-changing-style-relayout-body-scrollablearea.html [ Crash Pass Timeout ] crbug.com/591099 scrollbars/custom-scrollbar-enable-changes-thickness-with-iframe.html [ Failure Pass ] -crbug.com/591099 scrollbars/custom-scrollbar-not-inherited-by-iframe.html [ Crash ] -crbug.com/591099 scrollbars/custom-scrollbar-reconstruction-document-write.html [ Crash ] +crbug.com/591099 scrollbars/custom-scrollbar-not-inherited-by-iframe.html [ Crash Pass ] +crbug.com/591099 scrollbars/custom-scrollbar-reconstruction-document-write.html [ Crash Pass ] crbug.com/591099 scrollbars/custom-scrollbar-with-incomplete-style.html [ Failure ] crbug.com/591099 scrollbars/disabled-scrollbar.html [ Failure ] crbug.com/591099 scrollbars/hidden-iframe-scrollbar-crash.html [ Crash Failure ] crbug.com/591099 scrollbars/hidden-scrollbar-prevents-layout.html [ Failure ] -crbug.com/591099 scrollbars/iframe-scrollbar-becomes-custom.html [ Crash ] +crbug.com/591099 scrollbars/iframe-scrollbar-becomes-custom.html [ Crash Pass ] crbug.com/591099 scrollbars/listbox-scrollbar-combinations.html [ Failure ] -crbug.com/591099 scrollbars/scrollable-iframe-click-gets-focus.html [ Crash ] -crbug.com/591099 scrollbars/scrollable-iframe-remove-crash.html [ Crash ] +crbug.com/591099 scrollbars/scrollable-iframe-click-gets-focus.html [ Crash Pass ] +crbug.com/591099 scrollbars/scrollable-iframe-remove-crash.html [ Crash Pass ] crbug.com/591099 scrollbars/scrollbar-added-during-drag.html [ Timeout ] crbug.com/591099 scrollbars/scrollbar-buttons.html [ Failure ] -crbug.com/591099 scrollbars/scrollbar-click-does-not-blur-content.html [ Crash ] +crbug.com/591099 scrollbars/scrollbar-click-does-not-blur-content.html [ Crash Failure ] crbug.com/591099 scrollbars/scrollbar-content-crash.html [ Failure ] crbug.com/591099 scrollbars/scrollbar-crash-on-refresh.html [ Failure ] crbug.com/591099 scrollbars/scrollbar-miss-mousemove-disabled.html [ Failure ] @@ -18573,7 +18583,7 @@ crbug.com/591099 scrollbars/scrollbar-visibility-hidden.html [ Failure ] crbug.com/591099 scrollbars/scrollbars-on-positioned-content.html [ Failure ] crbug.com/591099 scrollbars/viewport-scrollbar-corner-with-percent-padding-crash.html [ Failure ] -crbug.com/591099 scrollingcoordinator/donot-compute-non-fast-scrollable-region-for-hidden-frames.html [ Crash Timeout ] +crbug.com/591099 scrollingcoordinator/donot-compute-non-fast-scrollable-region-for-hidden-frames.html [ Crash Pass Timeout ] crbug.com/591099 scrollingcoordinator/non-fast-scrollable-region-nested.html [ Failure ] crbug.com/591099 scrollingcoordinator/non-fast-scrollable-region-scaled-iframe.html [ Failure ] crbug.com/591099 scrollingcoordinator/non-fast-scrollable-region-transformed-iframe.html [ Failure ] @@ -18583,41 +18593,41 @@ crbug.com/591099 security/autocomplete-cleared-on-back.html [ Crash Failure ] crbug.com/591099 security/block-test-no-port.html [ Crash Failure ] crbug.com/591099 security/block-test.html [ Crash Failure ] -crbug.com/591099 security/cannot-read-self-from-file.html [ Crash ] -crbug.com/591099 sensor/accelerometer.html [ Crash ] -crbug.com/591099 sensor/orientation-sensor.html [ Crash ] -crbug.com/591099 shadow-dom/crashes/focus-navigation-infinite-loop.html [ Crash ] +crbug.com/591099 security/cannot-read-self-from-file.html [ Crash Pass ] +crbug.com/591099 sensor/accelerometer.html [ Crash Pass ] +crbug.com/591099 sensor/orientation-sensor.html [ Crash Pass ] +crbug.com/591099 shadow-dom/crashes/focus-navigation-infinite-loop.html [ Crash Pass ] crbug.com/591099 shadow-dom/css-cascade-inner-scope-important.html [ Failure ] crbug.com/591099 shadow-dom/css-cascade-outer-scope.html [ Failure ] crbug.com/591099 shadow-dom/css-cascade-slot-distributed.html [ Failure ] -crbug.com/591099 shadow-dom/css-focus-pseudo-match-shadow-host2.html [ Crash ] -crbug.com/591099 shadow-dom/css-focus-pseudo-match-shadow-host5.html [ Crash ] -crbug.com/591099 shadow-dom/delegatesFocus-highlight-sibling.html [ Crash ] +crbug.com/591099 shadow-dom/css-focus-pseudo-match-shadow-host2.html [ Crash Pass ] +crbug.com/591099 shadow-dom/css-focus-pseudo-match-shadow-host5.html [ Crash Pass ] +crbug.com/591099 shadow-dom/delegatesFocus-highlight-sibling.html [ Crash Pass ] crbug.com/591099 shadow-dom/event-composed-ua.html [ Timeout ] -crbug.com/591099 shadow-dom/focus-method-with-delegatesFocus.html [ Crash ] -crbug.com/591099 shadow-dom/focus-navigation-slot-fallback.html [ Crash ] -crbug.com/591099 shadow-dom/focus-navigation-slot-nested-2levels.html [ Crash ] -crbug.com/591099 shadow-dom/focus-navigation-slot-nested-delegatesFocus.html [ Crash ] -crbug.com/591099 shadow-dom/focus-navigation-slot-nested.html [ Crash ] -crbug.com/591099 shadow-dom/focus-navigation-slot-with-tabindex.html [ Crash ] -crbug.com/591099 shadow-dom/focus-navigation-slots.html [ Crash ] +crbug.com/591099 shadow-dom/focus-method-with-delegatesFocus.html [ Crash Pass ] +crbug.com/591099 shadow-dom/focus-navigation-slot-fallback.html [ Crash Pass ] +crbug.com/591099 shadow-dom/focus-navigation-slot-nested-2levels.html [ Crash Pass ] +crbug.com/591099 shadow-dom/focus-navigation-slot-nested-delegatesFocus.html [ Crash Pass ] +crbug.com/591099 shadow-dom/focus-navigation-slot-nested.html [ Crash Pass ] +crbug.com/591099 shadow-dom/focus-navigation-slot-with-tabindex.html [ Crash Pass ] +crbug.com/591099 shadow-dom/focus-navigation-slots.html [ Crash Pass ] crbug.com/591099 shadow-dom/focus-navigation-with-delegatesFocus.html [ Failure Timeout ] -crbug.com/591099 shadow-dom/focus-navigation.html [ Crash ] -crbug.com/591099 shadow-dom/focus-slide-on-shadow-host.html [ Crash ] -crbug.com/591099 shadow-dom/focus-with-negative-index.html [ Crash ] -crbug.com/591099 shadow-dom/nodetree-labels-node-list.html [ Crash ] -crbug.com/591099 shadow-dom/nodetree-radio-node-list.html [ Crash ] -crbug.com/591099 shadow-dom/pointer-lock-in-shadow.html [ Crash ] +crbug.com/591099 shadow-dom/focus-navigation.html [ Crash Pass ] +crbug.com/591099 shadow-dom/focus-slide-on-shadow-host.html [ Crash Pass ] +crbug.com/591099 shadow-dom/focus-with-negative-index.html [ Crash Pass ] +crbug.com/591099 shadow-dom/nodetree-labels-node-list.html [ Crash Pass ] +crbug.com/591099 shadow-dom/nodetree-radio-node-list.html [ Crash Pass ] +crbug.com/591099 shadow-dom/pointer-lock-in-shadow.html [ Crash Pass ] crbug.com/591099 shadow-dom/slotted-pseudo-element-in-v0-tree-crash.html [ Failure ] -crbug.com/591099 shadow-dom/v0/event-composed-path.html [ Crash ] +crbug.com/591099 shadow-dom/v0/event-composed-path.html [ Crash Pass ] crbug.com/591099 shadow-dom/v0/get-destination-insertion-points-re-distribution.html [ Failure ] crbug.com/591099 shadow-dom/v0/get-destination-insertion-points.html [ Failure ] crbug.com/591099 shadow-dom/v0/multiple-shadowroot-with-params.html [ Failure ] -crbug.com/591099 shadow-dom/v0/pointer-lock-in-shadow.html [ Crash ] -crbug.com/591099 shadow-dom/v0/pointer-lock-in-shadow2.html [ Crash ] -crbug.com/591099 shadow-dom/v0/pointer-lock-in-shadow3.html [ Crash ] -crbug.com/591099 shapedetection/detection-HTMLImageElement.html [ Crash ] -crbug.com/591099 shapedetection/detection-options.html [ Crash ] +crbug.com/591099 shadow-dom/v0/pointer-lock-in-shadow.html [ Crash Pass ] +crbug.com/591099 shadow-dom/v0/pointer-lock-in-shadow2.html [ Crash Pass ] +crbug.com/591099 shadow-dom/v0/pointer-lock-in-shadow3.html [ Crash Pass ] +crbug.com/591099 shapedetection/detection-HTMLImageElement.html [ Crash Pass ] +crbug.com/591099 shapedetection/detection-options.html [ Crash Pass ] crbug.com/591099 storage/domstorage/clear.html [ Failure ] crbug.com/591099 storage/domstorage/complex-keys.html [ Failure ] crbug.com/591099 storage/domstorage/complex-values.html [ Failure ] @@ -18867,20 +18877,20 @@ crbug.com/591099 storage/quota/storagequota-query-usage.html [ Failure ] crbug.com/591099 storage/quota/storagequota-request-quota.html [ Failure ] crbug.com/591099 storage/websql/close-during-stress-test.html [ Failure ] -crbug.com/591099 storage/websql/database-removed-context-crash.html [ Crash ] +crbug.com/591099 storage/websql/database-removed-context-crash.html [ Crash Pass ] crbug.com/591099 storage/websql/execute-sql-rowsAffected.html [ Failure ] crbug.com/591099 storage/websql/null-characters.html [ Failure ] -crbug.com/591099 storage/websql/transaction-removed-context-crash.html [ Crash ] -crbug.com/591099 svg/animations/accumulate-use-count.html [ Crash ] +crbug.com/591099 storage/websql/transaction-removed-context-crash.html [ Crash Pass ] +crbug.com/591099 svg/animations/accumulate-use-count.html [ Crash Pass ] crbug.com/591099 svg/animations/accumulate-values-width-animation.html [ Failure ] -crbug.com/591099 svg/animations/add-after-load-use-counter.html [ Crash ] +crbug.com/591099 svg/animations/add-after-load-use-counter.html [ Crash Pass ] crbug.com/591099 svg/animations/additive-from-to-width-animation.html [ Failure ] crbug.com/591099 svg/animations/additive-type-by-animation.html [ Failure Timeout ] -crbug.com/591099 svg/animations/additive-use-count.html [ Crash ] +crbug.com/591099 svg/animations/additive-use-count.html [ Crash Pass ] crbug.com/591099 svg/animations/additive-values-width-animation.html [ Failure ] crbug.com/591099 svg/animations/animVal-basics.html [ Timeout ] crbug.com/591099 svg/animations/animate-calcMode-spline-by.html [ Timeout ] -crbug.com/591099 svg/animations/animate-calcMode-spline-crash-bad-array-length.xhtml [ Crash ] +crbug.com/591099 svg/animations/animate-calcMode-spline-crash-bad-array-length.xhtml [ Crash Pass ] crbug.com/591099 svg/animations/animate-calcMode-spline-from-by.html [ Timeout ] crbug.com/591099 svg/animations/animate-calcMode-spline-from-to.html [ Timeout ] crbug.com/591099 svg/animations/animate-calcMode-spline-to.html [ Timeout ] @@ -18922,7 +18932,7 @@ crbug.com/591099 svg/animations/animate-insert-begin.html [ Failure ] crbug.com/591099 svg/animations/animate-insert-no-begin.html [ Failure ] crbug.com/591099 svg/animations/animate-keySplines.html [ Timeout ] -crbug.com/591099 svg/animations/animate-keysplines-crash.html [ Crash ] +crbug.com/591099 svg/animations/animate-keysplines-crash.html [ Crash Pass ] crbug.com/591099 svg/animations/animate-marker-orient-from-angle-to-angle.html [ Timeout ] crbug.com/591099 svg/animations/animate-marker-orient-from-angle-to-auto.html [ Timeout ] crbug.com/591099 svg/animations/animate-marker-orient-from-auto-to-angle.html [ Timeout ] @@ -18944,7 +18954,7 @@ crbug.com/591099 svg/animations/animate-path-to-animation.html [ Timeout ] crbug.com/591099 svg/animations/animate-setcurrenttime.html [ Failure ] crbug.com/591099 svg/animations/animate-text-nested-transforms.html [ Timeout ] -crbug.com/591099 svg/animations/animate-values-whitespace.html [ Crash ] +crbug.com/591099 svg/animations/animate-values-whitespace.html [ Crash Pass ] crbug.com/591099 svg/animations/animateMotion-fill-freeze.html [ Failure ] crbug.com/591099 svg/animations/animateMotion-fill-remove.html [ Failure ] crbug.com/591099 svg/animations/animateMotion-multiple.html [ Failure ] @@ -18953,13 +18963,13 @@ crbug.com/591099 svg/animations/animateTransform-translate-attributetype-auto.html [ Timeout ] crbug.com/591099 svg/animations/animateTransform-translate-invalid-attributetype.html [ Timeout ] crbug.com/591099 svg/animations/animation-begin-change-js.html [ Timeout ] -crbug.com/591099 svg/animations/animation-dependency-crash.html [ Crash ] -crbug.com/591099 svg/animations/animation-started-use-counter.html [ Crash ] -crbug.com/591099 svg/animations/animationElementTiming-use-counter.html [ Crash ] +crbug.com/591099 svg/animations/animation-dependency-crash.html [ Crash Pass ] +crbug.com/591099 svg/animations/animation-started-use-counter.html [ Crash Pass ] +crbug.com/591099 svg/animations/animationElementTiming-use-counter.html [ Crash Pass ] crbug.com/591099 svg/animations/attributeTypes.html [ Failure ] -crbug.com/591099 svg/animations/begin-use-counters.html [ Crash ] -crbug.com/591099 svg/animations/beginEndAnimationElement-use-counter.html [ Crash ] -crbug.com/591099 svg/animations/calcMode-use-counters.html [ Crash ] +crbug.com/591099 svg/animations/begin-use-counters.html [ Crash Pass ] +crbug.com/591099 svg/animations/beginEndAnimationElement-use-counter.html [ Crash Pass ] +crbug.com/591099 svg/animations/calcMode-use-counters.html [ Crash Pass ] crbug.com/591099 svg/animations/change-baseVal-while-animating-fill-freeze-2.html [ Failure ] crbug.com/591099 svg/animations/change-baseVal-while-animating-fill-freeze.html [ Failure ] crbug.com/591099 svg/animations/change-baseVal-while-animating-fill-remove-2.html [ Failure ] @@ -18967,32 +18977,32 @@ crbug.com/591099 svg/animations/change-css-property-while-animating-fill-freeze.html [ Failure ] crbug.com/591099 svg/animations/change-css-property-while-animating-fill-remove.html [ Failure ] crbug.com/591099 svg/animations/change-target-while-animating-SVG-property.html [ Failure ] -crbug.com/591099 svg/animations/cssanimation-inactivedocument-crash.html [ Crash ] -crbug.com/591099 svg/animations/currentTime-use-counter.html [ Crash ] +crbug.com/591099 svg/animations/cssanimation-inactivedocument-crash.html [ Crash Pass ] +crbug.com/591099 svg/animations/currentTime-use-counter.html [ Crash Pass ] crbug.com/591099 svg/animations/cyclic-syncbase.html [ Failure ] crbug.com/591099 svg/animations/deferred-insertion.html [ Timeout ] crbug.com/591099 svg/animations/discard-on-discard.html [ Failure ] -crbug.com/591099 svg/animations/discard-on-svg-crash-2.html [ Crash ] -crbug.com/591099 svg/animations/discard-on-svg-crash.html [ Crash ] -crbug.com/591099 svg/animations/dynamic-modify-transform-without-baseval.html [ Crash ] -crbug.com/591099 svg/animations/end-use-counters.html [ Crash ] +crbug.com/591099 svg/animations/discard-on-svg-crash-2.html [ Crash Failure ] +crbug.com/591099 svg/animations/discard-on-svg-crash.html [ Crash Pass ] +crbug.com/591099 svg/animations/dynamic-modify-transform-without-baseval.html [ Crash Pass ] +crbug.com/591099 svg/animations/end-use-counters.html [ Crash Pass ] crbug.com/591099 svg/animations/force-use-shadow-tree-recreation-while-animating.html [ Failure ] -crbug.com/591099 svg/animations/img-tag-css-length-animation-crash.html [ Crash ] +crbug.com/591099 svg/animations/img-tag-css-length-animation-crash.html [ Crash Pass ] crbug.com/591099 svg/animations/multiple-animations-ending.html [ Failure Timeout ] crbug.com/591099 svg/animations/multiple-animations-fill-freeze.html [ Failure ] crbug.com/591099 svg/animations/multiple-begin-additive-animation.html [ Failure ] crbug.com/591099 svg/animations/non-additive-type-by-animation.html [ Failure ] crbug.com/591099 svg/animations/non-additive-type-from-by-animation.html [ Failure ] -crbug.com/591099 svg/animations/pause-setcurrenttime-unpause-before-timeline-start.html [ Crash ] -crbug.com/591099 svg/animations/pausing-use-counter.html [ Crash ] +crbug.com/591099 svg/animations/pause-setcurrenttime-unpause-before-timeline-start.html [ Crash Pass ] +crbug.com/591099 svg/animations/pausing-use-counter.html [ Crash Pass ] crbug.com/591099 svg/animations/reinserting-svg-into-document.html [ Failure ] crbug.com/591099 svg/animations/remove-animation-element-while-animation-is-running.html [ Failure ] crbug.com/591099 svg/animations/repeatn-remove-add-animation.html [ Failure ] -crbug.com/591099 svg/animations/script-href-no-animate.html [ Crash ] +crbug.com/591099 svg/animations/script-href-no-animate.html [ Crash Pass ] crbug.com/591099 svg/animations/single-values-animation.html [ Failure ] -crbug.com/591099 svg/animations/smil-element-target-crash-main.html [ Crash ] +crbug.com/591099 svg/animations/smil-element-target-crash-main.html [ Crash Pass ] crbug.com/591099 svg/animations/smil-scheduled-in-inactive-document-crash.html [ Failure ] -crbug.com/591099 svg/animations/svg-animation-parseValues.html [ Crash ] +crbug.com/591099 svg/animations/svg-animation-parseValues.html [ Crash Pass ] crbug.com/591099 svg/animations/svg-animation-policy-none.html [ Failure ] crbug.com/591099 svg/animations/svg-animation-policy-once.html [ Failure ] crbug.com/591099 svg/animations/svgPreserveAspectRatio-animation-1.html [ Timeout ] @@ -19071,12 +19081,12 @@ crbug.com/591099 svg/animations/svgstring-animation-fallback-to-discrete.html [ Timeout ] crbug.com/591099 svg/animations/svgtransform-animation-1.html [ Timeout ] crbug.com/591099 svg/animations/svgtransform-animation-discrete.html [ Timeout ] -crbug.com/591099 svg/animations/target-condition-crash.html [ Crash ] -crbug.com/591099 svg/animations/target-move-crash.html [ Crash ] -crbug.com/591099 svg/animations/target-move-relative-length-invalidation-crash.html [ Crash ] +crbug.com/591099 svg/animations/target-condition-crash.html [ Crash Pass ] +crbug.com/591099 svg/animations/target-move-crash.html [ Crash Pass ] +crbug.com/591099 svg/animations/target-move-relative-length-invalidation-crash.html [ Crash Pass ] crbug.com/591099 svg/animations/use-animate-transform-and-position.html [ Timeout ] crbug.com/591099 svg/animations/use-animate-width-and-height.html [ Timeout ] -crbug.com/591099 svg/animations/use-while-animating-crash.html [ Crash ] +crbug.com/591099 svg/animations/use-while-animating-crash.html [ Crash Pass ] crbug.com/591099 svg/as-background-image/animated-svg-as-background.html [ Failure Pass ] crbug.com/591099 svg/as-background-image/background-image-preserveaspectRatio-support.html [ Failure Pass ] crbug.com/591099 svg/as-background-image/background-image-tiled.html [ Failure Pass ] @@ -19094,18 +19104,18 @@ crbug.com/591099 svg/as-background-image/svg-width-100p-as-background.html [ Failure Pass ] crbug.com/591099 svg/as-border-image/svg-as-border-image-2.html [ Failure ] crbug.com/591099 svg/as-border-image/svg-as-border-image.html [ Failure ] -crbug.com/591099 svg/as-iframe/svg-in-iframe.html [ Crash ] +crbug.com/591099 svg/as-iframe/svg-in-iframe.html [ Crash Pass ] crbug.com/591099 svg/as-image/animated-use-as-image-crash.html [ Failure ] -crbug.com/591099 svg/as-image/data-font-in-css-crash.html [ Crash ] -crbug.com/591099 svg/as-image/data-font-in-css-invalid-data-url-crash.html [ Crash ] -crbug.com/591099 svg/as-image/data-font-in-css-invalid-font-crash.html [ Crash ] +crbug.com/591099 svg/as-image/data-font-in-css-crash.html [ Crash Pass ] +crbug.com/591099 svg/as-image/data-font-in-css-invalid-data-url-crash.html [ Crash Pass ] +crbug.com/591099 svg/as-image/data-font-in-css-invalid-font-crash.html [ Crash Pass ] crbug.com/591099 svg/as-image/image-respects-deviceScaleFactor.html [ Failure ] crbug.com/591099 svg/as-image/image-respects-pageScaleFactor-change.html [ Failure ] crbug.com/591099 svg/as-image/image-respects-pageScaleFactor.html [ Failure ] crbug.com/591099 svg/as-image/img-preserveAspectRatio-support-1.html [ Failure Pass ] crbug.com/591099 svg/as-image/img-preserveAspectRatio-support-2.html [ Failure Pass ] crbug.com/591099 svg/as-image/same-image-two-instances.html [ Failure Pass ] -crbug.com/591099 svg/as-image/svg-as-image-intrinsic-size.html [ Crash ] +crbug.com/591099 svg/as-image/svg-as-image-intrinsic-size.html [ Crash Pass ] crbug.com/591099 svg/as-image/svg-as-image.html [ Failure ] crbug.com/591099 svg/as-image/svg-as-relative-image-with-explicit-size.html [ Failure ] crbug.com/591099 svg/as-image/svg-as-relative-image.html [ Failure ] @@ -19121,27 +19131,27 @@ crbug.com/591099 svg/as-object/svg-embedded-in-html-in-iframe.html [ Failure Pass Timeout ] crbug.com/591099 svg/canvas/canvas-default-object-sizing.html [ Failure Pass ] crbug.com/591099 svg/canvas/canvas-draw-image-globalalpha.html [ Failure Pass ] -crbug.com/591099 svg/canvas/canvas-draw-image-size.html [ Crash ] +crbug.com/591099 svg/canvas/canvas-draw-image-size.html [ Crash Pass ] crbug.com/591099 svg/canvas/canvas-draw-image-svg-fragment.html [ Crash Pass ] -crbug.com/591099 svg/canvas/canvas-draw-pattern-size.html [ Crash ] +crbug.com/591099 svg/canvas/canvas-draw-pattern-size.html [ Crash Pass ] crbug.com/591099 svg/canvas/canvas-draw-pattern-svg-fragment.html [ Crash Pass ] crbug.com/591099 svg/canvas/canvas-pattern-svg.html [ Failure ] -crbug.com/591099 svg/canvas/image-svg-intrinsic-size.html [ Crash ] +crbug.com/591099 svg/canvas/image-svg-intrinsic-size.html [ Crash Pass ] crbug.com/591099 svg/carto.net/frameless-svg-parse-error.html [ Failure ] -crbug.com/591099 svg/clip-path/clip-path-foreign-object-crash.html [ Crash ] +crbug.com/591099 svg/clip-path/clip-path-foreign-object-crash.html [ Crash Pass ] crbug.com/591099 svg/css/background-image-svg.html [ Crash Failure Pass ] -crbug.com/591099 svg/css/baseline-shift-inherit.html [ Crash ] +crbug.com/591099 svg/css/baseline-shift-inherit.html [ Crash Pass ] crbug.com/591099 svg/css/buffered-rendering.html [ Failure ] crbug.com/591099 svg/css/css-box-min-width.html [ Failure ] -crbug.com/591099 svg/css/display-computed.html [ Crash ] +crbug.com/591099 svg/css/display-computed.html [ Crash Pass ] crbug.com/591099 svg/css/getComputedStyle-listing.xhtml [ Failure ] -crbug.com/591099 svg/css/getComputedStyle-svg-text-width-height.html [ Crash ] +crbug.com/591099 svg/css/getComputedStyle-svg-text-width-height.html [ Crash Pass ] crbug.com/591099 svg/css/mask-type.html [ Failure ] crbug.com/591099 svg/css/max-height.html [ Failure ] crbug.com/591099 svg/css/max-width.html [ Failure ] crbug.com/591099 svg/css/opacity-not-supporting-percentage.html [ Failure ] crbug.com/591099 svg/css/parse-length.html [ Failure ] -crbug.com/591099 svg/css/path-element.html [ Crash ] +crbug.com/591099 svg/css/path-element.html [ Crash Pass ] crbug.com/591099 svg/css/rect-system-color.xhtml [ Failure ] crbug.com/591099 svg/css/scientific-numbers.html [ Failure ] crbug.com/591099 svg/css/svg-attribute-length-parsing.html [ Failure ] @@ -19154,9 +19164,9 @@ crbug.com/591099 svg/custom/absolute-sized-svg-in-xhtml.xhtml [ Failure ] crbug.com/591099 svg/custom/acid3-test-77.html [ Failure ] crbug.com/591099 svg/custom/anchor-on-use.svg [ Failure ] -crbug.com/591099 svg/custom/animate-initial-pause-unpause.html [ Crash ] -crbug.com/591099 svg/custom/animate-pause-resume.html [ Crash ] -crbug.com/591099 svg/custom/animate-svgsvgelement.html [ Crash ] +crbug.com/591099 svg/custom/animate-initial-pause-unpause.html [ Crash Pass ] +crbug.com/591099 svg/custom/animate-pause-resume.html [ Crash Pass ] +crbug.com/591099 svg/custom/animate-svgsvgelement.html [ Crash Pass ] crbug.com/591099 svg/custom/animation-values-parsing-error.html [ Failure ] crbug.com/591099 svg/custom/bad-attributeName-crash.html [ Failure ] crbug.com/591099 svg/custom/boundingBox.html [ Failure ] @@ -19168,13 +19178,13 @@ crbug.com/591099 svg/custom/crash-textPath-attributes.html [ Failure ] crbug.com/591099 svg/custom/createImageElement2.xhtml [ Failure ] crbug.com/591099 svg/custom/currentColor-on-color.html [ Failure ] -crbug.com/591099 svg/custom/disallow-non-lengths-in-attrs.html [ Crash ] -crbug.com/591099 svg/custom/display-none-a-does-not-stop-focus-navigation.html [ Crash ] +crbug.com/591099 svg/custom/disallow-non-lengths-in-attrs.html [ Crash Pass ] +crbug.com/591099 svg/custom/display-none-a-does-not-stop-focus-navigation.html [ Crash Pass ] crbug.com/591099 svg/custom/dominant-baseline-hanging.svg [ Failure ] crbug.com/591099 svg/custom/elementTimeControl-nan-crash.html [ Failure ] crbug.com/591099 svg/custom/embedded-svg-allowed-in-dashboard.xml [ Failure ] crbug.com/591099 svg/custom/embedding-external-svgs.xhtml [ Failure Pass ] -crbug.com/591099 svg/custom/events-in-shadow-tree.html [ Crash ] +crbug.com/591099 svg/custom/events-in-shadow-tree.html [ Crash Pass ] crbug.com/591099 svg/custom/external-paintserver-reference.svg [ Failure Pass ] crbug.com/591099 svg/custom/filter-css-transform-resolution.html [ Failure Pass ] crbug.com/591099 svg/custom/focus-event-handling-keyboard.xhtml [ Failure ] @@ -19183,13 +19193,13 @@ crbug.com/591099 svg/custom/fragment-navigation-01.html [ Failure ] crbug.com/591099 svg/custom/fragment-navigation-02.html [ Failure ] crbug.com/591099 svg/custom/frame-getSVGDocument.html [ Failure ] -crbug.com/591099 svg/custom/getBBox-circle-has-one-zero-value.html [ Crash ] -crbug.com/591099 svg/custom/getBBox-ellipse-has-one-zero-value.html [ Crash ] -crbug.com/591099 svg/custom/getBBox-empty-container.html [ Crash ] -crbug.com/591099 svg/custom/getBBox-rect-has-one-zero-value.html [ Crash ] -crbug.com/591099 svg/custom/getBBox-use.html [ Crash ] +crbug.com/591099 svg/custom/getBBox-circle-has-one-zero-value.html [ Crash Pass ] +crbug.com/591099 svg/custom/getBBox-ellipse-has-one-zero-value.html [ Crash Pass ] +crbug.com/591099 svg/custom/getBBox-empty-container.html [ Crash Pass ] +crbug.com/591099 svg/custom/getBBox-rect-has-one-zero-value.html [ Crash Pass ] +crbug.com/591099 svg/custom/getBBox-use.html [ Crash Pass ] crbug.com/591099 svg/custom/getBoundingClientRect.xhtml [ Failure ] -crbug.com/591099 svg/custom/getClientRects.html [ Crash ] +crbug.com/591099 svg/custom/getClientRects.html [ Crash Pass ] crbug.com/591099 svg/custom/getscreenctm-in-mixed-content.xhtml [ Failure ] crbug.com/591099 svg/custom/getscreenctm-in-mixed-content2.xhtml [ Failure ] crbug.com/591099 svg/custom/getscreenctm-in-scrollable-div-area-nested.xhtml [ Failure ] @@ -19203,7 +19213,7 @@ crbug.com/591099 svg/custom/image-parent-translation.xhtml [ Failure ] crbug.com/591099 svg/custom/image-rescale-clip.html [ Failure ] crbug.com/591099 svg/custom/image-rescale-scroll.html [ Failure ] -crbug.com/591099 svg/custom/image-svgload-after-docload.html [ Crash ] +crbug.com/591099 svg/custom/image-svgload-after-docload.html [ Crash Pass ] crbug.com/591099 svg/custom/image-with-attr-change-after-delete-crash.html [ Crash Pass ] crbug.com/591099 svg/custom/inline-svg-in-xhtml.xml [ Failure ] crbug.com/591099 svg/custom/inline-svg-use-available-width-in-stf.html [ Failure ] @@ -19213,10 +19223,10 @@ crbug.com/591099 svg/custom/junk-data.svg [ Failure ] crbug.com/591099 svg/custom/keySplines-parsing-error.html [ Failure ] crbug.com/591099 svg/custom/keyTimes-parsing-error.html [ Failure ] -crbug.com/591099 svg/custom/load-image-removed-in-onload.html [ Crash ] -crbug.com/591099 svg/custom/load-image-reparented-in-onload.html [ Crash ] +crbug.com/591099 svg/custom/load-image-removed-in-onload.html [ Crash Pass ] +crbug.com/591099 svg/custom/load-image-reparented-in-onload.html [ Crash Pass ] crbug.com/591099 svg/custom/load-non-wellformed.svg [ Failure ] -crbug.com/591099 svg/custom/load-svgfragments-inserted-after-docload.html [ Crash ] +crbug.com/591099 svg/custom/load-svgfragments-inserted-after-docload.html [ Crash Pass ] crbug.com/591099 svg/custom/manually-parsed-embedded-svg-allowed-in-dashboard.html [ Failure ] crbug.com/591099 svg/custom/manually-parsed-svg-allowed-in-dashboard.html [ Failure ] crbug.com/591099 svg/custom/marker-orient-auto.html [ Failure ] @@ -19230,7 +19240,7 @@ crbug.com/591099 svg/custom/object-sizing-explicit-width-height.xhtml [ Failure Pass ] crbug.com/591099 svg/custom/object-sizing-explicit-width.xhtml [ Failure ] crbug.com/591099 svg/custom/object-sizing-no-width-height.xhtml [ Failure ] -crbug.com/591099 svg/custom/object-sizing-zero-intrinsic-width-height.html [ Crash ] +crbug.com/591099 svg/custom/object-sizing-zero-intrinsic-width-height.html [ Crash Pass ] crbug.com/591099 svg/custom/object-sizing.xhtml [ Crash Failure ] crbug.com/591099 svg/custom/path-bad-data.svg [ Failure ] crbug.com/591099 svg/custom/pattern-3-step-cycle-dynamic-1.html [ Failure ] @@ -19245,13 +19255,13 @@ crbug.com/591099 svg/custom/pointer-events-on-svg-with-pointer.xhtml [ Failure ] crbug.com/591099 svg/custom/pointer-events-on-svg-without-pointer.xhtml [ Failure ] crbug.com/591099 svg/custom/poly-parsing-error.html [ Failure ] -crbug.com/591099 svg/custom/removed-from-animation-crash.html [ Crash ] +crbug.com/591099 svg/custom/removed-from-animation-crash.html [ Crash Pass ] crbug.com/591099 svg/custom/rootmost-svg-xy-attrs.xhtml [ Failure ] crbug.com/591099 svg/custom/scroll-to-svg-element-assertion.html [ Failure ] crbug.com/591099 svg/custom/second-inline-text.xhtml [ Failure Pass ] crbug.com/591099 svg/custom/simpleCDF.xml [ Failure Pass ] -crbug.com/591099 svg/custom/size-follows-container-size.html [ Crash ] -crbug.com/591099 svg/custom/stf-container-with-intrinsic-ratio-svg.html [ Crash ] +crbug.com/591099 svg/custom/size-follows-container-size.html [ Crash Failure ] +crbug.com/591099 svg/custom/stf-container-with-intrinsic-ratio-svg.html [ Crash Pass ] crbug.com/591099 svg/custom/svg-allowed-in-dashboard-object.html [ Failure ] crbug.com/591099 svg/custom/svg-createsvgtransform-type.html [ Failure ] crbug.com/591099 svg/custom/svg-float-border-padding.xml [ Failure ] @@ -19260,8 +19270,8 @@ crbug.com/591099 svg/custom/svg-fonts-no-latin-glyph.html [ Failure ] crbug.com/591099 svg/custom/svg-fonts-with-no-element-reference.html [ Failure Pass ] crbug.com/591099 svg/custom/svg-fonts-word-spacing.html [ Failure ] -crbug.com/591099 svg/custom/svg-image-intrinsic-size-with-cssstyle-auto-dynamic-image-change.html [ Crash ] -crbug.com/591099 svg/custom/svg-image-intrinsic-size-with-cssstyle-auto.html [ Crash ] +crbug.com/591099 svg/custom/svg-image-intrinsic-size-with-cssstyle-auto-dynamic-image-change.html [ Crash Pass ] +crbug.com/591099 svg/custom/svg-image-intrinsic-size-with-cssstyle-auto.html [ Crash Pass ] crbug.com/591099 svg/custom/svg-modify-currentTranslate.html [ Failure ] crbug.com/591099 svg/custom/svg-root-padding-border-margin.html [ Failure Pass ] crbug.com/591099 svg/custom/svg-viewBox-dynamic.html [ Failure ] @@ -19269,7 +19279,7 @@ crbug.com/591099 svg/custom/tabindex-order.html [ Failure ] crbug.com/591099 svg/custom/tearoffs-with-tearoffs.html [ Failure ] crbug.com/591099 svg/custom/text-match-highlight.html [ Failure ] -crbug.com/591099 svg/custom/text-use-click-crash.xhtml [ Crash ] +crbug.com/591099 svg/custom/text-use-click-crash.xhtml [ Crash Pass ] crbug.com/591099 svg/custom/text-zoom.xhtml [ Failure Pass ] crbug.com/591099 svg/custom/title-assertion.html [ Failure ] crbug.com/591099 svg/custom/touch-events.html [ Failure ] @@ -19282,7 +19292,7 @@ crbug.com/591099 svg/custom/use-invalid-html.xhtml [ Failure ] crbug.com/591099 svg/custom/use-invalid-pattern.svg [ Failure ] crbug.com/591099 svg/custom/use-invalid-style.svg [ Failure ] -crbug.com/591099 svg/custom/use-invalidate-click-crash.xhtml [ Crash ] +crbug.com/591099 svg/custom/use-invalidate-click-crash.xhtml [ Crash Pass ] crbug.com/591099 svg/custom/use-on-disallowed-foreign-object-1.svg [ Failure Pass ] crbug.com/591099 svg/custom/use-on-disallowed-foreign-object-2.svg [ Failure Pass ] crbug.com/591099 svg/custom/use-on-disallowed-foreign-object-3.svg [ Failure Pass ] @@ -19293,28 +19303,28 @@ crbug.com/591099 svg/custom/use-referencing-style-crash.svg [ Failure ] crbug.com/591099 svg/custom/viewport-em.svg [ Failure Pass ] crbug.com/591099 svg/custom/xhtml-no-svg-renderer.xhtml [ Crash Failure Pass ] -crbug.com/591099 svg/custom/zoomed-alignment-baseline.html [ Crash ] -crbug.com/591099 svg/custom/zoomed-baseline-shift.html [ Crash ] -crbug.com/591099 svg/custom/zoomed-ex-em-font-sizes.html [ Crash ] -crbug.com/591099 svg/custom/zoomed-mixed-scripts.html [ Crash ] +crbug.com/591099 svg/custom/zoomed-alignment-baseline.html [ Crash Pass ] +crbug.com/591099 svg/custom/zoomed-baseline-shift.html [ Crash Pass ] +crbug.com/591099 svg/custom/zoomed-ex-em-font-sizes.html [ Crash Pass ] +crbug.com/591099 svg/custom/zoomed-mixed-scripts.html [ Crash Pass ] crbug.com/591099 svg/dispatch-event-crash-on-destruct.html [ Failure ] crbug.com/591099 svg/dom/SVGAnimatedListPropertyTearOff-crash-2.html [ Failure ] crbug.com/591099 svg/dom/SVGAnimatedListPropertyTearOff-crash.html [ Failure ] -crbug.com/591099 svg/dom/SVGAnimationElement-exceptions.html [ Crash ] -crbug.com/591099 svg/dom/SVGGeometryElement-getPointAtLength-attached.html [ Crash ] -crbug.com/591099 svg/dom/SVGGeometryElement-getTotalLength-attached.html [ Crash ] -crbug.com/591099 svg/dom/SVGLength-calc-in-attr.html [ Crash ] -crbug.com/591099 svg/dom/SVGLength-viewport-units.html [ Crash ] -crbug.com/591099 svg/dom/SVGLengthList-appendItem.html [ Crash ] -crbug.com/591099 svg/dom/SVGLengthList-appendItemFromClearedList.html [ Crash ] -crbug.com/591099 svg/dom/SVGLengthList-basics.html [ Crash ] -crbug.com/591099 svg/dom/SVGLengthList-dom-modifications.html [ Crash ] -crbug.com/591099 svg/dom/SVGLengthList-getItem.html [ Crash ] -crbug.com/591099 svg/dom/SVGLengthList-initialize.html [ Crash ] -crbug.com/591099 svg/dom/SVGLengthList-insertItemBefore.html [ Crash ] -crbug.com/591099 svg/dom/SVGLengthList-removeItem.html [ Crash ] -crbug.com/591099 svg/dom/SVGLengthList-replaceItem.html [ Crash ] -crbug.com/591099 svg/dom/SVGLengthList-setEmptyString.html [ Crash ] +crbug.com/591099 svg/dom/SVGAnimationElement-exceptions.html [ Crash Pass ] +crbug.com/591099 svg/dom/SVGGeometryElement-getPointAtLength-attached.html [ Crash Pass ] +crbug.com/591099 svg/dom/SVGGeometryElement-getTotalLength-attached.html [ Crash Pass ] +crbug.com/591099 svg/dom/SVGLength-calc-in-attr.html [ Crash Pass ] +crbug.com/591099 svg/dom/SVGLength-viewport-units.html [ Crash Pass ] +crbug.com/591099 svg/dom/SVGLengthList-appendItem.html [ Crash Pass ] +crbug.com/591099 svg/dom/SVGLengthList-appendItemFromClearedList.html [ Crash Pass ] +crbug.com/591099 svg/dom/SVGLengthList-basics.html [ Crash Pass ] +crbug.com/591099 svg/dom/SVGLengthList-dom-modifications.html [ Crash Pass ] +crbug.com/591099 svg/dom/SVGLengthList-getItem.html [ Crash Pass ] +crbug.com/591099 svg/dom/SVGLengthList-initialize.html [ Crash Pass ] +crbug.com/591099 svg/dom/SVGLengthList-insertItemBefore.html [ Crash Pass ] +crbug.com/591099 svg/dom/SVGLengthList-removeItem.html [ Crash Pass ] +crbug.com/591099 svg/dom/SVGLengthList-replaceItem.html [ Crash Pass ] +crbug.com/591099 svg/dom/SVGLengthList-setEmptyString.html [ Crash Pass ] crbug.com/591099 svg/dom/SVGLocatable-getCTM-svg-root.html [ Failure ] crbug.com/591099 svg/dom/SVGMatrix-interface.xhtml [ Failure ] crbug.com/591099 svg/dom/SVGNumberList-basics.xhtml [ Failure ] @@ -19326,25 +19336,25 @@ crbug.com/591099 svg/dom/SVGSVGElement-intersection-enclosure.html [ Failure ] crbug.com/591099 svg/dom/SVGStringList-basics.xhtml [ Failure ] crbug.com/591099 svg/dom/SVGStringList.html [ Failure ] -crbug.com/591099 svg/dom/SVGStyleElement.html [ Crash ] +crbug.com/591099 svg/dom/SVGStyleElement.html [ Crash Pass ] crbug.com/591099 svg/dom/SVGStyleElement/disable-svg-style-element.html [ Failure ] crbug.com/591099 svg/dom/SVGStyleElement/style-langspace.html [ Failure ] -crbug.com/591099 svg/dom/SVGStyledElement-pendingResource-crash.html [ Crash ] -crbug.com/591099 svg/dom/SVGTransformList-basics.html [ Crash ] -crbug.com/591099 svg/dom/SVGTransformList-with-existing-item.html [ Crash ] +crbug.com/591099 svg/dom/SVGStyledElement-pendingResource-crash.html [ Crash Pass ] +crbug.com/591099 svg/dom/SVGTransformList-basics.html [ Crash Pass ] +crbug.com/591099 svg/dom/SVGTransformList-with-existing-item.html [ Crash Pass ] crbug.com/591099 svg/dom/content-model.html [ Failure ] crbug.com/591099 svg/dom/css-transforms.xhtml [ Failure ] crbug.com/591099 svg/dom/document-createEvent-mandatory-arg.html [ Failure ] crbug.com/591099 svg/dom/feFlood-no-in1.html [ Failure ] crbug.com/591099 svg/dom/frame-related-api-during-load.html [ Failure ] crbug.com/591099 svg/dom/getElementsByTagName-localName-matching.html [ Failure ] -crbug.com/591099 svg/dom/getScreenCTM-ancestor-transform.html [ Crash ] -crbug.com/591099 svg/dom/getbbox.html [ Crash ] -crbug.com/591099 svg/dom/getscreenctm-use-with-additional-translation.html [ Crash ] -crbug.com/591099 svg/dom/href-baseval-animval.html [ Crash ] +crbug.com/591099 svg/dom/getScreenCTM-ancestor-transform.html [ Crash Pass ] +crbug.com/591099 svg/dom/getbbox.html [ Crash Pass ] +crbug.com/591099 svg/dom/getscreenctm-use-with-additional-translation.html [ Crash Pass ] +crbug.com/591099 svg/dom/href-baseval-animval.html [ Crash Pass ] crbug.com/591099 svg/dom/id-reflect.html [ Failure ] crbug.com/591099 svg/dom/length-list-parser.html [ Failure Timeout ] -crbug.com/591099 svg/dom/linear-gradient-default-length.html [ Crash ] +crbug.com/591099 svg/dom/linear-gradient-default-length.html [ Crash Pass ] crbug.com/591099 svg/dom/method-argument-aritychecks.html [ Failure ] crbug.com/591099 svg/dom/method-argument-typechecks.html [ Failure ] crbug.com/591099 svg/dom/move-animating-svg-to-other-frame.html [ Failure ] @@ -19360,12 +19370,12 @@ crbug.com/591099 svg/dom/svg-element-attribute-js-null.xhtml [ Failure ] crbug.com/591099 svg/dom/svg-root-lengths.html [ Failure ] crbug.com/591099 svg/dom/svg2-inheritance.html [ Failure ] -crbug.com/591099 svg/dom/svgangle-units.html [ Crash ] -crbug.com/591099 svg/dom/svglength-units.html [ Crash ] +crbug.com/591099 svg/dom/svgangle-units.html [ Crash Timeout ] +crbug.com/591099 svg/dom/svglength-units.html [ Crash Pass ] crbug.com/591099 svg/dom/svgpath-getPathSegAtLength.html [ Failure ] crbug.com/591099 svg/dom/text-rotate-live.html [ Failure ] -crbug.com/591099 svg/dom/title-in-shadow-tree.html [ Crash ] -crbug.com/591099 svg/dom/tooltip-title-with-use.html [ Crash ] +crbug.com/591099 svg/dom/title-in-shadow-tree.html [ Crash Failure ] +crbug.com/591099 svg/dom/tooltip-title-with-use.html [ Crash Failure ] crbug.com/591099 svg/dom/undefined-null.html [ Failure ] crbug.com/591099 svg/dynamic-updates/SVG-dynamic-css-transform.html [ Failure ] crbug.com/591099 svg/dynamic-updates/SVGAElement-dom-href-attr.html [ Failure ] @@ -19701,11 +19711,11 @@ crbug.com/591099 svg/dynamic-updates/SVGUseElement-svgdom-href1-prop.html [ Failure ] crbug.com/591099 svg/dynamic-updates/SVGUseElement-svgdom-href2-prop.html [ Failure ] crbug.com/591099 svg/filters/feBlend-all-modes.html [ Failure Pass ] -crbug.com/591099 svg/filters/feComponentTransfer-style-crash.xhtml [ Crash ] -crbug.com/591099 svg/filters/feDisplacementMap-crash-test.xhtml [ Crash ] +crbug.com/591099 svg/filters/feComponentTransfer-style-crash.xhtml [ Crash Pass ] +crbug.com/591099 svg/filters/feDisplacementMap-crash-test.xhtml [ Crash Pass ] crbug.com/591099 svg/filters/feLight-non-lighting-parent-crash.html [ Failure ] crbug.com/591099 svg/filters/feTurbulence-bad-seeds.html [ Failure ] -crbug.com/591099 svg/filters/filter-detach-crash.html [ Crash ] +crbug.com/591099 svg/filters/filter-detach-crash.html [ Crash Pass ] crbug.com/591099 svg/filters/reparent-animated-filter-target.html [ Failure ] crbug.com/591099 svg/foreignObject/background-render-phase.html [ Failure ] crbug.com/591099 svg/foreignObject/body-background.svg [ Failure Pass ] @@ -19718,10 +19728,10 @@ crbug.com/591099 svg/foreignObject/no-crash-with-svg-content-in-html-document.svg [ Failure Pass ] crbug.com/591099 svg/foreignObject/svg-document-in-html-document.svg [ Failure Pass ] crbug.com/591099 svg/foreignObject/vertical-foreignObject.html [ Failure ] -crbug.com/591099 svg/foreignObject/viewport-foreignobject-crash.html [ Crash ] -crbug.com/591099 svg/hittest/clip-path-shape.html [ Crash ] +crbug.com/591099 svg/foreignObject/viewport-foreignobject-crash.html [ Crash Pass ] +crbug.com/591099 svg/hittest/clip-path-shape.html [ Crash Failure ] crbug.com/591099 svg/hittest/ellipse-hittest.html [ Failure ] -crbug.com/591099 svg/hittest/empty-container.html [ Crash ] +crbug.com/591099 svg/hittest/empty-container.html [ Crash Failure ] crbug.com/591099 svg/hittest/pointer-events-all.html [ Failure ] crbug.com/591099 svg/hittest/pointer-events-all2.html [ Failure ] crbug.com/591099 svg/hittest/rect-hittest.html [ Failure ] @@ -19738,13 +19748,13 @@ crbug.com/591099 svg/hittest/svg-small-path.xhtml [ Failure ] crbug.com/591099 svg/hittest/svg-small-viewbox.xhtml [ Failure ] crbug.com/591099 svg/hittest/svg-use-element-from-point.html [ Failure ] -crbug.com/591099 svg/hittest/text-small-font-size.html [ Crash ] -crbug.com/591099 svg/hittest/text-vertical.html [ Crash ] +crbug.com/591099 svg/hittest/text-small-font-size.html [ Crash Failure ] +crbug.com/591099 svg/hittest/text-vertical.html [ Crash Failure ] crbug.com/591099 svg/hittest/update-ellipse.html [ Failure ] crbug.com/591099 svg/hittest/update-rect.html [ Failure ] -crbug.com/591099 svg/hittest/zero-length-butt-cap-path.xhtml [ Crash ] -crbug.com/591099 svg/hittest/zero-length-round-cap-path.xhtml [ Crash ] -crbug.com/591099 svg/hittest/zero-length-square-cap-path.xhtml [ Crash ] +crbug.com/591099 svg/hittest/zero-length-butt-cap-path.xhtml [ Crash Failure ] +crbug.com/591099 svg/hittest/zero-length-round-cap-path.xhtml [ Crash Failure ] +crbug.com/591099 svg/hittest/zero-length-square-cap-path.xhtml [ Crash Failure ] crbug.com/591099 svg/hixie/data-types/002.xhtml [ Failure Pass ] crbug.com/591099 svg/hixie/error/012.xml [ Failure ] crbug.com/591099 svg/hixie/error/013.xml [ Failure ] @@ -19764,7 +19774,7 @@ crbug.com/591099 svg/hixie/rendering-model/004.xhtml [ Failure Pass ] crbug.com/591099 svg/in-html/by-reference.html [ Failure Pass ] crbug.com/591099 svg/in-html/circle.html [ Failure Pass ] -crbug.com/591099 svg/in-html/sizing/svg-inline-vertical.html [ Crash ] +crbug.com/591099 svg/in-html/sizing/svg-inline-vertical.html [ Crash Pass ] crbug.com/591099 svg/in-html/sizing/svg-inline.html [ Failure Timeout ] crbug.com/591099 svg/overflow/overflow-on-foreignObject.svg [ Crash Failure Pass ] crbug.com/591099 svg/overflow/overflow-on-outermost-svg-element-in-xhtml-auto.xhtml [ Failure ] @@ -19773,53 +19783,53 @@ crbug.com/591099 svg/overflow/overflow-on-outermost-svg-element-in-xhtml-scroll.xhtml [ Failure ] crbug.com/591099 svg/overflow/overflow-on-outermost-svg-element-in-xhtml-visible.xhtml [ Failure ] crbug.com/591099 svg/parser/foreign-object-case-sensitivity.html [ Failure ] -crbug.com/591099 svg/parser/whitespace-angle-1.html [ Crash ] -crbug.com/591099 svg/parser/whitespace-angle-2.html [ Crash ] -crbug.com/591099 svg/parser/whitespace-angle-invalid-1.html [ Crash ] -crbug.com/591099 svg/parser/whitespace-angle-invalid-2.html [ Crash ] -crbug.com/591099 svg/parser/whitespace-integer.html [ Crash ] -crbug.com/591099 svg/parser/whitespace-length-invalid-1.html [ Crash ] -crbug.com/591099 svg/parser/whitespace-length-invalid-2.html [ Crash ] -crbug.com/591099 svg/parser/whitespace-length-invalid-3.html [ Crash ] -crbug.com/591099 svg/parser/whitespace-length-invalid-4.html [ Crash ] -crbug.com/591099 svg/parser/whitespace-length.html [ Crash ] -crbug.com/591099 svg/parser/whitespace-number.html [ Crash ] +crbug.com/591099 svg/parser/whitespace-angle-1.html [ Crash Pass Timeout ] +crbug.com/591099 svg/parser/whitespace-angle-2.html [ Crash Pass ] +crbug.com/591099 svg/parser/whitespace-angle-invalid-1.html [ Crash Timeout ] +crbug.com/591099 svg/parser/whitespace-angle-invalid-2.html [ Crash Timeout ] +crbug.com/591099 svg/parser/whitespace-integer.html [ Crash Pass Timeout ] +crbug.com/591099 svg/parser/whitespace-length-invalid-1.html [ Crash Timeout ] +crbug.com/591099 svg/parser/whitespace-length-invalid-2.html [ Crash Timeout ] +crbug.com/591099 svg/parser/whitespace-length-invalid-3.html [ Crash Timeout ] +crbug.com/591099 svg/parser/whitespace-length-invalid-4.html [ Crash Timeout ] +crbug.com/591099 svg/parser/whitespace-length.html [ Crash Pass Timeout ] +crbug.com/591099 svg/parser/whitespace-number.html [ Crash Timeout ] crbug.com/591099 svg/stroke/empty-path.html [ Failure Pass ] crbug.com/591099 svg/text/bbox-with-glyph-overflow-on-path.html [ Failure ] crbug.com/591099 svg/text/bbox-with-glyph-overflow-zoomed.html [ Failure ] crbug.com/591099 svg/text/bbox-with-glyph-overflow.html [ Failure ] -crbug.com/591099 svg/text/bidi-getcharnumatpos.html [ Crash ] -crbug.com/591099 svg/text/bidi-getcomputedtextlength.html [ Crash ] -crbug.com/591099 svg/text/bidi-getsubstringlength.html [ Crash ] +crbug.com/591099 svg/text/bidi-getcharnumatpos.html [ Crash Pass ] +crbug.com/591099 svg/text/bidi-getcomputedtextlength.html [ Crash Pass ] +crbug.com/591099 svg/text/bidi-getsubstringlength.html [ Crash Pass ] crbug.com/591099 svg/text/combining-character-queries.html [ Failure Pass ] -crbug.com/591099 svg/text/empty-text-node-crash.html [ Crash ] +crbug.com/591099 svg/text/empty-text-node-crash.html [ Crash Pass ] crbug.com/591099 svg/text/foreignObject-repaint.xml [ Failure ] crbug.com/591099 svg/text/foreignObject-text-clipping-bug.xml [ Failure Pass ] -crbug.com/591099 svg/text/getcharnumatposition-multiple-fragments.html [ Crash ] -crbug.com/591099 svg/text/getextentofchar-nonbmp.html [ Crash ] +crbug.com/591099 svg/text/getcharnumatposition-multiple-fragments.html [ Crash Pass ] +crbug.com/591099 svg/text/getextentofchar-nonbmp.html [ Crash Pass ] crbug.com/591099 svg/text/invalid-glyph-crash.html [ Failure ] -crbug.com/591099 svg/text/invalid-non-bmp-characters.html [ Crash ] +crbug.com/591099 svg/text/invalid-non-bmp-characters.html [ Crash Pass ] crbug.com/591099 svg/text/lengthAdjust-text-metrics.html [ Failure ] crbug.com/591099 svg/text/ligature-queries.html [ Failure Pass ] crbug.com/591099 svg/text/scaling-font-with-geometric-precision.html [ Failure ] -crbug.com/591099 svg/text/select-svg-text-with-collapsed-whitespace.html [ Crash ] +crbug.com/591099 svg/text/select-svg-text-with-collapsed-whitespace.html [ Crash Failure ] crbug.com/591099 svg/text/select-text-inside-non-static-position.html [ Failure ] crbug.com/591099 svg/text/selection-background-color.xhtml [ Failure Pass ] -crbug.com/591099 svg/text/selection-dragging-outside-1.html [ Crash ] -crbug.com/591099 svg/text/selection-dragging-outside-2.html [ Crash ] -crbug.com/591099 svg/text/selection-dragging-outside-3.html [ Crash ] -crbug.com/591099 svg/text/selection-pseudo-resource-invalidation-crash.html [ Crash ] +crbug.com/591099 svg/text/selection-dragging-outside-1.html [ Crash Failure ] +crbug.com/591099 svg/text/selection-dragging-outside-2.html [ Crash Failure ] +crbug.com/591099 svg/text/selection-dragging-outside-3.html [ Crash Failure ] +crbug.com/591099 svg/text/selection-pseudo-resource-invalidation-crash.html [ Crash Pass ] crbug.com/591099 svg/text/selection-styles.xhtml [ Failure Pass ] crbug.com/591099 svg/text/small-fonts-in-html5.html [ Failure Pass ] crbug.com/591099 svg/text/surrogate-pair-queries.html [ Failure Pass ] -crbug.com/591099 svg/text/svgtextcontentelement-glyphqueries-rtl.html [ Crash ] -crbug.com/591099 svg/text/text-bbox-empty.html [ Crash ] -crbug.com/591099 svg/text/text-bbox-of-empty-after-change.html [ Crash ] -crbug.com/591099 svg/text/text-getSubStringLength.html [ Crash ] +crbug.com/591099 svg/text/svgtextcontentelement-glyphqueries-rtl.html [ Crash Pass ] +crbug.com/591099 svg/text/text-bbox-empty.html [ Crash Pass ] +crbug.com/591099 svg/text/text-bbox-of-empty-after-change.html [ Crash Pass ] +crbug.com/591099 svg/text/text-getSubStringLength.html [ Crash Pass ] crbug.com/591099 svg/text/text-repaint-rects.xhtml [ Failure ] crbug.com/591099 svg/text/text-style-recalc-crash.html [ Failure Pass ] -crbug.com/591099 svg/text/textpath-reference-crash.html [ Crash ] -crbug.com/591099 svg/text/textquery-collapsed-whitespace.html [ Crash ] +crbug.com/591099 svg/text/textpath-reference-crash.html [ Crash Pass ] +crbug.com/591099 svg/text/textquery-collapsed-whitespace.html [ Crash Pass ] crbug.com/591099 svg/text/unpaired-surrogate-with-trailing-char-crash.html [ Failure ] crbug.com/591099 svg/text/white-space-pre-wrap-whitespace-only-crash.html [ Failure ] crbug.com/591099 svg/transforms/negative-scale-value.html [ Failure ] @@ -19827,12 +19837,12 @@ crbug.com/591099 svg/transforms/svg-css-transforms-clip-path.xhtml [ Failure ] crbug.com/591099 svg/transforms/svg-css-transforms.xhtml [ Failure ] crbug.com/591099 svg/transforms/text-with-pattern-inside-transformed-html.xhtml [ Failure ] -crbug.com/591099 svg/transforms/transform-boxsize-usecounter-1.html [ Crash ] -crbug.com/591099 svg/transforms/transform-boxsize-usecounter-2.html [ Crash ] -crbug.com/591099 svg/transforms/transform-boxsize-usecounter-3.html [ Crash ] -crbug.com/591099 svg/transforms/transform-boxsize-usecounter-4.html [ Crash ] -crbug.com/591099 svg/transforms/transform-boxsize-usecounter-no-trigger-1.html [ Crash ] -crbug.com/591099 svg/transforms/transform-boxsize-usecounter-no-trigger-2.html [ Crash ] +crbug.com/591099 svg/transforms/transform-boxsize-usecounter-1.html [ Crash Pass ] +crbug.com/591099 svg/transforms/transform-boxsize-usecounter-2.html [ Crash Pass ] +crbug.com/591099 svg/transforms/transform-boxsize-usecounter-3.html [ Crash Pass ] +crbug.com/591099 svg/transforms/transform-boxsize-usecounter-4.html [ Crash Pass ] +crbug.com/591099 svg/transforms/transform-boxsize-usecounter-no-trigger-1.html [ Crash Pass ] +crbug.com/591099 svg/transforms/transform-boxsize-usecounter-no-trigger-2.html [ Crash Pass ] crbug.com/591099 svg/transforms/transform-origin-presentation-attribute.xhtml [ Failure ] crbug.com/591099 svg/wicd/test-rightsizing-a.xhtml [ Failure ] crbug.com/591099 svg/wicd/test-rightsizing-b.xhtml [ Failure ] @@ -19866,7 +19876,7 @@ crbug.com/591099 svg/zoom/text/zoom-hixie-mixed-009.xml [ Failure Pass ] crbug.com/591099 svg/zoom/text/zoom-hixie-rendering-model-004.xhtml [ Failure Pass ] crbug.com/591099 svg/zoom/text/zoom-svg-float-border-padding.xml [ Failure ] -crbug.com/591099 svg/zoom/xy-getcomputedstyle.html [ Crash ] +crbug.com/591099 svg/zoom/xy-getcomputedstyle.html [ Crash Pass ] crbug.com/591099 tables/hittesting/filltable-stress.html [ Pass Timeout ] crbug.com/591099 tables/layering/paint-test-layering-1.html [ Failure ] crbug.com/591099 tables/layering/paint-test-layering-2.html [ Failure ] @@ -20178,21 +20188,21 @@ crbug.com/591099 touchadjustment/context-menu-select-text.html [ Failure ] crbug.com/591099 touchadjustment/context-menu-shadow-node.html [ Failure ] crbug.com/591099 touchadjustment/context-menu-text-subtargets.html [ Failure ] -crbug.com/591099 touchadjustment/context-menu.html [ Crash ] -crbug.com/591099 touchadjustment/disabled-formelements.html [ Crash ] +crbug.com/591099 touchadjustment/context-menu.html [ Crash Failure ] +crbug.com/591099 touchadjustment/disabled-formelements.html [ Crash Failure ] crbug.com/591099 touchadjustment/editable-content.html [ Crash Failure ] -crbug.com/591099 touchadjustment/event-triggered-widgets.html [ Crash ] -crbug.com/591099 touchadjustment/html-label.html [ Crash ] +crbug.com/591099 touchadjustment/event-triggered-widgets.html [ Crash Failure ] +crbug.com/591099 touchadjustment/html-label.html [ Crash Failure ] crbug.com/591099 touchadjustment/iframe.html [ Failure ] crbug.com/591099 touchadjustment/nested-shadow-node.html [ Failure ] crbug.com/591099 touchadjustment/nested-touch.html [ Failure ] -crbug.com/591099 touchadjustment/plugin.html [ Crash ] +crbug.com/591099 touchadjustment/plugin.html [ Crash Failure ] crbug.com/591099 touchadjustment/pseudo-element.html [ Failure ] crbug.com/591099 touchadjustment/rotated-node.html [ Failure ] crbug.com/591099 touchadjustment/scroll-offset.html [ Failure ] crbug.com/591099 touchadjustment/search-cancel.html [ Crash Failure ] crbug.com/591099 touchadjustment/simple-shadow-dom.html [ Failure ] -crbug.com/591099 touchadjustment/small-target-test.html [ Crash ] +crbug.com/591099 touchadjustment/small-target-test.html [ Crash Failure ] crbug.com/591099 touchadjustment/touch-inlines.html [ Failure ] crbug.com/591099 touchadjustment/touch-links-active.html [ Failure ] crbug.com/591099 touchadjustment/touch-links-longpress.html [ Failure ] @@ -20240,11 +20250,11 @@ crbug.com/591099 transforms/mirror-transform-tiled-scaled-background.html [ Failure ] crbug.com/591099 transforms/no_transform_hit_testing.html [ Failure ] crbug.com/591099 transforms/overflow-with-transform.html [ Failure ] -crbug.com/591099 transforms/perspective-origin-parsing.html [ Crash ] -crbug.com/591099 transforms/rotate-parsing.html [ Crash ] +crbug.com/591099 transforms/perspective-origin-parsing.html [ Crash Pass ] +crbug.com/591099 transforms/rotate-parsing.html [ Crash Pass ] crbug.com/591099 transforms/rotated-transform-affects-scrolling-1.html [ Failure ] crbug.com/591099 transforms/rotated-transform-affects-scrolling-2.html [ Failure ] -crbug.com/591099 transforms/scale-parsing.html [ Crash ] +crbug.com/591099 transforms/scale-parsing.html [ Crash Pass ] crbug.com/591099 transforms/scrollIntoView-transformed.html [ Failure ] crbug.com/591099 transforms/shadows.html [ Failure ] crbug.com/591099 transforms/skew-with-unitless-zero.html [ Failure ] @@ -20253,9 +20263,9 @@ crbug.com/591099 transforms/transform-inherit-initial-unprefixed.html [ Failure ] crbug.com/591099 transforms/transform-inside-overflow-scroll.html [ Failure ] crbug.com/591099 transforms/transform-on-inline.html [ Failure ] -crbug.com/591099 transforms/transform-origin-parsing.html [ Crash ] +crbug.com/591099 transforms/transform-origin-parsing.html [ Crash Pass ] crbug.com/591099 transforms/transform-overflow.html [ Failure ] -crbug.com/591099 transforms/transform-parsing.html [ Crash ] +crbug.com/591099 transforms/transform-parsing.html [ Crash Pass ] crbug.com/591099 transforms/transform-positioned-ancestor.html [ Failure Pass ] crbug.com/591099 transforms/transform-table-row.html [ Failure Pass ] crbug.com/591099 transforms/transformed-caret.html [ Failure ] @@ -20263,31 +20273,31 @@ crbug.com/591099 transforms/transformed-focused-text-input.html [ Failure ] crbug.com/591099 transforms/transforms-with-opacity.html [ Failure ] crbug.com/591099 transforms/transforms-with-zoom.html [ Failure ] -crbug.com/591099 transforms/translate-parsing.html [ Crash ] +crbug.com/591099 transforms/translate-parsing.html [ Crash Pass ] crbug.com/591099 transitions/3d/interrupted-transition.html [ Failure ] crbug.com/591099 transitions/bad-transition-shorthand-crash.html [ Failure ] -crbug.com/591099 transitions/cubic-bezier-overflow-svg-length.html [ Crash ] +crbug.com/591099 transitions/cubic-bezier-overflow-svg-length.html [ Crash Pass ] crbug.com/591099 transitions/inherit-other-props-do-not-affect-transition-property.html [ Failure ] crbug.com/591099 transitions/inherit-other-props.html [ Failure ] crbug.com/591099 transitions/inherit.html [ Failure ] -crbug.com/591099 transitions/interrupted-accelerated-transition.html [ Crash ] +crbug.com/591099 transitions/interrupted-accelerated-transition.html [ Crash Pass ] crbug.com/591099 transitions/interrupted-immediately.html [ Failure ] crbug.com/591099 transitions/matched-transform-functions.html [ Failure ] -crbug.com/591099 transitions/mismatched-shadow-styles.html [ Crash ] -crbug.com/591099 transitions/no-transition-on-implicit-margins.html [ Crash ] -crbug.com/591099 transitions/object-position-transition.html [ Crash ] +crbug.com/591099 transitions/mismatched-shadow-styles.html [ Crash Pass ] +crbug.com/591099 transitions/no-transition-on-implicit-margins.html [ Crash Pass ] +crbug.com/591099 transitions/object-position-transition.html [ Crash Pass ] crbug.com/591099 transitions/opacity-transform-transitions-inside-iframe.html [ Failure ] crbug.com/591099 transitions/opacity-transition-zindex.html [ Failure Pass ] crbug.com/591099 transitions/override-transition-crash.html [ Failure ] crbug.com/591099 transitions/retargetted-transition.html [ Failure ] crbug.com/591099 transitions/shadow.html [ Failure ] -crbug.com/591099 transitions/svg-layout-transition-zoom.html [ Crash ] -crbug.com/591099 transitions/svg-layout-transition.html [ Crash ] -crbug.com/591099 transitions/svg-transitions.html [ Crash ] +crbug.com/591099 transitions/svg-layout-transition-zoom.html [ Crash Pass ] +crbug.com/591099 transitions/svg-layout-transition.html [ Crash Pass ] +crbug.com/591099 transitions/svg-transitions.html [ Crash Pass ] crbug.com/591099 transitions/transition-end-event-all-properties.html [ Failure ] crbug.com/591099 transitions/transition-end-event-attributes.html [ Failure ] crbug.com/591099 transitions/transition-end-event-container.html [ Failure ] -crbug.com/591099 transitions/transition-end-event-destroy-iframe.html [ Crash ] +crbug.com/591099 transitions/transition-end-event-destroy-iframe.html [ Crash Failure ] crbug.com/591099 transitions/transition-end-event-destroy-renderer.html [ Failure ] crbug.com/591099 transitions/transition-end-event-left.html [ Failure ] crbug.com/591099 transitions/transition-end-event-multiple-01.html [ Failure ] @@ -20327,7 +20337,7 @@ crbug.com/591099 traversal/tree-walker-003.html [ Failure ] crbug.com/591099 traversal/tree-walker-004.html [ Failure ] crbug.com/591099 traversal/tree-walker-006.html [ Failure ] -crbug.com/591099 usb/usbDevice-iframe.html [ Crash ] +crbug.com/591099 usb/usbDevice-iframe.html [ Crash Pass ] crbug.com/591099 vibration/cancel-vibration-during-pattern-vibrating.html [ Failure ] crbug.com/591099 vibration/vibration-detached-no-crash.html [ Failure ] crbug.com/591099 vibration/vibration-durations.html [ Failure ] @@ -20335,7 +20345,7 @@ crbug.com/591099 vibration/vibration-iframe.html [ Timeout ] crbug.com/591099 vibration/vibration-patterns.html [ Failure ] crbug.com/591099 virtual/android/fast/rootscroller/set-root-scroller.html [ Failure ] -crbug.com/591099 virtual/android/fullscreen/anonymous-block-merge-crash.html [ Crash ] +crbug.com/591099 virtual/android/fullscreen/anonymous-block-merge-crash.html [ Crash Pass ] crbug.com/591099 virtual/android/fullscreen/compositor-touch-hit-rects-fullscreen-video-controls.html [ Failure ] crbug.com/591099 virtual/android/fullscreen/exit-full-screen-iframe.html [ Crash Failure ] crbug.com/591099 virtual/android/fullscreen/full-screen-cancel-nested.html [ Crash Failure ] @@ -20344,7 +20354,7 @@ crbug.com/591099 virtual/android/fullscreen/full-screen-element-stack.html [ Failure ] crbug.com/591099 virtual/android/fullscreen/full-screen-frameset.html [ Failure ] crbug.com/591099 virtual/android/fullscreen/full-screen-iframe-allowed-nested.html [ Timeout ] -crbug.com/591099 virtual/android/fullscreen/full-screen-iframe-allowed.html [ Crash ] +crbug.com/591099 virtual/android/fullscreen/full-screen-iframe-allowed.html [ Crash Failure ] crbug.com/591099 virtual/android/fullscreen/full-screen-iframe-legacy.html [ Failure ] crbug.com/591099 virtual/android/fullscreen/full-screen-iframe-not-allowed.html [ Failure ] crbug.com/591099 virtual/android/fullscreen/full-screen-iframe-without-allow-attribute-allowed-from-parent.html [ Failure ] @@ -20352,40 +20362,40 @@ crbug.com/591099 virtual/android/fullscreen/full-screen-request-removed.html [ Failure ] crbug.com/591099 virtual/android/fullscreen/full-screen-table-section.html [ Failure ] crbug.com/591099 virtual/android/fullscreen/full-screen-with-css-reference-filter.html [ Failure ] -crbug.com/591099 virtual/android/fullscreen/full-screen-with-flex-item.html [ Crash ] -crbug.com/591099 virtual/android/fullscreen/model/fully-exit-fullscreen-nested-iframe.html [ Crash ] +crbug.com/591099 virtual/android/fullscreen/full-screen-with-flex-item.html [ Crash Failure ] +crbug.com/591099 virtual/android/fullscreen/model/fully-exit-fullscreen-nested-iframe.html [ Crash Pass ] crbug.com/591099 virtual/android/fullscreen/video-controls-override.html [ Failure ] crbug.com/591099 virtual/android/fullscreen/video-controls-timeline.html [ Failure ] crbug.com/591099 virtual/android/fullscreen/video-fail-to-enter-full-screen.html [ Failure ] crbug.com/591099 virtual/android/media/mediadocument/media-document-with-download-button.html [ Failure ] -crbug.com/591099 virtual/display_list_2d_canvas/fast/canvas/2d.composite.globalAlpha.fillPath.html [ Crash ] -crbug.com/591099 virtual/display_list_2d_canvas/fast/canvas/2d.fillText.gradient.html [ Crash ] -crbug.com/591099 virtual/display_list_2d_canvas/fast/canvas/2d.text.draw.fill.maxWidth.gradient.html [ Crash ] -crbug.com/591099 virtual/display_list_2d_canvas/fast/canvas/2d.text.draw.fill.maxWidth.negative.html [ Crash ] -crbug.com/591099 virtual/display_list_2d_canvas/fast/canvas/2d.text.draw.fill.maxWidth.veryLarge.html [ Crash ] -crbug.com/591099 virtual/display_list_2d_canvas/fast/canvas/2d.text.draw.fill.maxWidth.verySmall.html [ Crash ] +crbug.com/591099 virtual/display_list_2d_canvas/fast/canvas/2d.composite.globalAlpha.fillPath.html [ Crash Pass ] +crbug.com/591099 virtual/display_list_2d_canvas/fast/canvas/2d.fillText.gradient.html [ Crash Pass ] +crbug.com/591099 virtual/display_list_2d_canvas/fast/canvas/2d.text.draw.fill.maxWidth.gradient.html [ Crash Pass ] +crbug.com/591099 virtual/display_list_2d_canvas/fast/canvas/2d.text.draw.fill.maxWidth.negative.html [ Crash Pass ] +crbug.com/591099 virtual/display_list_2d_canvas/fast/canvas/2d.text.draw.fill.maxWidth.veryLarge.html [ Crash Pass ] +crbug.com/591099 virtual/display_list_2d_canvas/fast/canvas/2d.text.draw.fill.maxWidth.verySmall.html [ Crash Pass ] crbug.com/591099 virtual/display_list_2d_canvas/fast/canvas/OffscreenCanvas-constructor-in-worker.html [ Failure ] crbug.com/591099 virtual/display_list_2d_canvas/fast/canvas/OffscreenCanvas-invalid-args-in-worker.html [ Failure ] crbug.com/591099 virtual/display_list_2d_canvas/fast/canvas/OffscreenCanvas-transferable-exceptions.html [ Failure ] crbug.com/591099 virtual/display_list_2d_canvas/fast/canvas/OffscreenCanvas-transferable.html [ Failure ] -crbug.com/591099 virtual/display_list_2d_canvas/fast/canvas/access-zero-sized-canvas.html [ Crash ] -crbug.com/591099 virtual/display_list_2d_canvas/fast/canvas/alpha.html [ Crash ] -crbug.com/591099 virtual/display_list_2d_canvas/fast/canvas/arc-crash.html [ Crash ] -crbug.com/591099 virtual/display_list_2d_canvas/fast/canvas/arc360.html [ Crash ] -crbug.com/591099 virtual/display_list_2d_canvas/fast/canvas/bug544329.html [ Crash ] -crbug.com/591099 virtual/display_list_2d_canvas/fast/canvas/canvas-2d-clip-anti-aliasing.html [ Crash ] +crbug.com/591099 virtual/display_list_2d_canvas/fast/canvas/access-zero-sized-canvas.html [ Crash Pass ] +crbug.com/591099 virtual/display_list_2d_canvas/fast/canvas/alpha.html [ Crash Pass ] +crbug.com/591099 virtual/display_list_2d_canvas/fast/canvas/arc-crash.html [ Crash Pass ] +crbug.com/591099 virtual/display_list_2d_canvas/fast/canvas/arc360.html [ Crash Pass ] +crbug.com/591099 virtual/display_list_2d_canvas/fast/canvas/bug544329.html [ Crash Pass ] +crbug.com/591099 virtual/display_list_2d_canvas/fast/canvas/canvas-2d-clip-anti-aliasing.html [ Crash Pass ] crbug.com/591099 virtual/display_list_2d_canvas/fast/canvas/canvas-ImageBitmap-close.html [ Failure ] crbug.com/591099 virtual/display_list_2d_canvas/fast/canvas/canvas-ImageBitmap-structured-clone.html [ Failure ] crbug.com/591099 virtual/display_list_2d_canvas/fast/canvas/canvas-ImageBitmap-transferable.html [ Failure ] crbug.com/591099 virtual/display_list_2d_canvas/fast/canvas/canvas-ImageData-neutered-source.html [ Failure ] crbug.com/591099 virtual/display_list_2d_canvas/fast/canvas/canvas-ImageData-workers.html [ Failure ] -crbug.com/591099 virtual/display_list_2d_canvas/fast/canvas/canvas-after-destroy-iframe.html [ Crash ] -crbug.com/591099 virtual/display_list_2d_canvas/fast/canvas/canvas-alphaImageData-behavior.html [ Crash ] -crbug.com/591099 virtual/display_list_2d_canvas/fast/canvas/canvas-arc-zero-lineto.html [ Crash ] -crbug.com/591099 virtual/display_list_2d_canvas/fast/canvas/canvas-bezier-same-endpoint.html [ Crash ] +crbug.com/591099 virtual/display_list_2d_canvas/fast/canvas/canvas-after-destroy-iframe.html [ Crash Pass ] +crbug.com/591099 virtual/display_list_2d_canvas/fast/canvas/canvas-alphaImageData-behavior.html [ Crash Pass ] +crbug.com/591099 virtual/display_list_2d_canvas/fast/canvas/canvas-arc-zero-lineto.html [ Crash Pass ] +crbug.com/591099 virtual/display_list_2d_canvas/fast/canvas/canvas-bezier-same-endpoint.html [ Crash Pass ] crbug.com/591099 virtual/display_list_2d_canvas/fast/canvas/canvas-blending-image-over-image.html [ Failure ] crbug.com/591099 virtual/display_list_2d_canvas/fast/canvas/canvas-blending-text.html [ Failure ] -crbug.com/591099 virtual/display_list_2d_canvas/fast/canvas/canvas-closePath-single-point.html [ Crash ] +crbug.com/591099 virtual/display_list_2d_canvas/fast/canvas/canvas-closePath-single-point.html [ Crash Pass ] crbug.com/591099 virtual/display_list_2d_canvas/fast/canvas/canvas-composite-alpha.html [ Crash Failure ] crbug.com/591099 virtual/display_list_2d_canvas/fast/canvas/canvas-composite-canvas.html [ Failure ] crbug.com/591099 virtual/display_list_2d_canvas/fast/canvas/canvas-composite-image.html [ Failure ] @@ -20404,25 +20414,25 @@ crbug.com/591099 virtual/display_list_2d_canvas/fast/canvas/canvas-createImageBitmap-recursive.html [ Failure ] crbug.com/591099 virtual/display_list_2d_canvas/fast/canvas/canvas-createImageBitmap-svg-no-intrinsic-size.html [ Failure ] crbug.com/591099 virtual/display_list_2d_canvas/fast/canvas/canvas-createImageBitmap-svg.html [ Failure ] -crbug.com/591099 virtual/display_list_2d_canvas/fast/canvas/canvas-createPattern-fillRect-shadow.html [ Crash ] -crbug.com/591099 virtual/display_list_2d_canvas/fast/canvas/canvas-currentColor.html [ Crash ] -crbug.com/591099 virtual/display_list_2d_canvas/fast/canvas/canvas-direction.html [ Crash ] -crbug.com/591099 virtual/display_list_2d_canvas/fast/canvas/canvas-draw-canvas-on-canvas-shadow.html [ Crash ] +crbug.com/591099 virtual/display_list_2d_canvas/fast/canvas/canvas-createPattern-fillRect-shadow.html [ Crash Pass ] +crbug.com/591099 virtual/display_list_2d_canvas/fast/canvas/canvas-currentColor.html [ Crash Pass ] +crbug.com/591099 virtual/display_list_2d_canvas/fast/canvas/canvas-direction.html [ Crash Pass ] +crbug.com/591099 virtual/display_list_2d_canvas/fast/canvas/canvas-draw-canvas-on-canvas-shadow.html [ Crash Pass ] crbug.com/591099 virtual/display_list_2d_canvas/fast/canvas/canvas-drawImage-animated-images.html [ Failure ] -crbug.com/591099 virtual/display_list_2d_canvas/fast/canvas/canvas-drawImage-animated.html [ Crash ] -crbug.com/591099 virtual/display_list_2d_canvas/fast/canvas/canvas-drawImage-live-video.html [ Crash ] -crbug.com/591099 virtual/display_list_2d_canvas/fast/canvas/canvas-drawImage-shadow.html [ Crash ] -crbug.com/591099 virtual/display_list_2d_canvas/fast/canvas/canvas-ellipse-360-winding.html [ Crash ] +crbug.com/591099 virtual/display_list_2d_canvas/fast/canvas/canvas-drawImage-animated.html [ Crash Pass ] +crbug.com/591099 virtual/display_list_2d_canvas/fast/canvas/canvas-drawImage-live-video.html [ Crash Pass ] +crbug.com/591099 virtual/display_list_2d_canvas/fast/canvas/canvas-drawImage-shadow.html [ Crash Pass ] +crbug.com/591099 virtual/display_list_2d_canvas/fast/canvas/canvas-ellipse-360-winding.html [ Crash Pass ] crbug.com/591099 virtual/display_list_2d_canvas/fast/canvas/canvas-ellipse-connecting-line.html [ Failure Pass ] -crbug.com/591099 virtual/display_list_2d_canvas/fast/canvas/canvas-ellipse-zero-lineto.html [ Crash ] -crbug.com/591099 virtual/display_list_2d_canvas/fast/canvas/canvas-ellipse.html [ Crash ] -crbug.com/591099 virtual/display_list_2d_canvas/fast/canvas/canvas-empty-image-pattern.html [ Crash ] -crbug.com/591099 virtual/display_list_2d_canvas/fast/canvas/canvas-fillPath-alpha-shadow.html [ Crash ] -crbug.com/591099 virtual/display_list_2d_canvas/fast/canvas/canvas-fillPath-gradient-shadow.html [ Crash ] -crbug.com/591099 virtual/display_list_2d_canvas/fast/canvas/canvas-fillPath-pattern-shadow.html [ Crash ] -crbug.com/591099 virtual/display_list_2d_canvas/fast/canvas/canvas-fillPath-shadow.html [ Crash ] -crbug.com/591099 virtual/display_list_2d_canvas/fast/canvas/canvas-fillRect-gradient-shadow.html [ Crash ] -crbug.com/591099 virtual/display_list_2d_canvas/fast/canvas/canvas-fillRect-shadow.html [ Crash ] +crbug.com/591099 virtual/display_list_2d_canvas/fast/canvas/canvas-ellipse-zero-lineto.html [ Crash Pass ] +crbug.com/591099 virtual/display_list_2d_canvas/fast/canvas/canvas-ellipse.html [ Crash Pass ] +crbug.com/591099 virtual/display_list_2d_canvas/fast/canvas/canvas-empty-image-pattern.html [ Crash Pass ] +crbug.com/591099 virtual/display_list_2d_canvas/fast/canvas/canvas-fillPath-alpha-shadow.html [ Crash Pass ] +crbug.com/591099 virtual/display_list_2d_canvas/fast/canvas/canvas-fillPath-gradient-shadow.html [ Crash Failure ] +crbug.com/591099 virtual/display_list_2d_canvas/fast/canvas/canvas-fillPath-pattern-shadow.html [ Crash Pass ] +crbug.com/591099 virtual/display_list_2d_canvas/fast/canvas/canvas-fillPath-shadow.html [ Crash Pass ] +crbug.com/591099 virtual/display_list_2d_canvas/fast/canvas/canvas-fillRect-gradient-shadow.html [ Crash Pass ] +crbug.com/591099 virtual/display_list_2d_canvas/fast/canvas/canvas-fillRect-shadow.html [ Crash Pass ] crbug.com/591099 virtual/display_list_2d_canvas/fast/canvas/canvas-filter-fill-liveness.html [ Failure ] crbug.com/591099 virtual/display_list_2d_canvas/fast/canvas/canvas-filter-fill-paint-color.html [ Failure ] crbug.com/591099 virtual/display_list_2d_canvas/fast/canvas/canvas-filter-fill-paint-gradient.html [ Failure ] @@ -20439,100 +20449,100 @@ crbug.com/591099 virtual/display_list_2d_canvas/fast/canvas/canvas-filter-width-height-hidpi.html [ Failure ] crbug.com/591099 virtual/display_list_2d_canvas/fast/canvas/canvas-filter-width-height-scale.html [ Failure ] crbug.com/591099 virtual/display_list_2d_canvas/fast/canvas/canvas-filter-width-height.html [ Failure ] -crbug.com/591099 virtual/display_list_2d_canvas/fast/canvas/canvas-font-cache.html [ Crash ] +crbug.com/591099 virtual/display_list_2d_canvas/fast/canvas/canvas-font-cache.html [ Crash Pass ] crbug.com/591099 virtual/display_list_2d_canvas/fast/canvas/canvas-hides-fallback.html [ Failure ] -crbug.com/591099 virtual/display_list_2d_canvas/fast/canvas/canvas-hit-regions-accessibility-test.html [ Crash ] -crbug.com/591099 virtual/display_list_2d_canvas/fast/canvas/canvas-hit-regions-basic-test.html [ Crash ] -crbug.com/591099 virtual/display_list_2d_canvas/fast/canvas/canvas-hit-regions-clear-test.html [ Crash ] -crbug.com/591099 virtual/display_list_2d_canvas/fast/canvas/canvas-hit-regions-clip-test.html [ Crash ] -crbug.com/591099 virtual/display_list_2d_canvas/fast/canvas/canvas-hit-regions-css-transform-test.html [ Crash ] -crbug.com/591099 virtual/display_list_2d_canvas/fast/canvas/canvas-hit-regions-device-pixel-ratio-test.html [ Crash ] -crbug.com/591099 virtual/display_list_2d_canvas/fast/canvas/canvas-hit-regions-event-test.html [ Crash ] -crbug.com/591099 virtual/display_list_2d_canvas/fast/canvas/canvas-hit-regions-exception-test.html [ Crash ] -crbug.com/591099 virtual/display_list_2d_canvas/fast/canvas/canvas-hit-regions-fallback-element-test-1.html [ Crash ] -crbug.com/591099 virtual/display_list_2d_canvas/fast/canvas/canvas-hit-regions-fallback-element-test-2.html [ Crash ] -crbug.com/591099 virtual/display_list_2d_canvas/fast/canvas/canvas-hit-regions-fallback-element-test-3.html [ Crash ] -crbug.com/591099 virtual/display_list_2d_canvas/fast/canvas/canvas-hit-regions-fill-rule-test.html [ Crash ] -crbug.com/591099 virtual/display_list_2d_canvas/fast/canvas/canvas-hit-regions-path2d-test.html [ Crash ] -crbug.com/591099 virtual/display_list_2d_canvas/fast/canvas/canvas-hit-regions-path2d-transform-test.html [ Crash ] -crbug.com/591099 virtual/display_list_2d_canvas/fast/canvas/canvas-hit-regions-scale-factor.html [ Crash ] -crbug.com/591099 virtual/display_list_2d_canvas/fast/canvas/canvas-hit-regions-transform-test.html [ Crash ] -crbug.com/591099 virtual/display_list_2d_canvas/fast/canvas/canvas-imageSmoothingEnabled-repaint.html [ Crash ] -crbug.com/591099 virtual/display_list_2d_canvas/fast/canvas/canvas-imageSmoothingQuality.html [ Crash ] -crbug.com/591099 virtual/display_list_2d_canvas/fast/canvas/canvas-invalid-fillstyle.html [ Crash ] -crbug.com/591099 virtual/display_list_2d_canvas/fast/canvas/canvas-invalid-strokestyle.html [ Crash ] +crbug.com/591099 virtual/display_list_2d_canvas/fast/canvas/canvas-hit-regions-accessibility-test.html [ Crash Pass ] +crbug.com/591099 virtual/display_list_2d_canvas/fast/canvas/canvas-hit-regions-basic-test.html [ Crash Pass ] +crbug.com/591099 virtual/display_list_2d_canvas/fast/canvas/canvas-hit-regions-clear-test.html [ Crash Pass ] +crbug.com/591099 virtual/display_list_2d_canvas/fast/canvas/canvas-hit-regions-clip-test.html [ Crash Pass ] +crbug.com/591099 virtual/display_list_2d_canvas/fast/canvas/canvas-hit-regions-css-transform-test.html [ Crash Pass ] +crbug.com/591099 virtual/display_list_2d_canvas/fast/canvas/canvas-hit-regions-device-pixel-ratio-test.html [ Crash Pass ] +crbug.com/591099 virtual/display_list_2d_canvas/fast/canvas/canvas-hit-regions-event-test.html [ Crash Pass ] +crbug.com/591099 virtual/display_list_2d_canvas/fast/canvas/canvas-hit-regions-exception-test.html [ Crash Pass ] +crbug.com/591099 virtual/display_list_2d_canvas/fast/canvas/canvas-hit-regions-fallback-element-test-1.html [ Crash Pass ] +crbug.com/591099 virtual/display_list_2d_canvas/fast/canvas/canvas-hit-regions-fallback-element-test-2.html [ Crash Pass ] +crbug.com/591099 virtual/display_list_2d_canvas/fast/canvas/canvas-hit-regions-fallback-element-test-3.html [ Crash Pass ] +crbug.com/591099 virtual/display_list_2d_canvas/fast/canvas/canvas-hit-regions-fill-rule-test.html [ Crash Pass ] +crbug.com/591099 virtual/display_list_2d_canvas/fast/canvas/canvas-hit-regions-path2d-test.html [ Crash Pass ] +crbug.com/591099 virtual/display_list_2d_canvas/fast/canvas/canvas-hit-regions-path2d-transform-test.html [ Crash Pass ] +crbug.com/591099 virtual/display_list_2d_canvas/fast/canvas/canvas-hit-regions-scale-factor.html [ Crash Pass ] +crbug.com/591099 virtual/display_list_2d_canvas/fast/canvas/canvas-hit-regions-transform-test.html [ Crash Pass ] +crbug.com/591099 virtual/display_list_2d_canvas/fast/canvas/canvas-imageSmoothingEnabled-repaint.html [ Crash Pass ] +crbug.com/591099 virtual/display_list_2d_canvas/fast/canvas/canvas-imageSmoothingQuality.html [ Crash Pass ] +crbug.com/591099 virtual/display_list_2d_canvas/fast/canvas/canvas-invalid-fillstyle.html [ Crash Pass ] +crbug.com/591099 virtual/display_list_2d_canvas/fast/canvas/canvas-invalid-strokestyle.html [ Crash Pass ] crbug.com/591099 virtual/display_list_2d_canvas/fast/canvas/canvas-invalid-video.html [ Failure ] -crbug.com/591099 virtual/display_list_2d_canvas/fast/canvas/canvas-isPointInStroke-with-path.html [ Crash ] -crbug.com/591099 virtual/display_list_2d_canvas/fast/canvas/canvas-isPointInStroke.html [ Crash ] -crbug.com/591099 virtual/display_list_2d_canvas/fast/canvas/canvas-large-dimensions.html [ Crash ] -crbug.com/591099 virtual/display_list_2d_canvas/fast/canvas/canvas-lineDash-input-sequence.html [ Crash ] -crbug.com/591099 virtual/display_list_2d_canvas/fast/canvas/canvas-lineDash-invalid.html [ Crash ] -crbug.com/591099 virtual/display_list_2d_canvas/fast/canvas/canvas-lineDash.html [ Crash ] -crbug.com/591099 virtual/display_list_2d_canvas/fast/canvas/canvas-lineWidth-intact-after-strokeRect.html [ Crash ] +crbug.com/591099 virtual/display_list_2d_canvas/fast/canvas/canvas-isPointInStroke-with-path.html [ Crash Pass ] +crbug.com/591099 virtual/display_list_2d_canvas/fast/canvas/canvas-isPointInStroke.html [ Crash Pass ] +crbug.com/591099 virtual/display_list_2d_canvas/fast/canvas/canvas-large-dimensions.html [ Crash Pass ] +crbug.com/591099 virtual/display_list_2d_canvas/fast/canvas/canvas-lineDash-input-sequence.html [ Crash Pass ] +crbug.com/591099 virtual/display_list_2d_canvas/fast/canvas/canvas-lineDash-invalid.html [ Crash Pass ] +crbug.com/591099 virtual/display_list_2d_canvas/fast/canvas/canvas-lineDash.html [ Crash Pass ] +crbug.com/591099 virtual/display_list_2d_canvas/fast/canvas/canvas-lineWidth-intact-after-strokeRect.html [ Crash Pass ] crbug.com/591099 virtual/display_list_2d_canvas/fast/canvas/canvas-lost-gpu-context.html [ Failure ] crbug.com/591099 virtual/display_list_2d_canvas/fast/canvas/canvas-measure-bidi-text.html [ Failure Pass ] crbug.com/591099 virtual/display_list_2d_canvas/fast/canvas/canvas-negative-size.html [ Failure ] crbug.com/591099 virtual/display_list_2d_canvas/fast/canvas/canvas-normalize-string.html [ Failure ] -crbug.com/591099 virtual/display_list_2d_canvas/fast/canvas/canvas-path-context-clip.html [ Crash ] -crbug.com/591099 virtual/display_list_2d_canvas/fast/canvas/canvas-path-context-fill.html [ Crash ] -crbug.com/591099 virtual/display_list_2d_canvas/fast/canvas/canvas-path-context-stroke.html [ Crash ] -crbug.com/591099 virtual/display_list_2d_canvas/fast/canvas/canvas-path-object.html [ Crash ] -crbug.com/591099 virtual/display_list_2d_canvas/fast/canvas/canvas-path-with-inf-nan-dimensions.html [ Crash ] -crbug.com/591099 virtual/display_list_2d_canvas/fast/canvas/canvas-pattern-set-transform.html [ Crash ] -crbug.com/591099 virtual/display_list_2d_canvas/fast/canvas/canvas-putImageData.html [ Crash ] -crbug.com/591099 virtual/display_list_2d_canvas/fast/canvas/canvas-quadratic-same-endpoint.html [ Crash ] +crbug.com/591099 virtual/display_list_2d_canvas/fast/canvas/canvas-path-context-clip.html [ Crash Pass ] +crbug.com/591099 virtual/display_list_2d_canvas/fast/canvas/canvas-path-context-fill.html [ Crash Pass ] +crbug.com/591099 virtual/display_list_2d_canvas/fast/canvas/canvas-path-context-stroke.html [ Crash Pass ] +crbug.com/591099 virtual/display_list_2d_canvas/fast/canvas/canvas-path-object.html [ Crash Pass ] +crbug.com/591099 virtual/display_list_2d_canvas/fast/canvas/canvas-path-with-inf-nan-dimensions.html [ Crash Pass ] +crbug.com/591099 virtual/display_list_2d_canvas/fast/canvas/canvas-pattern-set-transform.html [ Crash Pass ] +crbug.com/591099 virtual/display_list_2d_canvas/fast/canvas/canvas-putImageData.html [ Crash Pass ] +crbug.com/591099 virtual/display_list_2d_canvas/fast/canvas/canvas-quadratic-same-endpoint.html [ Crash Pass ] crbug.com/591099 virtual/display_list_2d_canvas/fast/canvas/canvas-render-layer.html [ Failure Pass ] -crbug.com/591099 virtual/display_list_2d_canvas/fast/canvas/canvas-resetTransform.html [ Crash ] -crbug.com/591099 virtual/display_list_2d_canvas/fast/canvas/canvas-resize-after-paint.html [ Crash ] -crbug.com/591099 virtual/display_list_2d_canvas/fast/canvas/canvas-scale-drawImage-shadow.html [ Crash ] -crbug.com/591099 virtual/display_list_2d_canvas/fast/canvas/canvas-scale-fillPath-shadow.html [ Crash ] -crbug.com/591099 virtual/display_list_2d_canvas/fast/canvas/canvas-scale-fillRect-shadow.html [ Crash ] -crbug.com/591099 virtual/display_list_2d_canvas/fast/canvas/canvas-scale-shadowBlur.html [ Crash ] -crbug.com/591099 virtual/display_list_2d_canvas/fast/canvas/canvas-scale-strokePath-shadow.html [ Crash ] +crbug.com/591099 virtual/display_list_2d_canvas/fast/canvas/canvas-resetTransform.html [ Crash Pass ] +crbug.com/591099 virtual/display_list_2d_canvas/fast/canvas/canvas-resize-after-paint.html [ Crash Pass ] +crbug.com/591099 virtual/display_list_2d_canvas/fast/canvas/canvas-scale-drawImage-shadow.html [ Crash Pass ] +crbug.com/591099 virtual/display_list_2d_canvas/fast/canvas/canvas-scale-fillPath-shadow.html [ Crash Pass ] +crbug.com/591099 virtual/display_list_2d_canvas/fast/canvas/canvas-scale-fillRect-shadow.html [ Crash Pass ] +crbug.com/591099 virtual/display_list_2d_canvas/fast/canvas/canvas-scale-shadowBlur.html [ Crash Pass ] +crbug.com/591099 virtual/display_list_2d_canvas/fast/canvas/canvas-scale-strokePath-shadow.html [ Crash Pass ] crbug.com/591099 virtual/display_list_2d_canvas/fast/canvas/canvas-scroll-path-into-view.html [ Failure Timeout ] -crbug.com/591099 virtual/display_list_2d_canvas/fast/canvas/canvas-set-properties-with-non-invertible-ctm.html [ Crash ] +crbug.com/591099 virtual/display_list_2d_canvas/fast/canvas/canvas-set-properties-with-non-invertible-ctm.html [ Crash Pass ] crbug.com/591099 virtual/display_list_2d_canvas/fast/canvas/canvas-shadow-source-in.html [ Failure Pass ] -crbug.com/591099 virtual/display_list_2d_canvas/fast/canvas/canvas-skia-excessive-size.html [ Crash ] -crbug.com/591099 virtual/display_list_2d_canvas/fast/canvas/canvas-strokePath-alpha-shadow.html [ Crash ] -crbug.com/591099 virtual/display_list_2d_canvas/fast/canvas/canvas-strokePath-cap-join.html [ Crash ] -crbug.com/591099 virtual/display_list_2d_canvas/fast/canvas/canvas-strokePath-gradient-shadow.html [ Crash ] -crbug.com/591099 virtual/display_list_2d_canvas/fast/canvas/canvas-strokePath-shadow.html [ Crash ] -crbug.com/591099 virtual/display_list_2d_canvas/fast/canvas/canvas-strokeRect-alpha-shadow.html [ Crash ] -crbug.com/591099 virtual/display_list_2d_canvas/fast/canvas/canvas-strokeRect-gradient-shadow.html [ Crash ] +crbug.com/591099 virtual/display_list_2d_canvas/fast/canvas/canvas-skia-excessive-size.html [ Crash Pass ] +crbug.com/591099 virtual/display_list_2d_canvas/fast/canvas/canvas-strokePath-alpha-shadow.html [ Crash Pass ] +crbug.com/591099 virtual/display_list_2d_canvas/fast/canvas/canvas-strokePath-cap-join.html [ Crash Pass ] +crbug.com/591099 virtual/display_list_2d_canvas/fast/canvas/canvas-strokePath-gradient-shadow.html [ Crash Pass ] +crbug.com/591099 virtual/display_list_2d_canvas/fast/canvas/canvas-strokePath-shadow.html [ Crash Pass ] +crbug.com/591099 virtual/display_list_2d_canvas/fast/canvas/canvas-strokeRect-alpha-shadow.html [ Crash Pass ] +crbug.com/591099 virtual/display_list_2d_canvas/fast/canvas/canvas-strokeRect-gradient-shadow.html [ Crash Pass ] crbug.com/591099 virtual/display_list_2d_canvas/fast/canvas/canvas-text-baseline-tiny-fonts.html [ Failure Pass ] -crbug.com/591099 virtual/display_list_2d_canvas/fast/canvas/canvas-text-space-characters.html [ Crash ] +crbug.com/591099 virtual/display_list_2d_canvas/fast/canvas/canvas-text-space-characters.html [ Crash Pass ] crbug.com/591099 virtual/display_list_2d_canvas/fast/canvas/canvas-textMetrics-width.html [ Failure ] crbug.com/591099 virtual/display_list_2d_canvas/fast/canvas/canvas-transforms-during-path.html [ Failure ] -crbug.com/591099 virtual/display_list_2d_canvas/fast/canvas/canvas-transforms-fillRect-shadow.html [ Crash ] +crbug.com/591099 virtual/display_list_2d_canvas/fast/canvas/canvas-transforms-fillRect-shadow.html [ Crash Pass ] crbug.com/591099 virtual/display_list_2d_canvas/fast/canvas/currentTransform-null.html [ Failure ] -crbug.com/591099 virtual/display_list_2d_canvas/fast/canvas/draw-focus-if-needed-invisible-crash.html [ Crash ] -crbug.com/591099 virtual/display_list_2d_canvas/fast/canvas/draw-focus-if-needed-on-event.html [ Crash ] -crbug.com/591099 virtual/display_list_2d_canvas/fast/canvas/draw-focus-if-needed-with-path2d.html [ Crash ] -crbug.com/591099 virtual/display_list_2d_canvas/fast/canvas/draw-focus-if-needed.html [ Crash ] -crbug.com/591099 virtual/display_list_2d_canvas/fast/canvas/drawImage-with-negative-source-destination.html [ Crash ] -crbug.com/591099 virtual/display_list_2d_canvas/fast/canvas/fallback-content.html [ Crash ] -crbug.com/591099 virtual/display_list_2d_canvas/fast/canvas/feimage-with-foreignobject-taint-canvas-2.html [ Crash ] -crbug.com/591099 virtual/display_list_2d_canvas/fast/canvas/feimage-with-foreignobject-taint-canvas.html [ Crash ] +crbug.com/591099 virtual/display_list_2d_canvas/fast/canvas/draw-focus-if-needed-invisible-crash.html [ Crash Pass ] +crbug.com/591099 virtual/display_list_2d_canvas/fast/canvas/draw-focus-if-needed-on-event.html [ Crash Pass ] +crbug.com/591099 virtual/display_list_2d_canvas/fast/canvas/draw-focus-if-needed-with-path2d.html [ Crash Pass ] +crbug.com/591099 virtual/display_list_2d_canvas/fast/canvas/draw-focus-if-needed.html [ Crash Pass ] +crbug.com/591099 virtual/display_list_2d_canvas/fast/canvas/drawImage-with-negative-source-destination.html [ Crash Pass ] +crbug.com/591099 virtual/display_list_2d_canvas/fast/canvas/fallback-content.html [ Crash Pass ] +crbug.com/591099 virtual/display_list_2d_canvas/fast/canvas/feimage-with-foreignobject-taint-canvas-2.html [ Crash Pass ] +crbug.com/591099 virtual/display_list_2d_canvas/fast/canvas/feimage-with-foreignobject-taint-canvas.html [ Crash Pass ] crbug.com/591099 virtual/display_list_2d_canvas/fast/canvas/fill-stroke-clip-reset-path.html [ Failure ] -crbug.com/591099 virtual/display_list_2d_canvas/fast/canvas/fillText-shadow.html [ Crash ] +crbug.com/591099 virtual/display_list_2d_canvas/fast/canvas/fillText-shadow.html [ Crash Pass ] crbug.com/591099 virtual/display_list_2d_canvas/fast/canvas/fillrect_gradient.html [ Failure ] -crbug.com/591099 virtual/display_list_2d_canvas/fast/canvas/font-no-zoom.html [ Crash ] -crbug.com/591099 virtual/display_list_2d_canvas/fast/canvas/gradient-with-clip.html [ Crash ] +crbug.com/591099 virtual/display_list_2d_canvas/fast/canvas/font-no-zoom.html [ Crash Pass ] +crbug.com/591099 virtual/display_list_2d_canvas/fast/canvas/gradient-with-clip.html [ Crash Pass ] crbug.com/591099 virtual/display_list_2d_canvas/fast/canvas/image-object-in-canvas.html [ Failure ] -crbug.com/591099 virtual/display_list_2d_canvas/fast/canvas/image-with-foreignobject-taint-canvas-2.html [ Crash ] -crbug.com/591099 virtual/display_list_2d_canvas/fast/canvas/image-with-foreignobject-taint-canvas.html [ Crash ] -crbug.com/591099 virtual/display_list_2d_canvas/fast/canvas/painting-on-bad-canvas.html [ Crash ] -crbug.com/591099 virtual/display_list_2d_canvas/fast/canvas/pattern-with-transform.html [ Crash ] +crbug.com/591099 virtual/display_list_2d_canvas/fast/canvas/image-with-foreignobject-taint-canvas-2.html [ Crash Pass ] +crbug.com/591099 virtual/display_list_2d_canvas/fast/canvas/image-with-foreignobject-taint-canvas.html [ Crash Pass ] +crbug.com/591099 virtual/display_list_2d_canvas/fast/canvas/painting-on-bad-canvas.html [ Crash Pass ] +crbug.com/591099 virtual/display_list_2d_canvas/fast/canvas/pattern-with-transform.html [ Crash Pass ] crbug.com/591099 virtual/display_list_2d_canvas/fast/canvas/quadraticCurveTo.xml [ Failure ] -crbug.com/591099 virtual/display_list_2d_canvas/fast/canvas/resize-while-save-active.html [ Crash ] -crbug.com/591099 virtual/display_list_2d_canvas/fast/canvas/set-empty-font-crash.html [ Crash ] +crbug.com/591099 virtual/display_list_2d_canvas/fast/canvas/resize-while-save-active.html [ Crash Pass ] +crbug.com/591099 virtual/display_list_2d_canvas/fast/canvas/set-empty-font-crash.html [ Crash Pass ] crbug.com/591099 virtual/display_list_2d_canvas/fast/canvas/setWidthResetAfterForcedRender.html [ Failure ] -crbug.com/591099 virtual/display_list_2d_canvas/fast/canvas/shadow-huge-blur.html [ Crash ] +crbug.com/591099 virtual/display_list_2d_canvas/fast/canvas/shadow-huge-blur.html [ Crash Pass ] crbug.com/591099 virtual/display_list_2d_canvas/fast/canvas/shadow-offset-1.html [ Failure ] crbug.com/591099 virtual/display_list_2d_canvas/fast/canvas/toDataURL-alpha.html [ Failure ] -crbug.com/591099 virtual/display_list_2d_canvas/fast/canvas/toDataURL-noData.html [ Crash ] +crbug.com/591099 virtual/display_list_2d_canvas/fast/canvas/toDataURL-noData.html [ Crash Pass ] crbug.com/591099 virtual/display_list_2d_canvas/fast/canvas/toDataURL-supportedTypes.html [ Failure ] -crbug.com/591099 virtual/display_list_2d_canvas/fast/canvas/transformed-canvas-reset.html [ Crash ] +crbug.com/591099 virtual/display_list_2d_canvas/fast/canvas/transformed-canvas-reset.html [ Crash Pass ] crbug.com/591099 virtual/display_list_2d_canvas/fast/canvas/unclosed-canvas-1.html [ Failure ] crbug.com/591099 virtual/display_list_2d_canvas/fast/canvas/unclosed-canvas-3.html [ Failure ] crbug.com/591099 virtual/display_list_2d_canvas/fast/canvas/unclosed-canvas-4.html [ Failure ] @@ -20543,12 +20553,12 @@ crbug.com/591099 virtual/display_list_2d_canvas/fast/canvas/webgl/renderer-and-vendor-strings.html [ Failure ] crbug.com/591099 virtual/display_list_2d_canvas/fast/canvas/webgl/shader-deleted-by-accessor.html [ Failure ] crbug.com/591099 virtual/display_list_2d_canvas/fast/canvas/webgl/tex-sub-image-cube-maps.html [ Failure ] -crbug.com/591099 virtual/display_list_2d_canvas/fast/canvas/webgl/texImage-imageBitmap-from-canvas-resize.html [ Crash ] +crbug.com/591099 virtual/display_list_2d_canvas/fast/canvas/webgl/texImage-imageBitmap-from-canvas-resize.html [ Crash Pass ] crbug.com/591099 virtual/display_list_2d_canvas/fast/canvas/webgl/texture-color-profile.html [ Failure ] crbug.com/591099 virtual/display_list_2d_canvas/fast/canvas/webgl/webgl-texture-binding-preserved.html [ Failure ] crbug.com/591099 virtual/display_list_2d_canvas/fast/canvas/webgl/webgl-viewport-parameters-preserved.html [ Failure ] -crbug.com/591099 virtual/display_list_2d_canvas/fast/canvas/zero-size-fill-rect.html [ Crash ] -crbug.com/591099 virtual/enable_wasm/external/wpt/wasm/wasm_local_iframe_test.html [ Crash Timeout ] +crbug.com/591099 virtual/display_list_2d_canvas/fast/canvas/zero-size-fill-rect.html [ Crash Pass ] +crbug.com/591099 virtual/enable_wasm/external/wpt/wasm/wasm_local_iframe_test.html [ Crash Pass Timeout ] crbug.com/591099 virtual/exotic-color-space/images/12-55.html [ Failure ] crbug.com/591099 virtual/exotic-color-space/images/182.html [ Failure ] crbug.com/591099 virtual/exotic-color-space/images/2-comp.html [ Failure ] @@ -20592,7 +20602,7 @@ crbug.com/591099 virtual/exotic-color-space/images/cross-fade-svg-size-diff.html [ Failure ] crbug.com/591099 virtual/exotic-color-space/images/cross-fade-svg-size.html [ Failure ] crbug.com/591099 virtual/exotic-color-space/images/cross-fade-tiled.html [ Failure ] -crbug.com/591099 virtual/exotic-color-space/images/destroyed-image-load-event.html [ Crash ] +crbug.com/591099 virtual/exotic-color-space/images/destroyed-image-load-event.html [ Crash Failure ] crbug.com/591099 virtual/exotic-color-space/images/drag-svg-image.html [ Failure ] crbug.com/591099 virtual/exotic-color-space/images/embed-does-not-propagate-dimensions-to-object-ancestor.html [ Failure ] crbug.com/591099 virtual/exotic-color-space/images/exif-orientation-css.html [ Crash Failure ] @@ -20608,7 +20618,7 @@ crbug.com/591099 virtual/exotic-color-space/images/icon-0colors.html [ Failure ] crbug.com/591099 virtual/exotic-color-space/images/icon-decoding.html [ Failure ] crbug.com/591099 virtual/exotic-color-space/images/image-change-src.html [ Crash Pass ] -crbug.com/591099 virtual/exotic-color-space/images/image-change-without-resize-shouldnt-layout.html [ Crash ] +crbug.com/591099 virtual/exotic-color-space/images/image-change-without-resize-shouldnt-layout.html [ Crash Pass ] crbug.com/591099 virtual/exotic-color-space/images/image-click-scale-restore-zoomed-image.html [ Failure ] crbug.com/591099 virtual/exotic-color-space/images/image-css3-content-data.html [ Failure ] crbug.com/591099 virtual/exotic-color-space/images/image-document-write-assert.html [ Failure ] @@ -20623,7 +20633,7 @@ crbug.com/591099 virtual/exotic-color-space/images/image-map-zoom-alt-content.html [ Crash Failure ] crbug.com/591099 virtual/exotic-color-space/images/image-map-zoom.html [ Failure ] crbug.com/591099 virtual/exotic-color-space/images/image-page-injected-script-crash.html [ Crash Failure ] -crbug.com/591099 virtual/exotic-color-space/images/image-use-counters.html [ Crash ] +crbug.com/591099 virtual/exotic-color-space/images/image-use-counters.html [ Crash Pass ] crbug.com/591099 virtual/exotic-color-space/images/image-zoom-to-25.html [ Failure ] crbug.com/591099 virtual/exotic-color-space/images/image-zoom-to-500.html [ Failure ] crbug.com/591099 virtual/exotic-color-space/images/imagemap-circle-focus-ring.html [ Failure ] @@ -20639,17 +20649,17 @@ crbug.com/591099 virtual/exotic-color-space/images/imagemap-overflowing-circle-focus-ring.html [ Failure ] crbug.com/591099 virtual/exotic-color-space/images/imagemap-overflowing-polygon-focus-ring.html [ Failure ] crbug.com/591099 virtual/exotic-color-space/images/imagemap-polygon-focus-ring.html [ Failure ] -crbug.com/591099 virtual/exotic-color-space/images/imagemap-scroll.html [ Crash ] -crbug.com/591099 virtual/exotic-color-space/images/img-dimensions-styled.html [ Crash ] -crbug.com/591099 virtual/exotic-color-space/images/invalid-image-url-crash.html [ Crash ] +crbug.com/591099 virtual/exotic-color-space/images/imagemap-scroll.html [ Crash Failure ] +crbug.com/591099 virtual/exotic-color-space/images/img-dimensions-styled.html [ Crash Pass ] +crbug.com/591099 virtual/exotic-color-space/images/invalid-image-url-crash.html [ Crash Pass ] crbug.com/591099 virtual/exotic-color-space/images/jpeg-yuv-image-decoding.html [ Failure Pass ] crbug.com/591099 virtual/exotic-color-space/images/jpeg-yuv-progressive-canvas.html [ Failure Pass ] crbug.com/591099 virtual/exotic-color-space/images/jpeg-yuv-progressive-image.html [ Failure Pass ] crbug.com/591099 virtual/exotic-color-space/images/link-body-content-imageDimensionChanged-crash.html [ Failure ] crbug.com/591099 virtual/exotic-color-space/images/load-img-with-empty-src.html [ Failure ] crbug.com/591099 virtual/exotic-color-space/images/motion-jpeg-single-frame.html [ Failure ] -crbug.com/591099 virtual/exotic-color-space/images/move-image-to-new-document.html [ Crash ] -crbug.com/591099 virtual/exotic-color-space/images/multiple-inflight-error-event-crash.html [ Crash ] +crbug.com/591099 virtual/exotic-color-space/images/move-image-to-new-document.html [ Crash Pass ] +crbug.com/591099 virtual/exotic-color-space/images/multiple-inflight-error-event-crash.html [ Crash Pass ] crbug.com/591099 virtual/exotic-color-space/images/pdf-as-background.html [ Failure ] crbug.com/591099 virtual/exotic-color-space/images/pdf-as-tiled-background.html [ Failure ] crbug.com/591099 virtual/exotic-color-space/images/percent-height-image.html [ Failure ] @@ -20668,15 +20678,15 @@ crbug.com/591099 virtual/exotic-color-space/images/script-counter-imageDimensionChanged-crash.html [ Failure ] crbug.com/591099 virtual/exotic-color-space/images/sprite-no-bleed.html [ Failure ] crbug.com/591099 virtual/exotic-color-space/images/style-access-during-imageChanged-crash.html [ Crash Failure ] -crbug.com/591099 virtual/exotic-color-space/images/style-access-during-imageChanged-style-freeze.html [ Crash ] +crbug.com/591099 virtual/exotic-color-space/images/style-access-during-imageChanged-style-freeze.html [ Crash Pass ] crbug.com/591099 virtual/exotic-color-space/images/text-content-crash-2.html [ Failure ] crbug.com/591099 virtual/exotic-color-space/images/text-content-crash.html [ Failure ] -crbug.com/591099 virtual/exotic-color-space/images/update-alt-text.html [ Crash ] +crbug.com/591099 virtual/exotic-color-space/images/update-alt-text.html [ Crash Pass ] crbug.com/591099 virtual/exotic-color-space/images/viewport-in-standalone-image-document.html [ Failure ] -crbug.com/591099 virtual/exotic-color-space/images/webgl-teximage2d.html [ Crash ] +crbug.com/591099 virtual/exotic-color-space/images/webgl-teximage2d.html [ Crash Pass ] crbug.com/591099 virtual/exotic-color-space/images/webp-flip.html [ Failure ] crbug.com/591099 virtual/exotic-color-space/images/zoomed-img-size.html [ Failure ] -crbug.com/591099 virtual/exotic-color-space/images/zoomed-offset-size.html [ Crash ] +crbug.com/591099 virtual/exotic-color-space/images/zoomed-offset-size.html [ Crash Pass ] crbug.com/591099 virtual/gpu-rasterization/images/12-55.html [ Failure ] crbug.com/591099 virtual/gpu-rasterization/images/182.html [ Failure ] crbug.com/591099 virtual/gpu-rasterization/images/2-comp.html [ Failure ] @@ -20717,7 +20727,7 @@ crbug.com/591099 virtual/gpu-rasterization/images/cross-fade-simple.html [ Failure ] crbug.com/591099 virtual/gpu-rasterization/images/cross-fade-sizing.html [ Failure ] crbug.com/591099 virtual/gpu-rasterization/images/cross-fade-tiled.html [ Failure ] -crbug.com/591099 virtual/gpu-rasterization/images/destroyed-image-load-event.html [ Crash ] +crbug.com/591099 virtual/gpu-rasterization/images/destroyed-image-load-event.html [ Crash Failure ] crbug.com/591099 virtual/gpu-rasterization/images/drag-svg-image.html [ Failure ] crbug.com/591099 virtual/gpu-rasterization/images/embed-does-not-propagate-dimensions-to-object-ancestor.html [ Failure Pass ] crbug.com/591099 virtual/gpu-rasterization/images/exif-orientation-css.html [ Crash Failure ] @@ -20733,7 +20743,7 @@ crbug.com/591099 virtual/gpu-rasterization/images/icon-0colors.html [ Failure ] crbug.com/591099 virtual/gpu-rasterization/images/icon-decoding.html [ Failure ] crbug.com/591099 virtual/gpu-rasterization/images/image-change-src.html [ Crash Pass ] -crbug.com/591099 virtual/gpu-rasterization/images/image-change-without-resize-shouldnt-layout.html [ Crash ] +crbug.com/591099 virtual/gpu-rasterization/images/image-change-without-resize-shouldnt-layout.html [ Crash Pass ] crbug.com/591099 virtual/gpu-rasterization/images/image-click-scale-restore-zoomed-image.html [ Failure ] crbug.com/591099 virtual/gpu-rasterization/images/image-css3-content-data.html [ Failure ] crbug.com/591099 virtual/gpu-rasterization/images/image-document-write-assert.html [ Failure ] @@ -20748,7 +20758,7 @@ crbug.com/591099 virtual/gpu-rasterization/images/image-map-zoom-alt-content.html [ Crash Failure ] crbug.com/591099 virtual/gpu-rasterization/images/image-map-zoom.html [ Failure ] crbug.com/591099 virtual/gpu-rasterization/images/image-page-injected-script-crash.html [ Crash Failure ] -crbug.com/591099 virtual/gpu-rasterization/images/image-use-counters.html [ Crash ] +crbug.com/591099 virtual/gpu-rasterization/images/image-use-counters.html [ Crash Pass ] crbug.com/591099 virtual/gpu-rasterization/images/image-zoom-to-25.html [ Failure ] crbug.com/591099 virtual/gpu-rasterization/images/image-zoom-to-500.html [ Failure ] crbug.com/591099 virtual/gpu-rasterization/images/imagemap-circle-focus-ring.html [ Failure ] @@ -20764,17 +20774,17 @@ crbug.com/591099 virtual/gpu-rasterization/images/imagemap-overflowing-circle-focus-ring.html [ Failure ] crbug.com/591099 virtual/gpu-rasterization/images/imagemap-overflowing-polygon-focus-ring.html [ Failure ] crbug.com/591099 virtual/gpu-rasterization/images/imagemap-polygon-focus-ring.html [ Failure ] -crbug.com/591099 virtual/gpu-rasterization/images/imagemap-scroll.html [ Crash ] -crbug.com/591099 virtual/gpu-rasterization/images/img-dimensions-styled.html [ Crash ] -crbug.com/591099 virtual/gpu-rasterization/images/invalid-image-url-crash.html [ Crash ] +crbug.com/591099 virtual/gpu-rasterization/images/imagemap-scroll.html [ Crash Failure ] +crbug.com/591099 virtual/gpu-rasterization/images/img-dimensions-styled.html [ Crash Pass ] +crbug.com/591099 virtual/gpu-rasterization/images/invalid-image-url-crash.html [ Crash Pass ] crbug.com/591099 virtual/gpu-rasterization/images/jpeg-yuv-image-decoding.html [ Failure Pass ] crbug.com/591099 virtual/gpu-rasterization/images/jpeg-yuv-progressive-canvas.html [ Failure Pass ] crbug.com/591099 virtual/gpu-rasterization/images/jpeg-yuv-progressive-image.html [ Failure Pass ] crbug.com/591099 virtual/gpu-rasterization/images/link-body-content-imageDimensionChanged-crash.html [ Failure ] crbug.com/591099 virtual/gpu-rasterization/images/load-img-with-empty-src.html [ Failure ] crbug.com/591099 virtual/gpu-rasterization/images/motion-jpeg-single-frame.html [ Failure ] -crbug.com/591099 virtual/gpu-rasterization/images/move-image-to-new-document.html [ Crash ] -crbug.com/591099 virtual/gpu-rasterization/images/multiple-inflight-error-event-crash.html [ Crash ] +crbug.com/591099 virtual/gpu-rasterization/images/move-image-to-new-document.html [ Crash Pass ] +crbug.com/591099 virtual/gpu-rasterization/images/multiple-inflight-error-event-crash.html [ Crash Pass ] crbug.com/591099 virtual/gpu-rasterization/images/pdf-as-background.html [ Failure ] crbug.com/591099 virtual/gpu-rasterization/images/pdf-as-tiled-background.html [ Failure ] crbug.com/591099 virtual/gpu-rasterization/images/percent-height-image.html [ Failure ] @@ -20793,43 +20803,43 @@ crbug.com/591099 virtual/gpu-rasterization/images/script-counter-imageDimensionChanged-crash.html [ Failure ] crbug.com/591099 virtual/gpu-rasterization/images/sprite-no-bleed.html [ Failure ] crbug.com/591099 virtual/gpu-rasterization/images/style-access-during-imageChanged-crash.html [ Crash Failure ] -crbug.com/591099 virtual/gpu-rasterization/images/style-access-during-imageChanged-style-freeze.html [ Crash ] +crbug.com/591099 virtual/gpu-rasterization/images/style-access-during-imageChanged-style-freeze.html [ Crash Pass ] crbug.com/591099 virtual/gpu-rasterization/images/text-content-crash-2.html [ Failure ] crbug.com/591099 virtual/gpu-rasterization/images/text-content-crash.html [ Failure ] -crbug.com/591099 virtual/gpu-rasterization/images/update-alt-text.html [ Crash ] +crbug.com/591099 virtual/gpu-rasterization/images/update-alt-text.html [ Crash Pass ] crbug.com/591099 virtual/gpu-rasterization/images/viewport-in-standalone-image-document.html [ Failure ] -crbug.com/591099 virtual/gpu-rasterization/images/webgl-teximage2d.html [ Crash ] +crbug.com/591099 virtual/gpu-rasterization/images/webgl-teximage2d.html [ Crash Pass ] crbug.com/591099 virtual/gpu-rasterization/images/webp-flip.html [ Failure ] crbug.com/591099 virtual/gpu-rasterization/images/zoomed-img-size.html [ Failure ] -crbug.com/591099 virtual/gpu-rasterization/images/zoomed-offset-size.html [ Crash ] -crbug.com/591099 virtual/gpu/fast/canvas/2d.composite.globalAlpha.fillPath.html [ Crash ] -crbug.com/591099 virtual/gpu/fast/canvas/2d.fillText.gradient.html [ Crash ] -crbug.com/591099 virtual/gpu/fast/canvas/2d.text.draw.fill.maxWidth.gradient.html [ Crash ] -crbug.com/591099 virtual/gpu/fast/canvas/2d.text.draw.fill.maxWidth.negative.html [ Crash ] -crbug.com/591099 virtual/gpu/fast/canvas/2d.text.draw.fill.maxWidth.veryLarge.html [ Crash ] -crbug.com/591099 virtual/gpu/fast/canvas/2d.text.draw.fill.maxWidth.verySmall.html [ Crash ] +crbug.com/591099 virtual/gpu-rasterization/images/zoomed-offset-size.html [ Crash Pass ] +crbug.com/591099 virtual/gpu/fast/canvas/2d.composite.globalAlpha.fillPath.html [ Crash Pass ] +crbug.com/591099 virtual/gpu/fast/canvas/2d.fillText.gradient.html [ Crash Pass ] +crbug.com/591099 virtual/gpu/fast/canvas/2d.text.draw.fill.maxWidth.gradient.html [ Crash Pass ] +crbug.com/591099 virtual/gpu/fast/canvas/2d.text.draw.fill.maxWidth.negative.html [ Crash Pass ] +crbug.com/591099 virtual/gpu/fast/canvas/2d.text.draw.fill.maxWidth.veryLarge.html [ Crash Pass ] +crbug.com/591099 virtual/gpu/fast/canvas/2d.text.draw.fill.maxWidth.verySmall.html [ Crash Pass ] crbug.com/591099 virtual/gpu/fast/canvas/OffscreenCanvas-constructor-in-worker.html [ Failure ] crbug.com/591099 virtual/gpu/fast/canvas/OffscreenCanvas-invalid-args-in-worker.html [ Failure ] crbug.com/591099 virtual/gpu/fast/canvas/OffscreenCanvas-transferable-exceptions.html [ Failure ] crbug.com/591099 virtual/gpu/fast/canvas/OffscreenCanvas-transferable.html [ Failure ] -crbug.com/591099 virtual/gpu/fast/canvas/access-zero-sized-canvas.html [ Crash ] -crbug.com/591099 virtual/gpu/fast/canvas/alpha.html [ Crash ] -crbug.com/591099 virtual/gpu/fast/canvas/arc-crash.html [ Crash ] -crbug.com/591099 virtual/gpu/fast/canvas/arc360.html [ Crash ] -crbug.com/591099 virtual/gpu/fast/canvas/bug544329.html [ Crash ] -crbug.com/591099 virtual/gpu/fast/canvas/canvas-2d-clip-anti-aliasing.html [ Crash ] +crbug.com/591099 virtual/gpu/fast/canvas/access-zero-sized-canvas.html [ Crash Pass ] +crbug.com/591099 virtual/gpu/fast/canvas/alpha.html [ Crash Pass ] +crbug.com/591099 virtual/gpu/fast/canvas/arc-crash.html [ Crash Pass ] +crbug.com/591099 virtual/gpu/fast/canvas/arc360.html [ Crash Pass ] +crbug.com/591099 virtual/gpu/fast/canvas/bug544329.html [ Crash Pass ] +crbug.com/591099 virtual/gpu/fast/canvas/canvas-2d-clip-anti-aliasing.html [ Crash Pass ] crbug.com/591099 virtual/gpu/fast/canvas/canvas-ImageBitmap-close.html [ Failure ] crbug.com/591099 virtual/gpu/fast/canvas/canvas-ImageBitmap-structured-clone.html [ Failure ] crbug.com/591099 virtual/gpu/fast/canvas/canvas-ImageBitmap-transferable.html [ Failure ] crbug.com/591099 virtual/gpu/fast/canvas/canvas-ImageData-neutered-source.html [ Crash Failure ] crbug.com/591099 virtual/gpu/fast/canvas/canvas-ImageData-workers.html [ Failure ] -crbug.com/591099 virtual/gpu/fast/canvas/canvas-after-destroy-iframe.html [ Crash ] -crbug.com/591099 virtual/gpu/fast/canvas/canvas-alphaImageData-behavior.html [ Crash ] -crbug.com/591099 virtual/gpu/fast/canvas/canvas-arc-zero-lineto.html [ Crash ] -crbug.com/591099 virtual/gpu/fast/canvas/canvas-bezier-same-endpoint.html [ Crash ] +crbug.com/591099 virtual/gpu/fast/canvas/canvas-after-destroy-iframe.html [ Crash Pass ] +crbug.com/591099 virtual/gpu/fast/canvas/canvas-alphaImageData-behavior.html [ Crash Pass ] +crbug.com/591099 virtual/gpu/fast/canvas/canvas-arc-zero-lineto.html [ Crash Pass ] +crbug.com/591099 virtual/gpu/fast/canvas/canvas-bezier-same-endpoint.html [ Crash Pass ] crbug.com/591099 virtual/gpu/fast/canvas/canvas-blending-image-over-image.html [ Failure ] crbug.com/591099 virtual/gpu/fast/canvas/canvas-blending-text.html [ Failure ] -crbug.com/591099 virtual/gpu/fast/canvas/canvas-closePath-single-point.html [ Crash ] +crbug.com/591099 virtual/gpu/fast/canvas/canvas-closePath-single-point.html [ Crash Pass ] crbug.com/591099 virtual/gpu/fast/canvas/canvas-composite-alpha.html [ Crash Failure ] crbug.com/591099 virtual/gpu/fast/canvas/canvas-composite-canvas.html [ Failure ] crbug.com/591099 virtual/gpu/fast/canvas/canvas-composite-image.html [ Failure ] @@ -20848,25 +20858,25 @@ crbug.com/591099 virtual/gpu/fast/canvas/canvas-createImageBitmap-recursive.html [ Failure ] crbug.com/591099 virtual/gpu/fast/canvas/canvas-createImageBitmap-svg-no-intrinsic-size.html [ Failure ] crbug.com/591099 virtual/gpu/fast/canvas/canvas-createImageBitmap-svg.html [ Failure ] -crbug.com/591099 virtual/gpu/fast/canvas/canvas-createPattern-fillRect-shadow.html [ Crash ] -crbug.com/591099 virtual/gpu/fast/canvas/canvas-currentColor.html [ Crash ] -crbug.com/591099 virtual/gpu/fast/canvas/canvas-direction.html [ Crash ] -crbug.com/591099 virtual/gpu/fast/canvas/canvas-draw-canvas-on-canvas-shadow.html [ Crash ] +crbug.com/591099 virtual/gpu/fast/canvas/canvas-createPattern-fillRect-shadow.html [ Crash Pass ] +crbug.com/591099 virtual/gpu/fast/canvas/canvas-currentColor.html [ Crash Pass ] +crbug.com/591099 virtual/gpu/fast/canvas/canvas-direction.html [ Crash Pass ] +crbug.com/591099 virtual/gpu/fast/canvas/canvas-draw-canvas-on-canvas-shadow.html [ Crash Pass ] crbug.com/591099 virtual/gpu/fast/canvas/canvas-drawImage-animated-images.html [ Failure ] -crbug.com/591099 virtual/gpu/fast/canvas/canvas-drawImage-animated.html [ Crash ] -crbug.com/591099 virtual/gpu/fast/canvas/canvas-drawImage-live-video.html [ Crash ] -crbug.com/591099 virtual/gpu/fast/canvas/canvas-drawImage-shadow.html [ Crash ] -crbug.com/591099 virtual/gpu/fast/canvas/canvas-ellipse-360-winding.html [ Crash ] +crbug.com/591099 virtual/gpu/fast/canvas/canvas-drawImage-animated.html [ Crash Pass ] +crbug.com/591099 virtual/gpu/fast/canvas/canvas-drawImage-live-video.html [ Crash Pass ] +crbug.com/591099 virtual/gpu/fast/canvas/canvas-drawImage-shadow.html [ Crash Pass ] +crbug.com/591099 virtual/gpu/fast/canvas/canvas-ellipse-360-winding.html [ Crash Pass ] crbug.com/591099 virtual/gpu/fast/canvas/canvas-ellipse-connecting-line.html [ Failure Pass ] -crbug.com/591099 virtual/gpu/fast/canvas/canvas-ellipse-zero-lineto.html [ Crash ] -crbug.com/591099 virtual/gpu/fast/canvas/canvas-ellipse.html [ Crash ] -crbug.com/591099 virtual/gpu/fast/canvas/canvas-empty-image-pattern.html [ Crash ] -crbug.com/591099 virtual/gpu/fast/canvas/canvas-fillPath-alpha-shadow.html [ Crash ] -crbug.com/591099 virtual/gpu/fast/canvas/canvas-fillPath-gradient-shadow.html [ Crash ] -crbug.com/591099 virtual/gpu/fast/canvas/canvas-fillPath-pattern-shadow.html [ Crash ] -crbug.com/591099 virtual/gpu/fast/canvas/canvas-fillPath-shadow.html [ Crash ] -crbug.com/591099 virtual/gpu/fast/canvas/canvas-fillRect-gradient-shadow.html [ Crash ] -crbug.com/591099 virtual/gpu/fast/canvas/canvas-fillRect-shadow.html [ Crash ] +crbug.com/591099 virtual/gpu/fast/canvas/canvas-ellipse-zero-lineto.html [ Crash Pass ] +crbug.com/591099 virtual/gpu/fast/canvas/canvas-ellipse.html [ Crash Pass ] +crbug.com/591099 virtual/gpu/fast/canvas/canvas-empty-image-pattern.html [ Crash Pass ] +crbug.com/591099 virtual/gpu/fast/canvas/canvas-fillPath-alpha-shadow.html [ Crash Pass ] +crbug.com/591099 virtual/gpu/fast/canvas/canvas-fillPath-gradient-shadow.html [ Crash Pass ] +crbug.com/591099 virtual/gpu/fast/canvas/canvas-fillPath-pattern-shadow.html [ Crash Pass ] +crbug.com/591099 virtual/gpu/fast/canvas/canvas-fillPath-shadow.html [ Crash Pass ] +crbug.com/591099 virtual/gpu/fast/canvas/canvas-fillRect-gradient-shadow.html [ Crash Pass ] +crbug.com/591099 virtual/gpu/fast/canvas/canvas-fillRect-shadow.html [ Crash Pass ] crbug.com/591099 virtual/gpu/fast/canvas/canvas-filter-fill-liveness.html [ Failure ] crbug.com/591099 virtual/gpu/fast/canvas/canvas-filter-fill-paint-color.html [ Failure ] crbug.com/591099 virtual/gpu/fast/canvas/canvas-filter-fill-paint-gradient.html [ Failure ] @@ -20883,100 +20893,100 @@ crbug.com/591099 virtual/gpu/fast/canvas/canvas-filter-width-height-hidpi.html [ Failure ] crbug.com/591099 virtual/gpu/fast/canvas/canvas-filter-width-height-scale.html [ Failure ] crbug.com/591099 virtual/gpu/fast/canvas/canvas-filter-width-height.html [ Failure ] -crbug.com/591099 virtual/gpu/fast/canvas/canvas-font-cache.html [ Crash ] +crbug.com/591099 virtual/gpu/fast/canvas/canvas-font-cache.html [ Crash Pass ] crbug.com/591099 virtual/gpu/fast/canvas/canvas-hides-fallback.html [ Failure ] -crbug.com/591099 virtual/gpu/fast/canvas/canvas-hit-regions-accessibility-test.html [ Crash ] -crbug.com/591099 virtual/gpu/fast/canvas/canvas-hit-regions-basic-test.html [ Crash ] -crbug.com/591099 virtual/gpu/fast/canvas/canvas-hit-regions-clear-test.html [ Crash ] -crbug.com/591099 virtual/gpu/fast/canvas/canvas-hit-regions-clip-test.html [ Crash ] -crbug.com/591099 virtual/gpu/fast/canvas/canvas-hit-regions-css-transform-test.html [ Crash ] -crbug.com/591099 virtual/gpu/fast/canvas/canvas-hit-regions-device-pixel-ratio-test.html [ Crash ] -crbug.com/591099 virtual/gpu/fast/canvas/canvas-hit-regions-event-test.html [ Crash ] -crbug.com/591099 virtual/gpu/fast/canvas/canvas-hit-regions-exception-test.html [ Crash ] -crbug.com/591099 virtual/gpu/fast/canvas/canvas-hit-regions-fallback-element-test-1.html [ Crash ] -crbug.com/591099 virtual/gpu/fast/canvas/canvas-hit-regions-fallback-element-test-2.html [ Crash ] -crbug.com/591099 virtual/gpu/fast/canvas/canvas-hit-regions-fallback-element-test-3.html [ Crash ] -crbug.com/591099 virtual/gpu/fast/canvas/canvas-hit-regions-fill-rule-test.html [ Crash ] -crbug.com/591099 virtual/gpu/fast/canvas/canvas-hit-regions-path2d-test.html [ Crash ] -crbug.com/591099 virtual/gpu/fast/canvas/canvas-hit-regions-path2d-transform-test.html [ Crash ] -crbug.com/591099 virtual/gpu/fast/canvas/canvas-hit-regions-scale-factor.html [ Crash ] -crbug.com/591099 virtual/gpu/fast/canvas/canvas-hit-regions-transform-test.html [ Crash ] -crbug.com/591099 virtual/gpu/fast/canvas/canvas-imageSmoothingEnabled-repaint.html [ Crash ] -crbug.com/591099 virtual/gpu/fast/canvas/canvas-imageSmoothingQuality.html [ Crash ] -crbug.com/591099 virtual/gpu/fast/canvas/canvas-invalid-fillstyle.html [ Crash ] -crbug.com/591099 virtual/gpu/fast/canvas/canvas-invalid-strokestyle.html [ Crash ] +crbug.com/591099 virtual/gpu/fast/canvas/canvas-hit-regions-accessibility-test.html [ Crash Pass ] +crbug.com/591099 virtual/gpu/fast/canvas/canvas-hit-regions-basic-test.html [ Crash Pass ] +crbug.com/591099 virtual/gpu/fast/canvas/canvas-hit-regions-clear-test.html [ Crash Pass ] +crbug.com/591099 virtual/gpu/fast/canvas/canvas-hit-regions-clip-test.html [ Crash Pass ] +crbug.com/591099 virtual/gpu/fast/canvas/canvas-hit-regions-css-transform-test.html [ Crash Pass ] +crbug.com/591099 virtual/gpu/fast/canvas/canvas-hit-regions-device-pixel-ratio-test.html [ Crash Pass ] +crbug.com/591099 virtual/gpu/fast/canvas/canvas-hit-regions-event-test.html [ Crash Pass ] +crbug.com/591099 virtual/gpu/fast/canvas/canvas-hit-regions-exception-test.html [ Crash Pass ] +crbug.com/591099 virtual/gpu/fast/canvas/canvas-hit-regions-fallback-element-test-1.html [ Crash Pass ] +crbug.com/591099 virtual/gpu/fast/canvas/canvas-hit-regions-fallback-element-test-2.html [ Crash Pass ] +crbug.com/591099 virtual/gpu/fast/canvas/canvas-hit-regions-fallback-element-test-3.html [ Crash Pass ] +crbug.com/591099 virtual/gpu/fast/canvas/canvas-hit-regions-fill-rule-test.html [ Crash Pass ] +crbug.com/591099 virtual/gpu/fast/canvas/canvas-hit-regions-path2d-test.html [ Crash Pass ] +crbug.com/591099 virtual/gpu/fast/canvas/canvas-hit-regions-path2d-transform-test.html [ Crash Pass ] +crbug.com/591099 virtual/gpu/fast/canvas/canvas-hit-regions-scale-factor.html [ Crash Pass ] +crbug.com/591099 virtual/gpu/fast/canvas/canvas-hit-regions-transform-test.html [ Crash Pass ] +crbug.com/591099 virtual/gpu/fast/canvas/canvas-imageSmoothingEnabled-repaint.html [ Crash Pass ] +crbug.com/591099 virtual/gpu/fast/canvas/canvas-imageSmoothingQuality.html [ Crash Failure ] +crbug.com/591099 virtual/gpu/fast/canvas/canvas-invalid-fillstyle.html [ Crash Pass ] +crbug.com/591099 virtual/gpu/fast/canvas/canvas-invalid-strokestyle.html [ Crash Pass ] crbug.com/591099 virtual/gpu/fast/canvas/canvas-invalid-video.html [ Failure ] -crbug.com/591099 virtual/gpu/fast/canvas/canvas-isPointInStroke-with-path.html [ Crash ] -crbug.com/591099 virtual/gpu/fast/canvas/canvas-isPointInStroke.html [ Crash ] -crbug.com/591099 virtual/gpu/fast/canvas/canvas-large-dimensions.html [ Crash ] -crbug.com/591099 virtual/gpu/fast/canvas/canvas-lineDash-input-sequence.html [ Crash ] -crbug.com/591099 virtual/gpu/fast/canvas/canvas-lineDash-invalid.html [ Crash ] -crbug.com/591099 virtual/gpu/fast/canvas/canvas-lineDash.html [ Crash ] -crbug.com/591099 virtual/gpu/fast/canvas/canvas-lineWidth-intact-after-strokeRect.html [ Crash ] +crbug.com/591099 virtual/gpu/fast/canvas/canvas-isPointInStroke-with-path.html [ Crash Pass ] +crbug.com/591099 virtual/gpu/fast/canvas/canvas-isPointInStroke.html [ Crash Pass ] +crbug.com/591099 virtual/gpu/fast/canvas/canvas-large-dimensions.html [ Crash Pass ] +crbug.com/591099 virtual/gpu/fast/canvas/canvas-lineDash-input-sequence.html [ Crash Pass ] +crbug.com/591099 virtual/gpu/fast/canvas/canvas-lineDash-invalid.html [ Crash Pass ] +crbug.com/591099 virtual/gpu/fast/canvas/canvas-lineDash.html [ Crash Pass ] +crbug.com/591099 virtual/gpu/fast/canvas/canvas-lineWidth-intact-after-strokeRect.html [ Crash Pass ] crbug.com/591099 virtual/gpu/fast/canvas/canvas-lost-gpu-context.html [ Crash Failure ] crbug.com/591099 virtual/gpu/fast/canvas/canvas-measure-bidi-text.html [ Failure Pass ] crbug.com/591099 virtual/gpu/fast/canvas/canvas-negative-size.html [ Failure ] crbug.com/591099 virtual/gpu/fast/canvas/canvas-normalize-string.html [ Failure ] -crbug.com/591099 virtual/gpu/fast/canvas/canvas-path-context-clip.html [ Crash ] -crbug.com/591099 virtual/gpu/fast/canvas/canvas-path-context-fill.html [ Crash ] -crbug.com/591099 virtual/gpu/fast/canvas/canvas-path-context-stroke.html [ Crash ] -crbug.com/591099 virtual/gpu/fast/canvas/canvas-path-object.html [ Crash ] -crbug.com/591099 virtual/gpu/fast/canvas/canvas-path-with-inf-nan-dimensions.html [ Crash ] -crbug.com/591099 virtual/gpu/fast/canvas/canvas-pattern-set-transform.html [ Crash ] -crbug.com/591099 virtual/gpu/fast/canvas/canvas-putImageData.html [ Crash ] -crbug.com/591099 virtual/gpu/fast/canvas/canvas-quadratic-same-endpoint.html [ Crash ] +crbug.com/591099 virtual/gpu/fast/canvas/canvas-path-context-clip.html [ Crash Pass ] +crbug.com/591099 virtual/gpu/fast/canvas/canvas-path-context-fill.html [ Crash Pass ] +crbug.com/591099 virtual/gpu/fast/canvas/canvas-path-context-stroke.html [ Crash Pass ] +crbug.com/591099 virtual/gpu/fast/canvas/canvas-path-object.html [ Crash Pass ] +crbug.com/591099 virtual/gpu/fast/canvas/canvas-path-with-inf-nan-dimensions.html [ Crash Pass ] +crbug.com/591099 virtual/gpu/fast/canvas/canvas-pattern-set-transform.html [ Crash Pass ] +crbug.com/591099 virtual/gpu/fast/canvas/canvas-putImageData.html [ Crash Pass ] +crbug.com/591099 virtual/gpu/fast/canvas/canvas-quadratic-same-endpoint.html [ Crash Pass ] crbug.com/591099 virtual/gpu/fast/canvas/canvas-render-layer.html [ Failure Pass ] -crbug.com/591099 virtual/gpu/fast/canvas/canvas-resetTransform.html [ Crash ] -crbug.com/591099 virtual/gpu/fast/canvas/canvas-resize-after-paint.html [ Crash ] -crbug.com/591099 virtual/gpu/fast/canvas/canvas-scale-drawImage-shadow.html [ Crash ] -crbug.com/591099 virtual/gpu/fast/canvas/canvas-scale-fillPath-shadow.html [ Crash ] -crbug.com/591099 virtual/gpu/fast/canvas/canvas-scale-fillRect-shadow.html [ Crash ] -crbug.com/591099 virtual/gpu/fast/canvas/canvas-scale-shadowBlur.html [ Crash ] -crbug.com/591099 virtual/gpu/fast/canvas/canvas-scale-strokePath-shadow.html [ Crash ] +crbug.com/591099 virtual/gpu/fast/canvas/canvas-resetTransform.html [ Crash Pass ] +crbug.com/591099 virtual/gpu/fast/canvas/canvas-resize-after-paint.html [ Crash Pass ] +crbug.com/591099 virtual/gpu/fast/canvas/canvas-scale-drawImage-shadow.html [ Crash Pass ] +crbug.com/591099 virtual/gpu/fast/canvas/canvas-scale-fillPath-shadow.html [ Crash Pass ] +crbug.com/591099 virtual/gpu/fast/canvas/canvas-scale-fillRect-shadow.html [ Crash Pass ] +crbug.com/591099 virtual/gpu/fast/canvas/canvas-scale-shadowBlur.html [ Crash Pass ] +crbug.com/591099 virtual/gpu/fast/canvas/canvas-scale-strokePath-shadow.html [ Crash Pass ] crbug.com/591099 virtual/gpu/fast/canvas/canvas-scroll-path-into-view.html [ Failure Timeout ] -crbug.com/591099 virtual/gpu/fast/canvas/canvas-set-properties-with-non-invertible-ctm.html [ Crash ] +crbug.com/591099 virtual/gpu/fast/canvas/canvas-set-properties-with-non-invertible-ctm.html [ Crash Pass ] crbug.com/591099 virtual/gpu/fast/canvas/canvas-shadow-source-in.html [ Failure Pass ] -crbug.com/591099 virtual/gpu/fast/canvas/canvas-skia-excessive-size.html [ Crash ] -crbug.com/591099 virtual/gpu/fast/canvas/canvas-strokePath-alpha-shadow.html [ Crash ] -crbug.com/591099 virtual/gpu/fast/canvas/canvas-strokePath-cap-join.html [ Crash ] -crbug.com/591099 virtual/gpu/fast/canvas/canvas-strokePath-gradient-shadow.html [ Crash ] -crbug.com/591099 virtual/gpu/fast/canvas/canvas-strokePath-shadow.html [ Crash ] -crbug.com/591099 virtual/gpu/fast/canvas/canvas-strokeRect-alpha-shadow.html [ Crash ] -crbug.com/591099 virtual/gpu/fast/canvas/canvas-strokeRect-gradient-shadow.html [ Crash ] +crbug.com/591099 virtual/gpu/fast/canvas/canvas-skia-excessive-size.html [ Crash Pass ] +crbug.com/591099 virtual/gpu/fast/canvas/canvas-strokePath-alpha-shadow.html [ Crash Pass ] +crbug.com/591099 virtual/gpu/fast/canvas/canvas-strokePath-cap-join.html [ Crash Pass ] +crbug.com/591099 virtual/gpu/fast/canvas/canvas-strokePath-gradient-shadow.html [ Crash Pass ] +crbug.com/591099 virtual/gpu/fast/canvas/canvas-strokePath-shadow.html [ Crash Pass ] +crbug.com/591099 virtual/gpu/fast/canvas/canvas-strokeRect-alpha-shadow.html [ Crash Pass ] +crbug.com/591099 virtual/gpu/fast/canvas/canvas-strokeRect-gradient-shadow.html [ Crash Pass ] crbug.com/591099 virtual/gpu/fast/canvas/canvas-text-baseline-tiny-fonts.html [ Failure Pass ] -crbug.com/591099 virtual/gpu/fast/canvas/canvas-text-space-characters.html [ Crash ] +crbug.com/591099 virtual/gpu/fast/canvas/canvas-text-space-characters.html [ Crash Pass ] crbug.com/591099 virtual/gpu/fast/canvas/canvas-textMetrics-width.html [ Failure ] crbug.com/591099 virtual/gpu/fast/canvas/canvas-transforms-during-path.html [ Failure ] -crbug.com/591099 virtual/gpu/fast/canvas/canvas-transforms-fillRect-shadow.html [ Crash ] +crbug.com/591099 virtual/gpu/fast/canvas/canvas-transforms-fillRect-shadow.html [ Crash Pass ] crbug.com/591099 virtual/gpu/fast/canvas/currentTransform-null.html [ Failure ] -crbug.com/591099 virtual/gpu/fast/canvas/draw-focus-if-needed-invisible-crash.html [ Crash ] -crbug.com/591099 virtual/gpu/fast/canvas/draw-focus-if-needed-on-event.html [ Crash ] -crbug.com/591099 virtual/gpu/fast/canvas/draw-focus-if-needed-with-path2d.html [ Crash ] -crbug.com/591099 virtual/gpu/fast/canvas/draw-focus-if-needed.html [ Crash ] -crbug.com/591099 virtual/gpu/fast/canvas/drawImage-with-negative-source-destination.html [ Crash ] -crbug.com/591099 virtual/gpu/fast/canvas/fallback-content.html [ Crash ] -crbug.com/591099 virtual/gpu/fast/canvas/feimage-with-foreignobject-taint-canvas-2.html [ Crash ] -crbug.com/591099 virtual/gpu/fast/canvas/feimage-with-foreignobject-taint-canvas.html [ Crash ] +crbug.com/591099 virtual/gpu/fast/canvas/draw-focus-if-needed-invisible-crash.html [ Crash Pass ] +crbug.com/591099 virtual/gpu/fast/canvas/draw-focus-if-needed-on-event.html [ Crash Pass ] +crbug.com/591099 virtual/gpu/fast/canvas/draw-focus-if-needed-with-path2d.html [ Crash Pass ] +crbug.com/591099 virtual/gpu/fast/canvas/draw-focus-if-needed.html [ Crash Pass ] +crbug.com/591099 virtual/gpu/fast/canvas/drawImage-with-negative-source-destination.html [ Crash Pass ] +crbug.com/591099 virtual/gpu/fast/canvas/fallback-content.html [ Crash Pass ] +crbug.com/591099 virtual/gpu/fast/canvas/feimage-with-foreignobject-taint-canvas-2.html [ Crash Pass ] +crbug.com/591099 virtual/gpu/fast/canvas/feimage-with-foreignobject-taint-canvas.html [ Crash Pass ] crbug.com/591099 virtual/gpu/fast/canvas/fill-stroke-clip-reset-path.html [ Failure ] -crbug.com/591099 virtual/gpu/fast/canvas/fillText-shadow.html [ Crash ] +crbug.com/591099 virtual/gpu/fast/canvas/fillText-shadow.html [ Crash Pass ] crbug.com/591099 virtual/gpu/fast/canvas/fillrect_gradient.html [ Failure ] -crbug.com/591099 virtual/gpu/fast/canvas/font-no-zoom.html [ Crash ] -crbug.com/591099 virtual/gpu/fast/canvas/gradient-with-clip.html [ Crash ] +crbug.com/591099 virtual/gpu/fast/canvas/font-no-zoom.html [ Crash Pass ] +crbug.com/591099 virtual/gpu/fast/canvas/gradient-with-clip.html [ Crash Pass ] crbug.com/591099 virtual/gpu/fast/canvas/image-object-in-canvas.html [ Failure ] -crbug.com/591099 virtual/gpu/fast/canvas/image-with-foreignobject-taint-canvas-2.html [ Crash ] -crbug.com/591099 virtual/gpu/fast/canvas/image-with-foreignobject-taint-canvas.html [ Crash ] -crbug.com/591099 virtual/gpu/fast/canvas/painting-on-bad-canvas.html [ Crash ] -crbug.com/591099 virtual/gpu/fast/canvas/pattern-with-transform.html [ Crash ] +crbug.com/591099 virtual/gpu/fast/canvas/image-with-foreignobject-taint-canvas-2.html [ Crash Pass ] +crbug.com/591099 virtual/gpu/fast/canvas/image-with-foreignobject-taint-canvas.html [ Crash Pass ] +crbug.com/591099 virtual/gpu/fast/canvas/painting-on-bad-canvas.html [ Crash Pass ] +crbug.com/591099 virtual/gpu/fast/canvas/pattern-with-transform.html [ Crash Pass ] crbug.com/591099 virtual/gpu/fast/canvas/quadraticCurveTo.xml [ Failure ] -crbug.com/591099 virtual/gpu/fast/canvas/resize-while-save-active.html [ Crash ] -crbug.com/591099 virtual/gpu/fast/canvas/set-empty-font-crash.html [ Crash ] +crbug.com/591099 virtual/gpu/fast/canvas/resize-while-save-active.html [ Crash Pass ] +crbug.com/591099 virtual/gpu/fast/canvas/set-empty-font-crash.html [ Crash Pass ] crbug.com/591099 virtual/gpu/fast/canvas/setWidthResetAfterForcedRender.html [ Failure ] -crbug.com/591099 virtual/gpu/fast/canvas/shadow-huge-blur.html [ Crash ] +crbug.com/591099 virtual/gpu/fast/canvas/shadow-huge-blur.html [ Crash Pass ] crbug.com/591099 virtual/gpu/fast/canvas/shadow-offset-1.html [ Failure ] crbug.com/591099 virtual/gpu/fast/canvas/toDataURL-alpha.html [ Failure ] -crbug.com/591099 virtual/gpu/fast/canvas/toDataURL-noData.html [ Crash ] +crbug.com/591099 virtual/gpu/fast/canvas/toDataURL-noData.html [ Crash Pass ] crbug.com/591099 virtual/gpu/fast/canvas/toDataURL-supportedTypes.html [ Failure ] -crbug.com/591099 virtual/gpu/fast/canvas/transformed-canvas-reset.html [ Crash ] +crbug.com/591099 virtual/gpu/fast/canvas/transformed-canvas-reset.html [ Crash Pass ] crbug.com/591099 virtual/gpu/fast/canvas/unclosed-canvas-1.html [ Failure ] crbug.com/591099 virtual/gpu/fast/canvas/unclosed-canvas-3.html [ Crash Failure ] crbug.com/591099 virtual/gpu/fast/canvas/unclosed-canvas-4.html [ Failure ] @@ -20987,11 +20997,11 @@ crbug.com/591099 virtual/gpu/fast/canvas/webgl/renderer-and-vendor-strings.html [ Failure ] crbug.com/591099 virtual/gpu/fast/canvas/webgl/shader-deleted-by-accessor.html [ Failure ] crbug.com/591099 virtual/gpu/fast/canvas/webgl/tex-sub-image-cube-maps.html [ Failure ] -crbug.com/591099 virtual/gpu/fast/canvas/webgl/texImage-imageBitmap-from-canvas-resize.html [ Crash ] +crbug.com/591099 virtual/gpu/fast/canvas/webgl/texImage-imageBitmap-from-canvas-resize.html [ Crash Pass ] crbug.com/591099 virtual/gpu/fast/canvas/webgl/texture-color-profile.html [ Failure ] crbug.com/591099 virtual/gpu/fast/canvas/webgl/webgl-texture-binding-preserved.html [ Failure ] crbug.com/591099 virtual/gpu/fast/canvas/webgl/webgl-viewport-parameters-preserved.html [ Failure ] -crbug.com/591099 virtual/gpu/fast/canvas/zero-size-fill-rect.html [ Crash ] +crbug.com/591099 virtual/gpu/fast/canvas/zero-size-fill-rect.html [ Crash Pass ] crbug.com/591099 virtual/high-contrast-mode/paint/high-contrast-mode/image-filter-all/text-on-backgrounds.html [ Failure ] crbug.com/591099 virtual/layout_ng/external/wpt/css/CSS2/floats/floats-wrap-top-below-inline-003r.xht [ Failure Pass ] crbug.com/591099 virtual/layout_ng/external/wpt/css/CSS2/normal-flow/block-replaced-width-006.xht [ Failure ] @@ -21016,11 +21026,13 @@ crbug.com/591099 virtual/layout_ng/fast/block/float/002.html [ Failure ] crbug.com/591099 virtual/layout_ng/fast/block/float/014.html [ Crash Failure ] crbug.com/591099 virtual/layout_ng/fast/block/float/017.html [ Failure ] +crbug.com/591099 virtual/layout_ng/fast/block/float/assert-when-moving-float.html [ Failure ] crbug.com/591099 virtual/layout_ng/fast/block/float/formatting-context-changes.html [ Failure ] crbug.com/591099 virtual/layout_ng/fast/block/float/overhanging-float-add-in-static-position-block.html [ Failure Pass ] crbug.com/591099 virtual/layout_ng/fast/block/float/overhanging-float-add-in-static-position-block2.html [ Failure Pass ] crbug.com/591099 virtual/layout_ng/fast/block/float/rubybase-children-made-inline-crash.html [ Failure ] crbug.com/591099 virtual/layout_ng/fast/block/float/rubybase-children-moved-crash-2.html [ Crash Failure ] +crbug.com/591099 virtual/layout_ng/fast/block/float/rubybase-children-moved-crash.html [ Failure ] crbug.com/591099 virtual/layout_ng/fast/block/margin-collapse/line-beside-float-complex-margin-collapsing.html [ Failure ] crbug.com/591099 virtual/layout_ng/fast/block/margin-collapse/self-collapsing-block-creates-block-formatting-context.html [ Failure ] crbug.com/591099 virtual/mojo-loading/http/tests/inspector-protocol/network/disable-interception-midway.html [ Failure Pass Timeout ] @@ -21032,91 +21044,91 @@ crbug.com/591099 virtual/mojo-loading/http/tests/inspector/persistence/automapping-sourcemap.html [ Failure Pass Timeout ] crbug.com/591099 virtual/mojo-loading/http/tests/security/cors-rfc1918/addressspace-document-csp-appcache.html [ Failure Pass Timeout ] crbug.com/591099 virtual/mojo-loading/http/tests/serviceworker/ServiceWorkerGlobalScope/registration-attribute.html [ Failure Pass ] -crbug.com/591099 virtual/mojo-localstorage/external/wpt/webstorage/event_no_duplicates.html [ Crash ] +crbug.com/591099 virtual/mojo-localstorage/external/wpt/webstorage/event_no_duplicates.html [ Crash Pass ] crbug.com/591099 virtual/mojo-localstorage/external/wpt/webstorage/storage_setitem.html [ Pass Timeout ] crbug.com/591099 virtual/mojo-localstorage/storage/domstorage/localstorage/missing-arguments.html [ Failure ] -crbug.com/591099 virtual/mse-1mb-buffers/http/tests/media/media-source/stream_memory_tests/mediasource-appendbuffer-quota-exceeded-1mb-buffers.html [ Crash ] -crbug.com/591099 virtual/new-remote-playback-pipeline/external/wpt/remote-playback/idlharness.html [ Crash ] -crbug.com/591099 virtual/new-remote-playback-pipeline/http/tests/media/controls/controls-list-add-hide.html [ Crash ] -crbug.com/591099 virtual/new-remote-playback-pipeline/http/tests/media/controls/controls-list-remove-show.html [ Crash ] -crbug.com/591099 virtual/new-remote-playback-pipeline/http/tests/media/controls/video-controls-overflow-menu-correct-ordering.html [ Crash ] -crbug.com/591099 virtual/new-remote-playback-pipeline/http/tests/media/controls/video-controls-overflow-menu-updates-appropriately.html [ Crash ] -crbug.com/591099 virtual/new-remote-playback-pipeline/media/controls/closed-captions-dynamic-update.html [ Crash ] -crbug.com/591099 virtual/new-remote-playback-pipeline/media/controls/closed-captions-on-off.html [ Crash ] -crbug.com/591099 virtual/new-remote-playback-pipeline/media/controls/closed-captions-single-track.html [ Crash ] -crbug.com/591099 virtual/new-remote-playback-pipeline/media/controls/closed-captions-switch-track.html [ Crash ] -crbug.com/591099 virtual/new-remote-playback-pipeline/media/controls/controls-cast-button-narrow.html [ Crash ] -crbug.com/591099 virtual/new-remote-playback-pipeline/media/controls/controls-cast-button.html [ Crash ] -crbug.com/591099 virtual/new-remote-playback-pipeline/media/controls/controls-cast-do-not-fade-out.html [ Crash ] -crbug.com/591099 virtual/new-remote-playback-pipeline/media/controls/controls-cast-overlay-slow-fade.html [ Crash Timeout ] -crbug.com/591099 virtual/new-remote-playback-pipeline/media/controls/controls-overlay-cast-button.html [ Crash ] -crbug.com/591099 virtual/new-remote-playback-pipeline/media/controls/controls-video-keynav-no-controls.html [ Crash ] -crbug.com/591099 virtual/new-remote-playback-pipeline/media/controls/controls-video-keynav.html [ Crash ] -crbug.com/591099 virtual/new-remote-playback-pipeline/media/controls/download-button-displays-with-preload-none.html [ Crash ] -crbug.com/591099 virtual/new-remote-playback-pipeline/media/controls/overflow-fully-hidden.html [ Crash ] -crbug.com/591099 virtual/new-remote-playback-pipeline/media/controls/overlay-play-button-document-move.html [ Crash ] -crbug.com/591099 virtual/new-remote-playback-pipeline/media/controls/overlay-play-button-narrow.html [ Crash ] -crbug.com/591099 virtual/new-remote-playback-pipeline/media/controls/settings-disable-controls.html [ Crash ] -crbug.com/591099 virtual/new-remote-playback-pipeline/media/controls/video-controls-overflow-menu-hide-on-click-outside.html [ Crash ] -crbug.com/591099 virtual/new-remote-playback-pipeline/media/controls/video-controls-overflow-menu-hide-on-click-panel.html [ Crash ] -crbug.com/591099 virtual/new-remote-playback-pipeline/media/controls/video-controls-overflow-menu-hide-on-click.html [ Crash ] -crbug.com/591099 virtual/new-remote-playback-pipeline/media/controls/video-controls-overflow-menu-hide-on-resize.html [ Crash ] -crbug.com/591099 virtual/new-remote-playback-pipeline/media/controls/video-controls-overflow-menu-text.html [ Crash ] -crbug.com/591099 virtual/new-remote-playback-pipeline/media/controls/video-controls-overflow-menu-visibility.html [ Crash ] +crbug.com/591099 virtual/mse-1mb-buffers/http/tests/media/media-source/stream_memory_tests/mediasource-appendbuffer-quota-exceeded-1mb-buffers.html [ Crash Pass ] +crbug.com/591099 virtual/new-remote-playback-pipeline/external/wpt/remote-playback/idlharness.html [ Crash Pass ] +crbug.com/591099 virtual/new-remote-playback-pipeline/http/tests/media/controls/controls-list-add-hide.html [ Crash Pass ] +crbug.com/591099 virtual/new-remote-playback-pipeline/http/tests/media/controls/controls-list-remove-show.html [ Crash Pass ] +crbug.com/591099 virtual/new-remote-playback-pipeline/http/tests/media/controls/video-controls-overflow-menu-correct-ordering.html [ Crash Pass ] +crbug.com/591099 virtual/new-remote-playback-pipeline/http/tests/media/controls/video-controls-overflow-menu-updates-appropriately.html [ Crash Pass ] +crbug.com/591099 virtual/new-remote-playback-pipeline/media/controls/closed-captions-dynamic-update.html [ Crash Pass ] +crbug.com/591099 virtual/new-remote-playback-pipeline/media/controls/closed-captions-on-off.html [ Crash Pass ] +crbug.com/591099 virtual/new-remote-playback-pipeline/media/controls/closed-captions-single-track.html [ Crash Pass ] +crbug.com/591099 virtual/new-remote-playback-pipeline/media/controls/closed-captions-switch-track.html [ Crash Pass ] +crbug.com/591099 virtual/new-remote-playback-pipeline/media/controls/controls-cast-button-narrow.html [ Crash Pass ] +crbug.com/591099 virtual/new-remote-playback-pipeline/media/controls/controls-cast-button.html [ Crash Pass ] +crbug.com/591099 virtual/new-remote-playback-pipeline/media/controls/controls-cast-do-not-fade-out.html [ Crash Pass ] +crbug.com/591099 virtual/new-remote-playback-pipeline/media/controls/controls-cast-overlay-slow-fade.html [ Crash Pass Timeout ] +crbug.com/591099 virtual/new-remote-playback-pipeline/media/controls/controls-overlay-cast-button.html [ Crash Pass ] +crbug.com/591099 virtual/new-remote-playback-pipeline/media/controls/controls-video-keynav-no-controls.html [ Crash Pass ] +crbug.com/591099 virtual/new-remote-playback-pipeline/media/controls/controls-video-keynav.html [ Crash Pass ] +crbug.com/591099 virtual/new-remote-playback-pipeline/media/controls/download-button-displays-with-preload-none.html [ Crash Pass ] +crbug.com/591099 virtual/new-remote-playback-pipeline/media/controls/overflow-fully-hidden.html [ Crash Pass ] +crbug.com/591099 virtual/new-remote-playback-pipeline/media/controls/overlay-play-button-document-move.html [ Crash Pass ] +crbug.com/591099 virtual/new-remote-playback-pipeline/media/controls/overlay-play-button-narrow.html [ Crash Pass ] +crbug.com/591099 virtual/new-remote-playback-pipeline/media/controls/settings-disable-controls.html [ Crash Pass ] +crbug.com/591099 virtual/new-remote-playback-pipeline/media/controls/video-controls-overflow-menu-hide-on-click-outside.html [ Crash Pass ] +crbug.com/591099 virtual/new-remote-playback-pipeline/media/controls/video-controls-overflow-menu-hide-on-click-panel.html [ Crash Pass ] +crbug.com/591099 virtual/new-remote-playback-pipeline/media/controls/video-controls-overflow-menu-hide-on-click.html [ Crash Pass ] +crbug.com/591099 virtual/new-remote-playback-pipeline/media/controls/video-controls-overflow-menu-hide-on-resize.html [ Crash Pass ] +crbug.com/591099 virtual/new-remote-playback-pipeline/media/controls/video-controls-overflow-menu-text.html [ Crash Pass ] +crbug.com/591099 virtual/new-remote-playback-pipeline/media/controls/video-controls-overflow-menu-visibility.html [ Crash Pass ] crbug.com/591099 virtual/new-remote-playback-pipeline/media/controls/video-controls-with-cast-rendering.html [ Failure ] -crbug.com/591099 virtual/new-remote-playback-pipeline/media/controls/video-enter-exit-fullscreen-while-hovering-shows-controls.html [ Crash ] -crbug.com/591099 virtual/new-remote-playback-pipeline/media/controls/video-enter-exit-fullscreen-without-hovering-doesnt-show-controls.html [ Crash ] +crbug.com/591099 virtual/new-remote-playback-pipeline/media/controls/video-enter-exit-fullscreen-while-hovering-shows-controls.html [ Crash Pass ] +crbug.com/591099 virtual/new-remote-playback-pipeline/media/controls/video-enter-exit-fullscreen-without-hovering-doesnt-show-controls.html [ Crash Pass ] crbug.com/591099 virtual/new-remote-playback-pipeline/media/controls/video-overlay-cast-dark-rendering.html [ Failure ] crbug.com/591099 virtual/new-remote-playback-pipeline/media/controls/video-overlay-cast-light-rendering.html [ Failure ] -crbug.com/591099 virtual/new-remote-playback-pipeline/media/controls/video-overlay-play-button.html [ Crash ] -crbug.com/591099 virtual/new-remote-playback-pipeline/media/remoteplayback/availability-callback-gc.html [ Crash ] -crbug.com/591099 virtual/new-remote-playback-pipeline/media/remoteplayback/prompt-twice-throws.html [ Crash ] -crbug.com/591099 virtual/new-remote-playback-pipeline/media/remoteplayback/watch-availability-throws-low-end-device.html [ Crash ] -crbug.com/591099 virtual/off-main-thread-fetch/external/wpt/service-workers/service-worker/ServiceWorkerGlobalScope/extendable-message-event.https.html [ Crash Timeout ] +crbug.com/591099 virtual/new-remote-playback-pipeline/media/controls/video-overlay-play-button.html [ Crash Pass ] +crbug.com/591099 virtual/new-remote-playback-pipeline/media/remoteplayback/availability-callback-gc.html [ Crash Pass ] +crbug.com/591099 virtual/new-remote-playback-pipeline/media/remoteplayback/prompt-twice-throws.html [ Crash Pass ] +crbug.com/591099 virtual/new-remote-playback-pipeline/media/remoteplayback/watch-availability-throws-low-end-device.html [ Crash Pass ] +crbug.com/591099 virtual/off-main-thread-fetch/external/wpt/service-workers/service-worker/ServiceWorkerGlobalScope/extendable-message-event.https.html [ Crash Pass Timeout ] crbug.com/591099 virtual/off-main-thread-fetch/external/wpt/service-workers/service-worker/ServiceWorkerGlobalScope/registration-attribute.https.html [ Failure Pass ] -crbug.com/591099 virtual/off-main-thread-fetch/external/wpt/service-workers/service-worker/ServiceWorkerGlobalScope/unregister.https.html [ Crash ] -crbug.com/591099 virtual/off-main-thread-fetch/external/wpt/service-workers/service-worker/ServiceWorkerGlobalScope/update.https.html [ Crash ] -crbug.com/591099 virtual/off-main-thread-fetch/external/wpt/service-workers/service-worker/activation.https.html [ Crash ] +crbug.com/591099 virtual/off-main-thread-fetch/external/wpt/service-workers/service-worker/ServiceWorkerGlobalScope/unregister.https.html [ Crash Pass ] +crbug.com/591099 virtual/off-main-thread-fetch/external/wpt/service-workers/service-worker/ServiceWorkerGlobalScope/update.https.html [ Crash Pass ] +crbug.com/591099 virtual/off-main-thread-fetch/external/wpt/service-workers/service-worker/activation.https.html [ Crash Pass ] crbug.com/591099 virtual/off-main-thread-fetch/external/wpt/service-workers/service-worker/claim-fetch.https.html [ Crash Pass ] -crbug.com/591099 virtual/off-main-thread-fetch/external/wpt/service-workers/service-worker/claim-not-using-registration.https.html [ Crash ] -crbug.com/591099 virtual/off-main-thread-fetch/external/wpt/service-workers/service-worker/client-id.https.html [ Crash ] -crbug.com/591099 virtual/off-main-thread-fetch/external/wpt/service-workers/service-worker/clients-get-cross-origin.https.html [ Crash ] -crbug.com/591099 virtual/off-main-thread-fetch/external/wpt/service-workers/service-worker/clients-get.https.html [ Crash ] -crbug.com/591099 virtual/off-main-thread-fetch/external/wpt/service-workers/service-worker/clients-matchall-exact-controller.https.html [ Crash ] -crbug.com/591099 virtual/off-main-thread-fetch/external/wpt/service-workers/service-worker/clients-matchall-include-uncontrolled.https.html [ Crash ] -crbug.com/591099 virtual/off-main-thread-fetch/external/wpt/service-workers/service-worker/clients-matchall-order.https.html [ Crash ] -crbug.com/591099 virtual/off-main-thread-fetch/external/wpt/service-workers/service-worker/clients-matchall.https.html [ Crash ] -crbug.com/591099 virtual/off-main-thread-fetch/external/wpt/service-workers/service-worker/extendable-event-async-waituntil.https.html [ Crash ] -crbug.com/591099 virtual/off-main-thread-fetch/external/wpt/service-workers/service-worker/fetch-canvas-tainting-cache.https.html [ Crash ] -crbug.com/591099 virtual/off-main-thread-fetch/external/wpt/service-workers/service-worker/fetch-canvas-tainting.https.html [ Crash ] -crbug.com/591099 virtual/off-main-thread-fetch/external/wpt/service-workers/service-worker/fetch-cors-xhr.https.html [ Crash ] -crbug.com/591099 virtual/off-main-thread-fetch/external/wpt/service-workers/service-worker/fetch-event.https.html [ Crash ] -crbug.com/591099 virtual/off-main-thread-fetch/external/wpt/service-workers/service-worker/fetch-frame-resource.https.html [ Crash ] -crbug.com/591099 virtual/off-main-thread-fetch/external/wpt/service-workers/service-worker/fetch-mixed-content-to-inscope.https.html [ Crash ] -crbug.com/591099 virtual/off-main-thread-fetch/external/wpt/service-workers/service-worker/fetch-mixed-content-to-outscope.https.html [ Crash ] -crbug.com/591099 virtual/off-main-thread-fetch/external/wpt/service-workers/service-worker/fetch-request-css-images.https.html [ Crash ] +crbug.com/591099 virtual/off-main-thread-fetch/external/wpt/service-workers/service-worker/claim-not-using-registration.https.html [ Crash Pass ] +crbug.com/591099 virtual/off-main-thread-fetch/external/wpt/service-workers/service-worker/client-id.https.html [ Crash Pass ] +crbug.com/591099 virtual/off-main-thread-fetch/external/wpt/service-workers/service-worker/clients-get-cross-origin.https.html [ Crash Pass ] +crbug.com/591099 virtual/off-main-thread-fetch/external/wpt/service-workers/service-worker/clients-get.https.html [ Crash Pass ] +crbug.com/591099 virtual/off-main-thread-fetch/external/wpt/service-workers/service-worker/clients-matchall-exact-controller.https.html [ Crash Pass ] +crbug.com/591099 virtual/off-main-thread-fetch/external/wpt/service-workers/service-worker/clients-matchall-include-uncontrolled.https.html [ Crash Pass ] +crbug.com/591099 virtual/off-main-thread-fetch/external/wpt/service-workers/service-worker/clients-matchall-order.https.html [ Crash Pass ] +crbug.com/591099 virtual/off-main-thread-fetch/external/wpt/service-workers/service-worker/clients-matchall.https.html [ Crash Pass ] +crbug.com/591099 virtual/off-main-thread-fetch/external/wpt/service-workers/service-worker/extendable-event-async-waituntil.https.html [ Crash Pass ] +crbug.com/591099 virtual/off-main-thread-fetch/external/wpt/service-workers/service-worker/fetch-canvas-tainting-cache.https.html [ Crash Pass ] +crbug.com/591099 virtual/off-main-thread-fetch/external/wpt/service-workers/service-worker/fetch-canvas-tainting.https.html [ Crash Pass ] +crbug.com/591099 virtual/off-main-thread-fetch/external/wpt/service-workers/service-worker/fetch-cors-xhr.https.html [ Crash Pass ] +crbug.com/591099 virtual/off-main-thread-fetch/external/wpt/service-workers/service-worker/fetch-event.https.html [ Crash Pass ] +crbug.com/591099 virtual/off-main-thread-fetch/external/wpt/service-workers/service-worker/fetch-frame-resource.https.html [ Crash Timeout ] +crbug.com/591099 virtual/off-main-thread-fetch/external/wpt/service-workers/service-worker/fetch-mixed-content-to-inscope.https.html [ Crash Pass ] +crbug.com/591099 virtual/off-main-thread-fetch/external/wpt/service-workers/service-worker/fetch-mixed-content-to-outscope.https.html [ Crash Pass ] +crbug.com/591099 virtual/off-main-thread-fetch/external/wpt/service-workers/service-worker/fetch-request-css-images.https.html [ Crash Pass ] crbug.com/591099 virtual/off-main-thread-fetch/external/wpt/service-workers/service-worker/fetch-request-fallback.https.html [ Crash Pass ] -crbug.com/591099 virtual/off-main-thread-fetch/external/wpt/service-workers/service-worker/fetch-request-redirect.https.html [ Crash ] -crbug.com/591099 virtual/off-main-thread-fetch/external/wpt/service-workers/service-worker/fetch-response-taint.https.html [ Crash ] -crbug.com/591099 virtual/off-main-thread-fetch/external/wpt/service-workers/service-worker/foreign-fetch-basics.https.html [ Crash ] -crbug.com/591099 virtual/off-main-thread-fetch/external/wpt/service-workers/service-worker/foreign-fetch-cors.https.html [ Crash ] -crbug.com/591099 virtual/off-main-thread-fetch/external/wpt/service-workers/service-worker/foreign-fetch-workers.https.html [ Crash ] -crbug.com/591099 virtual/off-main-thread-fetch/external/wpt/service-workers/service-worker/iframe-sandbox-register-link-element.https.html [ Crash ] -crbug.com/591099 virtual/off-main-thread-fetch/external/wpt/service-workers/service-worker/multi-globals/url-parsing.https.html [ Crash ] -crbug.com/591099 virtual/off-main-thread-fetch/external/wpt/service-workers/service-worker/navigation-preload/redirect.https.html [ Crash ] -crbug.com/591099 virtual/off-main-thread-fetch/external/wpt/service-workers/service-worker/navigation-preload/resource-timing.https.html [ Crash ] -crbug.com/591099 virtual/off-main-thread-fetch/external/wpt/service-workers/service-worker/navigation-redirect-to-http.https.html [ Crash ] -crbug.com/591099 virtual/off-main-thread-fetch/external/wpt/service-workers/service-worker/navigation-redirect.https.html [ Crash ] -crbug.com/591099 virtual/off-main-thread-fetch/external/wpt/service-workers/service-worker/ready.https.html [ Crash ] -crbug.com/591099 virtual/off-main-thread-fetch/external/wpt/service-workers/service-worker/register-closed-window.https.html [ Crash ] -crbug.com/591099 virtual/off-main-thread-fetch/external/wpt/service-workers/service-worker/register-link-header.https.html [ Crash ] -crbug.com/591099 virtual/off-main-thread-fetch/external/wpt/service-workers/service-worker/register-same-scope-different-script-url.https.html [ Crash ] -crbug.com/591099 virtual/off-main-thread-fetch/external/wpt/service-workers/service-worker/registration-iframe.https.html [ Crash ] -crbug.com/591099 virtual/off-main-thread-fetch/external/wpt/service-workers/service-worker/unregister-controller.https.html [ Crash ] -crbug.com/591099 virtual/off-main-thread-fetch/external/wpt/service-workers/service-worker/unregister-then-register-new-script.https.html [ Crash ] -crbug.com/591099 virtual/off-main-thread-fetch/external/wpt/service-workers/service-worker/unregister-then-register.https.html [ Crash ] -crbug.com/591099 virtual/off-main-thread-fetch/external/wpt/service-workers/service-worker/windowclient-navigate.https.html [ Crash ] -crbug.com/591099 virtual/off-main-thread-fetch/http/tests/fetch/chromium/discarded-window.html [ Crash ] +crbug.com/591099 virtual/off-main-thread-fetch/external/wpt/service-workers/service-worker/fetch-request-redirect.https.html [ Crash Pass ] +crbug.com/591099 virtual/off-main-thread-fetch/external/wpt/service-workers/service-worker/fetch-response-taint.https.html [ Crash Timeout ] +crbug.com/591099 virtual/off-main-thread-fetch/external/wpt/service-workers/service-worker/foreign-fetch-basics.https.html [ Crash Pass ] +crbug.com/591099 virtual/off-main-thread-fetch/external/wpt/service-workers/service-worker/foreign-fetch-cors.https.html [ Crash Pass ] +crbug.com/591099 virtual/off-main-thread-fetch/external/wpt/service-workers/service-worker/foreign-fetch-workers.https.html [ Crash Pass ] +crbug.com/591099 virtual/off-main-thread-fetch/external/wpt/service-workers/service-worker/iframe-sandbox-register-link-element.https.html [ Crash Pass ] +crbug.com/591099 virtual/off-main-thread-fetch/external/wpt/service-workers/service-worker/multi-globals/url-parsing.https.html [ Crash Pass ] +crbug.com/591099 virtual/off-main-thread-fetch/external/wpt/service-workers/service-worker/navigation-preload/redirect.https.html [ Crash Pass ] +crbug.com/591099 virtual/off-main-thread-fetch/external/wpt/service-workers/service-worker/navigation-preload/resource-timing.https.html [ Crash Pass ] +crbug.com/591099 virtual/off-main-thread-fetch/external/wpt/service-workers/service-worker/navigation-redirect-to-http.https.html [ Crash Pass ] +crbug.com/591099 virtual/off-main-thread-fetch/external/wpt/service-workers/service-worker/navigation-redirect.https.html [ Crash Pass ] +crbug.com/591099 virtual/off-main-thread-fetch/external/wpt/service-workers/service-worker/ready.https.html [ Crash Pass ] +crbug.com/591099 virtual/off-main-thread-fetch/external/wpt/service-workers/service-worker/register-closed-window.https.html [ Crash Pass ] +crbug.com/591099 virtual/off-main-thread-fetch/external/wpt/service-workers/service-worker/register-link-header.https.html [ Crash Pass ] +crbug.com/591099 virtual/off-main-thread-fetch/external/wpt/service-workers/service-worker/register-same-scope-different-script-url.https.html [ Crash Pass ] +crbug.com/591099 virtual/off-main-thread-fetch/external/wpt/service-workers/service-worker/registration-iframe.https.html [ Crash Pass ] +crbug.com/591099 virtual/off-main-thread-fetch/external/wpt/service-workers/service-worker/unregister-controller.https.html [ Crash Pass ] +crbug.com/591099 virtual/off-main-thread-fetch/external/wpt/service-workers/service-worker/unregister-then-register-new-script.https.html [ Crash Pass ] +crbug.com/591099 virtual/off-main-thread-fetch/external/wpt/service-workers/service-worker/unregister-then-register.https.html [ Crash Pass ] +crbug.com/591099 virtual/off-main-thread-fetch/external/wpt/service-workers/service-worker/windowclient-navigate.https.html [ Crash Pass ] +crbug.com/591099 virtual/off-main-thread-fetch/http/tests/fetch/chromium/discarded-window.html [ Crash Pass ] crbug.com/591099 virtual/off-main-thread-fetch/http/tests/inspector/service-workers/lazy-addeventlisteners.html [ Failure ] crbug.com/591099 virtual/off-main-thread-fetch/http/tests/inspector/service-workers/service-worker-agents.html [ Failure ] crbug.com/591099 virtual/off-main-thread-fetch/http/tests/inspector/service-workers/service-worker-manager.html [ Failure ] @@ -21124,14 +21136,14 @@ crbug.com/591099 virtual/off-main-thread-fetch/http/tests/inspector/service-workers/service-workers-bypass-for-network-redirect.html [ Failure ] crbug.com/591099 virtual/off-main-thread-fetch/http/tests/inspector/service-workers/service-workers-force-update-on-page-load.html [ Failure ] crbug.com/591099 virtual/off-main-thread-fetch/http/tests/inspector/service-workers/service-workers-navigation-preload.html [ Failure ] -crbug.com/591099 virtual/off-main-thread-fetch/http/tests/inspector/service-workers/service-workers-redundant.html [ Crash ] -crbug.com/591099 virtual/off-main-thread-fetch/http/tests/inspector/service-workers/service-workers-view.html [ Crash ] +crbug.com/591099 virtual/off-main-thread-fetch/http/tests/inspector/service-workers/service-workers-redundant.html [ Crash Failure ] +crbug.com/591099 virtual/off-main-thread-fetch/http/tests/inspector/service-workers/service-workers-view.html [ Crash Failure ] crbug.com/591099 virtual/off-main-thread-fetch/http/tests/misc/BOM-override-script.html [ Failure ] -crbug.com/591099 virtual/off-main-thread-fetch/http/tests/misc/DOMContentLoaded-event.html [ Crash ] -crbug.com/591099 virtual/off-main-thread-fetch/http/tests/misc/acid2-pixel.html [ Crash ] -crbug.com/591099 virtual/off-main-thread-fetch/http/tests/misc/acid2.html [ Crash ] +crbug.com/591099 virtual/off-main-thread-fetch/http/tests/misc/DOMContentLoaded-event.html [ Crash Failure ] +crbug.com/591099 virtual/off-main-thread-fetch/http/tests/misc/acid2-pixel.html [ Crash Failure ] +crbug.com/591099 virtual/off-main-thread-fetch/http/tests/misc/acid2.html [ Crash Failure ] crbug.com/591099 virtual/off-main-thread-fetch/http/tests/misc/acid3.html [ Failure ] -crbug.com/591099 virtual/off-main-thread-fetch/http/tests/misc/adopt-iframe-src-attr-after-remove.html [ Crash ] +crbug.com/591099 virtual/off-main-thread-fetch/http/tests/misc/adopt-iframe-src-attr-after-remove.html [ Crash Pass ] crbug.com/591099 virtual/off-main-thread-fetch/http/tests/misc/async-script-removed.html [ Failure ] crbug.com/591099 virtual/off-main-thread-fetch/http/tests/misc/async-script.html [ Crash Failure ] crbug.com/591099 virtual/off-main-thread-fetch/http/tests/misc/bad-charset-alias.html [ Failure ] @@ -21146,26 +21158,26 @@ crbug.com/591099 virtual/off-main-thread-fetch/http/tests/misc/char-encoding-in-hidden-charset-field-with-one-field.html [ Failure ] crbug.com/591099 virtual/off-main-thread-fetch/http/tests/misc/char-encoding-in-text-charset-field-with-value.html [ Crash Failure ] crbug.com/591099 virtual/off-main-thread-fetch/http/tests/misc/char-encoding-without-charset-field.html [ Failure ] -crbug.com/591099 virtual/off-main-thread-fetch/http/tests/misc/client-hint-accept-on-subresource.html [ Crash ] -crbug.com/591099 virtual/off-main-thread-fetch/http/tests/misc/client-hints-accept-iframe.html [ Crash ] -crbug.com/591099 virtual/off-main-thread-fetch/http/tests/misc/client-hints-accept-meta.html [ Crash ] -crbug.com/591099 virtual/off-main-thread-fetch/http/tests/misc/client-hints-accept-parent.php [ Crash ] -crbug.com/591099 virtual/off-main-thread-fetch/http/tests/misc/client-hints-accept.php [ Crash ] -crbug.com/591099 virtual/off-main-thread-fetch/http/tests/misc/client-hints-dynamic-rw-sizes.html [ Crash ] -crbug.com/591099 virtual/off-main-thread-fetch/http/tests/misc/client-hints-invalid-accept.php [ Crash ] -crbug.com/591099 virtual/off-main-thread-fetch/http/tests/misc/client-hints-no-accept.html [ Crash ] -crbug.com/591099 virtual/off-main-thread-fetch/http/tests/misc/client-hints-picture-source-removal.html [ Crash ] -crbug.com/591099 virtual/off-main-thread-fetch/http/tests/misc/client-hints-picture.html [ Crash ] -crbug.com/591099 virtual/off-main-thread-fetch/http/tests/misc/client-hints-preload-rw-sizes.html [ Crash ] +crbug.com/591099 virtual/off-main-thread-fetch/http/tests/misc/client-hint-accept-on-subresource.html [ Crash Pass ] +crbug.com/591099 virtual/off-main-thread-fetch/http/tests/misc/client-hints-accept-iframe.html [ Crash Pass ] +crbug.com/591099 virtual/off-main-thread-fetch/http/tests/misc/client-hints-accept-meta.html [ Crash Pass ] +crbug.com/591099 virtual/off-main-thread-fetch/http/tests/misc/client-hints-accept-parent.php [ Crash Pass ] +crbug.com/591099 virtual/off-main-thread-fetch/http/tests/misc/client-hints-accept.php [ Crash Pass ] +crbug.com/591099 virtual/off-main-thread-fetch/http/tests/misc/client-hints-dynamic-rw-sizes.html [ Crash Pass ] +crbug.com/591099 virtual/off-main-thread-fetch/http/tests/misc/client-hints-invalid-accept.php [ Crash Pass ] +crbug.com/591099 virtual/off-main-thread-fetch/http/tests/misc/client-hints-no-accept.html [ Crash Pass ] +crbug.com/591099 virtual/off-main-thread-fetch/http/tests/misc/client-hints-picture-source-removal.html [ Crash Pass ] +crbug.com/591099 virtual/off-main-thread-fetch/http/tests/misc/client-hints-picture.html [ Crash Pass ] +crbug.com/591099 virtual/off-main-thread-fetch/http/tests/misc/client-hints-preload-rw-sizes.html [ Crash Pass ] crbug.com/591099 virtual/off-main-thread-fetch/http/tests/misc/copy-resolves-urls.html [ Crash Failure ] crbug.com/591099 virtual/off-main-thread-fetch/http/tests/misc/crash-multiple-family-fontface.html [ Failure ] crbug.com/591099 virtual/off-main-thread-fetch/http/tests/misc/css-reject-any-type-in-strict-mode.html [ Failure ] -crbug.com/591099 virtual/off-main-thread-fetch/http/tests/misc/delete-frame-during-readystatechange-with-gc-after-video-removal.html [ Crash ] -crbug.com/591099 virtual/off-main-thread-fetch/http/tests/misc/delete-frame-during-readystatechange.html [ Crash ] -crbug.com/591099 virtual/off-main-thread-fetch/http/tests/misc/detach-during-notifyDone.html [ Crash ] +crbug.com/591099 virtual/off-main-thread-fetch/http/tests/misc/delete-frame-during-readystatechange-with-gc-after-video-removal.html [ Crash Pass ] +crbug.com/591099 virtual/off-main-thread-fetch/http/tests/misc/delete-frame-during-readystatechange.html [ Crash Pass ] +crbug.com/591099 virtual/off-main-thread-fetch/http/tests/misc/detach-during-notifyDone.html [ Crash Pass ] crbug.com/591099 virtual/off-main-thread-fetch/http/tests/misc/dns-prefetch-control.html [ Failure ] crbug.com/591099 virtual/off-main-thread-fetch/http/tests/misc/drag-over-iframe-invalid-source-crash.html [ Crash Failure ] -crbug.com/591099 virtual/off-main-thread-fetch/http/tests/misc/embed-image-load-outlives-gc-without-crashing.html [ Crash ] +crbug.com/591099 virtual/off-main-thread-fetch/http/tests/misc/embed-image-load-outlives-gc-without-crashing.html [ Crash Pass ] crbug.com/591099 virtual/off-main-thread-fetch/http/tests/misc/empty-cookie.html [ Crash Failure ] crbug.com/591099 virtual/off-main-thread-fetch/http/tests/misc/empty-file-formdata.html [ Crash Failure ] crbug.com/591099 virtual/off-main-thread-fetch/http/tests/misc/empty-urls.html [ Crash Failure ] @@ -21176,17 +21188,17 @@ crbug.com/591099 virtual/off-main-thread-fetch/http/tests/misc/extract-http-content-language.php [ Failure ] crbug.com/591099 virtual/off-main-thread-fetch/http/tests/misc/favicon-as-image.html [ Crash Failure ] crbug.com/591099 virtual/off-main-thread-fetch/http/tests/misc/font-face-in-multiple-segmented-faces.html [ Crash Failure ] -crbug.com/591099 virtual/off-main-thread-fetch/http/tests/misc/form-action-using-replaceChild.html [ Crash ] +crbug.com/591099 virtual/off-main-thread-fetch/http/tests/misc/form-action-using-replaceChild.html [ Crash Pass ] crbug.com/591099 virtual/off-main-thread-fetch/http/tests/misc/form-post-textplain.html [ Failure ] crbug.com/591099 virtual/off-main-thread-fetch/http/tests/misc/frame-access-during-load.html [ Failure ] crbug.com/591099 virtual/off-main-thread-fetch/http/tests/misc/generated-content-inside-table.html [ Failure ] crbug.com/591099 virtual/off-main-thread-fetch/http/tests/misc/gmail-assert-on-load.html [ Failure ] crbug.com/591099 virtual/off-main-thread-fetch/http/tests/misc/iframe-reparenting-id-collision.html [ Failure ] -crbug.com/591099 virtual/off-main-thread-fetch/http/tests/misc/iframe404.html [ Crash ] +crbug.com/591099 virtual/off-main-thread-fetch/http/tests/misc/iframe404.html [ Crash Failure ] crbug.com/591099 virtual/off-main-thread-fetch/http/tests/misc/image-blocked-src-change.html [ Failure ] crbug.com/591099 virtual/off-main-thread-fetch/http/tests/misc/image-blocked-src-no-change.html [ Crash Failure ] -crbug.com/591099 virtual/off-main-thread-fetch/http/tests/misc/image-input-type-outlives-gc-without-crashing.html [ Crash ] -crbug.com/591099 virtual/off-main-thread-fetch/http/tests/misc/image-load-outlives-gc-without-crashing.html [ Crash ] +crbug.com/591099 virtual/off-main-thread-fetch/http/tests/misc/image-input-type-outlives-gc-without-crashing.html [ Crash Pass ] +crbug.com/591099 virtual/off-main-thread-fetch/http/tests/misc/image-load-outlives-gc-without-crashing.html [ Crash Pass ] crbug.com/591099 virtual/off-main-thread-fetch/http/tests/misc/image-onerror-no-load-event.html [ Failure ] crbug.com/591099 virtual/off-main-thread-fetch/http/tests/misc/javascript-url-stop-loaders.html [ Failure ] crbug.com/591099 virtual/off-main-thread-fetch/http/tests/misc/link-rel-prefetch.html [ Crash Failure ] @@ -21195,14 +21207,14 @@ crbug.com/591099 virtual/off-main-thread-fetch/http/tests/misc/object-embedding-svg-delayed-size-negotiation.xhtml [ Failure ] crbug.com/591099 virtual/off-main-thread-fetch/http/tests/misc/object-image-error-with-onload.html [ Crash Failure ] crbug.com/591099 virtual/off-main-thread-fetch/http/tests/misc/object-image-error.html [ Crash Failure ] -crbug.com/591099 virtual/off-main-thread-fetch/http/tests/misc/object-image-load-outlives-gc-without-crashing.html [ Crash ] -crbug.com/591099 virtual/off-main-thread-fetch/http/tests/misc/onload-remove-iframe-crash-2.html [ Crash ] +crbug.com/591099 virtual/off-main-thread-fetch/http/tests/misc/object-image-load-outlives-gc-without-crashing.html [ Crash Pass ] +crbug.com/591099 virtual/off-main-thread-fetch/http/tests/misc/onload-remove-iframe-crash-2.html [ Crash Pass ] crbug.com/591099 virtual/off-main-thread-fetch/http/tests/misc/percent-sign-in-form-field-name.html [ Crash Failure ] -crbug.com/591099 virtual/off-main-thread-fetch/http/tests/misc/plugin-array-detach.html [ Crash ] +crbug.com/591099 virtual/off-main-thread-fetch/http/tests/misc/plugin-array-detach.html [ Crash Pass ] crbug.com/591099 virtual/off-main-thread-fetch/http/tests/misc/refresh-headers.php [ Failure ] crbug.com/591099 virtual/off-main-thread-fetch/http/tests/misc/resource-timing-iframe-restored-from-history.html [ Failure ] -crbug.com/591099 virtual/off-main-thread-fetch/http/tests/misc/resource-timing-sizes-multipart.html [ Crash ] -crbug.com/591099 virtual/off-main-thread-fetch/http/tests/misc/resource-timing-sizes-tags.html [ Crash ] +crbug.com/591099 virtual/off-main-thread-fetch/http/tests/misc/resource-timing-sizes-multipart.html [ Crash Pass ] +crbug.com/591099 virtual/off-main-thread-fetch/http/tests/misc/resource-timing-sizes-tags.html [ Crash Pass ] crbug.com/591099 virtual/off-main-thread-fetch/http/tests/misc/script-after-slow-stylesheet-removed.html [ Failure ] crbug.com/591099 virtual/off-main-thread-fetch/http/tests/misc/script-defer-after-slow-stylesheet.html [ Failure ] crbug.com/591099 virtual/off-main-thread-fetch/http/tests/misc/script-sync-slow-scripts-onerror.html [ Failure ] @@ -21217,10 +21229,10 @@ crbug.com/591099 virtual/off-main-thread-fetch/http/tests/misc/submit-post-in-utf16le.html [ Crash Failure ] crbug.com/591099 virtual/off-main-thread-fetch/http/tests/misc/submit-post-in-utf32be.html [ Crash Failure ] crbug.com/591099 virtual/off-main-thread-fetch/http/tests/misc/submit-post-in-utf32le.html [ Crash Failure ] -crbug.com/591099 virtual/off-main-thread-fetch/http/tests/misc/svg-image-load-outlives-gc-without-crashing.html [ Crash ] +crbug.com/591099 virtual/off-main-thread-fetch/http/tests/misc/svg-image-load-outlives-gc-without-crashing.html [ Crash Pass ] crbug.com/591099 virtual/off-main-thread-fetch/http/tests/misc/uncacheable-script-repeated.html [ Crash Failure ] crbug.com/591099 virtual/off-main-thread-fetch/http/tests/misc/unloadable-script.html [ Failure ] -crbug.com/591099 virtual/off-main-thread-fetch/http/tests/misc/video-poster-image-load-outlives-gc-without-crashing.html [ Crash ] +crbug.com/591099 virtual/off-main-thread-fetch/http/tests/misc/video-poster-image-load-outlives-gc-without-crashing.html [ Crash Pass ] crbug.com/591099 virtual/off-main-thread-fetch/http/tests/misc/webtiming-buffer-full-no-event.html [ Failure ] crbug.com/591099 virtual/off-main-thread-fetch/http/tests/misc/webtiming-cross-origin-and-back.html [ Crash Failure ] crbug.com/591099 virtual/off-main-thread-fetch/http/tests/misc/webtiming-cross-origin-redirect.php [ Failure ] @@ -21229,12 +21241,12 @@ crbug.com/591099 virtual/off-main-thread-fetch/http/tests/misc/webtiming-resolution.html [ Failure ] crbug.com/591099 virtual/off-main-thread-fetch/http/tests/misc/webtiming-slow-load.php [ Failure ] crbug.com/591099 virtual/off-main-thread-fetch/http/tests/misc/webtiming-two-redirects.php [ Failure ] -crbug.com/591099 virtual/off-main-thread-fetch/http/tests/misc/xslt-bad-import.html [ Crash ] -crbug.com/591099 virtual/off-main-thread-fetch/http/tests/security/cookies/third-party-cookie-blocking-worker.html [ Crash ] -crbug.com/591099 virtual/off-main-thread-fetch/http/tests/security/cookies/websocket/third-party-cookie-blocked-on-cross-origin-websocket.html [ Crash ] -crbug.com/591099 virtual/off-main-thread-fetch/http/tests/security/cookies/websocket/third-party-cookie-blocked-on-same-origin-websocket.html [ Crash ] +crbug.com/591099 virtual/off-main-thread-fetch/http/tests/misc/xslt-bad-import.html [ Crash Pass ] +crbug.com/591099 virtual/off-main-thread-fetch/http/tests/security/cookies/third-party-cookie-blocking-worker.html [ Crash Pass ] +crbug.com/591099 virtual/off-main-thread-fetch/http/tests/security/cookies/websocket/third-party-cookie-blocked-on-cross-origin-websocket.html [ Crash Pass ] +crbug.com/591099 virtual/off-main-thread-fetch/http/tests/security/cookies/websocket/third-party-cookie-blocked-on-same-origin-websocket.html [ Crash Pass ] crbug.com/591099 virtual/off-main-thread-fetch/http/tests/serviceworker/ServiceWorkerGlobalScope/registration-attribute.html [ Failure Pass ] -crbug.com/591099 virtual/off-main-thread-fetch/http/tests/serviceworker/chromium/frame-detached-by-navigation.html [ Crash ] +crbug.com/591099 virtual/off-main-thread-fetch/http/tests/serviceworker/chromium/frame-detached-by-navigation.html [ Crash Failure ] crbug.com/591099 virtual/off-main-thread-fetch/http/tests/serviceworker/chromium/resolve-after-window-close.html [ Crash Failure ] crbug.com/591099 virtual/off-main-thread-fetch/http/tests/serviceworker/chromium/service-worker-gc.html [ Failure ] crbug.com/591099 virtual/off-main-thread-fetch/http/tests/serviceworker/chromium/window-close-during-registration.html [ Failure ] @@ -21347,23 +21359,23 @@ crbug.com/591099 virtual/prefer_compositing_to_lcd_text/scrollbars/custom-scrollbar-changing-style-relayout-div-body-scrollablearea.html [ Crash Pass Timeout ] crbug.com/591099 virtual/prefer_compositing_to_lcd_text/scrollbars/custom-scrollbar-display.html [ Failure ] crbug.com/591099 virtual/prefer_compositing_to_lcd_text/scrollbars/custom-scrollbar-enable-changes-thickness-with-iframe.html [ Failure Pass ] -crbug.com/591099 virtual/prefer_compositing_to_lcd_text/scrollbars/custom-scrollbar-not-inherited-by-iframe.html [ Crash ] -crbug.com/591099 virtual/prefer_compositing_to_lcd_text/scrollbars/custom-scrollbar-reconstruction-document-write.html [ Crash ] +crbug.com/591099 virtual/prefer_compositing_to_lcd_text/scrollbars/custom-scrollbar-not-inherited-by-iframe.html [ Crash Pass ] +crbug.com/591099 virtual/prefer_compositing_to_lcd_text/scrollbars/custom-scrollbar-reconstruction-document-write.html [ Crash Pass ] crbug.com/591099 virtual/prefer_compositing_to_lcd_text/scrollbars/custom-scrollbar-with-incomplete-style.html [ Failure ] crbug.com/591099 virtual/prefer_compositing_to_lcd_text/scrollbars/disabled-scrollbar.html [ Failure ] crbug.com/591099 virtual/prefer_compositing_to_lcd_text/scrollbars/hidden-iframe-scrollbar-crash.html [ Crash Failure ] crbug.com/591099 virtual/prefer_compositing_to_lcd_text/scrollbars/hidden-scrollbar-prevents-layout.html [ Failure ] -crbug.com/591099 virtual/prefer_compositing_to_lcd_text/scrollbars/iframe-scrollbar-becomes-custom.html [ Crash ] +crbug.com/591099 virtual/prefer_compositing_to_lcd_text/scrollbars/iframe-scrollbar-becomes-custom.html [ Crash Pass ] crbug.com/591099 virtual/prefer_compositing_to_lcd_text/scrollbars/listbox-scrollbar-combinations.html [ Failure ] crbug.com/591099 virtual/prefer_compositing_to_lcd_text/scrollbars/overlay-scrollbars-within-overflow-scroll.html [ Failure ] crbug.com/591099 virtual/prefer_compositing_to_lcd_text/scrollbars/resize-scales-with-dpi-150.html [ Failure ] crbug.com/591099 virtual/prefer_compositing_to_lcd_text/scrollbars/rtl-resizer-position.html [ Failure ] crbug.com/591099 virtual/prefer_compositing_to_lcd_text/scrollbars/rtl/overflow-scroll-rtl.html [ Failure ] -crbug.com/591099 virtual/prefer_compositing_to_lcd_text/scrollbars/scrollable-iframe-click-gets-focus.html [ Crash ] -crbug.com/591099 virtual/prefer_compositing_to_lcd_text/scrollbars/scrollable-iframe-remove-crash.html [ Crash ] -crbug.com/591099 virtual/prefer_compositing_to_lcd_text/scrollbars/scrollbar-added-during-drag.html [ Crash ] +crbug.com/591099 virtual/prefer_compositing_to_lcd_text/scrollbars/scrollable-iframe-click-gets-focus.html [ Crash Pass ] +crbug.com/591099 virtual/prefer_compositing_to_lcd_text/scrollbars/scrollable-iframe-remove-crash.html [ Crash Pass ] +crbug.com/591099 virtual/prefer_compositing_to_lcd_text/scrollbars/scrollbar-added-during-drag.html [ Crash Pass ] crbug.com/591099 virtual/prefer_compositing_to_lcd_text/scrollbars/scrollbar-buttons.html [ Failure ] -crbug.com/591099 virtual/prefer_compositing_to_lcd_text/scrollbars/scrollbar-click-does-not-blur-content.html [ Crash ] +crbug.com/591099 virtual/prefer_compositing_to_lcd_text/scrollbars/scrollbar-click-does-not-blur-content.html [ Crash Failure ] crbug.com/591099 virtual/prefer_compositing_to_lcd_text/scrollbars/scrollbar-content-crash.html [ Failure ] crbug.com/591099 virtual/prefer_compositing_to_lcd_text/scrollbars/scrollbar-crash-on-refresh.html [ Failure ] crbug.com/591099 virtual/prefer_compositing_to_lcd_text/scrollbars/scrollbar-miss-mousemove-disabled.html [ Failure ] @@ -21375,11 +21387,11 @@ crbug.com/591099 virtual/prefer_compositing_to_lcd_text/scrollbars/scrollbar-visibility-hidden.html [ Failure ] crbug.com/591099 virtual/prefer_compositing_to_lcd_text/scrollbars/scrollbars-on-positioned-content.html [ Failure ] crbug.com/591099 virtual/prefer_compositing_to_lcd_text/scrollbars/viewport-scrollbar-corner-with-percent-padding-crash.html [ Failure ] -crbug.com/591099 virtual/rootlayerscrolls/fast/history/scroll-restoration/scroll-restoration-fragment-navigation-crossdoc.html [ Crash ] -crbug.com/591099 virtual/rootlayerscrolls/fast/history/scroll-restoration/scroll-restoration-navigation.html [ Crash ] +crbug.com/591099 virtual/rootlayerscrolls/fast/history/scroll-restoration/scroll-restoration-fragment-navigation-crossdoc.html [ Crash Pass ] +crbug.com/591099 virtual/rootlayerscrolls/fast/history/scroll-restoration/scroll-restoration-navigation.html [ Crash Pass ] crbug.com/591099 virtual/rootlayerscrolls/fast/rootscroller/set-root-scroller.html [ Failure ] crbug.com/591099 virtual/rootlayerscrolls/fast/scrolling/abspos-relayout-overflow-style-change.html [ Failure ] -crbug.com/591099 virtual/rootlayerscrolls/fast/scrolling/content-box-smaller-than-scrollbar.html [ Crash ] +crbug.com/591099 virtual/rootlayerscrolls/fast/scrolling/content-box-smaller-than-scrollbar.html [ Crash Failure ] crbug.com/591099 virtual/rootlayerscrolls/fast/scrolling/custom-scrollbar-style-applied.html [ Failure ] crbug.com/591099 virtual/rootlayerscrolls/fast/scrolling/editor-command-scroll-page-scale.html [ Failure ] crbug.com/591099 virtual/rootlayerscrolls/fast/scrolling/fractional-scroll-height-chaining.html [ Failure ] @@ -21393,7 +21405,7 @@ crbug.com/591099 virtual/rootlayerscrolls/fast/scrolling/scroll-clears-fragment-anchor.html [ Failure ] crbug.com/591099 virtual/rootlayerscrolls/fast/scrolling/scroll-element-into-view.html [ Failure ] crbug.com/591099 virtual/rootlayerscrolls/fast/scrolling/scroll-into-view-collapsed-div.html [ Failure ] -crbug.com/591099 virtual/rootlayerscrolls/fast/scrolling/scroll-into-view-small-size-ancestor.html [ Crash ] +crbug.com/591099 virtual/rootlayerscrolls/fast/scrolling/scroll-into-view-small-size-ancestor.html [ Crash Pass ] crbug.com/591099 virtual/rootlayerscrolls/fast/scrolling/scroll-max-value.html [ Crash Failure ] crbug.com/591099 virtual/rootlayerscrolls/fast/scrolling/scrollable-area-frame-overflow-hidden.html [ Crash Failure ] crbug.com/591099 virtual/rootlayerscrolls/fast/scrolling/scrollbar-mousedown-mouseup.html [ Failure ] @@ -21411,23 +21423,23 @@ crbug.com/591099 virtual/rootlayerscrolls/scrollbars/custom-scrollbar-changing-style-relayout-div-body-scrollablearea.html [ Crash Pass Timeout ] crbug.com/591099 virtual/rootlayerscrolls/scrollbars/custom-scrollbar-display.html [ Failure ] crbug.com/591099 virtual/rootlayerscrolls/scrollbars/custom-scrollbar-enable-changes-thickness-with-iframe.html [ Failure Pass ] -crbug.com/591099 virtual/rootlayerscrolls/scrollbars/custom-scrollbar-not-inherited-by-iframe.html [ Crash ] -crbug.com/591099 virtual/rootlayerscrolls/scrollbars/custom-scrollbar-reconstruction-document-write.html [ Crash ] +crbug.com/591099 virtual/rootlayerscrolls/scrollbars/custom-scrollbar-not-inherited-by-iframe.html [ Crash Pass ] +crbug.com/591099 virtual/rootlayerscrolls/scrollbars/custom-scrollbar-reconstruction-document-write.html [ Crash Pass ] crbug.com/591099 virtual/rootlayerscrolls/scrollbars/custom-scrollbar-with-incomplete-style.html [ Failure ] crbug.com/591099 virtual/rootlayerscrolls/scrollbars/disabled-scrollbar.html [ Failure ] crbug.com/591099 virtual/rootlayerscrolls/scrollbars/hidden-iframe-scrollbar-crash.html [ Crash Failure ] crbug.com/591099 virtual/rootlayerscrolls/scrollbars/hidden-scrollbar-prevents-layout.html [ Failure ] -crbug.com/591099 virtual/rootlayerscrolls/scrollbars/iframe-scrollbar-becomes-custom.html [ Crash ] +crbug.com/591099 virtual/rootlayerscrolls/scrollbars/iframe-scrollbar-becomes-custom.html [ Crash Pass ] crbug.com/591099 virtual/rootlayerscrolls/scrollbars/listbox-scrollbar-combinations.html [ Failure ] crbug.com/591099 virtual/rootlayerscrolls/scrollbars/overlay-scrollbars-within-overflow-scroll.html [ Failure ] crbug.com/591099 virtual/rootlayerscrolls/scrollbars/resize-scales-with-dpi-150.html [ Failure ] crbug.com/591099 virtual/rootlayerscrolls/scrollbars/rtl-resizer-position.html [ Failure ] crbug.com/591099 virtual/rootlayerscrolls/scrollbars/rtl/overflow-scroll-rtl.html [ Failure ] -crbug.com/591099 virtual/rootlayerscrolls/scrollbars/scrollable-iframe-click-gets-focus.html [ Crash ] -crbug.com/591099 virtual/rootlayerscrolls/scrollbars/scrollable-iframe-remove-crash.html [ Crash ] +crbug.com/591099 virtual/rootlayerscrolls/scrollbars/scrollable-iframe-click-gets-focus.html [ Crash Pass ] +crbug.com/591099 virtual/rootlayerscrolls/scrollbars/scrollable-iframe-remove-crash.html [ Crash Pass ] crbug.com/591099 virtual/rootlayerscrolls/scrollbars/scrollbar-added-during-drag.html [ Timeout ] crbug.com/591099 virtual/rootlayerscrolls/scrollbars/scrollbar-buttons.html [ Failure ] -crbug.com/591099 virtual/rootlayerscrolls/scrollbars/scrollbar-click-does-not-blur-content.html [ Crash ] +crbug.com/591099 virtual/rootlayerscrolls/scrollbars/scrollbar-click-does-not-blur-content.html [ Crash Failure ] crbug.com/591099 virtual/rootlayerscrolls/scrollbars/scrollbar-content-crash.html [ Failure ] crbug.com/591099 virtual/rootlayerscrolls/scrollbars/scrollbar-crash-on-refresh.html [ Failure ] crbug.com/591099 virtual/rootlayerscrolls/scrollbars/scrollbar-miss-mousemove-disabled.html [ Failure ] @@ -21439,7 +21451,7 @@ crbug.com/591099 virtual/rootlayerscrolls/scrollbars/scrollbar-visibility-hidden.html [ Failure ] crbug.com/591099 virtual/rootlayerscrolls/scrollbars/scrollbars-on-positioned-content.html [ Failure ] crbug.com/591099 virtual/rootlayerscrolls/scrollbars/viewport-scrollbar-corner-with-percent-padding-crash.html [ Failure ] -crbug.com/591099 virtual/rootlayerscrolls/scrollingcoordinator/donot-compute-non-fast-scrollable-region-for-hidden-frames.html [ Crash Timeout ] +crbug.com/591099 virtual/rootlayerscrolls/scrollingcoordinator/donot-compute-non-fast-scrollable-region-for-hidden-frames.html [ Crash Pass Timeout ] crbug.com/591099 virtual/rootlayerscrolls/scrollingcoordinator/non-fast-scrollable-region-nested.html [ Failure ] crbug.com/591099 virtual/rootlayerscrolls/scrollingcoordinator/non-fast-scrollable-region-scaled-iframe.html [ Failure ] crbug.com/591099 virtual/rootlayerscrolls/scrollingcoordinator/non-fast-scrollable-region-transformed-iframe.html [ Failure ] @@ -21473,50 +21485,50 @@ crbug.com/591099 virtual/service-worker-navigation-preload-disabled/webexposed/global-interface-listing.html [ Timeout ] crbug.com/591099 virtual/service-worker-navigation-preload-disabled/webexposed/nonstable-css-properties.html [ Failure ] crbug.com/591099 virtual/service-worker-navigation-preload-disabled/webexposed/permissions-attribute.html [ Failure ] -crbug.com/591099 virtual/service-worker-script-streaming/external/wpt/service-workers/service-worker/ServiceWorkerGlobalScope/extendable-message-event.https.html [ Crash Timeout ] -crbug.com/591099 virtual/service-worker-script-streaming/external/wpt/service-workers/service-worker/ServiceWorkerGlobalScope/unregister.https.html [ Crash ] -crbug.com/591099 virtual/service-worker-script-streaming/external/wpt/service-workers/service-worker/ServiceWorkerGlobalScope/update.https.html [ Crash ] -crbug.com/591099 virtual/service-worker-script-streaming/external/wpt/service-workers/service-worker/activation.https.html [ Crash ] -crbug.com/591099 virtual/service-worker-script-streaming/external/wpt/service-workers/service-worker/claim-fetch.https.html [ Crash ] -crbug.com/591099 virtual/service-worker-script-streaming/external/wpt/service-workers/service-worker/claim-not-using-registration.https.html [ Crash ] -crbug.com/591099 virtual/service-worker-script-streaming/external/wpt/service-workers/service-worker/claim-with-redirect.https.html [ Crash ] -crbug.com/591099 virtual/service-worker-script-streaming/external/wpt/service-workers/service-worker/client-id.https.html [ Crash ] -crbug.com/591099 virtual/service-worker-script-streaming/external/wpt/service-workers/service-worker/clients-get-cross-origin.https.html [ Crash ] -crbug.com/591099 virtual/service-worker-script-streaming/external/wpt/service-workers/service-worker/clients-get.https.html [ Crash ] -crbug.com/591099 virtual/service-worker-script-streaming/external/wpt/service-workers/service-worker/clients-matchall-exact-controller.https.html [ Crash ] -crbug.com/591099 virtual/service-worker-script-streaming/external/wpt/service-workers/service-worker/clients-matchall-include-uncontrolled.https.html [ Crash ] -crbug.com/591099 virtual/service-worker-script-streaming/external/wpt/service-workers/service-worker/clients-matchall-order.https.html [ Crash ] -crbug.com/591099 virtual/service-worker-script-streaming/external/wpt/service-workers/service-worker/clients-matchall.https.html [ Crash ] -crbug.com/591099 virtual/service-worker-script-streaming/external/wpt/service-workers/service-worker/extendable-event-async-waituntil.https.html [ Crash ] -crbug.com/591099 virtual/service-worker-script-streaming/external/wpt/service-workers/service-worker/fetch-canvas-tainting-cache.https.html [ Crash ] -crbug.com/591099 virtual/service-worker-script-streaming/external/wpt/service-workers/service-worker/fetch-canvas-tainting.https.html [ Crash ] -crbug.com/591099 virtual/service-worker-script-streaming/external/wpt/service-workers/service-worker/fetch-cors-xhr.https.html [ Crash ] -crbug.com/591099 virtual/service-worker-script-streaming/external/wpt/service-workers/service-worker/fetch-event.https.html [ Crash ] -crbug.com/591099 virtual/service-worker-script-streaming/external/wpt/service-workers/service-worker/fetch-frame-resource.https.html [ Crash ] -crbug.com/591099 virtual/service-worker-script-streaming/external/wpt/service-workers/service-worker/fetch-mixed-content-to-inscope.https.html [ Crash ] -crbug.com/591099 virtual/service-worker-script-streaming/external/wpt/service-workers/service-worker/fetch-mixed-content-to-outscope.https.html [ Crash ] -crbug.com/591099 virtual/service-worker-script-streaming/external/wpt/service-workers/service-worker/fetch-request-css-images.https.html [ Crash ] -crbug.com/591099 virtual/service-worker-script-streaming/external/wpt/service-workers/service-worker/fetch-request-redirect.https.html [ Crash ] -crbug.com/591099 virtual/service-worker-script-streaming/external/wpt/service-workers/service-worker/fetch-response-taint.https.html [ Crash ] -crbug.com/591099 virtual/service-worker-script-streaming/external/wpt/service-workers/service-worker/foreign-fetch-basics.https.html [ Crash ] -crbug.com/591099 virtual/service-worker-script-streaming/external/wpt/service-workers/service-worker/foreign-fetch-cors.https.html [ Crash ] -crbug.com/591099 virtual/service-worker-script-streaming/external/wpt/service-workers/service-worker/foreign-fetch-workers.https.html [ Crash ] -crbug.com/591099 virtual/service-worker-script-streaming/external/wpt/service-workers/service-worker/iframe-sandbox-register-link-element.https.html [ Crash ] -crbug.com/591099 virtual/service-worker-script-streaming/external/wpt/service-workers/service-worker/multi-globals/url-parsing.https.html [ Crash ] -crbug.com/591099 virtual/service-worker-script-streaming/external/wpt/service-workers/service-worker/navigation-preload/redirect.https.html [ Crash ] -crbug.com/591099 virtual/service-worker-script-streaming/external/wpt/service-workers/service-worker/navigation-preload/resource-timing.https.html [ Crash ] -crbug.com/591099 virtual/service-worker-script-streaming/external/wpt/service-workers/service-worker/navigation-redirect-to-http.https.html [ Crash ] -crbug.com/591099 virtual/service-worker-script-streaming/external/wpt/service-workers/service-worker/navigation-redirect.https.html [ Crash ] -crbug.com/591099 virtual/service-worker-script-streaming/external/wpt/service-workers/service-worker/ready.https.html [ Crash ] -crbug.com/591099 virtual/service-worker-script-streaming/external/wpt/service-workers/service-worker/register-closed-window.https.html [ Crash ] -crbug.com/591099 virtual/service-worker-script-streaming/external/wpt/service-workers/service-worker/register-link-header.https.html [ Crash ] -crbug.com/591099 virtual/service-worker-script-streaming/external/wpt/service-workers/service-worker/register-same-scope-different-script-url.https.html [ Crash ] -crbug.com/591099 virtual/service-worker-script-streaming/external/wpt/service-workers/service-worker/registration-iframe.https.html [ Crash ] -crbug.com/591099 virtual/service-worker-script-streaming/external/wpt/service-workers/service-worker/unregister-controller.https.html [ Crash ] -crbug.com/591099 virtual/service-worker-script-streaming/external/wpt/service-workers/service-worker/unregister-then-register-new-script.https.html [ Crash ] -crbug.com/591099 virtual/service-worker-script-streaming/external/wpt/service-workers/service-worker/unregister-then-register.https.html [ Crash ] -crbug.com/591099 virtual/service-worker-script-streaming/external/wpt/service-workers/service-worker/windowclient-navigate.https.html [ Crash ] -crbug.com/591099 virtual/service-worker-script-streaming/http/tests/serviceworker/chromium/frame-detached-by-navigation.html [ Crash ] +crbug.com/591099 virtual/service-worker-script-streaming/external/wpt/service-workers/service-worker/ServiceWorkerGlobalScope/extendable-message-event.https.html [ Crash Pass Timeout ] +crbug.com/591099 virtual/service-worker-script-streaming/external/wpt/service-workers/service-worker/ServiceWorkerGlobalScope/unregister.https.html [ Crash Pass ] +crbug.com/591099 virtual/service-worker-script-streaming/external/wpt/service-workers/service-worker/ServiceWorkerGlobalScope/update.https.html [ Crash Pass ] +crbug.com/591099 virtual/service-worker-script-streaming/external/wpt/service-workers/service-worker/activation.https.html [ Crash Pass ] +crbug.com/591099 virtual/service-worker-script-streaming/external/wpt/service-workers/service-worker/claim-fetch.https.html [ Crash Pass ] +crbug.com/591099 virtual/service-worker-script-streaming/external/wpt/service-workers/service-worker/claim-not-using-registration.https.html [ Crash Pass ] +crbug.com/591099 virtual/service-worker-script-streaming/external/wpt/service-workers/service-worker/claim-with-redirect.https.html [ Crash Pass ] +crbug.com/591099 virtual/service-worker-script-streaming/external/wpt/service-workers/service-worker/client-id.https.html [ Crash Pass ] +crbug.com/591099 virtual/service-worker-script-streaming/external/wpt/service-workers/service-worker/clients-get-cross-origin.https.html [ Crash Pass ] +crbug.com/591099 virtual/service-worker-script-streaming/external/wpt/service-workers/service-worker/clients-get.https.html [ Crash Pass ] +crbug.com/591099 virtual/service-worker-script-streaming/external/wpt/service-workers/service-worker/clients-matchall-exact-controller.https.html [ Crash Pass ] +crbug.com/591099 virtual/service-worker-script-streaming/external/wpt/service-workers/service-worker/clients-matchall-include-uncontrolled.https.html [ Crash Pass ] +crbug.com/591099 virtual/service-worker-script-streaming/external/wpt/service-workers/service-worker/clients-matchall-order.https.html [ Crash Pass ] +crbug.com/591099 virtual/service-worker-script-streaming/external/wpt/service-workers/service-worker/clients-matchall.https.html [ Crash Pass ] +crbug.com/591099 virtual/service-worker-script-streaming/external/wpt/service-workers/service-worker/extendable-event-async-waituntil.https.html [ Crash Pass ] +crbug.com/591099 virtual/service-worker-script-streaming/external/wpt/service-workers/service-worker/fetch-canvas-tainting-cache.https.html [ Crash Pass ] +crbug.com/591099 virtual/service-worker-script-streaming/external/wpt/service-workers/service-worker/fetch-canvas-tainting.https.html [ Crash Pass ] +crbug.com/591099 virtual/service-worker-script-streaming/external/wpt/service-workers/service-worker/fetch-cors-xhr.https.html [ Crash Pass ] +crbug.com/591099 virtual/service-worker-script-streaming/external/wpt/service-workers/service-worker/fetch-event.https.html [ Crash Pass ] +crbug.com/591099 virtual/service-worker-script-streaming/external/wpt/service-workers/service-worker/fetch-frame-resource.https.html [ Crash Timeout ] +crbug.com/591099 virtual/service-worker-script-streaming/external/wpt/service-workers/service-worker/fetch-mixed-content-to-inscope.https.html [ Crash Pass ] +crbug.com/591099 virtual/service-worker-script-streaming/external/wpt/service-workers/service-worker/fetch-mixed-content-to-outscope.https.html [ Crash Pass ] +crbug.com/591099 virtual/service-worker-script-streaming/external/wpt/service-workers/service-worker/fetch-request-css-images.https.html [ Crash Pass ] +crbug.com/591099 virtual/service-worker-script-streaming/external/wpt/service-workers/service-worker/fetch-request-redirect.https.html [ Crash Pass ] +crbug.com/591099 virtual/service-worker-script-streaming/external/wpt/service-workers/service-worker/fetch-response-taint.https.html [ Crash Timeout ] +crbug.com/591099 virtual/service-worker-script-streaming/external/wpt/service-workers/service-worker/foreign-fetch-basics.https.html [ Crash Pass ] +crbug.com/591099 virtual/service-worker-script-streaming/external/wpt/service-workers/service-worker/foreign-fetch-cors.https.html [ Crash Pass ] +crbug.com/591099 virtual/service-worker-script-streaming/external/wpt/service-workers/service-worker/foreign-fetch-workers.https.html [ Crash Pass ] +crbug.com/591099 virtual/service-worker-script-streaming/external/wpt/service-workers/service-worker/iframe-sandbox-register-link-element.https.html [ Crash Pass ] +crbug.com/591099 virtual/service-worker-script-streaming/external/wpt/service-workers/service-worker/multi-globals/url-parsing.https.html [ Crash Pass ] +crbug.com/591099 virtual/service-worker-script-streaming/external/wpt/service-workers/service-worker/navigation-preload/redirect.https.html [ Crash Pass ] +crbug.com/591099 virtual/service-worker-script-streaming/external/wpt/service-workers/service-worker/navigation-preload/resource-timing.https.html [ Crash Pass ] +crbug.com/591099 virtual/service-worker-script-streaming/external/wpt/service-workers/service-worker/navigation-redirect-to-http.https.html [ Crash Pass ] +crbug.com/591099 virtual/service-worker-script-streaming/external/wpt/service-workers/service-worker/navigation-redirect.https.html [ Crash Pass ] +crbug.com/591099 virtual/service-worker-script-streaming/external/wpt/service-workers/service-worker/ready.https.html [ Crash Pass ] +crbug.com/591099 virtual/service-worker-script-streaming/external/wpt/service-workers/service-worker/register-closed-window.https.html [ Crash Pass ] +crbug.com/591099 virtual/service-worker-script-streaming/external/wpt/service-workers/service-worker/register-link-header.https.html [ Crash Pass ] +crbug.com/591099 virtual/service-worker-script-streaming/external/wpt/service-workers/service-worker/register-same-scope-different-script-url.https.html [ Crash Pass ] +crbug.com/591099 virtual/service-worker-script-streaming/external/wpt/service-workers/service-worker/registration-iframe.https.html [ Crash Pass ] +crbug.com/591099 virtual/service-worker-script-streaming/external/wpt/service-workers/service-worker/unregister-controller.https.html [ Crash Pass ] +crbug.com/591099 virtual/service-worker-script-streaming/external/wpt/service-workers/service-worker/unregister-then-register-new-script.https.html [ Crash Pass ] +crbug.com/591099 virtual/service-worker-script-streaming/external/wpt/service-workers/service-worker/unregister-then-register.https.html [ Crash Pass ] +crbug.com/591099 virtual/service-worker-script-streaming/external/wpt/service-workers/service-worker/windowclient-navigate.https.html [ Crash Pass ] +crbug.com/591099 virtual/service-worker-script-streaming/http/tests/serviceworker/chromium/frame-detached-by-navigation.html [ Crash Failure ] crbug.com/591099 virtual/service-worker-script-streaming/http/tests/serviceworker/chromium/resolve-after-window-close.html [ Failure ] crbug.com/591099 virtual/service-worker-script-streaming/http/tests/serviceworker/chromium/service-worker-gc.html [ Failure ] crbug.com/591099 virtual/service-worker-script-streaming/http/tests/serviceworker/chromium/window-close-during-registration.html [ Failure ] @@ -21533,20 +21545,20 @@ crbug.com/591099 virtual/stable/http/tests/navigation/anchor-goback.html [ Crash Failure ] crbug.com/591099 virtual/stable/http/tests/navigation/back-to-slow-frame.html [ Failure ] crbug.com/591099 virtual/stable/http/tests/navigation/cross-origin-fragment-navigation-is-async.html [ Failure ] -crbug.com/591099 virtual/stable/http/tests/navigation/fallback-anchor-reload.html [ Crash ] +crbug.com/591099 virtual/stable/http/tests/navigation/fallback-anchor-reload.html [ Crash Pass ] crbug.com/591099 virtual/stable/http/tests/navigation/form-targets-cross-site-frame-get.html [ Crash Failure ] crbug.com/591099 virtual/stable/http/tests/navigation/form-targets-cross-site-frame-no-referrer.html [ Crash Failure ] crbug.com/591099 virtual/stable/http/tests/navigation/form-targets-cross-site-frame-post.html [ Crash Failure ] crbug.com/591099 virtual/stable/http/tests/navigation/form-with-enctype-targets-cross-site-frame.html [ Crash Failure ] crbug.com/591099 virtual/stable/http/tests/navigation/forward-to-fragment-fires-onload.html [ Crash Failure ] crbug.com/591099 virtual/stable/http/tests/navigation/history-back-across-form-submission-to-fragment.html [ Failure ] -crbug.com/591099 virtual/stable/http/tests/navigation/image-load-in-subframe-unload-handler.html [ Crash ] +crbug.com/591099 virtual/stable/http/tests/navigation/image-load-in-subframe-unload-handler.html [ Crash Pass ] crbug.com/591099 virtual/stable/http/tests/navigation/javascriptlink-basic.html [ Crash Failure Timeout ] crbug.com/591099 virtual/stable/http/tests/navigation/javascriptlink-goback.html [ Crash Failure Timeout ] crbug.com/591099 virtual/stable/http/tests/navigation/lockedhistory-iframe.html [ Failure ] crbug.com/591099 virtual/stable/http/tests/navigation/metaredirect-basic.html [ Crash Failure ] crbug.com/591099 virtual/stable/http/tests/navigation/metaredirect-goback.html [ Crash Failure ] -crbug.com/591099 virtual/stable/http/tests/navigation/navigate-during-commit.html [ Crash ] +crbug.com/591099 virtual/stable/http/tests/navigation/navigate-during-commit.html [ Crash Pass ] crbug.com/591099 virtual/stable/http/tests/navigation/navigation-with-detached-origin-document.html [ Crash Pass ] crbug.com/591099 virtual/stable/http/tests/navigation/no-referrer-reset.html [ Failure Timeout ] crbug.com/591099 virtual/stable/http/tests/navigation/onload-navigation-iframe-2.html [ Failure ] @@ -21577,7 +21589,7 @@ crbug.com/591099 virtual/stable/http/tests/navigation/success200-goback.html [ Crash Failure ] crbug.com/591099 virtual/stable/http/tests/navigation/success200-loadsame.html [ Crash Failure ] crbug.com/591099 virtual/stable/http/tests/navigation/success200-reload.html [ Crash Failure ] -crbug.com/591099 virtual/stable/http/tests/navigation/targeted-navigation-in-unload-handler.html [ Crash ] +crbug.com/591099 virtual/stable/http/tests/navigation/targeted-navigation-in-unload-handler.html [ Crash Pass ] crbug.com/591099 virtual/stable/http/tests/navigation/timerredirect-basic.html [ Crash Failure ] crbug.com/591099 virtual/stable/http/tests/navigation/timerredirect-goback.html [ Crash Failure ] crbug.com/591099 virtual/stable/http/tests/navigation/useragent.php [ Failure ] @@ -21590,7 +21602,7 @@ crbug.com/591099 virtual/stable/http/tests/sendbeacon/beacon-detached-no-crash.html [ Failure ] crbug.com/591099 virtual/stable/http/tests/sendbeacon/beacon-same-origin.html [ Failure ] crbug.com/591099 virtual/stable/http/tests/serviceworker/webexposed/global-interface-listing-service-worker.html [ Pass Timeout ] -crbug.com/591099 virtual/stable/svg/transforms/stable/legacy-transform-box.html [ Crash ] +crbug.com/591099 virtual/stable/svg/transforms/stable/legacy-transform-box.html [ Crash Pass ] crbug.com/591099 virtual/stable/webexposed/custom-elements.html [ Failure ] crbug.com/591099 virtual/stable/webexposed/element-instance-property-listing.html [ Timeout ] crbug.com/591099 virtual/stable/webexposed/event-target-in-prototype.html [ Failure ] @@ -21607,105 +21619,105 @@ crbug.com/591099 virtual/threaded/animations/animation-css-rule-types.html [ Failure ] crbug.com/591099 virtual/threaded/animations/animation-events-create.html [ Failure ] crbug.com/591099 virtual/threaded/animations/animations-parsing.html [ Timeout ] -crbug.com/591099 virtual/threaded/animations/animations-responsive-to-color-change.html [ Crash ] -crbug.com/591099 virtual/threaded/animations/clear-svg-animation-effects.html [ Crash ] -crbug.com/591099 virtual/threaded/animations/composition/background-position-composition.html [ Crash ] -crbug.com/591099 virtual/threaded/animations/composition/caret-color-composition.html [ Crash ] -crbug.com/591099 virtual/threaded/animations/composition/stroke-dasharray-composition.html [ Crash ] +crbug.com/591099 virtual/threaded/animations/animations-responsive-to-color-change.html [ Crash Pass ] +crbug.com/591099 virtual/threaded/animations/clear-svg-animation-effects.html [ Crash Pass ] +crbug.com/591099 virtual/threaded/animations/composition/background-position-composition.html [ Crash Pass ] +crbug.com/591099 virtual/threaded/animations/composition/caret-color-composition.html [ Crash Pass ] +crbug.com/591099 virtual/threaded/animations/composition/stroke-dasharray-composition.html [ Crash Pass ] crbug.com/591099 virtual/threaded/animations/computed-style.html [ Failure ] -crbug.com/591099 virtual/threaded/animations/css-animation-overrides-svg-presentation-attribute-animation.html [ Crash ] +crbug.com/591099 virtual/threaded/animations/css-animation-overrides-svg-presentation-attribute-animation.html [ Crash Pass ] crbug.com/591099 virtual/threaded/animations/delay-start-event.html [ Failure ] -crbug.com/591099 virtual/threaded/animations/display-change-does-not-terminate-animation.html [ Crash ] +crbug.com/591099 virtual/threaded/animations/display-change-does-not-terminate-animation.html [ Crash Failure ] crbug.com/591099 virtual/threaded/animations/display-inline-style-adjust.html [ Failure Timeout ] crbug.com/591099 virtual/threaded/animations/display-none-cancel-computedstyle.html [ Failure ] crbug.com/591099 virtual/threaded/animations/display-none-terminates-animation.html [ Failure ] -crbug.com/591099 virtual/threaded/animations/img-element-transform.html [ Crash Timeout ] -crbug.com/591099 virtual/threaded/animations/inline-block-transform.html [ Crash ] +crbug.com/591099 virtual/threaded/animations/img-element-transform.html [ Crash Pass Timeout ] +crbug.com/591099 virtual/threaded/animations/inline-block-transform.html [ Crash Pass ] crbug.com/591099 virtual/threaded/animations/inline-element-animation-end-hit-test.html [ Failure ] -crbug.com/591099 virtual/threaded/animations/interpolation/backdrop-filter-interpolation.html [ Crash ] -crbug.com/591099 virtual/threaded/animations/interpolation/background-color-interpolation.html [ Crash ] -crbug.com/591099 virtual/threaded/animations/interpolation/background-image-interpolation.html [ Crash ] -crbug.com/591099 virtual/threaded/animations/interpolation/background-position-interpolation.html [ Crash ] -crbug.com/591099 virtual/threaded/animations/interpolation/background-position-origin-interpolation.html [ Crash ] -crbug.com/591099 virtual/threaded/animations/interpolation/background-size-interpolation.html [ Crash ] -crbug.com/591099 virtual/threaded/animations/interpolation/border-color-interpolation.html [ Crash ] -crbug.com/591099 virtual/threaded/animations/interpolation/border-image-outset-interpolation.html [ Crash ] -crbug.com/591099 virtual/threaded/animations/interpolation/border-image-slice-interpolation.html [ Crash ] -crbug.com/591099 virtual/threaded/animations/interpolation/border-image-source-interpolation.html [ Crash ] -crbug.com/591099 virtual/threaded/animations/interpolation/border-image-width-interpolation.html [ Crash ] -crbug.com/591099 virtual/threaded/animations/interpolation/border-radius-interpolation.html [ Crash ] -crbug.com/591099 virtual/threaded/animations/interpolation/border-spacing-interpolation.html [ Crash ] -crbug.com/591099 virtual/threaded/animations/interpolation/border-width-interpolation.html [ Crash ] -crbug.com/591099 virtual/threaded/animations/interpolation/bottom-interpolation.html [ Crash ] -crbug.com/591099 virtual/threaded/animations/interpolation/box-shadow-interpolation.html [ Crash ] -crbug.com/591099 virtual/threaded/animations/interpolation/calc-interpolation.html [ Crash ] -crbug.com/591099 virtual/threaded/animations/interpolation/caret-color-interpolation.html [ Crash ] -crbug.com/591099 virtual/threaded/animations/interpolation/clip-interpolation.html [ Crash ] -crbug.com/591099 virtual/threaded/animations/interpolation/color-interpolation.html [ Crash ] -crbug.com/591099 virtual/threaded/animations/interpolation/filter-interpolation.html [ Crash ] -crbug.com/591099 virtual/threaded/animations/interpolation/font-size-adjust-interpolation.html [ Crash ] -crbug.com/591099 virtual/threaded/animations/interpolation/font-size-interpolation-unset.html [ Crash ] -crbug.com/591099 virtual/threaded/animations/interpolation/font-size-interpolation.html [ Crash ] -crbug.com/591099 virtual/threaded/animations/interpolation/font-size-zoom-interpolation.html [ Crash ] -crbug.com/591099 virtual/threaded/animations/interpolation/font-weight-interpolation.html [ Crash ] -crbug.com/591099 virtual/threaded/animations/interpolation/height-interpolation.html [ Crash ] -crbug.com/591099 virtual/threaded/animations/interpolation/line-height-interpolation.html [ Crash ] -crbug.com/591099 virtual/threaded/animations/interpolation/margin-interpolation.html [ Crash ] -crbug.com/591099 virtual/threaded/animations/interpolation/max-height-interpolation.html [ Crash ] -crbug.com/591099 virtual/threaded/animations/interpolation/min-height-interpolation.html [ Crash ] -crbug.com/591099 virtual/threaded/animations/interpolation/object-position-interpolation.html [ Crash ] -crbug.com/591099 virtual/threaded/animations/interpolation/offset-rotate-interpolation.html [ Crash ] -crbug.com/591099 virtual/threaded/animations/interpolation/opacity-interpolation.html [ Crash ] -crbug.com/591099 virtual/threaded/animations/interpolation/outline-color-interpolation.html [ Crash ] -crbug.com/591099 virtual/threaded/animations/interpolation/outline-offset-interpolation.html [ Crash ] -crbug.com/591099 virtual/threaded/animations/interpolation/outline-width-interpolation.html [ Crash ] -crbug.com/591099 virtual/threaded/animations/interpolation/padding-interpolation.html [ Crash ] -crbug.com/591099 virtual/threaded/animations/interpolation/perspective-interpolation.html [ Crash ] -crbug.com/591099 virtual/threaded/animations/interpolation/perspective-origin-interpolation.html [ Crash ] -crbug.com/591099 virtual/threaded/animations/interpolation/position-interpolation.html [ Crash ] -crbug.com/591099 virtual/threaded/animations/interpolation/sample-interpolation-test.html [ Crash ] -crbug.com/591099 virtual/threaded/animations/interpolation/svg-baseline-shift-interpolation.html [ Crash ] -crbug.com/591099 virtual/threaded/animations/interpolation/svg-cx-interpolation.html [ Crash ] -crbug.com/591099 virtual/threaded/animations/interpolation/svg-cy-interpolation.html [ Crash ] -crbug.com/591099 virtual/threaded/animations/interpolation/svg-d-interpolation.html [ Crash ] -crbug.com/591099 virtual/threaded/animations/interpolation/svg-fill-interpolation.html [ Crash ] -crbug.com/591099 virtual/threaded/animations/interpolation/svg-fill-opacity-interpolation.html [ Crash ] -crbug.com/591099 virtual/threaded/animations/interpolation/svg-flood-color-interpolation.html [ Crash ] -crbug.com/591099 virtual/threaded/animations/interpolation/svg-flood-opacity-interpolation.html [ Crash ] -crbug.com/591099 virtual/threaded/animations/interpolation/svg-lighting-color-interpolation.html [ Crash ] -crbug.com/591099 virtual/threaded/animations/interpolation/svg-r-interpolation.html [ Crash ] -crbug.com/591099 virtual/threaded/animations/interpolation/svg-rx-interpolation.html [ Crash ] -crbug.com/591099 virtual/threaded/animations/interpolation/svg-ry-interpolation.html [ Crash ] -crbug.com/591099 virtual/threaded/animations/interpolation/svg-stop-color-interpolation.html [ Crash ] -crbug.com/591099 virtual/threaded/animations/interpolation/svg-stop-opacity-interpolation.html [ Crash ] -crbug.com/591099 virtual/threaded/animations/interpolation/svg-stroke-dasharray-interpolation.html [ Crash ] -crbug.com/591099 virtual/threaded/animations/interpolation/svg-stroke-dashoffset-interpolation.html [ Crash ] -crbug.com/591099 virtual/threaded/animations/interpolation/svg-stroke-interpolation.html [ Crash ] -crbug.com/591099 virtual/threaded/animations/interpolation/svg-stroke-miterlimit-interpolation.html [ Crash ] -crbug.com/591099 virtual/threaded/animations/interpolation/svg-stroke-opacity-interpolation.html [ Crash ] -crbug.com/591099 virtual/threaded/animations/interpolation/svg-stroke-width-interpolation.html [ Crash ] -crbug.com/591099 virtual/threaded/animations/interpolation/text-decoration-color-interpolation.html [ Crash ] -crbug.com/591099 virtual/threaded/animations/interpolation/text-shadow-interpolation.html [ Crash ] -crbug.com/591099 virtual/threaded/animations/interpolation/top-interpolation.html [ Crash ] -crbug.com/591099 virtual/threaded/animations/interpolation/transform-interpolation.html [ Crash ] -crbug.com/591099 virtual/threaded/animations/interpolation/transform-origin-interpolation.html [ Crash ] -crbug.com/591099 virtual/threaded/animations/interpolation/vertical-align-interpolation.html [ Crash ] -crbug.com/591099 virtual/threaded/animations/interpolation/viewport-unit-interpolation.html [ Crash ] -crbug.com/591099 virtual/threaded/animations/interpolation/webkit-background-size-interpolation.html [ Crash ] -crbug.com/591099 virtual/threaded/animations/interpolation/webkit-clip-path-interpolation.html [ Crash ] -crbug.com/591099 virtual/threaded/animations/interpolation/webkit-column-rule-color-interpolation.html [ Crash ] -crbug.com/591099 virtual/threaded/animations/interpolation/webkit-mask-box-image-outset-interpolation.html [ Crash ] -crbug.com/591099 virtual/threaded/animations/interpolation/webkit-mask-box-image-slice-interpolation.html [ Crash ] -crbug.com/591099 virtual/threaded/animations/interpolation/webkit-mask-box-image-source-interpolation.html [ Crash ] -crbug.com/591099 virtual/threaded/animations/interpolation/webkit-mask-box-image-width-interpolation.html [ Crash ] -crbug.com/591099 virtual/threaded/animations/interpolation/webkit-mask-image-interpolation.html [ Crash ] -crbug.com/591099 virtual/threaded/animations/interpolation/webkit-mask-position-interpolation.html [ Crash ] -crbug.com/591099 virtual/threaded/animations/interpolation/webkit-mask-size-interpolation.html [ Crash ] -crbug.com/591099 virtual/threaded/animations/interpolation/webkit-perspective-interpolation.html [ Crash ] -crbug.com/591099 virtual/threaded/animations/interpolation/webkit-perspective-origin-interpolation.html [ Crash ] -crbug.com/591099 virtual/threaded/animations/interpolation/webkit-text-stroke-color-interpolation.html [ Crash ] -crbug.com/591099 virtual/threaded/animations/interpolation/webkit-transform-interpolation.html [ Crash ] -crbug.com/591099 virtual/threaded/animations/interpolation/webkit-transform-origin-interpolation.html [ Crash ] +crbug.com/591099 virtual/threaded/animations/interpolation/backdrop-filter-interpolation.html [ Crash Timeout ] +crbug.com/591099 virtual/threaded/animations/interpolation/background-color-interpolation.html [ Crash Pass ] +crbug.com/591099 virtual/threaded/animations/interpolation/background-image-interpolation.html [ Crash Timeout ] +crbug.com/591099 virtual/threaded/animations/interpolation/background-position-interpolation.html [ Crash Pass ] +crbug.com/591099 virtual/threaded/animations/interpolation/background-position-origin-interpolation.html [ Crash Pass ] +crbug.com/591099 virtual/threaded/animations/interpolation/background-size-interpolation.html [ Crash Pass ] +crbug.com/591099 virtual/threaded/animations/interpolation/border-color-interpolation.html [ Crash Pass ] +crbug.com/591099 virtual/threaded/animations/interpolation/border-image-outset-interpolation.html [ Crash Pass ] +crbug.com/591099 virtual/threaded/animations/interpolation/border-image-slice-interpolation.html [ Crash Pass ] +crbug.com/591099 virtual/threaded/animations/interpolation/border-image-source-interpolation.html [ Crash Pass ] +crbug.com/591099 virtual/threaded/animations/interpolation/border-image-width-interpolation.html [ Crash Timeout ] +crbug.com/591099 virtual/threaded/animations/interpolation/border-radius-interpolation.html [ Crash Pass ] +crbug.com/591099 virtual/threaded/animations/interpolation/border-spacing-interpolation.html [ Crash Pass ] +crbug.com/591099 virtual/threaded/animations/interpolation/border-width-interpolation.html [ Crash Pass ] +crbug.com/591099 virtual/threaded/animations/interpolation/bottom-interpolation.html [ Crash Pass ] +crbug.com/591099 virtual/threaded/animations/interpolation/box-shadow-interpolation.html [ Crash Pass ] +crbug.com/591099 virtual/threaded/animations/interpolation/calc-interpolation.html [ Crash Pass ] +crbug.com/591099 virtual/threaded/animations/interpolation/caret-color-interpolation.html [ Crash Pass ] +crbug.com/591099 virtual/threaded/animations/interpolation/clip-interpolation.html [ Crash Pass ] +crbug.com/591099 virtual/threaded/animations/interpolation/color-interpolation.html [ Crash Pass ] +crbug.com/591099 virtual/threaded/animations/interpolation/filter-interpolation.html [ Crash Pass ] +crbug.com/591099 virtual/threaded/animations/interpolation/font-size-adjust-interpolation.html [ Crash Pass ] +crbug.com/591099 virtual/threaded/animations/interpolation/font-size-interpolation-unset.html [ Crash Pass ] +crbug.com/591099 virtual/threaded/animations/interpolation/font-size-interpolation.html [ Crash Pass ] +crbug.com/591099 virtual/threaded/animations/interpolation/font-size-zoom-interpolation.html [ Crash Pass ] +crbug.com/591099 virtual/threaded/animations/interpolation/font-weight-interpolation.html [ Crash Pass ] +crbug.com/591099 virtual/threaded/animations/interpolation/height-interpolation.html [ Crash Pass ] +crbug.com/591099 virtual/threaded/animations/interpolation/line-height-interpolation.html [ Crash Timeout ] +crbug.com/591099 virtual/threaded/animations/interpolation/margin-interpolation.html [ Crash Pass ] +crbug.com/591099 virtual/threaded/animations/interpolation/max-height-interpolation.html [ Crash Pass ] +crbug.com/591099 virtual/threaded/animations/interpolation/min-height-interpolation.html [ Crash Pass ] +crbug.com/591099 virtual/threaded/animations/interpolation/object-position-interpolation.html [ Crash Pass ] +crbug.com/591099 virtual/threaded/animations/interpolation/offset-rotate-interpolation.html [ Crash Pass ] +crbug.com/591099 virtual/threaded/animations/interpolation/opacity-interpolation.html [ Crash Pass ] +crbug.com/591099 virtual/threaded/animations/interpolation/outline-color-interpolation.html [ Crash Pass ] +crbug.com/591099 virtual/threaded/animations/interpolation/outline-offset-interpolation.html [ Crash Pass ] +crbug.com/591099 virtual/threaded/animations/interpolation/outline-width-interpolation.html [ Crash Pass ] +crbug.com/591099 virtual/threaded/animations/interpolation/padding-interpolation.html [ Crash Pass ] +crbug.com/591099 virtual/threaded/animations/interpolation/perspective-interpolation.html [ Crash Pass ] +crbug.com/591099 virtual/threaded/animations/interpolation/perspective-origin-interpolation.html [ Crash Pass ] +crbug.com/591099 virtual/threaded/animations/interpolation/position-interpolation.html [ Crash Pass ] +crbug.com/591099 virtual/threaded/animations/interpolation/sample-interpolation-test.html [ Crash Pass ] +crbug.com/591099 virtual/threaded/animations/interpolation/svg-baseline-shift-interpolation.html [ Crash Pass ] +crbug.com/591099 virtual/threaded/animations/interpolation/svg-cx-interpolation.html [ Crash Pass ] +crbug.com/591099 virtual/threaded/animations/interpolation/svg-cy-interpolation.html [ Crash Pass ] +crbug.com/591099 virtual/threaded/animations/interpolation/svg-d-interpolation.html [ Crash Timeout ] +crbug.com/591099 virtual/threaded/animations/interpolation/svg-fill-interpolation.html [ Crash Pass ] +crbug.com/591099 virtual/threaded/animations/interpolation/svg-fill-opacity-interpolation.html [ Crash Pass ] +crbug.com/591099 virtual/threaded/animations/interpolation/svg-flood-color-interpolation.html [ Crash Pass ] +crbug.com/591099 virtual/threaded/animations/interpolation/svg-flood-opacity-interpolation.html [ Crash Pass ] +crbug.com/591099 virtual/threaded/animations/interpolation/svg-lighting-color-interpolation.html [ Crash Pass ] +crbug.com/591099 virtual/threaded/animations/interpolation/svg-r-interpolation.html [ Crash Pass ] +crbug.com/591099 virtual/threaded/animations/interpolation/svg-rx-interpolation.html [ Crash Pass ] +crbug.com/591099 virtual/threaded/animations/interpolation/svg-ry-interpolation.html [ Crash Pass ] +crbug.com/591099 virtual/threaded/animations/interpolation/svg-stop-color-interpolation.html [ Crash Pass ] +crbug.com/591099 virtual/threaded/animations/interpolation/svg-stop-opacity-interpolation.html [ Crash Pass ] +crbug.com/591099 virtual/threaded/animations/interpolation/svg-stroke-dasharray-interpolation.html [ Crash Timeout ] +crbug.com/591099 virtual/threaded/animations/interpolation/svg-stroke-dashoffset-interpolation.html [ Crash Pass ] +crbug.com/591099 virtual/threaded/animations/interpolation/svg-stroke-interpolation.html [ Crash Pass ] +crbug.com/591099 virtual/threaded/animations/interpolation/svg-stroke-miterlimit-interpolation.html [ Crash Pass ] +crbug.com/591099 virtual/threaded/animations/interpolation/svg-stroke-opacity-interpolation.html [ Crash Pass ] +crbug.com/591099 virtual/threaded/animations/interpolation/svg-stroke-width-interpolation.html [ Crash Pass ] +crbug.com/591099 virtual/threaded/animations/interpolation/text-decoration-color-interpolation.html [ Crash Pass ] +crbug.com/591099 virtual/threaded/animations/interpolation/text-shadow-interpolation.html [ Crash Pass ] +crbug.com/591099 virtual/threaded/animations/interpolation/top-interpolation.html [ Crash Pass ] +crbug.com/591099 virtual/threaded/animations/interpolation/transform-interpolation.html [ Crash Timeout ] +crbug.com/591099 virtual/threaded/animations/interpolation/transform-origin-interpolation.html [ Crash Pass ] +crbug.com/591099 virtual/threaded/animations/interpolation/vertical-align-interpolation.html [ Crash Pass ] +crbug.com/591099 virtual/threaded/animations/interpolation/viewport-unit-interpolation.html [ Crash Pass ] +crbug.com/591099 virtual/threaded/animations/interpolation/webkit-background-size-interpolation.html [ Crash Pass ] +crbug.com/591099 virtual/threaded/animations/interpolation/webkit-clip-path-interpolation.html [ Crash Timeout ] +crbug.com/591099 virtual/threaded/animations/interpolation/webkit-column-rule-color-interpolation.html [ Crash Pass ] +crbug.com/591099 virtual/threaded/animations/interpolation/webkit-mask-box-image-outset-interpolation.html [ Crash Pass ] +crbug.com/591099 virtual/threaded/animations/interpolation/webkit-mask-box-image-slice-interpolation.html [ Crash Pass ] +crbug.com/591099 virtual/threaded/animations/interpolation/webkit-mask-box-image-source-interpolation.html [ Crash Pass ] +crbug.com/591099 virtual/threaded/animations/interpolation/webkit-mask-box-image-width-interpolation.html [ Crash Pass ] +crbug.com/591099 virtual/threaded/animations/interpolation/webkit-mask-image-interpolation.html [ Crash Pass ] +crbug.com/591099 virtual/threaded/animations/interpolation/webkit-mask-position-interpolation.html [ Crash Pass ] +crbug.com/591099 virtual/threaded/animations/interpolation/webkit-mask-size-interpolation.html [ Crash Pass ] +crbug.com/591099 virtual/threaded/animations/interpolation/webkit-perspective-interpolation.html [ Crash Pass ] +crbug.com/591099 virtual/threaded/animations/interpolation/webkit-perspective-origin-interpolation.html [ Crash Pass ] +crbug.com/591099 virtual/threaded/animations/interpolation/webkit-text-stroke-color-interpolation.html [ Crash Pass ] +crbug.com/591099 virtual/threaded/animations/interpolation/webkit-transform-interpolation.html [ Crash Timeout ] +crbug.com/591099 virtual/threaded/animations/interpolation/webkit-transform-origin-interpolation.html [ Crash Pass ] crbug.com/591099 virtual/threaded/animations/keyframes-rule.html [ Failure ] crbug.com/591099 virtual/threaded/animations/lazy-detached-animation-stop.html [ Failure ] crbug.com/591099 virtual/threaded/animations/negative-delay-events.html [ Failure ] @@ -21714,7 +21726,7 @@ crbug.com/591099 virtual/threaded/animations/prefixed/animation-inherit-initial-unprefixed.html [ Failure ] crbug.com/591099 virtual/threaded/animations/prefixed/keyframes-cssom-prefixed-02.html [ Failure ] crbug.com/591099 virtual/threaded/animations/prefixed/keyframes-cssom-unprefixed-02.html [ Failure ] -crbug.com/591099 virtual/threaded/animations/responsive/d-responsive.html [ Crash ] +crbug.com/591099 virtual/threaded/animations/responsive/d-responsive.html [ Crash Pass ] crbug.com/591099 virtual/threaded/animations/responsive/line-height-responsive.html [ Pass Timeout ] crbug.com/591099 virtual/threaded/animations/rotate-transform-equivalent.html [ Failure Timeout ] crbug.com/591099 virtual/threaded/animations/skew-notsequential-compositor.html [ Failure Timeout ] @@ -21722,171 +21734,171 @@ crbug.com/591099 virtual/threaded/animations/stability/animation-iteration-event-destroy-renderer.html [ Failure ] crbug.com/591099 virtual/threaded/animations/stability/animation-on-inline-crash.html [ Failure ] crbug.com/591099 virtual/threaded/animations/stability/animation-start-event-destroy-renderer.html [ Failure ] -crbug.com/591099 virtual/threaded/animations/stability/base-render-style-crash.html [ Crash ] -crbug.com/591099 virtual/threaded/animations/stability/checkbox-padding-animation-crash.html [ Crash ] +crbug.com/591099 virtual/threaded/animations/stability/base-render-style-crash.html [ Crash Pass ] +crbug.com/591099 virtual/threaded/animations/stability/checkbox-padding-animation-crash.html [ Crash Pass ] crbug.com/591099 virtual/threaded/animations/stability/element-animate-float-crash.html [ Failure Pass ] crbug.com/591099 virtual/threaded/animations/stability/empty-keyframe-animation-composited.html [ Failure ] crbug.com/591099 virtual/threaded/animations/stability/empty-keyframes-composited.html [ Failure ] crbug.com/591099 virtual/threaded/animations/stability/empty-keyframes.html [ Failure ] crbug.com/591099 virtual/threaded/animations/stability/import-crash.html [ Failure ] crbug.com/591099 virtual/threaded/animations/stability/length-zero-percent-crash.html [ Failure Pass ] -crbug.com/591099 virtual/threaded/animations/stability/option-element-crash.html [ Crash ] -crbug.com/591099 virtual/threaded/animations/stability/option-opacity-inherit-crash.html [ Crash ] +crbug.com/591099 virtual/threaded/animations/stability/option-element-crash.html [ Crash Pass ] +crbug.com/591099 virtual/threaded/animations/stability/option-opacity-inherit-crash.html [ Crash Pass ] crbug.com/591099 virtual/threaded/animations/stability/pause-crash.html [ Failure ] -crbug.com/591099 virtual/threaded/animations/stability/svg-element-css-animation-crash.html [ Crash ] -crbug.com/591099 virtual/threaded/animations/stability/svg-length-unittype-crash.html [ Crash ] +crbug.com/591099 virtual/threaded/animations/stability/svg-element-css-animation-crash.html [ Crash Pass ] +crbug.com/591099 virtual/threaded/animations/stability/svg-length-unittype-crash.html [ Crash Pass ] crbug.com/591099 virtual/threaded/animations/stability/zero-duration-infinite-iterations.html [ Failure ] crbug.com/591099 virtual/threaded/animations/stability/zero-duration-large-start-delay.html [ Failure ] crbug.com/591099 virtual/threaded/animations/state-at-end-event.html [ Failure Pass Timeout ] -crbug.com/591099 virtual/threaded/animations/svg-attribute-composition/svg-amplitude-composition.html [ Crash ] -crbug.com/591099 virtual/threaded/animations/svg-attribute-composition/svg-azimuth-composition.html [ Crash ] -crbug.com/591099 virtual/threaded/animations/svg-attribute-composition/svg-baseFrequency-composition.html [ Crash ] -crbug.com/591099 virtual/threaded/animations/svg-attribute-composition/svg-bias-composition.html [ Crash ] -crbug.com/591099 virtual/threaded/animations/svg-attribute-composition/svg-cx-cy-composition.html [ Crash ] -crbug.com/591099 virtual/threaded/animations/svg-attribute-composition/svg-d-composition.html [ Crash ] -crbug.com/591099 virtual/threaded/animations/svg-attribute-composition/svg-diffuseConstant-composition.html [ Crash ] -crbug.com/591099 virtual/threaded/animations/svg-attribute-composition/svg-divisor-composition.html [ Crash ] -crbug.com/591099 virtual/threaded/animations/svg-attribute-composition/svg-dx-dy-length-list-composition.html [ Crash ] -crbug.com/591099 virtual/threaded/animations/svg-attribute-composition/svg-dx-dy-number-composition.html [ Crash ] -crbug.com/591099 virtual/threaded/animations/svg-attribute-composition/svg-elevation-composition.html [ Crash ] -crbug.com/591099 virtual/threaded/animations/svg-attribute-composition/svg-exponent-composition.html [ Crash ] -crbug.com/591099 virtual/threaded/animations/svg-attribute-composition/svg-fx-fy-composition.html [ Crash ] -crbug.com/591099 virtual/threaded/animations/svg-attribute-composition/svg-gradientTransform-composition.html [ Crash ] -crbug.com/591099 virtual/threaded/animations/svg-attribute-composition/svg-height-composition.html [ Crash ] -crbug.com/591099 virtual/threaded/animations/svg-attribute-composition/svg-intercept-composition.html [ Crash ] -crbug.com/591099 virtual/threaded/animations/svg-attribute-composition/svg-k1-k2-k3-k4-composition.html [ Crash ] -crbug.com/591099 virtual/threaded/animations/svg-attribute-composition/svg-kernelMatrix-composition.html [ Crash ] -crbug.com/591099 virtual/threaded/animations/svg-attribute-composition/svg-kernelUnitLength-composition.html [ Crash ] -crbug.com/591099 virtual/threaded/animations/svg-attribute-composition/svg-limitingConeAngle-composition.html [ Crash ] -crbug.com/591099 virtual/threaded/animations/svg-attribute-composition/svg-markerHeight-composition.html [ Crash ] -crbug.com/591099 virtual/threaded/animations/svg-attribute-composition/svg-markerWidth-composition.html [ Crash ] -crbug.com/591099 virtual/threaded/animations/svg-attribute-composition/svg-mode-composition.html [ Crash ] -crbug.com/591099 virtual/threaded/animations/svg-attribute-composition/svg-numOctaves-composition.html [ Crash ] -crbug.com/591099 virtual/threaded/animations/svg-attribute-composition/svg-offset-composition.html [ Crash ] -crbug.com/591099 virtual/threaded/animations/svg-attribute-composition/svg-order-composition.html [ Crash ] -crbug.com/591099 virtual/threaded/animations/svg-attribute-composition/svg-orient-composition.html [ Crash ] -crbug.com/591099 virtual/threaded/animations/svg-attribute-composition/svg-pathLength-composition.html [ Crash ] -crbug.com/591099 virtual/threaded/animations/svg-attribute-composition/svg-patternTransform-composition.html [ Crash ] -crbug.com/591099 virtual/threaded/animations/svg-attribute-composition/svg-points-composition.html [ Crash ] -crbug.com/591099 virtual/threaded/animations/svg-attribute-composition/svg-pointsAtX-pointsAtY-pointsAtZ-composition.html [ Crash ] -crbug.com/591099 virtual/threaded/animations/svg-attribute-composition/svg-r-composition.html [ Crash ] -crbug.com/591099 virtual/threaded/animations/svg-attribute-composition/svg-radius-composition.html [ Crash ] -crbug.com/591099 virtual/threaded/animations/svg-attribute-composition/svg-refX-refY-composition.html [ Crash ] -crbug.com/591099 virtual/threaded/animations/svg-attribute-composition/svg-rotate-composition.html [ Crash ] -crbug.com/591099 virtual/threaded/animations/svg-attribute-composition/svg-rx-composition.html [ Crash ] -crbug.com/591099 virtual/threaded/animations/svg-attribute-composition/svg-scale-composition.html [ Crash ] -crbug.com/591099 virtual/threaded/animations/svg-attribute-composition/svg-seed-composition.html [ Crash ] -crbug.com/591099 virtual/threaded/animations/svg-attribute-composition/svg-slope-composition.html [ Crash ] -crbug.com/591099 virtual/threaded/animations/svg-attribute-composition/svg-specularConstant-composition.html [ Crash ] -crbug.com/591099 virtual/threaded/animations/svg-attribute-composition/svg-specularExponent-composition.html [ Crash ] -crbug.com/591099 virtual/threaded/animations/svg-attribute-composition/svg-startOffset-composition.html [ Crash ] -crbug.com/591099 virtual/threaded/animations/svg-attribute-composition/svg-stdDeviation-composition.html [ Crash ] -crbug.com/591099 virtual/threaded/animations/svg-attribute-composition/svg-surfaceScale-composition.html [ Crash ] -crbug.com/591099 virtual/threaded/animations/svg-attribute-composition/svg-tableValues-composition.html [ Crash ] -crbug.com/591099 virtual/threaded/animations/svg-attribute-composition/svg-targetX-targetY-composition.html [ Crash ] -crbug.com/591099 virtual/threaded/animations/svg-attribute-composition/svg-textLength-composition.html [ Crash ] -crbug.com/591099 virtual/threaded/animations/svg-attribute-composition/svg-transform-composition-distinct.html [ Crash ] -crbug.com/591099 virtual/threaded/animations/svg-attribute-composition/svg-transform-composition-list.html [ Crash ] -crbug.com/591099 virtual/threaded/animations/svg-attribute-composition/svg-transform-composition.html [ Crash ] -crbug.com/591099 virtual/threaded/animations/svg-attribute-composition/svg-transform-matrix.html [ Crash ] -crbug.com/591099 virtual/threaded/animations/svg-attribute-composition/svg-values-composition.html [ Crash ] -crbug.com/591099 virtual/threaded/animations/svg-attribute-composition/svg-viewBox-composition.html [ Crash ] -crbug.com/591099 virtual/threaded/animations/svg-attribute-composition/svg-width-composition.html [ Crash ] -crbug.com/591099 virtual/threaded/animations/svg-attribute-composition/svg-x-composition.html [ Crash ] -crbug.com/591099 virtual/threaded/animations/svg-attribute-composition/svg-x-list-composition.html [ Crash ] -crbug.com/591099 virtual/threaded/animations/svg-attribute-composition/svg-x1-x2-y1-y2-composition.html [ Crash ] -crbug.com/591099 virtual/threaded/animations/svg-attribute-composition/svg-y-composition.html [ Crash ] -crbug.com/591099 virtual/threaded/animations/svg-attribute-composition/svg-y-list-composition.html [ Crash ] -crbug.com/591099 virtual/threaded/animations/svg-attribute-composition/svg-z-composition.html [ Crash ] -crbug.com/591099 virtual/threaded/animations/svg-attribute-interpolation/svg-amplitude-interpolation.html [ Crash ] -crbug.com/591099 virtual/threaded/animations/svg-attribute-interpolation/svg-azimuth-interpolation.html [ Crash ] -crbug.com/591099 virtual/threaded/animations/svg-attribute-interpolation/svg-baseFrequency-interpolation.html [ Crash ] -crbug.com/591099 virtual/threaded/animations/svg-attribute-interpolation/svg-bias-interpolation.html [ Crash ] -crbug.com/591099 virtual/threaded/animations/svg-attribute-interpolation/svg-calc-interpolation.html [ Crash ] -crbug.com/591099 virtual/threaded/animations/svg-attribute-interpolation/svg-class-interpolation.html [ Crash ] -crbug.com/591099 virtual/threaded/animations/svg-attribute-interpolation/svg-clipPathUnits-interpolation.html [ Crash ] -crbug.com/591099 virtual/threaded/animations/svg-attribute-interpolation/svg-cx-cy-interpolation.html [ Crash ] -crbug.com/591099 virtual/threaded/animations/svg-attribute-interpolation/svg-d-interpolation.html [ Crash ] -crbug.com/591099 virtual/threaded/animations/svg-attribute-interpolation/svg-diffuseConstant-interpolation.html [ Crash ] -crbug.com/591099 virtual/threaded/animations/svg-attribute-interpolation/svg-divisor-interpolation.html [ Crash ] -crbug.com/591099 virtual/threaded/animations/svg-attribute-interpolation/svg-dx-dy-length-list-interpolation.html [ Crash ] -crbug.com/591099 virtual/threaded/animations/svg-attribute-interpolation/svg-dx-dy-number-interpolation.html [ Crash ] -crbug.com/591099 virtual/threaded/animations/svg-attribute-interpolation/svg-edgeMode-interpolation.html [ Crash ] -crbug.com/591099 virtual/threaded/animations/svg-attribute-interpolation/svg-elevation-interpolation.html [ Crash ] -crbug.com/591099 virtual/threaded/animations/svg-attribute-interpolation/svg-exponent-interpolation.html [ Crash ] -crbug.com/591099 virtual/threaded/animations/svg-attribute-interpolation/svg-filterUnits-interpolation.html [ Crash ] -crbug.com/591099 virtual/threaded/animations/svg-attribute-interpolation/svg-fx-fy-interpolation.html [ Crash ] -crbug.com/591099 virtual/threaded/animations/svg-attribute-interpolation/svg-gradientTransform-interpolation.html [ Crash ] -crbug.com/591099 virtual/threaded/animations/svg-attribute-interpolation/svg-gradientUnits-interpolation.html [ Crash ] -crbug.com/591099 virtual/threaded/animations/svg-attribute-interpolation/svg-height-interpolation.html [ Crash ] -crbug.com/591099 virtual/threaded/animations/svg-attribute-interpolation/svg-href-interpolation.html [ Crash ] -crbug.com/591099 virtual/threaded/animations/svg-attribute-interpolation/svg-in-interpolation.html [ Crash ] -crbug.com/591099 virtual/threaded/animations/svg-attribute-interpolation/svg-intercept-interpolation.html [ Crash ] -crbug.com/591099 virtual/threaded/animations/svg-attribute-interpolation/svg-k1-k2-k3-k4-interpolation.html [ Crash ] -crbug.com/591099 virtual/threaded/animations/svg-attribute-interpolation/svg-kernelMatrix-interpolation.html [ Crash ] -crbug.com/591099 virtual/threaded/animations/svg-attribute-interpolation/svg-kernelUnitLength-interpolation.html [ Crash ] -crbug.com/591099 virtual/threaded/animations/svg-attribute-interpolation/svg-lengthAdjust-interpolation.html [ Crash ] -crbug.com/591099 virtual/threaded/animations/svg-attribute-interpolation/svg-limitingConeAngle-interpolation.html [ Crash ] -crbug.com/591099 virtual/threaded/animations/svg-attribute-interpolation/svg-markerHeight-interpolation.html [ Crash ] -crbug.com/591099 virtual/threaded/animations/svg-attribute-interpolation/svg-markerUnits-interpolation.html [ Crash ] -crbug.com/591099 virtual/threaded/animations/svg-attribute-interpolation/svg-markerWidth-interpolation.html [ Crash ] -crbug.com/591099 virtual/threaded/animations/svg-attribute-interpolation/svg-maskContentUnits-interpolation.html [ Crash ] -crbug.com/591099 virtual/threaded/animations/svg-attribute-interpolation/svg-maskUnits-interpolation.html [ Crash Timeout ] -crbug.com/591099 virtual/threaded/animations/svg-attribute-interpolation/svg-method-interpolation.html [ Crash ] -crbug.com/591099 virtual/threaded/animations/svg-attribute-interpolation/svg-mode-interpolation.html [ Crash ] -crbug.com/591099 virtual/threaded/animations/svg-attribute-interpolation/svg-numOctaves-interpolation.html [ Crash ] -crbug.com/591099 virtual/threaded/animations/svg-attribute-interpolation/svg-offset-interpolation.html [ Crash ] -crbug.com/591099 virtual/threaded/animations/svg-attribute-interpolation/svg-operator-interpolation.html [ Crash ] -crbug.com/591099 virtual/threaded/animations/svg-attribute-interpolation/svg-order-interpolation.html [ Crash ] -crbug.com/591099 virtual/threaded/animations/svg-attribute-interpolation/svg-orient-interpolation.html [ Crash ] -crbug.com/591099 virtual/threaded/animations/svg-attribute-interpolation/svg-pathLength-interpolation.html [ Crash ] -crbug.com/591099 virtual/threaded/animations/svg-attribute-interpolation/svg-patternContentUnits-interpolation.html [ Crash ] -crbug.com/591099 virtual/threaded/animations/svg-attribute-interpolation/svg-patternTransform-interpolation.html [ Crash ] -crbug.com/591099 virtual/threaded/animations/svg-attribute-interpolation/svg-patternUnits-interpolation.html [ Crash ] -crbug.com/591099 virtual/threaded/animations/svg-attribute-interpolation/svg-points-interpolation.html [ Crash ] -crbug.com/591099 virtual/threaded/animations/svg-attribute-interpolation/svg-pointsAtX-pointsAtY-pointsAtZ-interpolation.html [ Crash ] -crbug.com/591099 virtual/threaded/animations/svg-attribute-interpolation/svg-preserveAlpha-interpolation.html [ Crash ] -crbug.com/591099 virtual/threaded/animations/svg-attribute-interpolation/svg-preserveAspectRatio-interpolation.html [ Crash ] -crbug.com/591099 virtual/threaded/animations/svg-attribute-interpolation/svg-primitiveUnits-interpolation.html [ Crash ] -crbug.com/591099 virtual/threaded/animations/svg-attribute-interpolation/svg-r-interpolation.html [ Crash ] -crbug.com/591099 virtual/threaded/animations/svg-attribute-interpolation/svg-radius-interpolation.html [ Crash ] -crbug.com/591099 virtual/threaded/animations/svg-attribute-interpolation/svg-refX-refY-interpolation.html [ Crash ] -crbug.com/591099 virtual/threaded/animations/svg-attribute-interpolation/svg-result-interpolation.html [ Crash ] -crbug.com/591099 virtual/threaded/animations/svg-attribute-interpolation/svg-rotate-interpolation.html [ Crash ] -crbug.com/591099 virtual/threaded/animations/svg-attribute-interpolation/svg-rx-interpolation.html [ Crash ] -crbug.com/591099 virtual/threaded/animations/svg-attribute-interpolation/svg-scale-interpolation.html [ Crash ] -crbug.com/591099 virtual/threaded/animations/svg-attribute-interpolation/svg-seed-interpolation.html [ Crash ] -crbug.com/591099 virtual/threaded/animations/svg-attribute-interpolation/svg-slope-interpolation.html [ Crash ] -crbug.com/591099 virtual/threaded/animations/svg-attribute-interpolation/svg-spacing-interpolation.html [ Crash ] -crbug.com/591099 virtual/threaded/animations/svg-attribute-interpolation/svg-specularConstant-interpolation.html [ Crash ] -crbug.com/591099 virtual/threaded/animations/svg-attribute-interpolation/svg-specularExponent-interpolation.html [ Crash ] -crbug.com/591099 virtual/threaded/animations/svg-attribute-interpolation/svg-spreadMethod-interpolation.html [ Crash ] -crbug.com/591099 virtual/threaded/animations/svg-attribute-interpolation/svg-startOffset-interpolation.html [ Crash ] -crbug.com/591099 virtual/threaded/animations/svg-attribute-interpolation/svg-stdDeviation-interpolation.html [ Crash ] -crbug.com/591099 virtual/threaded/animations/svg-attribute-interpolation/svg-stitchTiles-interpolation.html [ Crash ] -crbug.com/591099 virtual/threaded/animations/svg-attribute-interpolation/svg-surfaceScale-interpolation.html [ Crash ] -crbug.com/591099 virtual/threaded/animations/svg-attribute-interpolation/svg-tableValues-interpolation.html [ Crash ] -crbug.com/591099 virtual/threaded/animations/svg-attribute-interpolation/svg-target-interpolation.html [ Crash ] -crbug.com/591099 virtual/threaded/animations/svg-attribute-interpolation/svg-targetX-targetY-interpolation.html [ Crash ] -crbug.com/591099 virtual/threaded/animations/svg-attribute-interpolation/svg-textLength-interpolation.html [ Crash ] -crbug.com/591099 virtual/threaded/animations/svg-attribute-interpolation/svg-transform-interpolation.html [ Crash ] -crbug.com/591099 virtual/threaded/animations/svg-attribute-interpolation/svg-type-interpolation.html [ Crash ] -crbug.com/591099 virtual/threaded/animations/svg-attribute-interpolation/svg-values-interpolation.html [ Crash ] -crbug.com/591099 virtual/threaded/animations/svg-attribute-interpolation/svg-viewBox-interpolation.html [ Crash ] -crbug.com/591099 virtual/threaded/animations/svg-attribute-interpolation/svg-width-interpolation.html [ Crash ] -crbug.com/591099 virtual/threaded/animations/svg-attribute-interpolation/svg-x-list-interpolation.html [ Crash ] -crbug.com/591099 virtual/threaded/animations/svg-attribute-interpolation/svg-x-y-interpolation.html [ Crash ] -crbug.com/591099 virtual/threaded/animations/svg-attribute-interpolation/svg-x1-x2-y1-y2-interpolation.html [ Crash ] -crbug.com/591099 virtual/threaded/animations/svg-attribute-interpolation/svg-xChannelSelector-interpolation.html [ Crash ] -crbug.com/591099 virtual/threaded/animations/svg-attribute-interpolation/svg-y-list-interpolation.html [ Crash ] -crbug.com/591099 virtual/threaded/animations/svg-attribute-interpolation/svg-z-interpolation.html [ Crash ] -crbug.com/591099 virtual/threaded/animations/svg-attribute-responsive/svg-d-responsive.html [ Crash ] -crbug.com/591099 virtual/threaded/animations/svg-attribute-responsive/svg-points-responsive.html [ Crash ] -crbug.com/591099 virtual/threaded/animations/svg-attribute-responsive/svg-tableValues-responsive.html [ Crash ] -crbug.com/591099 virtual/threaded/animations/svg-attribute-responsive/svg-transform-responsive.html [ Crash ] -crbug.com/591099 virtual/threaded/animations/svg-attribute-responsive/svg-x-list-responsive.html [ Crash ] -crbug.com/591099 virtual/threaded/animations/svg-presentation-attribute-animation.html [ Crash ] -crbug.com/591099 virtual/threaded/animations/svg-responsive-to-timing-updates.html [ Crash ] +crbug.com/591099 virtual/threaded/animations/svg-attribute-composition/svg-amplitude-composition.html [ Crash Pass ] +crbug.com/591099 virtual/threaded/animations/svg-attribute-composition/svg-azimuth-composition.html [ Crash Pass ] +crbug.com/591099 virtual/threaded/animations/svg-attribute-composition/svg-baseFrequency-composition.html [ Crash Pass ] +crbug.com/591099 virtual/threaded/animations/svg-attribute-composition/svg-bias-composition.html [ Crash Pass ] +crbug.com/591099 virtual/threaded/animations/svg-attribute-composition/svg-cx-cy-composition.html [ Crash Pass ] +crbug.com/591099 virtual/threaded/animations/svg-attribute-composition/svg-d-composition.html [ Crash Pass ] +crbug.com/591099 virtual/threaded/animations/svg-attribute-composition/svg-diffuseConstant-composition.html [ Crash Pass ] +crbug.com/591099 virtual/threaded/animations/svg-attribute-composition/svg-divisor-composition.html [ Crash Pass ] +crbug.com/591099 virtual/threaded/animations/svg-attribute-composition/svg-dx-dy-length-list-composition.html [ Crash Pass ] +crbug.com/591099 virtual/threaded/animations/svg-attribute-composition/svg-dx-dy-number-composition.html [ Crash Pass ] +crbug.com/591099 virtual/threaded/animations/svg-attribute-composition/svg-elevation-composition.html [ Crash Pass ] +crbug.com/591099 virtual/threaded/animations/svg-attribute-composition/svg-exponent-composition.html [ Crash Pass ] +crbug.com/591099 virtual/threaded/animations/svg-attribute-composition/svg-fx-fy-composition.html [ Crash Pass ] +crbug.com/591099 virtual/threaded/animations/svg-attribute-composition/svg-gradientTransform-composition.html [ Crash Pass ] +crbug.com/591099 virtual/threaded/animations/svg-attribute-composition/svg-height-composition.html [ Crash Pass ] +crbug.com/591099 virtual/threaded/animations/svg-attribute-composition/svg-intercept-composition.html [ Crash Pass ] +crbug.com/591099 virtual/threaded/animations/svg-attribute-composition/svg-k1-k2-k3-k4-composition.html [ Crash Pass ] +crbug.com/591099 virtual/threaded/animations/svg-attribute-composition/svg-kernelMatrix-composition.html [ Crash Pass ] +crbug.com/591099 virtual/threaded/animations/svg-attribute-composition/svg-kernelUnitLength-composition.html [ Crash Pass ] +crbug.com/591099 virtual/threaded/animations/svg-attribute-composition/svg-limitingConeAngle-composition.html [ Crash Pass ] +crbug.com/591099 virtual/threaded/animations/svg-attribute-composition/svg-markerHeight-composition.html [ Crash Pass ] +crbug.com/591099 virtual/threaded/animations/svg-attribute-composition/svg-markerWidth-composition.html [ Crash Pass ] +crbug.com/591099 virtual/threaded/animations/svg-attribute-composition/svg-mode-composition.html [ Crash Pass ] +crbug.com/591099 virtual/threaded/animations/svg-attribute-composition/svg-numOctaves-composition.html [ Crash Pass ] +crbug.com/591099 virtual/threaded/animations/svg-attribute-composition/svg-offset-composition.html [ Crash Pass ] +crbug.com/591099 virtual/threaded/animations/svg-attribute-composition/svg-order-composition.html [ Crash Pass ] +crbug.com/591099 virtual/threaded/animations/svg-attribute-composition/svg-orient-composition.html [ Crash Pass ] +crbug.com/591099 virtual/threaded/animations/svg-attribute-composition/svg-pathLength-composition.html [ Crash Pass ] +crbug.com/591099 virtual/threaded/animations/svg-attribute-composition/svg-patternTransform-composition.html [ Crash Pass ] +crbug.com/591099 virtual/threaded/animations/svg-attribute-composition/svg-points-composition.html [ Crash Pass ] +crbug.com/591099 virtual/threaded/animations/svg-attribute-composition/svg-pointsAtX-pointsAtY-pointsAtZ-composition.html [ Crash Pass ] +crbug.com/591099 virtual/threaded/animations/svg-attribute-composition/svg-r-composition.html [ Crash Pass ] +crbug.com/591099 virtual/threaded/animations/svg-attribute-composition/svg-radius-composition.html [ Crash Pass ] +crbug.com/591099 virtual/threaded/animations/svg-attribute-composition/svg-refX-refY-composition.html [ Crash Pass ] +crbug.com/591099 virtual/threaded/animations/svg-attribute-composition/svg-rotate-composition.html [ Crash Pass ] +crbug.com/591099 virtual/threaded/animations/svg-attribute-composition/svg-rx-composition.html [ Crash Pass ] +crbug.com/591099 virtual/threaded/animations/svg-attribute-composition/svg-scale-composition.html [ Crash Pass ] +crbug.com/591099 virtual/threaded/animations/svg-attribute-composition/svg-seed-composition.html [ Crash Pass ] +crbug.com/591099 virtual/threaded/animations/svg-attribute-composition/svg-slope-composition.html [ Crash Pass ] +crbug.com/591099 virtual/threaded/animations/svg-attribute-composition/svg-specularConstant-composition.html [ Crash Pass ] +crbug.com/591099 virtual/threaded/animations/svg-attribute-composition/svg-specularExponent-composition.html [ Crash Pass ] +crbug.com/591099 virtual/threaded/animations/svg-attribute-composition/svg-startOffset-composition.html [ Crash Pass ] +crbug.com/591099 virtual/threaded/animations/svg-attribute-composition/svg-stdDeviation-composition.html [ Crash Pass ] +crbug.com/591099 virtual/threaded/animations/svg-attribute-composition/svg-surfaceScale-composition.html [ Crash Pass ] +crbug.com/591099 virtual/threaded/animations/svg-attribute-composition/svg-tableValues-composition.html [ Crash Pass ] +crbug.com/591099 virtual/threaded/animations/svg-attribute-composition/svg-targetX-targetY-composition.html [ Crash Pass ] +crbug.com/591099 virtual/threaded/animations/svg-attribute-composition/svg-textLength-composition.html [ Crash Pass ] +crbug.com/591099 virtual/threaded/animations/svg-attribute-composition/svg-transform-composition-distinct.html [ Crash Pass ] +crbug.com/591099 virtual/threaded/animations/svg-attribute-composition/svg-transform-composition-list.html [ Crash Pass ] +crbug.com/591099 virtual/threaded/animations/svg-attribute-composition/svg-transform-composition.html [ Crash Pass ] +crbug.com/591099 virtual/threaded/animations/svg-attribute-composition/svg-transform-matrix.html [ Crash Pass ] +crbug.com/591099 virtual/threaded/animations/svg-attribute-composition/svg-values-composition.html [ Crash Pass ] +crbug.com/591099 virtual/threaded/animations/svg-attribute-composition/svg-viewBox-composition.html [ Crash Pass ] +crbug.com/591099 virtual/threaded/animations/svg-attribute-composition/svg-width-composition.html [ Crash Pass ] +crbug.com/591099 virtual/threaded/animations/svg-attribute-composition/svg-x-composition.html [ Crash Pass ] +crbug.com/591099 virtual/threaded/animations/svg-attribute-composition/svg-x-list-composition.html [ Crash Pass ] +crbug.com/591099 virtual/threaded/animations/svg-attribute-composition/svg-x1-x2-y1-y2-composition.html [ Crash Pass ] +crbug.com/591099 virtual/threaded/animations/svg-attribute-composition/svg-y-composition.html [ Crash Pass ] +crbug.com/591099 virtual/threaded/animations/svg-attribute-composition/svg-y-list-composition.html [ Crash Pass ] +crbug.com/591099 virtual/threaded/animations/svg-attribute-composition/svg-z-composition.html [ Crash Pass ] +crbug.com/591099 virtual/threaded/animations/svg-attribute-interpolation/svg-amplitude-interpolation.html [ Crash Pass ] +crbug.com/591099 virtual/threaded/animations/svg-attribute-interpolation/svg-azimuth-interpolation.html [ Crash Pass ] +crbug.com/591099 virtual/threaded/animations/svg-attribute-interpolation/svg-baseFrequency-interpolation.html [ Crash Pass ] +crbug.com/591099 virtual/threaded/animations/svg-attribute-interpolation/svg-bias-interpolation.html [ Crash Pass ] +crbug.com/591099 virtual/threaded/animations/svg-attribute-interpolation/svg-calc-interpolation.html [ Crash Pass ] +crbug.com/591099 virtual/threaded/animations/svg-attribute-interpolation/svg-class-interpolation.html [ Crash Pass ] +crbug.com/591099 virtual/threaded/animations/svg-attribute-interpolation/svg-clipPathUnits-interpolation.html [ Crash Pass ] +crbug.com/591099 virtual/threaded/animations/svg-attribute-interpolation/svg-cx-cy-interpolation.html [ Crash Pass ] +crbug.com/591099 virtual/threaded/animations/svg-attribute-interpolation/svg-d-interpolation.html [ Crash Timeout ] +crbug.com/591099 virtual/threaded/animations/svg-attribute-interpolation/svg-diffuseConstant-interpolation.html [ Crash Pass ] +crbug.com/591099 virtual/threaded/animations/svg-attribute-interpolation/svg-divisor-interpolation.html [ Crash Pass ] +crbug.com/591099 virtual/threaded/animations/svg-attribute-interpolation/svg-dx-dy-length-list-interpolation.html [ Crash Pass ] +crbug.com/591099 virtual/threaded/animations/svg-attribute-interpolation/svg-dx-dy-number-interpolation.html [ Crash Pass ] +crbug.com/591099 virtual/threaded/animations/svg-attribute-interpolation/svg-edgeMode-interpolation.html [ Crash Pass ] +crbug.com/591099 virtual/threaded/animations/svg-attribute-interpolation/svg-elevation-interpolation.html [ Crash Pass ] +crbug.com/591099 virtual/threaded/animations/svg-attribute-interpolation/svg-exponent-interpolation.html [ Crash Pass ] +crbug.com/591099 virtual/threaded/animations/svg-attribute-interpolation/svg-filterUnits-interpolation.html [ Crash Pass ] +crbug.com/591099 virtual/threaded/animations/svg-attribute-interpolation/svg-fx-fy-interpolation.html [ Crash Pass ] +crbug.com/591099 virtual/threaded/animations/svg-attribute-interpolation/svg-gradientTransform-interpolation.html [ Crash Pass ] +crbug.com/591099 virtual/threaded/animations/svg-attribute-interpolation/svg-gradientUnits-interpolation.html [ Crash Pass ] +crbug.com/591099 virtual/threaded/animations/svg-attribute-interpolation/svg-height-interpolation.html [ Crash Pass ] +crbug.com/591099 virtual/threaded/animations/svg-attribute-interpolation/svg-href-interpolation.html [ Crash Pass ] +crbug.com/591099 virtual/threaded/animations/svg-attribute-interpolation/svg-in-interpolation.html [ Crash Pass ] +crbug.com/591099 virtual/threaded/animations/svg-attribute-interpolation/svg-intercept-interpolation.html [ Crash Pass ] +crbug.com/591099 virtual/threaded/animations/svg-attribute-interpolation/svg-k1-k2-k3-k4-interpolation.html [ Crash Pass ] +crbug.com/591099 virtual/threaded/animations/svg-attribute-interpolation/svg-kernelMatrix-interpolation.html [ Crash Pass ] +crbug.com/591099 virtual/threaded/animations/svg-attribute-interpolation/svg-kernelUnitLength-interpolation.html [ Crash Pass ] +crbug.com/591099 virtual/threaded/animations/svg-attribute-interpolation/svg-lengthAdjust-interpolation.html [ Crash Pass ] +crbug.com/591099 virtual/threaded/animations/svg-attribute-interpolation/svg-limitingConeAngle-interpolation.html [ Crash Pass ] +crbug.com/591099 virtual/threaded/animations/svg-attribute-interpolation/svg-markerHeight-interpolation.html [ Crash Pass ] +crbug.com/591099 virtual/threaded/animations/svg-attribute-interpolation/svg-markerUnits-interpolation.html [ Crash Pass ] +crbug.com/591099 virtual/threaded/animations/svg-attribute-interpolation/svg-markerWidth-interpolation.html [ Crash Pass ] +crbug.com/591099 virtual/threaded/animations/svg-attribute-interpolation/svg-maskContentUnits-interpolation.html [ Crash Pass ] +crbug.com/591099 virtual/threaded/animations/svg-attribute-interpolation/svg-maskUnits-interpolation.html [ Crash Pass Timeout ] +crbug.com/591099 virtual/threaded/animations/svg-attribute-interpolation/svg-method-interpolation.html [ Crash Pass ] +crbug.com/591099 virtual/threaded/animations/svg-attribute-interpolation/svg-mode-interpolation.html [ Crash Pass ] +crbug.com/591099 virtual/threaded/animations/svg-attribute-interpolation/svg-numOctaves-interpolation.html [ Crash Pass ] +crbug.com/591099 virtual/threaded/animations/svg-attribute-interpolation/svg-offset-interpolation.html [ Crash Pass ] +crbug.com/591099 virtual/threaded/animations/svg-attribute-interpolation/svg-operator-interpolation.html [ Crash Pass ] +crbug.com/591099 virtual/threaded/animations/svg-attribute-interpolation/svg-order-interpolation.html [ Crash Pass ] +crbug.com/591099 virtual/threaded/animations/svg-attribute-interpolation/svg-orient-interpolation.html [ Crash Pass ] +crbug.com/591099 virtual/threaded/animations/svg-attribute-interpolation/svg-pathLength-interpolation.html [ Crash Pass ] +crbug.com/591099 virtual/threaded/animations/svg-attribute-interpolation/svg-patternContentUnits-interpolation.html [ Crash Pass ] +crbug.com/591099 virtual/threaded/animations/svg-attribute-interpolation/svg-patternTransform-interpolation.html [ Crash Pass ] +crbug.com/591099 virtual/threaded/animations/svg-attribute-interpolation/svg-patternUnits-interpolation.html [ Crash Pass ] +crbug.com/591099 virtual/threaded/animations/svg-attribute-interpolation/svg-points-interpolation.html [ Crash Pass ] +crbug.com/591099 virtual/threaded/animations/svg-attribute-interpolation/svg-pointsAtX-pointsAtY-pointsAtZ-interpolation.html [ Crash Pass ] +crbug.com/591099 virtual/threaded/animations/svg-attribute-interpolation/svg-preserveAlpha-interpolation.html [ Crash Pass ] +crbug.com/591099 virtual/threaded/animations/svg-attribute-interpolation/svg-preserveAspectRatio-interpolation.html [ Crash Pass ] +crbug.com/591099 virtual/threaded/animations/svg-attribute-interpolation/svg-primitiveUnits-interpolation.html [ Crash Pass ] +crbug.com/591099 virtual/threaded/animations/svg-attribute-interpolation/svg-r-interpolation.html [ Crash Pass ] +crbug.com/591099 virtual/threaded/animations/svg-attribute-interpolation/svg-radius-interpolation.html [ Crash Pass ] +crbug.com/591099 virtual/threaded/animations/svg-attribute-interpolation/svg-refX-refY-interpolation.html [ Crash Pass ] +crbug.com/591099 virtual/threaded/animations/svg-attribute-interpolation/svg-result-interpolation.html [ Crash Pass ] +crbug.com/591099 virtual/threaded/animations/svg-attribute-interpolation/svg-rotate-interpolation.html [ Crash Pass ] +crbug.com/591099 virtual/threaded/animations/svg-attribute-interpolation/svg-rx-interpolation.html [ Crash Pass ] +crbug.com/591099 virtual/threaded/animations/svg-attribute-interpolation/svg-scale-interpolation.html [ Crash Pass ] +crbug.com/591099 virtual/threaded/animations/svg-attribute-interpolation/svg-seed-interpolation.html [ Crash Pass ] +crbug.com/591099 virtual/threaded/animations/svg-attribute-interpolation/svg-slope-interpolation.html [ Crash Pass ] +crbug.com/591099 virtual/threaded/animations/svg-attribute-interpolation/svg-spacing-interpolation.html [ Crash Pass ] +crbug.com/591099 virtual/threaded/animations/svg-attribute-interpolation/svg-specularConstant-interpolation.html [ Crash Pass ] +crbug.com/591099 virtual/threaded/animations/svg-attribute-interpolation/svg-specularExponent-interpolation.html [ Crash Pass ] +crbug.com/591099 virtual/threaded/animations/svg-attribute-interpolation/svg-spreadMethod-interpolation.html [ Crash Pass ] +crbug.com/591099 virtual/threaded/animations/svg-attribute-interpolation/svg-startOffset-interpolation.html [ Crash Pass ] +crbug.com/591099 virtual/threaded/animations/svg-attribute-interpolation/svg-stdDeviation-interpolation.html [ Crash Pass ] +crbug.com/591099 virtual/threaded/animations/svg-attribute-interpolation/svg-stitchTiles-interpolation.html [ Crash Pass ] +crbug.com/591099 virtual/threaded/animations/svg-attribute-interpolation/svg-surfaceScale-interpolation.html [ Crash Pass ] +crbug.com/591099 virtual/threaded/animations/svg-attribute-interpolation/svg-tableValues-interpolation.html [ Crash Pass ] +crbug.com/591099 virtual/threaded/animations/svg-attribute-interpolation/svg-target-interpolation.html [ Crash Pass ] +crbug.com/591099 virtual/threaded/animations/svg-attribute-interpolation/svg-targetX-targetY-interpolation.html [ Crash Pass ] +crbug.com/591099 virtual/threaded/animations/svg-attribute-interpolation/svg-textLength-interpolation.html [ Crash Pass ] +crbug.com/591099 virtual/threaded/animations/svg-attribute-interpolation/svg-transform-interpolation.html [ Crash Pass ] +crbug.com/591099 virtual/threaded/animations/svg-attribute-interpolation/svg-type-interpolation.html [ Crash Pass ] +crbug.com/591099 virtual/threaded/animations/svg-attribute-interpolation/svg-values-interpolation.html [ Crash Pass ] +crbug.com/591099 virtual/threaded/animations/svg-attribute-interpolation/svg-viewBox-interpolation.html [ Crash Pass ] +crbug.com/591099 virtual/threaded/animations/svg-attribute-interpolation/svg-width-interpolation.html [ Crash Pass ] +crbug.com/591099 virtual/threaded/animations/svg-attribute-interpolation/svg-x-list-interpolation.html [ Crash Pass ] +crbug.com/591099 virtual/threaded/animations/svg-attribute-interpolation/svg-x-y-interpolation.html [ Crash Pass ] +crbug.com/591099 virtual/threaded/animations/svg-attribute-interpolation/svg-x1-x2-y1-y2-interpolation.html [ Crash Pass ] +crbug.com/591099 virtual/threaded/animations/svg-attribute-interpolation/svg-xChannelSelector-interpolation.html [ Crash Pass ] +crbug.com/591099 virtual/threaded/animations/svg-attribute-interpolation/svg-y-list-interpolation.html [ Crash Pass ] +crbug.com/591099 virtual/threaded/animations/svg-attribute-interpolation/svg-z-interpolation.html [ Crash Pass ] +crbug.com/591099 virtual/threaded/animations/svg-attribute-responsive/svg-d-responsive.html [ Crash Pass ] +crbug.com/591099 virtual/threaded/animations/svg-attribute-responsive/svg-points-responsive.html [ Crash Pass ] +crbug.com/591099 virtual/threaded/animations/svg-attribute-responsive/svg-tableValues-responsive.html [ Crash Pass ] +crbug.com/591099 virtual/threaded/animations/svg-attribute-responsive/svg-transform-responsive.html [ Crash Pass ] +crbug.com/591099 virtual/threaded/animations/svg-attribute-responsive/svg-x-list-responsive.html [ Crash Pass ] +crbug.com/591099 virtual/threaded/animations/svg-presentation-attribute-animation.html [ Crash Pass ] +crbug.com/591099 virtual/threaded/animations/svg-responsive-to-timing-updates.html [ Crash Pass ] crbug.com/591099 virtual/threaded/animations/timing-model.html [ Pass Timeout ] crbug.com/591099 virtual/threaded/compositing/visibility/compositing-and-visibility-turned-off-together.html [ Failure ] crbug.com/591099 virtual/threaded/compositing/visibility/hidden-iframe.html [ Failure ] @@ -21914,77 +21926,77 @@ crbug.com/591099 virtual/threaded/fast/scroll-behavior/overflow-scroll-triggers-layout.html [ Failure ] crbug.com/591099 virtual/threaded/fast/scroll-behavior/parse-scroll-behavior.html [ Failure ] crbug.com/591099 virtual/threaded/fast/scroll-behavior/scroll-into-view-scrolls-layout-viewport.html [ Failure ] -crbug.com/591099 virtual/threaded/fast/scroll-behavior/scroll-over-resizer.html [ Crash ] +crbug.com/591099 virtual/threaded/fast/scroll-behavior/scroll-over-resizer.html [ Crash Pass ] crbug.com/591099 virtual/threaded/fast/scroll-behavior/smooth-scroll/fixed-background-in-iframe.html [ Failure ] crbug.com/591099 virtual/threaded/fast/scroll-behavior/smooth-scroll/keyboard-scroll.html [ Failure ] crbug.com/591099 virtual/threaded/fast/scroll-behavior/smooth-scroll/main-thread-scrolling-reason-added.html [ Failure ] crbug.com/591099 virtual/threaded/fast/scroll-behavior/smooth-scroll/main-thread-scrolling-reason-correctness.html [ Failure Timeout ] -crbug.com/591099 virtual/threaded/http/tests/worklet/chromium/import-on-detached-iframe.html [ Crash ] -crbug.com/591099 virtual/threaded/inspector/tracing/anonymous-image-object.html [ Crash ] +crbug.com/591099 virtual/threaded/http/tests/worklet/chromium/import-on-detached-iframe.html [ Crash Pass ] +crbug.com/591099 virtual/threaded/inspector/tracing/anonymous-image-object.html [ Crash Failure ] crbug.com/591099 virtual/threaded/inspector/tracing/buffer-usage.html [ Failure ] crbug.com/591099 virtual/threaded/inspector/tracing/category-filter.html [ Failure ] -crbug.com/591099 virtual/threaded/inspector/tracing/console-timeline.html [ Crash ] -crbug.com/591099 virtual/threaded/inspector/tracing/decode-resize.html [ Crash ] -crbug.com/591099 virtual/threaded/inspector/tracing/frame-model-instrumentation.html [ Crash ] +crbug.com/591099 virtual/threaded/inspector/tracing/console-timeline.html [ Crash Failure ] +crbug.com/591099 virtual/threaded/inspector/tracing/decode-resize.html [ Crash Failure ] +crbug.com/591099 virtual/threaded/inspector/tracing/frame-model-instrumentation.html [ Crash Pass ] crbug.com/591099 virtual/threaded/inspector/tracing/frame-model.html [ Failure ] -crbug.com/591099 virtual/threaded/inspector/tracing/hit-test.html [ Crash ] -crbug.com/591099 virtual/threaded/inspector/tracing/idle-callback.html [ Crash ] -crbug.com/591099 virtual/threaded/inspector/tracing/scroll-invalidations.html [ Crash ] -crbug.com/591099 virtual/threaded/inspector/tracing/timeline-js/compile-script.html [ Crash ] -crbug.com/591099 virtual/threaded/inspector/tracing/timeline-js/timeline-gc-event.html [ Crash ] -crbug.com/591099 virtual/threaded/inspector/tracing/timeline-js/timeline-injected-script-eval.html [ Crash ] -crbug.com/591099 virtual/threaded/inspector/tracing/timeline-js/timeline-js-line-level-profile.html [ Crash ] -crbug.com/591099 virtual/threaded/inspector/tracing/timeline-js/timeline-microtasks.html [ Crash ] +crbug.com/591099 virtual/threaded/inspector/tracing/hit-test.html [ Crash Failure ] +crbug.com/591099 virtual/threaded/inspector/tracing/idle-callback.html [ Crash Failure ] +crbug.com/591099 virtual/threaded/inspector/tracing/scroll-invalidations.html [ Crash Failure ] +crbug.com/591099 virtual/threaded/inspector/tracing/timeline-js/compile-script.html [ Crash Failure ] +crbug.com/591099 virtual/threaded/inspector/tracing/timeline-js/timeline-gc-event.html [ Crash Failure ] +crbug.com/591099 virtual/threaded/inspector/tracing/timeline-js/timeline-injected-script-eval.html [ Crash Pass ] +crbug.com/591099 virtual/threaded/inspector/tracing/timeline-js/timeline-js-line-level-profile.html [ Crash Pass ] +crbug.com/591099 virtual/threaded/inspector/tracing/timeline-js/timeline-microtasks.html [ Crash Failure ] crbug.com/591099 virtual/threaded/inspector/tracing/timeline-js/timeline-open-function-call.html [ Failure ] -crbug.com/591099 virtual/threaded/inspector/tracing/timeline-js/timeline-runtime-stats.html [ Crash ] -crbug.com/591099 virtual/threaded/inspector/tracing/timeline-js/timeline-script-id.html [ Crash ] -crbug.com/591099 virtual/threaded/inspector/tracing/timeline-js/timeline-script-tag-1.html [ Crash ] -crbug.com/591099 virtual/threaded/inspector/tracing/timeline-js/timeline-script-tag-2.html [ Crash ] -crbug.com/591099 virtual/threaded/inspector/tracing/timeline-layout/timeline-layout-reason.html [ Crash ] -crbug.com/591099 virtual/threaded/inspector/tracing/timeline-layout/timeline-layout-with-invalidations.html [ Crash ] -crbug.com/591099 virtual/threaded/inspector/tracing/timeline-layout/timeline-layout.html [ Crash ] -crbug.com/591099 virtual/threaded/inspector/tracing/timeline-misc/timeline-aggregated-details.html [ Crash ] -crbug.com/591099 virtual/threaded/inspector/tracing/timeline-misc/timeline-animation-frame.html [ Crash ] -crbug.com/591099 virtual/threaded/inspector/tracing/timeline-misc/timeline-bound-function.html [ Crash ] -crbug.com/591099 virtual/threaded/inspector/tracing/timeline-misc/timeline-event-causes.html [ Crash ] +crbug.com/591099 virtual/threaded/inspector/tracing/timeline-js/timeline-runtime-stats.html [ Crash Failure ] +crbug.com/591099 virtual/threaded/inspector/tracing/timeline-js/timeline-script-id.html [ Crash Failure ] +crbug.com/591099 virtual/threaded/inspector/tracing/timeline-js/timeline-script-tag-1.html [ Crash Failure ] +crbug.com/591099 virtual/threaded/inspector/tracing/timeline-js/timeline-script-tag-2.html [ Crash Failure ] +crbug.com/591099 virtual/threaded/inspector/tracing/timeline-layout/timeline-layout-reason.html [ Crash Failure ] +crbug.com/591099 virtual/threaded/inspector/tracing/timeline-layout/timeline-layout-with-invalidations.html [ Crash Failure ] +crbug.com/591099 virtual/threaded/inspector/tracing/timeline-layout/timeline-layout.html [ Crash Failure ] +crbug.com/591099 virtual/threaded/inspector/tracing/timeline-misc/timeline-aggregated-details.html [ Crash Pass ] +crbug.com/591099 virtual/threaded/inspector/tracing/timeline-misc/timeline-animation-frame.html [ Crash Failure ] +crbug.com/591099 virtual/threaded/inspector/tracing/timeline-misc/timeline-bound-function.html [ Crash Failure ] +crbug.com/591099 virtual/threaded/inspector/tracing/timeline-misc/timeline-event-causes.html [ Crash Failure ] crbug.com/591099 virtual/threaded/inspector/tracing/timeline-misc/timeline-event-details.html [ Crash Failure ] -crbug.com/591099 virtual/threaded/inspector/tracing/timeline-misc/timeline-event-dispatch.html [ Crash ] +crbug.com/591099 virtual/threaded/inspector/tracing/timeline-misc/timeline-event-dispatch.html [ Crash Failure ] crbug.com/591099 virtual/threaded/inspector/tracing/timeline-misc/timeline-filtering.html [ Crash Failure ] -crbug.com/591099 virtual/threaded/inspector/tracing/timeline-misc/timeline-flame-chart-automatically-size-window.html [ Crash ] -crbug.com/591099 virtual/threaded/inspector/tracing/timeline-misc/timeline-grouped-invalidations.html [ Crash ] -crbug.com/591099 virtual/threaded/inspector/tracing/timeline-misc/timeline-load-event.html [ Crash ] -crbug.com/591099 virtual/threaded/inspector/tracing/timeline-misc/timeline-mark-timeline.html [ Crash ] +crbug.com/591099 virtual/threaded/inspector/tracing/timeline-misc/timeline-flame-chart-automatically-size-window.html [ Crash Failure ] +crbug.com/591099 virtual/threaded/inspector/tracing/timeline-misc/timeline-grouped-invalidations.html [ Crash Failure ] +crbug.com/591099 virtual/threaded/inspector/tracing/timeline-misc/timeline-load-event.html [ Crash Failure ] +crbug.com/591099 virtual/threaded/inspector/tracing/timeline-misc/timeline-mark-timeline.html [ Crash Failure ] crbug.com/591099 virtual/threaded/inspector/tracing/timeline-misc/timeline-model.html [ Crash Failure ] -crbug.com/591099 virtual/threaded/inspector/tracing/timeline-misc/timeline-node-reference.html [ Crash ] -crbug.com/591099 virtual/threaded/inspector/tracing/timeline-misc/timeline-parse-html.html [ Crash ] +crbug.com/591099 virtual/threaded/inspector/tracing/timeline-misc/timeline-node-reference.html [ Crash Failure ] +crbug.com/591099 virtual/threaded/inspector/tracing/timeline-misc/timeline-parse-html.html [ Crash Failure ] crbug.com/591099 virtual/threaded/inspector/tracing/timeline-misc/timeline-range-stats.html [ Crash Failure ] -crbug.com/591099 virtual/threaded/inspector/tracing/timeline-misc/timeline-record-reload.html [ Crash ] +crbug.com/591099 virtual/threaded/inspector/tracing/timeline-misc/timeline-record-reload.html [ Crash Failure ] crbug.com/591099 virtual/threaded/inspector/tracing/timeline-misc/timeline-search.html [ Failure ] crbug.com/591099 virtual/threaded/inspector/tracing/timeline-misc/timeline-tree-search.html [ Crash Failure ] -crbug.com/591099 virtual/threaded/inspector/tracing/timeline-misc/timeline-trivial.html [ Crash ] -crbug.com/591099 virtual/threaded/inspector/tracing/timeline-misc/timeline-window-filter.html [ Crash ] +crbug.com/591099 virtual/threaded/inspector/tracing/timeline-misc/timeline-trivial.html [ Crash Failure ] +crbug.com/591099 virtual/threaded/inspector/tracing/timeline-misc/timeline-window-filter.html [ Crash Failure ] crbug.com/591099 virtual/threaded/inspector/tracing/timeline-network/timeline-network-resource-details.html [ Failure ] crbug.com/591099 virtual/threaded/inspector/tracing/timeline-network/timeline-network-resource.html [ Failure ] -crbug.com/591099 virtual/threaded/inspector/tracing/timeline-paint/paint-profiler-update.html [ Crash ] -crbug.com/591099 virtual/threaded/inspector/tracing/timeline-paint/timeline-paint-and-multiple-style-invalidations.html [ Crash ] -crbug.com/591099 virtual/threaded/inspector/tracing/timeline-paint/timeline-paint-with-layout-invalidations-on-deleted-node.html [ Crash ] -crbug.com/591099 virtual/threaded/inspector/tracing/timeline-paint/timeline-paint-with-layout-invalidations.html [ Crash ] -crbug.com/591099 virtual/threaded/inspector/tracing/timeline-paint/timeline-paint-with-style-recalc-invalidations.html [ Crash ] -crbug.com/591099 virtual/threaded/inspector/tracing/timeline-paint/timeline-paint.html [ Crash ] -crbug.com/591099 virtual/threaded/inspector/tracing/timeline-paint/update-layer-tree.html [ Crash ] -crbug.com/591099 virtual/threaded/inspector/tracing/timeline-style/parse-author-style-sheet.html [ Crash ] -crbug.com/591099 virtual/threaded/inspector/tracing/timeline-style/timeline-recalculate-styles.html [ Crash ] -crbug.com/591099 virtual/threaded/inspector/tracing/timeline-style/timeline-style-recalc-all-invalidator-types.html [ Crash ] -crbug.com/591099 virtual/threaded/inspector/tracing/timeline-style/timeline-style-recalc-with-invalidations.html [ Crash ] -crbug.com/591099 virtual/threaded/inspector/tracing/timeline-style/timeline-style-recalc-with-invalidator-invalidations.html [ Crash ] -crbug.com/591099 virtual/threaded/inspector/tracing/timeline-time/timeline-time-stamp.html [ Crash ] -crbug.com/591099 virtual/threaded/inspector/tracing/timeline-time/timeline-time.html [ Crash ] -crbug.com/591099 virtual/threaded/inspector/tracing/timeline-time/timeline-timer-fired-from-eval-call-site.html [ Crash ] -crbug.com/591099 virtual/threaded/inspector/tracing/timeline-time/timeline-timer.html [ Crash ] -crbug.com/591099 virtual/threaded/inspector/tracing/timeline-time/timeline-usertiming.html [ Crash ] +crbug.com/591099 virtual/threaded/inspector/tracing/timeline-paint/paint-profiler-update.html [ Crash Failure ] +crbug.com/591099 virtual/threaded/inspector/tracing/timeline-paint/timeline-paint-and-multiple-style-invalidations.html [ Crash Failure ] +crbug.com/591099 virtual/threaded/inspector/tracing/timeline-paint/timeline-paint-with-layout-invalidations-on-deleted-node.html [ Crash Failure ] +crbug.com/591099 virtual/threaded/inspector/tracing/timeline-paint/timeline-paint-with-layout-invalidations.html [ Crash Failure ] +crbug.com/591099 virtual/threaded/inspector/tracing/timeline-paint/timeline-paint-with-style-recalc-invalidations.html [ Crash Failure ] +crbug.com/591099 virtual/threaded/inspector/tracing/timeline-paint/timeline-paint.html [ Crash Failure ] +crbug.com/591099 virtual/threaded/inspector/tracing/timeline-paint/update-layer-tree.html [ Crash Failure ] +crbug.com/591099 virtual/threaded/inspector/tracing/timeline-style/parse-author-style-sheet.html [ Crash Failure ] +crbug.com/591099 virtual/threaded/inspector/tracing/timeline-style/timeline-recalculate-styles.html [ Crash Failure ] +crbug.com/591099 virtual/threaded/inspector/tracing/timeline-style/timeline-style-recalc-all-invalidator-types.html [ Crash Failure ] +crbug.com/591099 virtual/threaded/inspector/tracing/timeline-style/timeline-style-recalc-with-invalidations.html [ Crash Failure ] +crbug.com/591099 virtual/threaded/inspector/tracing/timeline-style/timeline-style-recalc-with-invalidator-invalidations.html [ Crash Failure ] +crbug.com/591099 virtual/threaded/inspector/tracing/timeline-time/timeline-time-stamp.html [ Crash Failure ] +crbug.com/591099 virtual/threaded/inspector/tracing/timeline-time/timeline-time.html [ Crash Failure ] +crbug.com/591099 virtual/threaded/inspector/tracing/timeline-time/timeline-timer-fired-from-eval-call-site.html [ Crash Failure ] +crbug.com/591099 virtual/threaded/inspector/tracing/timeline-time/timeline-timer.html [ Crash Failure ] +crbug.com/591099 virtual/threaded/inspector/tracing/timeline-time/timeline-usertiming.html [ Crash Failure ] crbug.com/591099 virtual/threaded/inspector/tracing/tracing-timeline-load.html [ Failure ] -crbug.com/591099 virtual/threaded/inspector/tracing/worker-events.html [ Crash ] -crbug.com/591099 virtual/threaded/inspector/tracing/worker-js-frames.html [ Crash ] +crbug.com/591099 virtual/threaded/inspector/tracing/worker-events.html [ Crash Failure ] +crbug.com/591099 virtual/threaded/inspector/tracing/worker-js-frames.html [ Crash Failure ] crbug.com/591099 virtual/threaded/printing/absolute-position-headers-and-footers.html [ Failure ] crbug.com/591099 virtual/threaded/printing/absolute-positioned.html [ Failure ] crbug.com/591099 virtual/threaded/printing/allowed-page-breaks.html [ Failure ] @@ -22042,28 +22054,28 @@ crbug.com/591099 virtual/threaded/printing/viewport-size-dependant-iframe-with-multicol-crash.html [ Failure ] crbug.com/591099 virtual/threaded/transitions/3d/interrupted-transition.html [ Failure ] crbug.com/591099 virtual/threaded/transitions/bad-transition-shorthand-crash.html [ Failure ] -crbug.com/591099 virtual/threaded/transitions/cubic-bezier-overflow-svg-length.html [ Crash ] +crbug.com/591099 virtual/threaded/transitions/cubic-bezier-overflow-svg-length.html [ Crash Pass ] crbug.com/591099 virtual/threaded/transitions/inherit-other-props-do-not-affect-transition-property.html [ Failure ] crbug.com/591099 virtual/threaded/transitions/inherit-other-props.html [ Failure ] crbug.com/591099 virtual/threaded/transitions/inherit.html [ Failure ] -crbug.com/591099 virtual/threaded/transitions/interrupted-accelerated-transition.html [ Crash ] +crbug.com/591099 virtual/threaded/transitions/interrupted-accelerated-transition.html [ Crash Pass ] crbug.com/591099 virtual/threaded/transitions/interrupted-immediately.html [ Failure ] crbug.com/591099 virtual/threaded/transitions/matched-transform-functions.html [ Failure ] -crbug.com/591099 virtual/threaded/transitions/mismatched-shadow-styles.html [ Crash ] -crbug.com/591099 virtual/threaded/transitions/no-transition-on-implicit-margins.html [ Crash ] -crbug.com/591099 virtual/threaded/transitions/object-position-transition.html [ Crash ] +crbug.com/591099 virtual/threaded/transitions/mismatched-shadow-styles.html [ Crash Pass ] +crbug.com/591099 virtual/threaded/transitions/no-transition-on-implicit-margins.html [ Crash Pass ] +crbug.com/591099 virtual/threaded/transitions/object-position-transition.html [ Crash Pass ] crbug.com/591099 virtual/threaded/transitions/opacity-transform-transitions-inside-iframe.html [ Failure Timeout ] crbug.com/591099 virtual/threaded/transitions/opacity-transition-zindex.html [ Failure Pass Timeout ] crbug.com/591099 virtual/threaded/transitions/override-transition-crash.html [ Failure ] crbug.com/591099 virtual/threaded/transitions/retargetted-transition.html [ Failure ] crbug.com/591099 virtual/threaded/transitions/shadow.html [ Failure ] -crbug.com/591099 virtual/threaded/transitions/svg-layout-transition-zoom.html [ Crash ] -crbug.com/591099 virtual/threaded/transitions/svg-layout-transition.html [ Crash ] -crbug.com/591099 virtual/threaded/transitions/svg-transitions.html [ Crash ] +crbug.com/591099 virtual/threaded/transitions/svg-layout-transition-zoom.html [ Crash Pass ] +crbug.com/591099 virtual/threaded/transitions/svg-layout-transition.html [ Crash Pass ] +crbug.com/591099 virtual/threaded/transitions/svg-transitions.html [ Crash Pass ] crbug.com/591099 virtual/threaded/transitions/transition-end-event-all-properties.html [ Failure Timeout ] crbug.com/591099 virtual/threaded/transitions/transition-end-event-attributes.html [ Failure ] crbug.com/591099 virtual/threaded/transitions/transition-end-event-container.html [ Failure ] -crbug.com/591099 virtual/threaded/transitions/transition-end-event-destroy-iframe.html [ Crash ] +crbug.com/591099 virtual/threaded/transitions/transition-end-event-destroy-iframe.html [ Crash Failure ] crbug.com/591099 virtual/threaded/transitions/transition-end-event-destroy-renderer.html [ Failure ] crbug.com/591099 virtual/threaded/transitions/transition-end-event-left.html [ Failure ] crbug.com/591099 virtual/threaded/transitions/transition-end-event-multiple-01.html [ Failure Timeout ] @@ -22097,34 +22109,34 @@ crbug.com/591099 virtual/wheelscrolllatching/fast/events/wheel/wheelevent-in-horizontal-scrollbar-in-rtl.html [ Failure ] crbug.com/591099 virtual/wheelscrolllatching/fast/events/wheel/wheelevent-in-vertical-scrollbar-in-rtl.html [ Failure ] crbug.com/591099 virtual/wheelscrolllatching/fast/events/wheel/wheelevent-mousewheel-interaction.html [ Failure ] -crbug.com/591099 vr/events_vrdisplayactivate.html [ Crash ] -crbug.com/591099 vr/events_vrdisplayconnect.html [ Crash ] -crbug.com/591099 vr/events_vrdisplaypresentchange.html [ Crash ] -crbug.com/591099 vr/exitPresent_reject_notpresenting.html [ Crash ] -crbug.com/591099 vr/exitPresent_resolve.html [ Crash ] -crbug.com/591099 vr/getEyeParameters_match.html [ Crash ] -crbug.com/591099 vr/getLayers_notpresenting.html [ Crash ] -crbug.com/591099 vr/getLayers_presenting.html [ Crash ] -crbug.com/591099 vr/getLayers_presenting_nondefaultbounds.html [ Crash ] -crbug.com/591099 vr/getLayers_update.html [ Crash ] -crbug.com/591099 vr/requestAnimationFrame_consistentTimestamps.html [ Crash ] -crbug.com/591099 vr/requestAnimationFrame_handoff.html [ Crash ] -crbug.com/591099 vr/requestAnimationFrame_submitFrame_combinations.html [ Crash Timeout ] -crbug.com/591099 vr/requestPresent_reject_badleftbounds.html [ Crash ] -crbug.com/591099 vr/requestPresent_reject_badrightbounds.html [ Crash ] -crbug.com/591099 vr/requestPresent_reject_nogesture.html [ Crash ] -crbug.com/591099 vr/requestPresent_reject_nolayers.html [ Crash ] -crbug.com/591099 vr/requestPresent_reject_nosource.html [ Crash ] -crbug.com/591099 vr/requestPresent_reject_notsupported.html [ Crash ] -crbug.com/591099 vr/requestPresent_reject_nowebgl.html [ Crash ] -crbug.com/591099 vr/requestPresent_reject_nullsource.html [ Crash ] -crbug.com/591099 vr/requestPresent_reject_toomanylayers.html [ Crash ] -crbug.com/591099 vr/requestPresent_resolve.html [ Crash ] -crbug.com/591099 vr/requestPresent_resolve_repeatwithgesture.html [ Crash ] -crbug.com/591099 vr/requestPresent_resolve_repeatwithoutgesture.html [ Crash ] -crbug.com/591099 vr/requestPresent_resolve_then_reject.html [ Crash Timeout ] -crbug.com/591099 vr/requestPresent_resolve_webgl2.html [ Crash ] -crbug.com/591099 vr/stageParameters_match.html [ Crash ] +crbug.com/591099 vr/events_vrdisplayactivate.html [ Crash Pass ] +crbug.com/591099 vr/events_vrdisplayconnect.html [ Crash Pass ] +crbug.com/591099 vr/events_vrdisplaypresentchange.html [ Crash Pass ] +crbug.com/591099 vr/exitPresent_reject_notpresenting.html [ Crash Pass ] +crbug.com/591099 vr/exitPresent_resolve.html [ Crash Pass ] +crbug.com/591099 vr/getEyeParameters_match.html [ Crash Pass ] +crbug.com/591099 vr/getLayers_notpresenting.html [ Crash Pass ] +crbug.com/591099 vr/getLayers_presenting.html [ Crash Pass ] +crbug.com/591099 vr/getLayers_presenting_nondefaultbounds.html [ Crash Pass ] +crbug.com/591099 vr/getLayers_update.html [ Crash Pass ] +crbug.com/591099 vr/requestAnimationFrame_consistentTimestamps.html [ Crash Pass ] +crbug.com/591099 vr/requestAnimationFrame_handoff.html [ Crash Pass ] +crbug.com/591099 vr/requestAnimationFrame_submitFrame_combinations.html [ Crash Pass Timeout ] +crbug.com/591099 vr/requestPresent_reject_badleftbounds.html [ Crash Pass ] +crbug.com/591099 vr/requestPresent_reject_badrightbounds.html [ Crash Pass ] +crbug.com/591099 vr/requestPresent_reject_nogesture.html [ Crash Pass ] +crbug.com/591099 vr/requestPresent_reject_nolayers.html [ Crash Pass ] +crbug.com/591099 vr/requestPresent_reject_nosource.html [ Crash Pass ] +crbug.com/591099 vr/requestPresent_reject_notsupported.html [ Crash Pass ] +crbug.com/591099 vr/requestPresent_reject_nowebgl.html [ Crash Pass ] +crbug.com/591099 vr/requestPresent_reject_nullsource.html [ Crash Pass ] +crbug.com/591099 vr/requestPresent_reject_toomanylayers.html [ Crash Pass ] +crbug.com/591099 vr/requestPresent_resolve.html [ Crash Pass ] +crbug.com/591099 vr/requestPresent_resolve_repeatwithgesture.html [ Crash Pass ] +crbug.com/591099 vr/requestPresent_resolve_repeatwithoutgesture.html [ Crash Pass ] +crbug.com/591099 vr/requestPresent_resolve_then_reject.html [ Crash Pass Timeout ] +crbug.com/591099 vr/requestPresent_resolve_webgl2.html [ Crash Pass ] +crbug.com/591099 vr/stageParameters_match.html [ Crash Pass ] crbug.com/591099 webaudio/BiquadFilter/tail-time-lowpass.html [ Timeout ] crbug.com/591099 webaudio/OfflineAudioContext/offlineaudiocontext-detached-no-crash.html [ Failure ] crbug.com/591099 webaudio/ScriptProcessor/scriptprocessornode-detached-no-crash.html [ Failure ]
diff --git a/third_party/WebKit/LayoutTests/FlagExpectations/enable-slimming-paint-v2 b/third_party/WebKit/LayoutTests/FlagExpectations/enable-slimming-paint-v2 index ffcbead..c28216d 100644 --- a/third_party/WebKit/LayoutTests/FlagExpectations/enable-slimming-paint-v2 +++ b/third_party/WebKit/LayoutTests/FlagExpectations/enable-slimming-paint-v2
@@ -520,11 +520,9 @@ Bug(none) fast/canvas/OffscreenCanvas-transform-shadow-in-worker.html [ Failure ] Bug(none) fast/canvas/webgl/pixelated.html [ Failure ] Bug(none) fast/clip/nestedTransparencyClip.html [ Failure ] -Bug(none) fast/clip/overflow-border-radius-clip.html [ Failure ] Bug(none) fast/clip/overflow-border-radius-combinations.html [ Failure ] Bug(none) fast/clip/overflow-border-radius-composited-parent.html [ Failure ] Bug(none) fast/clip/overflow-border-radius-composited.html [ Failure ] -Bug(none) fast/clip/overflow-border-radius-fixed-position.html [ Failure ] Bug(none) fast/clip/overflow-border-radius-transformed.html [ Failure ] Bug(none) fast/css-generated-content/014.html [ Failure ] Bug(none) fast/css-generated-content/table-parts-before-and-after.html [ Failure ] @@ -637,7 +635,6 @@ Bug(none) fast/inline/inline-continuation-borders.html [ Failure ] Bug(none) fast/layers/normal-flow-hit-test.html [ Crash Failure ] Bug(none) fast/layers/opacity-outline.html [ Failure ] -Bug(none) fast/layers/overflow-hidden-rounded-corners-occlusion.html [ Failure ] Bug(none) fast/layers/remove-layer-with-nested-stacking.html [ Skip ] Bug(none) fast/layers/scroll-rect-to-visible.html [ Failure ] Bug(none) fast/lists/008.html [ Failure ] @@ -1006,7 +1003,6 @@ Bug(none) paint/invalidation/svg/deep-nested-embedded-svg-size-changes-no-layout-triggers-1.html [ Failure ] Bug(none) paint/invalidation/svg/deep-nested-embedded-svg-size-changes-no-layout-triggers-2.html [ Failure ] Bug(none) paint/invalidation/svg/use-detach.svg [ Failure ] -Bug(none) paint/background/rounded-clip-fractional-offset.html [ Failure ] Bug(none) paint/clipath/clip-path-with-background-and-box-behind.html [ Failure ] Bug(none) paint/frames/frameset-with-stacking-context-and-not-stacking-context-children.html [ Failure ] Bug(none) paint/frames/frameset-with-stacking-contexts.html [ Failure ] @@ -1252,7 +1248,6 @@ # Mask does not work correctly crbug.com/707444 svg/W3C-SVG-1.1/masking-intro-01-f.svg [ Failure ] -crbug.com/707444 svg/as-background-image/svg-as-background-6.html [ Failure ] crbug.com/707444 svg/batik/masking/maskRegions.svg [ Failure ] crbug.com/707444 svg/custom/clamped-masking-clipping.svg [ Failure ] crbug.com/707444 svg/custom/clip-mask-negative-scale.svg [ Failure ] @@ -1568,9 +1563,16 @@ crbug.com/589265 css3/blending/mix-blend-mode-isolated-group-3.html [ Failure ] crbug.com/589265 css3/blending/svg-blend-exclusion.html [ Failure ] crbug.com/589265 css3/blending/svg-blend-screen.html [ Failure ] +crbug.com/589265 fast/backgrounds/size/contain-and-cover-zoomed.html [ Failure ] crbug.com/589265 fast/css/ZeroOpacityLayers.html [ Failure ] crbug.com/589265 fast/css/ZeroOpacityLayers2.html [ Failure ] +crbug.com/589265 fast/forms/datalist/input-appearance-range-with-transform.html [ Failure ] crbug.com/589265 fast/forms/indeterminate.html [ Failure ] +crbug.com/589265 images/color-profile-filter.html [ Failure ] +crbug.com/589265 paint/invalidation/svg/repaint-paintorder.svg [ Failure ] +crbug.com/589265 paint/invalidation/svg/tabgroup.svg [ Failure ] +crbug.com/589265 svg/W3C-SVG-1.1/animate-elem-33-t.svg [ Failure ] +crbug.com/589265 svg/as-background-image/background-image-preserveaspectRatio-support.html [ Failure ] crbug.com/589265 svg/custom/small-rect-scale.svg [ Failure ] crbug.com/589265 svg/dynamic-updates/SVGFEBlendElement-dom-in-attr.html [ Failure ] crbug.com/589265 svg/dynamic-updates/SVGFEBlendElement-dom-in2-attr.html [ Failure ] @@ -1578,6 +1580,9 @@ crbug.com/589265 svg/dynamic-updates/SVGFEBlendElement-svgdom-in-prop.html [ Failure ] crbug.com/589265 svg/dynamic-updates/SVGFEBlendElement-svgdom-in2-prop.html [ Failure ] crbug.com/589265 svg/dynamic-updates/SVGFEBlendElement-svgdom-mode-prop.html [ Failure ] +crbug.com/589265 svg/text/text-selection-align-01-b.svg [ Failure ] +crbug.com/589265 svg/text/text-selection-align-05-b.svg [ Failure ] +crbug.com/589265 svg/zoom/page/zoom-svg-as-background-with-relative-size.html [ Failure ] # Failures due to SPv2 using SkBlendMode::kDstIn to implement masks. # Some rounding differences is expected but none of them should be apparent. @@ -1620,7 +1625,6 @@ # Subpixel adjustments due to differences in compositing crbug.com/589265 animations/animated-filter-svg-element.html [ Failure Crash ] crbug.com/589265 compositing/overflow/do-not-paint-outline-into-composited-scrolling-contents.html [ Failure ] -crbug.com/589265 fast/css/all-shorthand-first-letter.html [ Failure ] crbug.com/589265 fast/forms/number/number-appearance-spinbutton-layer.html [ Failure ] crbug.com/589265 fast/layers/add-layer-with-nested-stacking.html [ Failure ] crbug.com/589265 fast/layers/opacity-transforms.html [ Failure ] @@ -1673,7 +1677,6 @@ Bug(700530) fast/css3-text/css3-text-decoration/text-underline-position/text-underline-position-cjk.html [ Failure ] # The following debug crashes have not been triaged. -crbug.com/702805 css3/blending/svg-blend-layer-filter.html [ Crash ] crbug.com/702805 virtual/threaded/compositing/visibility/overlays-persist-on-navigation.html [ Crash ] crbug.com/702805 svg/filters/feImage-self-referencing.html [ Crash ] crbug.com/702805 svg/filters/feImage-self-and-other-referencing.html [ Crash ] @@ -1745,3 +1748,5 @@ # reasons, in particular that the composited layerization algorithm provides # different results. Bug(none) paint/invalidation/compositing/subpixel-offset-scaled-transform-composited.html [ Failure ] + +crbug.com/737275 svg/as-background-image/svg-as-background-6.html [ Crash Failure ]
diff --git a/third_party/WebKit/LayoutTests/TestExpectations b/third_party/WebKit/LayoutTests/TestExpectations index 6e6368b..cbf0890 100644 --- a/third_party/WebKit/LayoutTests/TestExpectations +++ b/third_party/WebKit/LayoutTests/TestExpectations
@@ -592,7 +592,7 @@ crbug.com/635619 virtual/layout_ng/fast/block/float/035.html [ Failure ] crbug.com/635619 virtual/layout_ng/fast/block/float/add-float-back-to-anonymous-block.html [ Failure ] crbug.com/719615 virtual/layout_ng/fast/block/float/add-inlines-in-block-children-block.html [ Failure ] -crbug.com/635619 virtual/layout_ng/fast/block/float/assert-when-moving-float.html [ Crash ] +crbug.com/635619 virtual/layout_ng/fast/block/float/assert-when-moving-float.html [ Failure ] crbug.com/635619 virtual/layout_ng/fast/block/float/avoid-floats-when-negative-margin-top-2.html [ Failure ] crbug.com/635619 virtual/layout_ng/fast/block/float/avoid-floats-when-negative-margin-top-3.html [ Failure ] crbug.com/635619 virtual/layout_ng/fast/block/float/avoid-floats-when-negative-margin-top-4.html [ Failure ] @@ -673,7 +673,7 @@ crbug.com/635619 virtual/layout_ng/fast/block/float/remove-line-above-float-above-line-crash.html [ Failure ] crbug.com/635619 virtual/layout_ng/fast/block/float/rubybase-children-made-inline-crash.html [ Failure ] crbug.com/635619 virtual/layout_ng/fast/block/float/rubybase-children-moved-crash-2.html [ Failure Crash ] -crbug.com/635619 virtual/layout_ng/fast/block/float/rubybase-children-moved-crash.html [ Crash ] +crbug.com/635619 virtual/layout_ng/fast/block/float/rubybase-children-moved-crash.html [ Crash Failure ] crbug.com/635619 virtual/layout_ng/fast/block/float/shrink-to-avoid-float-complexity.html [ Failure ] crbug.com/635619 virtual/layout_ng/fast/block/float/shrink-to-fit-width.html [ Failure ] crbug.com/635619 virtual/layout_ng/fast/block/float/split-inline-sibling-of-float-crash.html [ Crash ] @@ -1527,9 +1527,6 @@ crbug.com/321237 [ Win ] fast/multicol/span/pseudo-before-after-in-content.html [ Failure ] crbug.com/321237 [ Win ] fast/selectors/004.html [ Failure ] -crbug.com/739514 external/wpt/html/semantics/scripting-1/the-script-element/load-error-events-2.html [ Failure ] -crbug.com/715369 external/wpt/html/semantics/scripting-1/the-script-element/module/load-error-events-inline.html [ Failure ] - crbug.com/501659 fast/xsl/xslt-missing-namespace-in-xslt.xml [ Failure ] crbug.com/501659 http/tests/security/xss-DENIED-xml-external-entity.xhtml [ Failure ]
diff --git a/third_party/WebKit/LayoutTests/W3CImportExpectations b/third_party/WebKit/LayoutTests/W3CImportExpectations index edbe374..634d8150 100644 --- a/third_party/WebKit/LayoutTests/W3CImportExpectations +++ b/third_party/WebKit/LayoutTests/W3CImportExpectations
@@ -19,6 +19,8 @@ ## Owners: paint-dev@chromium.org # external/wpt/2dcontext [ Pass ] +## Owners: garykac@chromium.org +# external/wpt/clipboard-apis [Pass] ## Owners: jsbell@chromium.org # external/wpt/FileAPI [ Pass ] ## Owners: jsbell@chromium.org
diff --git a/third_party/WebKit/LayoutTests/editing/selection/empty-cell-right-click-expected.txt b/third_party/WebKit/LayoutTests/editing/selection/empty-cell-right-click-expected.txt deleted file mode 100644 index e0c1ba4..0000000 --- a/third_party/WebKit/LayoutTests/editing/selection/empty-cell-right-click-expected.txt +++ /dev/null
@@ -1,2 +0,0 @@ -Before: selection type is Caret -After: selection type is Caret
diff --git a/third_party/WebKit/LayoutTests/editing/selection/empty-cell-right-click.html b/third_party/WebKit/LayoutTests/editing/selection/empty-cell-right-click.html deleted file mode 100644 index ed29b8c..0000000 --- a/third_party/WebKit/LayoutTests/editing/selection/empty-cell-right-click.html +++ /dev/null
@@ -1,36 +0,0 @@ -<html> -<head> -<title>Right clicking on an empty cell should not extend the selection to the next cell.</title> -</head> -<body> -<div contentEditable="true"> -<table border="1" cellspacing="0"><tr><td id="first" width="50" height="25pt"></td><td width="50" height="25pt"></td><td width="50" height="25pt"></td></tr></table> -</div> -<ul id="console"></ul> -</body> -<script> -if (window.testRunner) { - testRunner.dumpAsText(); - var elem = document.getElementById("first"); - x = elem.offsetLeft + elem.offsetWidth / 2; - y = elem.offsetTop + elem.offsetHeight / 2; - eventSender.mouseMoveTo(x, y); - eventSender.mouseDown(); - eventSender.mouseUp(); - - log("Before: selection type is " + window.getSelection().type); - - eventSender.contextClick(); - - log("After: selection type is " + window.getSelection().type); -} - -function log(str) { - var li = document.createElement("li"); - li.appendChild(document.createTextNode(str)); - var console = document.getElementById("console"); - console.appendChild(li); -} - -</script> -</html>
diff --git a/third_party/WebKit/LayoutTests/external/wpt/clipboard-apis/async-interfaces.https.html b/third_party/WebKit/LayoutTests/external/wpt/clipboard-apis/async-interfaces.https.html new file mode 100644 index 0000000..a82e39f --- /dev/null +++ b/third_party/WebKit/LayoutTests/external/wpt/clipboard-apis/async-interfaces.https.html
@@ -0,0 +1,34 @@ +<!DOCTYPE html> +<meta charset=utf-8> +<title>Clipboard IDL test</title> +<link rel="help" href="https://w3c.github.io/clipboard-apis/"> +<script src=/resources/testharness.js></script> +<script src=/resources/testharnessreport.js></script> +<script src=/resources/WebIDLParser.js></script> +<script src=/resources/idlharness.js></script> +<script> +'use strict'; + +function doTest(idls) { + var idl_array = new IdlArray(); + idl_array.add_untested_idls('interface Navigator {};'); + idl_array.add_untested_idls('interface EventTarget {};'); + for (let idl of idls) { + idl_array.add_idls(idl); + } + idl_array.add_objects({ + Navigator: ['navigator'], + Clipboard: ['navigator.clipboard'], + }); + idl_array.test(); +}; + +function fetchText(url) { + return fetch(url).then((response) => response.text()); +} + +promise_test(() => { + return Promise.all(["/interfaces/clipboard.idl"].map(fetchText)) + .then(doTest); +}, "Test driver"); +</script>
diff --git a/third_party/WebKit/LayoutTests/external/wpt/clipboard-apis/async-navigator-clipboard-basics.https.html b/third_party/WebKit/LayoutTests/external/wpt/clipboard-apis/async-navigator-clipboard-basics.https.html new file mode 100644 index 0000000..3126655 --- /dev/null +++ b/third_party/WebKit/LayoutTests/external/wpt/clipboard-apis/async-navigator-clipboard-basics.https.html
@@ -0,0 +1,69 @@ +<!DOCTYPE html> +<meta charset="utf-8"> +<title>Async Clipboard basic tests</title> +<script src="/resources/testharness.js"></script> +<script src="/resources/testharnessreport.js"></script> +<script> + +test(function() { + assert_not_equals(navigator.clipboard, undefined); + assert_true(navigator.clipboard instanceof Clipboard); + assert_equals(navigator.clipboard, navigator.clipboard); +}, "navigator.clipboard exists"); + +/* clipboard.write() */ + +promise_test(function() { + var dt = new DataTransfer(); + dt.items.add("Howdy", "text/plain"); + return navigator.clipboard.write(dt); +}, "navigator.clipboard.write(DataTransfer) succeeds"); + +promise_test(function(t) { + return promise_rejects(t, new TypeError(), + navigator.clipboard.write()); +}, "navigator.clipboard.write() fails (expect DataTransfer)"); + +promise_test(function(t) { + return promise_rejects(t, new TypeError(), + navigator.clipboard.write(null)); +}, "navigator.clipboard.write(null) fails (expect DataTransfer)"); + +promise_test(function(t) { + return promise_rejects(t, new TypeError(), + navigator.clipboard.write("Bad string")); +}, "navigator.clipboard.write(DOMString) fails (expect DataTransfer)"); + + +/* clipboard.writeText() */ + +promise_test(function() { + return navigator.clipboard.writeText("New clipboard text"); +}, "navigator.clipboard.writeText(DOMString) succeeds"); + +promise_test(function(t) { + return promise_rejects(t, new TypeError(), + navigator.clipboard.writeText()); +}, "navigator.clipboard.writeText() fails (expect DOMString)"); + + +/* clipboard.read() */ + +promise_test(function() { + return navigator.clipboard.read() + .then(function(result) { + assert_true(result instanceof DataTransfer); + }); +}, "navigator.clipboard.read() succeeds"); + + +/* clipboard.readText() */ + +promise_test(function() { + return navigator.clipboard.readText() + .then(function(result) { + assert_equals(typeof result, "string"); + }); +}, "navigator.clipboard.readText() succeeds"); + +</script>
diff --git a/third_party/WebKit/LayoutTests/external/wpt/clipboard-apis/async-write-dttext-read-dttext-manual.https.html b/third_party/WebKit/LayoutTests/external/wpt/clipboard-apis/async-write-dttext-read-dttext-manual.https.html new file mode 100644 index 0000000..1fe946a --- /dev/null +++ b/third_party/WebKit/LayoutTests/external/wpt/clipboard-apis/async-write-dttext-read-dttext-manual.https.html
@@ -0,0 +1,30 @@ +<!DOCTYPE html> +<meta charset="utf-8"> +<title>Async Clipboard write (dt/text) -> read (dt/text) tests</title> +<script src="/resources/testharness.js"></script> +<script src="/resources/testharnessreport.js"></script> +<script> +async_test(function(t) { + var test_data = "Clipboard write (dt/text) -> read (dt/text) test data"; + var cb = navigator.clipboard; + var dt = new DataTransfer(); + dt.items.add(test_data, "text/plain"); + + cb.write(dt).then(t.step_func(() => { + cb.read().then(t.step_func((data) => { + assert_equals(data.items.length, 1); + data.items[0].getAsString(t.step_func((s) => { + assert_equals(s, test_data); + t.done(); + })); + }), function() { + t.unreached_func("clipboard.read() fail"); + }); + }), function() { + t.unreached_func("clipboard.write() fail"); + }); +}, "Verify write and read clipboard (DataTransfer/text)"); +</script> +Note: This is a manual test because it writes/reads to the shared system +clipboard and thus cannot be run async with other tests that might interact +with the clipboard.
diff --git a/third_party/WebKit/LayoutTests/external/wpt/clipboard-apis/async-write-dttext-read-text-manual.https.html b/third_party/WebKit/LayoutTests/external/wpt/clipboard-apis/async-write-dttext-read-text-manual.https.html new file mode 100644 index 0000000..b341d92 --- /dev/null +++ b/third_party/WebKit/LayoutTests/external/wpt/clipboard-apis/async-write-dttext-read-text-manual.https.html
@@ -0,0 +1,27 @@ +<!DOCTYPE html> +<meta charset="utf-8"> +<title>Async Clipboard write (dt/text) -> readText tests</title> +<script src="/resources/testharness.js"></script> +<script src="/resources/testharnessreport.js"></script> +<script> +async_test(function(t) { + var test_data = "Clipboard write (dt/text) -> readText test data"; + var cb = navigator.clipboard; + var dt = new DataTransfer(); + dt.items.add(test_data, "text/plain"); + + cb.write(dt).then(t.step_func(() => { + cb.readText().then(t.step_func((data) => { + assert_equals(data, test_data); + t.done(); + }), function() { + t.unreached_func("clipboard.read() fail"); + }); + }), function() { + t.unreached_func("clipboard.write() fail"); + }); +}, "Verify write and read clipboard (DataTransfer/text)"); +</script> +Note: This is a manual test because it writes/reads to the shared system +clipboard and thus cannot be run async with other tests that might interact +with the clipboard.
diff --git a/third_party/WebKit/LayoutTests/external/wpt/clipboard-apis/async-write-text-read-dttext-manual.https.html b/third_party/WebKit/LayoutTests/external/wpt/clipboard-apis/async-write-text-read-dttext-manual.https.html new file mode 100644 index 0000000..ab11ab9 --- /dev/null +++ b/third_party/WebKit/LayoutTests/external/wpt/clipboard-apis/async-write-text-read-dttext-manual.https.html
@@ -0,0 +1,27 @@ +<!DOCTYPE html> +<meta charset="utf-8"> +<title>Async Clipboard writeText -> read (dt/text) tests</title> +<script src="/resources/testharness.js"></script> +<script src="/resources/testharnessreport.js"></script> +<script> +async_test(function(t) { + var test_data = "Clipboard writeText -> read(dt/text) test data"; + var cb = navigator.clipboard; + cb.writeText(test_data).then(t.step_func(() => { + cb.read().then(t.step_func((data) => { + assert_equals(data.items.length, 1); + data.items[0].getAsString(t.step_func((s) => { + assert_equals(s, test_data); + t.done(); + })); + }), function() { + t.unreached_func("clipboard.read() fail"); + }); + }), function() { + t.unreached_func("clipboard.writeText() fail"); + }); +}, "Verify write and read clipboard (DOMString)"); +</script> +Note: This is a manual test because it writes/reads to the shared system +clipboard and thus cannot be run async with other tests that might interact +with the clipboard.
diff --git a/third_party/WebKit/LayoutTests/external/wpt/clipboard-apis/async-write-text-read-text-manual.https.html b/third_party/WebKit/LayoutTests/external/wpt/clipboard-apis/async-write-text-read-text-manual.https.html new file mode 100644 index 0000000..a557216 --- /dev/null +++ b/third_party/WebKit/LayoutTests/external/wpt/clipboard-apis/async-write-text-read-text-manual.https.html
@@ -0,0 +1,24 @@ +<!DOCTYPE html> +<meta charset="utf-8"> +<title>Async Clipboard writeText -> readText tests</title> +<script src="/resources/testharness.js"></script> +<script src="/resources/testharnessreport.js"></script> +<script> +async_test(function(t) { + var test_data = "Clipboard writeText -> readText test data"; + var cb = navigator.clipboard; + cb.writeText(test_data).then(t.step_func(() => { + cb.readText().then(t.step_func((data) => { + assert_equals(data, test_data); + t.done(); + }), function() { + t.unreached_func("clipboard.readText() fail"); + }); + }), function() { + t.unreached_func("clipboard.writeText() fail"); + }); +}, "Verify write and read clipboard (DOMString)"); +</script> +Note: This is a manual test because it writes/reads to the shared system +clipboard and thus cannot be run async with other tests that might interact +with the clipboard.
diff --git a/third_party/WebKit/LayoutTests/external/wpt/interfaces/clipboard.idl b/third_party/WebKit/LayoutTests/external/wpt/interfaces/clipboard.idl new file mode 100644 index 0000000..ea969ca9 --- /dev/null +++ b/third_party/WebKit/LayoutTests/external/wpt/interfaces/clipboard.idl
@@ -0,0 +1,13 @@ +[SecureContext] +interface Clipboard : EventTarget { + Promise<DataTransfer> read(); + Promise<DOMString> readText(); + + Promise<void> write(DataTransfer data); + Promise<void> writeText(DOMString data); +}; + +[SecureContext] +partial interface Navigator { + [SameObject] readonly attribute Clipboard clipboard; +};
diff --git a/third_party/WebKit/LayoutTests/external/wpt/webusb/usbIsochronousInTransferResult.https.html b/third_party/WebKit/LayoutTests/external/wpt/webusb/usbIsochronousInTransferResult.https.html index da7c395..5cad38a 100644 --- a/third_party/WebKit/LayoutTests/external/wpt/webusb/usbIsochronousInTransferResult.https.html +++ b/third_party/WebKit/LayoutTests/external/wpt/webusb/usbIsochronousInTransferResult.https.html
@@ -4,7 +4,6 @@ <script> 'use strict'; - test(t => { let data_view = new DataView(Uint8Array.from([1, 2, 3, 4]).buffer); let packet_data_view = new DataView(data_view.buffer);
diff --git a/third_party/WebKit/LayoutTests/fast/forms/validation-bubble-appearance-escape.html b/third_party/WebKit/LayoutTests/fast/forms/validation-bubble-appearance-escape.html new file mode 100644 index 0000000..1e2b5d5 --- /dev/null +++ b/third_party/WebKit/LayoutTests/fast/forms/validation-bubble-appearance-escape.html
@@ -0,0 +1,12 @@ +<!DOCTYPE html> +<body> +<script src="../../resources/testharness.js"></script> +<script src="../../resources/testharnessreport.js"></script> +<input pattern="\d{4}" title="Please specify four digits." value="abc" style="position:absolute; bottom:600px"> +<script> +test(() => { + document.querySelector('input').setCustomValidity('<script>'); + document.querySelector('input').reportValidity(); +}, 'Showing a validation message with HTML tags should not cause a DCHECK failure.'); +</script> +</body>
diff --git a/third_party/WebKit/LayoutTests/http/tests/inspector/inspector-test.js b/third_party/WebKit/LayoutTests/http/tests/inspector/inspector-test.js index 0d394984..c71d83c 100644 --- a/third_party/WebKit/LayoutTests/http/tests/inspector/inspector-test.js +++ b/third_party/WebKit/LayoutTests/http/tests/inspector/inspector-test.js
@@ -856,7 +856,6 @@ * @constructor * @param {!string} dirPath * @param {!string} name - * @param {!function(?Bindings.TempFile)} callback */ InspectorTest.TempFileMock = function(dirPath, name) { @@ -905,9 +904,10 @@ /** * @param {!Common.OutputStream} outputStream - * @param {!Bindings.OutputStreamDelegate} delegate + * @param {function(*)=} progress + * @return {!Promise<boolean>} */ - copyToOutputStream: function(outputStream, delegate) + copyToOutputStream: function(outputStream, progress) { var name = this._name; var text = this._chunks.join(""); @@ -929,11 +929,11 @@ cancel: function() { } } - delegate.onTransferStarted(chunkedReaderMock); outputStream.write(text); - delegate.onChunkTransferred(chunkedReaderMock); + if (progress) + progress(chunkedReaderMock); outputStream.close(); - delegate.onTransferFinished(chunkedReaderMock); + return Promise.resolve(true); }, remove: function() { }
diff --git a/third_party/WebKit/LayoutTests/http/tests/inspector/timeline-test.js b/third_party/WebKit/LayoutTests/http/tests/inspector/timeline-test.js index 616b8ed7..3cae88d 100644 --- a/third_party/WebKit/LayoutTests/http/tests/inspector/timeline-test.js +++ b/third_party/WebKit/LayoutTests/http/tests/inspector/timeline-test.js
@@ -69,9 +69,6 @@ return "{reason: " + cause.reason + ", stackTrace: " + stackTrace + "}"; } -InspectorTest.preloadPanel("timeline"); -Bindings.TempFile = InspectorTest.TempFileMock; - InspectorTest.createTracingModel = function(events) { var model = new SDK.TracingModel(new Bindings.TempFileBackingStorage("tracing")); @@ -302,13 +299,57 @@ return null; } -InspectorTest.FakeFileReader = function(input, delegate, callback) -{ - this._delegate = delegate; - this._callback = callback; - this._input = input; - this._loadedSize = 0; - this._fileSize = input.length; +InspectorTest.FakeFileReader = class { + constructor(input, chunkSize, chunkTransferredCallback) + { + this._input = input; + this._loadedSize = 0; + this._fileSize = input.length; + this._chunkTransferredCallback = chunkTransferredCallback; + } + + read(output) + { + var length = this._input.length; + var half = (length + 1) >> 1; + + var chunk = this._input.substring(0, half); + this._loadedSize += chunk.length; + output.write(chunk); + if (this._chunkTransferredCallback) + this._chunkTransferredCallback(this); + + chunk = this._input.substring(half); + this._loadedSize += chunk.length; + output.write(chunk); + if (this._chunkTransferredCallback) + this._chunkTransferredCallback(this); + + output.close(); + return Promise.resolve(true); + } + + cancel() { } + + loadedSize() + { + return this._loadedSize; + } + + fileSize() + { + return this._fileSize; + } + + fileName() + { + return "fakeFile"; + } + + error() + { + return null; + } }; InspectorTest.dumpFrame = function(frame) @@ -372,60 +413,11 @@ InspectorTest.dumpFlameChartProvider(provider, includeGroups); } -InspectorTest.FakeFileReader.prototype = { - start: function(output) - { - this._delegate.onTransferStarted(this); - - var length = this._input.length; - var half = (length + 1) >> 1; - - var chunk = this._input.substring(0, half); - this._loadedSize += chunk.length; - output.write(chunk); - this._delegate.onChunkTransferred(this); - - chunk = this._input.substring(half); - this._loadedSize += chunk.length; - output.write(chunk); - this._delegate.onChunkTransferred(this); - - output.close(); - this._delegate.onTransferFinished(this); - - this._callback(); - }, - - cancel: function() { }, - - loadedSize: function() - { - return this._loadedSize; - }, - - fileSize: function() - { - return this._fileSize; - }, - - fileName: function() - { - return "fakeFile"; - } -}; - InspectorTest.loadTimeline = function(timelineData) { - var timeline = UI.panels.timeline; - - function createFileReader(file, delegate) - { - return new InspectorTest.FakeFileReader(timelineData, delegate, timeline._saveToFile.bind(timeline)); - } - - InspectorTest.override(Timeline.TimelineLoader, "_createFileReader", createFileReader); + Bindings.ChunkedFileReader = InspectorTest.FakeFileReader; var promise = new Promise(fulfill => InspectorTest.runWhenTimelineIsReady(fulfill)); - timeline._loadFromFile({}); + UI.panels.timeline._loadFromFile(timelineData); return promise; }
diff --git a/third_party/WebKit/LayoutTests/images/color-profile-reflection.html b/third_party/WebKit/LayoutTests/images/color-profile-reflection.html index 21f87cb4..ec58703 100644 --- a/third_party/WebKit/LayoutTests/images/color-profile-reflection.html +++ b/third_party/WebKit/LayoutTests/images/color-profile-reflection.html
@@ -27,8 +27,7 @@ }; function done() { - runAfterLayoutAndPaint(function() { testRunner.notifyDone() }); + window.testRunner.notifyDone(); } - </script> </html>
diff --git a/third_party/WebKit/LayoutTests/inspector-protocol/page/setDocumentContent-expected.txt b/third_party/WebKit/LayoutTests/inspector-protocol/page/setDocumentContent-expected.txt new file mode 100644 index 0000000..1c202f1 --- /dev/null +++ b/third_party/WebKit/LayoutTests/inspector-protocol/page/setDocumentContent-expected.txt
@@ -0,0 +1,7 @@ +Tests that Page.setDocumentContent works. +Page enabled +Main Frame obtained +Document content before: <html><head></head><body><div>Привет мир</div></body></html> +Document content set +Document content after: <html><head></head><body><div>こんにちは世界</div></body></html> +
diff --git a/third_party/WebKit/LayoutTests/inspector-protocol/page/setDocumentContent.js b/third_party/WebKit/LayoutTests/inspector-protocol/page/setDocumentContent.js new file mode 100644 index 0000000..6131fa3 --- /dev/null +++ b/third_party/WebKit/LayoutTests/inspector-protocol/page/setDocumentContent.js
@@ -0,0 +1,18 @@ +(async function(testRunner) { + let {page, session, dp} = await testRunner.startHTML(`<div>Привет мир</div>`, + 'Tests that Page.setDocumentContent works.'); + + await dp.Page.enable(); + testRunner.log('Page enabled'); + + var resourceTreeResponse = await dp.Page.getResourceTree(); + var mainFrameId = resourceTreeResponse.result.frameTree.frame.id; + testRunner.log('Main Frame obtained'); + + testRunner.log('Document content before: ' + await session.evaluate(() => document.documentElement.outerHTML)); + await dp.Page.setDocumentContent({frameId: mainFrameId, html: '<div>こんにちは世界</div>'}); + testRunner.log('Document content set'); + testRunner.log('Document content after: ' + await session.evaluate(() => document.documentElement.outerHTML)); + + testRunner.completeTest(); +})
diff --git a/third_party/WebKit/LayoutTests/inspector/components/chunked-file-reader-expected.txt b/third_party/WebKit/LayoutTests/inspector/components/chunked-file-reader-expected.txt index 05a9d67..54b6b5d 100644 --- a/third_party/WebKit/LayoutTests/inspector/components/chunked-file-reader-expected.txt +++ b/third_party/WebKit/LayoutTests/inspector/components/chunked-file-reader-expected.txt
@@ -1,7 +1,6 @@ This tests that ChunkedFileReader properly re-assembles chunks, especially in case these contain multibyte characters. -Bindings.OutputStreamDelegate.onTransferStarted() called -Chunks transferred: 40 -Bindings.OutputStreamDelegate.onTransferFinished() called +Read result: true +Chunks transferred: 41 DONE
diff --git a/third_party/WebKit/LayoutTests/inspector/components/chunked-file-reader.html b/third_party/WebKit/LayoutTests/inspector/components/chunked-file-reader.html index 4226238..78a6cb0 100644 --- a/third_party/WebKit/LayoutTests/inspector/components/chunked-file-reader.html +++ b/third_party/WebKit/LayoutTests/inspector/components/chunked-file-reader.html
@@ -4,50 +4,7 @@ <script src="../../http/tests/inspector/inspector-test.js"></script> <script> -function initialize_ChunkedFileReaderTest() -{ - -InspectorTest.TestOutputStreamDelegate = function(doneCallback) -{ - this._doneCallback = doneCallback; - this._chunkCount = 0; -} - -InspectorTest.TestOutputStreamDelegate.prototype = { - onTransferStarted: function() - { - InspectorTest.addResult("Bindings.OutputStreamDelegate.onTransferStarted() called"); - }, - - onTransferFinished: function() - { - InspectorTest.addResult("Chunks transferred: " + this._chunkCount); - InspectorTest.addResult("Bindings.OutputStreamDelegate.onTransferFinished() called"); - this._doneCallback(); - }, - - /** - * @param {!Bindings.ChunkedReader} reader - */ - onChunkTransferred: function(reader) - { - this._chunkCount++; - }, - - /** - * @param {!Bindings.ChunkedReader} reader - * @param {!Event} event - */ - onError: function(reader, event) - { - InspectorTest.addResult("Bindings.OutputStreamDelegate.onError() called"); - this._doneCallback(); - } -}; - -} - -function test() +async function test() { var text = ["Латынь из моды вышла ныне:\n", "Так, если правду вам сказать,\n", @@ -58,15 +15,17 @@ // Most of the characters above will be encoded as 2 bytes, so make sure we use odd // chunk size to cause chunk boundaries sometimes to happen between chaacter bytes. var chunkSize = 5; - var reader = new Bindings.ChunkedFileReader(blob, chunkSize, new InspectorTest.TestOutputStreamDelegate(onTransferFinished)); + var chunkCount = 0; + var reader = new Bindings.ChunkedFileReader(blob, chunkSize, () => ++chunkCount); var output = new Common.StringOutputStream(); - reader.start(output); - function onTransferFinished() - { - InspectorTest.assertEquals(text.join(""), output.data(), "Read text is different from written text"); - InspectorTest.addResult("DONE"); - InspectorTest.completeTest(); - } + + var error = await reader.read(output); + + InspectorTest.addResult("Read result: " + error); + InspectorTest.addResult("Chunks transferred: " + chunkCount); + InspectorTest.assertEquals(text.join(""), output.data(), "Read text is different from written text"); + InspectorTest.addResult("DONE"); + InspectorTest.completeTest(); } </script>
diff --git a/third_party/WebKit/LayoutTests/inspector/profiler/cpu-profiler-save-load.html b/third_party/WebKit/LayoutTests/inspector/profiler/cpu-profiler-save-load.html index 2ee335f..c13248d7 100644 --- a/third_party/WebKit/LayoutTests/inspector/profiler/cpu-profiler-save-load.html +++ b/third_party/WebKit/LayoutTests/inspector/profiler/cpu-profiler-save-load.html
@@ -108,13 +108,12 @@ var profileName = file.name.substr(0, file.name.length - ".cpuprofile".length); InspectorTest.waitUntilProfileViewIsShown(profileName, checkLoadedContent); profilesPanel._loadFromFile(file); - var onTransferFinished = Profiler.CPUProfileHeader.prototype.onTransferFinished; - Profiler.CPUProfileHeader.prototype.onTransferFinished = function() - { + InspectorTest.addSniffer(Profiler.CPUProfileHeader.prototype, "updateStatus", function(statusText) { + if (!statusText.startsWith("Parsing")) + return; loadedProfileData = this._jsonifiedProfile; - onTransferFinished.call(this); - UI.panels.js_profiler.showProfile(this); - } + setTimeout(() => UI.panels.js_profiler.showProfile(this), 0); + }, true); } ]);
diff --git a/third_party/WebKit/LayoutTests/inspector/profiler/heap-snapshot-loader.html b/third_party/WebKit/LayoutTests/inspector/profiler/heap-snapshot-loader.html index 556787f3..4a42abc 100644 --- a/third_party/WebKit/LayoutTests/inspector/profiler/heap-snapshot-loader.html +++ b/third_party/WebKit/LayoutTests/inspector/profiler/heap-snapshot-loader.html
@@ -81,33 +81,31 @@ size: sourceStringified.length }; - InspectorTest.override(Profiler.HeapProfileHeader.prototype, '_createFileReader', function(fileMock, delegate) { - return { - start: function(receiver) { - delegate.onTransferStarted(this); - receiver.write(sourceStringified); - delegate.onChunkTransferred(this); - receiver.close(); - delegate.onTransferFinished(this); - }, + Bindings.ChunkedFileReader = class { + constructor() {} - loadedSize: function() - { - return fileMock.size; - }, + read(receiver) { + receiver.write(sourceStringified); + receiver.close(); + return Promise.resolve(true); + } - fileSize: function() - { - return fileMock.size; - }, + loadedSize() + { + return fileMock.size; + } - fileName: function() - { - return fileMock.name; - } - }; - }); - InspectorTest.addSniffer(Profiler.HeapProfileHeader.prototype, "_snapshotReceived", function() { next(); }); + fileSize() + { + return fileMock.size; + } + + fileName() + { + return fileMock.name; + } + }; + InspectorTest.addSniffer(Profiler.HeapProfileHeader.prototype, "_snapshotReceived", next); panel._loadFromFile(fileMock); },
diff --git a/third_party/WebKit/LayoutTests/inspector/throttling/mobile-throttling.html b/third_party/WebKit/LayoutTests/inspector/throttling/mobile-throttling.html index ce09f425..a133853 100644 --- a/third_party/WebKit/LayoutTests/inspector/throttling/mobile-throttling.html +++ b/third_party/WebKit/LayoutTests/inspector/throttling/mobile-throttling.html
@@ -3,7 +3,6 @@ <title> Change mobile throttling setting.</title> <script src = "../../http/tests/inspector/inspector-test.js"></script> <script> - function initialize_ThrottlingTest() { InspectorTest.preloadPanel("network"); InspectorTest.preloadPanel("timeline"); @@ -14,8 +13,8 @@ var deviceModeView = new Emulation.DeviceModeView(); var deviceModeThrottling = deviceModeView._toolbar._throttlingConditionsItem; - var networkPanelThrottling = UI.panels.network._throttlingSelect; - var networkPanelOfflineCheckbox = UI.panels.network._offlineCheckbox.inputElement; + var networkPanelThrottling = UI.panels.network.throttlingSelectForTest(); + var networkPanelOfflineCheckbox = UI.panels.network.offlineCheckboxForTest().inputElement; var networkConditionsDrawerThrottlingSelector = self.runtime.sharedInstance(Network.NetworkConfigView)._networkThrottlingSelect; var performancePanelNetworkThrottling = UI.panels.timeline._networkThrottlingSelect;
diff --git a/third_party/WebKit/LayoutTests/inspector/tracing/timeline-misc/timeline-flame-chart-automatically-size-window.html b/third_party/WebKit/LayoutTests/inspector/tracing/timeline-misc/timeline-flame-chart-automatically-size-window.html index 3707495..0538d5f 100644 --- a/third_party/WebKit/LayoutTests/inspector/tracing/timeline-misc/timeline-flame-chart-automatically-size-window.html +++ b/third_party/WebKit/LayoutTests/inspector/tracing/timeline-misc/timeline-flame-chart-automatically-size-window.html
@@ -6,7 +6,7 @@ <script src="../resources/timeline-data.js"></script> <script> -function test() +async function test() { var timeline = UI.panels.timeline; timeline._onModeChanged(); @@ -19,7 +19,8 @@ } timeline.requestWindowTimes = requestWindowTimesHook; - InspectorTest.loadTimeline(InspectorTest.timelineData()).then(() => InspectorTest.completeTest()); + await InspectorTest.loadTimeline(InspectorTest.timelineData()); + InspectorTest.completeTest(); } </script>
diff --git a/third_party/WebKit/LayoutTests/inspector/tracing/tracing-timeline-load.html b/third_party/WebKit/LayoutTests/inspector/tracing/tracing-timeline-load.html index cc2856a..b707015 100644 --- a/third_party/WebKit/LayoutTests/inspector/tracing/tracing-timeline-load.html +++ b/third_party/WebKit/LayoutTests/inspector/tracing/tracing-timeline-load.html
@@ -6,9 +6,9 @@ function test() { - InspectorTest.TestTimelineLoaderClient = function(callback) + InspectorTest.TestTimelineLoaderClient = function() { - this._callback = callback; + this._completePromise = new Promise(resolve => this._resolve = resolve); } InspectorTest.TestTimelineLoaderClient.prototype = { @@ -29,19 +29,18 @@ loadingComplete: function(model) { - this.model = model; InspectorTest.addResult(`TimelineLoaderClient.loadingComplete(${!!model})`); - this._callback(); + this._resolve(model); }, + + modelPromise: function() + { + return this._completePromise; + } } - function runTestWithDataAndCheck(input, expectedOutput, callback) + async function runTestWithDataAndCheck(input, expectedOutput, callback) { - function createFileReader(file, delegate) - { - return new InspectorTest.FakeFileReader(input, delegate, () => {}); - } - function checkSaveData(output) { var saveData = JSON.parse(output); @@ -49,36 +48,24 @@ callback(); } - InspectorTest.override(Timeline.TimelineLoader, "_createFileReader", createFileReader); - var delegate = new InspectorTest.TestTimelineLoaderClient(onTimelineLoaded); - Timeline.TimelineLoader.loadFromFile({}, delegate); - async function onTimelineLoaded() - { - var saver = new Timeline.TracingTimelineSaver(); - var stream = new InspectorTest.StringOutputStream(InspectorTest.safeWrap(checkSaveData)); - var storage = delegate.model.backingStorage(); - await stream.open(""); - storage.writeToStream(stream, saver); - } + Bindings.ChunkedFileReader = InspectorTest.FakeFileReader; + var client = new InspectorTest.TestTimelineLoaderClient(); + var loader = Timeline.TimelineLoader.loadFromFile(input, client); + var stream = new InspectorTest.StringOutputStream(InspectorTest.safeWrap(checkSaveData)); + var model = await client.modelPromise(); + var storage = model.backingStorage(); + await stream.open(""); + storage.writeToStream(stream); } - function runTestOnMalformedInput(input, callback) + async function runTestOnMalformedInput(input, callback) { - function createFileReader(file, delegate) - { - return new InspectorTest.FakeFileReader(input, delegate, () => {}); - } - - function checkLoadedData(data) - { - var model = delegate.model; - InspectorTest.addResult("Model is empty: " + (!model || (!model.minimumRecordTime() && !model.maximumRecordTime()))); - callback(); - } - - InspectorTest.override(Timeline.TimelineLoader, "_createFileReader", createFileReader); - var delegate = new InspectorTest.TestTimelineLoaderClient(checkLoadedData); - Timeline.TimelineLoader.loadFromFile({}, delegate); + Bindings.ChunkedFileReader = InspectorTest.FakeFileReader; + var client = new InspectorTest.TestTimelineLoaderClient(); + var loader = Timeline.TimelineLoader.loadFromFile(input, client); + var model = await client.modelPromise(); + InspectorTest.addResult("Model is empty: " + (!model || (!model.minimumRecordTime() && !model.maximumRecordTime()))); + callback(); } var data = [{"args":{"number":32},"cat":"__metadata","name":"num_cpus","ph":"M","pid":32127,"tid":0,"ts":0},
diff --git a/third_party/WebKit/LayoutTests/media/controls/controls-cast-button-low-end-device.html b/third_party/WebKit/LayoutTests/media/controls/controls-cast-button-low-end-device.html new file mode 100644 index 0000000..a21dd2ba --- /dev/null +++ b/third_party/WebKit/LayoutTests/media/controls/controls-cast-button-low-end-device.html
@@ -0,0 +1,28 @@ +<!DOCTYPE html> +<title>media controls cast button low end device</title> +<script src="../../resources/testharness.js"></script> +<script src="../../resources/testharnessreport.js"></script> +<script src="../media-file.js"></script> +<script src="../media-controls.js"></script> +<script src="../remoteplayback/util.js"></script> +<video width="500"></video> +<script> +async_test(function(t) { + setIsLowEndDeviceForTest(t); + enableRemotePlaybackBackendForTest(t); + + var video = document.querySelector("video"); + video.controls = true; + + // No idea why waiting for the metadata to load is needed (or a couple + // of timeouts) since the button should show with the rest of the + // controls with no need for metadata. + // NOTE: shouldn't report the availability as true unless there's a URL + // to fling. + video.onloadedmetadata = t.step_func_done(_ => { + assert_true(isVisible(castButton(video))); + }); + + video.src = findMediaFile("video", "../content/test"); +}); +</script>
diff --git a/third_party/WebKit/LayoutTests/media/remoteplayback/util.js b/third_party/WebKit/LayoutTests/media/remoteplayback/util.js index 3502d1312..a38219f 100644 --- a/third_party/WebKit/LayoutTests/media/remoteplayback/util.js +++ b/third_party/WebKit/LayoutTests/media/remoteplayback/util.js
@@ -8,3 +8,12 @@ remotePlaybackBackendEnabledOldValue; }); } + +function setIsLowEndDeviceForTest(t) { + var isLowEndDeviceOldValue = internals.isLowEndDevice(); + internals.setIsLowEndDevice(true); + + t.add_cleanup(_ => { + internals.setIsLowEndDevice(isLowEndDeviceOldValue); + }); +}
diff --git a/third_party/WebKit/LayoutTests/media/remoteplayback/watch-availability-throws-low-end-device.html b/third_party/WebKit/LayoutTests/media/remoteplayback/watch-availability-throws-low-end-device.html index 87579191..60d46036 100644 --- a/third_party/WebKit/LayoutTests/media/remoteplayback/watch-availability-throws-low-end-device.html +++ b/third_party/WebKit/LayoutTests/media/remoteplayback/watch-availability-throws-low-end-device.html
@@ -5,6 +5,7 @@ <script src="../../resources/testharness.js"></script> <script src="../../resources/testharnessreport.js"></script> <script src="../media-file.js"></script> + <script src="util.js"></script> </head> <body> <script> @@ -12,6 +13,7 @@ // - internals.setIsLowEndDevice() async_test(function(t) { + enableRemotePlaybackBackendForTest(t); var v = document.createElement('video'); v.src = findMediaFile('video', '../content/test'); document.body.appendChild(v);
diff --git a/third_party/WebKit/LayoutTests/paint/overflow/composited-rounded-clip-floating-element-expected.txt b/third_party/WebKit/LayoutTests/paint/overflow/composited-rounded-clip-floating-element-expected.txt new file mode 100644 index 0000000..c0c1300 --- /dev/null +++ b/third_party/WebKit/LayoutTests/paint/overflow/composited-rounded-clip-floating-element-expected.txt
@@ -0,0 +1,16 @@ +layer at (0,0) size 800x600 + LayoutView at (0,0) size 800x600 +layer at (0,0) size 800x36 + LayoutBlockFlow {HTML} at (0,0) size 800x36 + LayoutBlockFlow {BODY} at (8,8) size 784x20 +layer at (8,8) size 784x20 + LayoutBlockFlow {DIV} at (0,0) size 784x20 +layer at (8,8) size 784x0 + LayoutBlockFlow {DIV} at (0,0) size 784x0 +layer at (8,8) size 784x0 + LayoutBlockFlow {DIV} at (0,0) size 784x0 +layer at (8,8) size 784x0 + LayoutBlockFlow (relative positioned) {DIV} at (0,0) size 784x0 + LayoutBlockFlow (floating) {DIV} at (0,0) size 21x20 + LayoutText {#text} at (0,0) size 21x19 + text run at (0,0) width 21: "test"
diff --git a/third_party/WebKit/LayoutTests/paint/overflow/composited-rounded-clip-floating-element.html b/third_party/WebKit/LayoutTests/paint/overflow/composited-rounded-clip-floating-element.html new file mode 100644 index 0000000..169d6fb --- /dev/null +++ b/third_party/WebKit/LayoutTests/paint/overflow/composited-rounded-clip-floating-element.html
@@ -0,0 +1,14 @@ +<!DOCTYPE html> +<!-- Passes if the word "test" is visible --> +<div style="border-radius:2px;overflow:hidden;"> + <div style="overflow:hidden;"> + <div style="transform: translateZ(0);"></div> + </div> + + <!-- This div has zero height because its child is floating. Nevertheless the + child should get the rounded clip mask applied to it. It is indirectly + composited due to overlapping the above div --> + <div style="position:relative;"> + <div style="float:left">test</div> + </div> +</div>
diff --git a/third_party/WebKit/LayoutTests/platform/linux/paint/overflow/composited-rounded-clip-floating-element-expected.png b/third_party/WebKit/LayoutTests/platform/linux/paint/overflow/composited-rounded-clip-floating-element-expected.png new file mode 100644 index 0000000..6f07a96d --- /dev/null +++ b/third_party/WebKit/LayoutTests/platform/linux/paint/overflow/composited-rounded-clip-floating-element-expected.png Binary files differ
diff --git a/third_party/WebKit/LayoutTests/platform/mac/paint/overflow/composited-rounded-clip-floating-element-expected.png b/third_party/WebKit/LayoutTests/platform/mac/paint/overflow/composited-rounded-clip-floating-element-expected.png new file mode 100644 index 0000000..194cd5ea --- /dev/null +++ b/third_party/WebKit/LayoutTests/platform/mac/paint/overflow/composited-rounded-clip-floating-element-expected.png Binary files differ
diff --git a/third_party/WebKit/LayoutTests/platform/mac/paint/overflow/composited-rounded-clip-floating-element-expected.txt b/third_party/WebKit/LayoutTests/platform/mac/paint/overflow/composited-rounded-clip-floating-element-expected.txt new file mode 100644 index 0000000..b920092 --- /dev/null +++ b/third_party/WebKit/LayoutTests/platform/mac/paint/overflow/composited-rounded-clip-floating-element-expected.txt
@@ -0,0 +1,16 @@ +layer at (0,0) size 800x600 + LayoutView at (0,0) size 800x600 +layer at (0,0) size 800x34 + LayoutBlockFlow {HTML} at (0,0) size 800x34 + LayoutBlockFlow {BODY} at (8,8) size 784x18 +layer at (8,8) size 784x18 + LayoutBlockFlow {DIV} at (0,0) size 784x18 +layer at (8,8) size 784x0 + LayoutBlockFlow {DIV} at (0,0) size 784x0 +layer at (8,8) size 784x0 + LayoutBlockFlow {DIV} at (0,0) size 784x0 +layer at (8,8) size 784x0 + LayoutBlockFlow (relative positioned) {DIV} at (0,0) size 784x0 + LayoutBlockFlow (floating) {DIV} at (0,0) size 22.22x18 + LayoutText {#text} at (0,0) size 23x18 + text run at (0,0) width 23: "test"
diff --git a/third_party/WebKit/LayoutTests/platform/mac/virtual/stable/webexposed/global-interface-listing-expected.txt b/third_party/WebKit/LayoutTests/platform/mac/virtual/stable/webexposed/global-interface-listing-expected.txt index 81844b5..4757310 100644 --- a/third_party/WebKit/LayoutTests/platform/mac/virtual/stable/webexposed/global-interface-listing-expected.txt +++ b/third_party/WebKit/LayoutTests/platform/mac/virtual/stable/webexposed/global-interface-listing-expected.txt
@@ -615,6 +615,13 @@ method @@iterator method constructor method item +interface Clipboard : EventTarget + attribute @@toStringTag + method constructor + method read + method readText + method write + method writeText interface ClipboardEvent : Event attribute @@toStringTag getter clipboardData
diff --git a/third_party/WebKit/LayoutTests/platform/win/paint/overflow/composited-rounded-clip-floating-element-expected.png b/third_party/WebKit/LayoutTests/platform/win/paint/overflow/composited-rounded-clip-floating-element-expected.png new file mode 100644 index 0000000..e7415340 --- /dev/null +++ b/third_party/WebKit/LayoutTests/platform/win/paint/overflow/composited-rounded-clip-floating-element-expected.png Binary files differ
diff --git a/third_party/WebKit/LayoutTests/platform/win/virtual/stable/webexposed/global-interface-listing-expected.txt b/third_party/WebKit/LayoutTests/platform/win/virtual/stable/webexposed/global-interface-listing-expected.txt index 6fd2bfa..65eb1cda 100644 --- a/third_party/WebKit/LayoutTests/platform/win/virtual/stable/webexposed/global-interface-listing-expected.txt +++ b/third_party/WebKit/LayoutTests/platform/win/virtual/stable/webexposed/global-interface-listing-expected.txt
@@ -544,6 +544,13 @@ method @@iterator method constructor method item +interface Clipboard : EventTarget + attribute @@toStringTag + method constructor + method read + method readText + method write + method writeText interface ClipboardEvent : Event attribute @@toStringTag getter clipboardData
diff --git a/third_party/WebKit/LayoutTests/svg/animations/animate-linear-discrete-additive-b.svg b/third_party/WebKit/LayoutTests/svg/animations/animate-linear-discrete-additive-b.svg index f8952627..92f14fc6 100644 --- a/third_party/WebKit/LayoutTests/svg/animations/animate-linear-discrete-additive-b.svg +++ b/third_party/WebKit/LayoutTests/svg/animations/animate-linear-discrete-additive-b.svg
@@ -29,6 +29,8 @@ function loaded() { document.documentElement.setCurrentTime(8); + // Pause the timeline to avoid it advancing before the result is sampled. + document.documentElement.pauseAnimations(); if (window.testRunner) testRunner.notifyDone(); }
diff --git a/third_party/WebKit/LayoutTests/svg/animations/animate-linear-discrete-additive-c.svg b/third_party/WebKit/LayoutTests/svg/animations/animate-linear-discrete-additive-c.svg index b134383..f960e37 100644 --- a/third_party/WebKit/LayoutTests/svg/animations/animate-linear-discrete-additive-c.svg +++ b/third_party/WebKit/LayoutTests/svg/animations/animate-linear-discrete-additive-c.svg
@@ -29,6 +29,8 @@ function loaded() { document.documentElement.setCurrentTime(11); + // Pause the timeline to avoid it advancing before the result is sampled. + document.documentElement.pauseAnimations(); if (window.testRunner) testRunner.notifyDone(); }
diff --git a/third_party/WebKit/LayoutTests/svg/animations/animate-linear-discrete-additive.svg b/third_party/WebKit/LayoutTests/svg/animations/animate-linear-discrete-additive.svg index 5b8310aa..587a7bd 100644 --- a/third_party/WebKit/LayoutTests/svg/animations/animate-linear-discrete-additive.svg +++ b/third_party/WebKit/LayoutTests/svg/animations/animate-linear-discrete-additive.svg
@@ -29,6 +29,8 @@ function loaded() { document.documentElement.setCurrentTime(3); + // Pause the timeline to avoid it advancing before the result is sampled. + document.documentElement.pauseAnimations(); if (window.testRunner) testRunner.notifyDone(); }
diff --git a/third_party/WebKit/LayoutTests/typedcssom/cssUnitValue_toMethod.html b/third_party/WebKit/LayoutTests/typedcssom/cssUnitValue_toMethod.html index 00f1a12..bccac27 100644 --- a/third_party/WebKit/LayoutTests/typedcssom/cssUnitValue_toMethod.html +++ b/third_party/WebKit/LayoutTests/typedcssom/cssUnitValue_toMethod.html
@@ -12,6 +12,15 @@ 'turn' ]; +let fixedLengthUnits = [ + 'px', + 'in', + 'cm', + 'mm', + 'pt', + 'pc' +]; + let conversionFactors = { 'deg': { 'deg': 1, @@ -37,6 +46,59 @@ 'grad': 400, 'turn': 1, }, + // 96 px per in + // 2.54 cm per in + // 10 mm per cm + // 72 pt per in + // 6 pc per in + 'px': { + 'px': 1, + 'in': 1 / 96, + 'cm': 2.54 / 96, + 'mm': 25.4 / 96, + 'pt': 72 / 96, + 'pc': 6 / 96 + }, + 'in': { + 'px': 96, + 'in': 1, + 'cm': 2.54, + 'mm': 25.4, + 'pt': 72, + 'pc': 6 + }, + 'cm': { + 'px': 96 / 2.54, + 'in': 1 / 2.54, + 'cm': 1, + 'mm': 10, + 'pt': 72 / 2.54, + 'pc': 6 / 2.54 + }, + 'mm': { + 'px': 96 / 25.4, + 'in': 1 / 25.4, + 'cm': 1 / 10, + 'mm': 1, + 'pt': 72 / 25.4, + 'pc': 6 / 25.4 + }, + 'pt': { + 'px': 96 / 72, + 'in': 1 / 72, + 'cm': 2.54 / 72, + 'mm': 25.4 / 72, + 'pt': 1, + 'pc': 6 / 72, + }, + 'pc': { + 'px': 96 / 6, + 'in': 1 / 6, + 'cm': 2.54 / 6, + 'mm': 25.4 / 6, + 'pt': 72 / 6, + 'pc': 1 + } } test(() => { @@ -65,4 +127,16 @@ } } +for (let unit of fixedLengthUnits) { + for (let toUnit of fixedLengthUnits) { + test(() => { + let unitValue = new CSSUnitValue(1, unit); + let result = unitValue.to(toUnit); + assert_approx_equals( + result.value, conversionFactors[unit][toUnit], EPSILON); + assert_equals(result.unit, toUnit); + }, 'Converting fixed length unit ' + unit + ' to ' + toUnit); + } +} + </script>
diff --git a/third_party/WebKit/LayoutTests/virtual/service-worker-navigation-preload-disabled/webexposed/global-interface-listing-expected.txt b/third_party/WebKit/LayoutTests/virtual/service-worker-navigation-preload-disabled/webexposed/global-interface-listing-expected.txt index 9aa28ab3..c3fc5dc5 100644 --- a/third_party/WebKit/LayoutTests/virtual/service-worker-navigation-preload-disabled/webexposed/global-interface-listing-expected.txt +++ b/third_party/WebKit/LayoutTests/virtual/service-worker-navigation-preload-disabled/webexposed/global-interface-listing-expected.txt
@@ -1025,6 +1025,13 @@ method @@iterator method constructor method item +interface Clipboard : EventTarget + attribute @@toStringTag + method constructor + method read + method readText + method write + method writeText interface ClipboardEvent : Event attribute @@toStringTag getter clipboardData @@ -4411,6 +4418,7 @@ getter authentication getter bluetooth getter budget + getter clipboard getter connection getter cookieEnabled getter credentials
diff --git a/third_party/WebKit/LayoutTests/webexposed/global-interface-listing-expected.txt b/third_party/WebKit/LayoutTests/webexposed/global-interface-listing-expected.txt index 84197b0..d72d71e 100644 --- a/third_party/WebKit/LayoutTests/webexposed/global-interface-listing-expected.txt +++ b/third_party/WebKit/LayoutTests/webexposed/global-interface-listing-expected.txt
@@ -1025,6 +1025,13 @@ method @@iterator method constructor method item +interface Clipboard : EventTarget + attribute @@toStringTag + method constructor + method read + method readText + method write + method writeText interface ClipboardEvent : Event attribute @@toStringTag getter clipboardData @@ -4418,6 +4425,7 @@ getter authentication getter bluetooth getter budget + getter clipboard getter connection getter cookieEnabled getter credentials
diff --git a/third_party/WebKit/Source/DEPS b/third_party/WebKit/Source/DEPS index 510a74f9..2ad1573e 100644 --- a/third_party/WebKit/Source/DEPS +++ b/third_party/WebKit/Source/DEPS
@@ -3,6 +3,7 @@ "+base/gtest_prod_util.h", "+build", "+services/service_manager/public/cpp/connector.h", + "+services/service_manager/public/cpp/interface_provider.h", "+testing/gmock/include/gmock", "+testing/gtest/include/gtest", "+v8",
diff --git a/third_party/WebKit/Source/core/BUILD.gn b/third_party/WebKit/Source/core/BUILD.gn index 123b123..087ea36 100644 --- a/third_party/WebKit/Source/core/BUILD.gn +++ b/third_party/WebKit/Source/core/BUILD.gn
@@ -465,7 +465,6 @@ "$blink_core_output_dir/css/properties/CSSPropertyAPIAnimationIterationCount.h", "$blink_core_output_dir/css/properties/CSSPropertyAPIAnimationName.h", "$blink_core_output_dir/css/properties/CSSPropertyAPIAnimationPlayState.h", - "$blink_core_output_dir/css/properties/CSSPropertyAPIBackgroundColor.h", "$blink_core_output_dir/css/properties/CSSPropertyAPIBaselineShift.h", "$blink_core_output_dir/css/properties/CSSPropertyAPIBorderImageOutset.h", "$blink_core_output_dir/css/properties/CSSPropertyAPIBorderImageRepeat.h", @@ -478,6 +477,7 @@ "$blink_core_output_dir/css/properties/CSSPropertyAPIClip.h", "$blink_core_output_dir/css/properties/CSSPropertyAPIClipPath.h", "$blink_core_output_dir/css/properties/CSSPropertyAPIColor.h", + "$blink_core_output_dir/css/properties/CSSPropertyAPIColorNoQuirks.h", "$blink_core_output_dir/css/properties/CSSPropertyAPIColumnCount.h", "$blink_core_output_dir/css/properties/CSSPropertyAPIColumnGap.h", "$blink_core_output_dir/css/properties/CSSPropertyAPIColumnRuleWidth.h",
diff --git a/third_party/WebKit/Source/core/DEPS b/third_party/WebKit/Source/core/DEPS index 76e014f4..591e0d8 100644 --- a/third_party/WebKit/Source/core/DEPS +++ b/third_party/WebKit/Source/core/DEPS
@@ -11,7 +11,6 @@ "+platform", "+public/platform", "+public/web", - "+services/service_manager/public/cpp", "+third_party/skia/include", "+ui/gfx/geometry", "-web", @@ -21,5 +20,6 @@ # We do not want any new dependencies on Web(Local|Remote)FrameBase.h until # we resolve the control layer. "!core/frame/WebLocalFrameBase.h", - "!core/frame/WebRemoteFrameBase.h" + "!core/frame/WebRemoteFrameBase.h", + "!core/frame/WebRemoteFrameImpl.h", ]
diff --git a/third_party/WebKit/Source/core/animation/CSSImageInterpolationType.cpp b/third_party/WebKit/Source/core/animation/CSSImageInterpolationType.cpp index daf53ac..c9b5048 100644 --- a/third_party/WebKit/Source/core/animation/CSSImageInterpolationType.cpp +++ b/third_party/WebKit/Source/core/animation/CSSImageInterpolationType.cpp
@@ -38,7 +38,7 @@ return start_; if (progress >= 1) return end_; - return CSSCrossfadeValue::Create( + return cssvalue::CSSCrossfadeValue::Create( start_, end_, CSSPrimitiveValue::Create(progress, CSSPrimitiveValue::UnitType::kNumber));
diff --git a/third_party/WebKit/Source/core/clipboard/BUILD.gn b/third_party/WebKit/Source/core/clipboard/BUILD.gn index 7c3af33d..cebb63e 100644 --- a/third_party/WebKit/Source/core/clipboard/BUILD.gn +++ b/third_party/WebKit/Source/core/clipboard/BUILD.gn
@@ -6,6 +6,10 @@ blink_core_sources("clipboard") { sources = [ + "Clipboard.cpp", + "Clipboard.h", + "ClipboardPromise.cpp", + "ClipboardPromise.h", "DataObject.cpp", "DataObject.h", "DataObjectItem.cpp",
diff --git a/third_party/WebKit/Source/core/clipboard/Clipboard.cpp b/third_party/WebKit/Source/core/clipboard/Clipboard.cpp new file mode 100644 index 0000000..98b0ac9c --- /dev/null +++ b/third_party/WebKit/Source/core/clipboard/Clipboard.cpp
@@ -0,0 +1,45 @@ +// Copyright 2017 The Chromium Authors. All rights reserved. +// Use of this source code is governed by a BSD-style license that can be +// found in the LICENSE file. + +#include "core/clipboard/Clipboard.h" + +#include "bindings/core/v8/ScriptPromiseResolver.h" +#include "core/clipboard/ClipboardPromise.h" + +namespace blink { + +Clipboard::Clipboard(ExecutionContext* context) + : ContextLifecycleObserver(context) {} + +ScriptPromise Clipboard::read(ScriptState* script_state) { + return ClipboardPromise::CreateForRead(script_state); +} + +ScriptPromise Clipboard::readText(ScriptState* script_state) { + return ClipboardPromise::CreateForReadText(script_state); +} + +ScriptPromise Clipboard::write(ScriptState* script_state, DataTransfer* data) { + return ClipboardPromise::CreateForWrite(script_state, data); +} + +ScriptPromise Clipboard::writeText(ScriptState* script_state, + const String& data) { + return ClipboardPromise::CreateForWriteText(script_state, data); +} + +const AtomicString& Clipboard::InterfaceName() const { + return EventTargetNames::Clipboard; +} + +ExecutionContext* Clipboard::GetExecutionContext() const { + return ContextLifecycleObserver::GetExecutionContext(); +} + +DEFINE_TRACE(Clipboard) { + EventTarget::Trace(visitor); + ContextLifecycleObserver::Trace(visitor); +} + +} // namespace blink
diff --git a/third_party/WebKit/Source/core/clipboard/Clipboard.h b/third_party/WebKit/Source/core/clipboard/Clipboard.h new file mode 100644 index 0000000..568b45b --- /dev/null +++ b/third_party/WebKit/Source/core/clipboard/Clipboard.h
@@ -0,0 +1,42 @@ +// Copyright 2017 The Chromium Authors. All rights reserved. +// Use of this source code is governed by a BSD-style license that can be +// found in the LICENSE file. + +#ifndef Clipboard_h +#define Clipboard_h + +#include "bindings/core/v8/ScriptPromise.h" +#include "core/dom/ContextLifecycleObserver.h" +#include "core/events/EventTarget.h" +#include "platform/wtf/Noncopyable.h" + +namespace blink { + +class DataTransfer; +class ScriptState; + +class Clipboard : public EventTargetWithInlineData, + public ContextLifecycleObserver { + USING_GARBAGE_COLLECTED_MIXIN(Clipboard); + DEFINE_WRAPPERTYPEINFO(); + WTF_MAKE_NONCOPYABLE(Clipboard); + + public: + explicit Clipboard(ExecutionContext*); + + ScriptPromise read(ScriptState*); + ScriptPromise readText(ScriptState*); + + ScriptPromise write(ScriptState*, DataTransfer*); + ScriptPromise writeText(ScriptState*, const String&); + + // EventTarget + const AtomicString& InterfaceName() const override; + ExecutionContext* GetExecutionContext() const override; + + DECLARE_VIRTUAL_TRACE(); +}; + +} // namespace blink + +#endif // Clipboard_h
diff --git a/third_party/WebKit/Source/core/clipboard/Clipboard.idl b/third_party/WebKit/Source/core/clipboard/Clipboard.idl new file mode 100644 index 0000000..22a02471 --- /dev/null +++ b/third_party/WebKit/Source/core/clipboard/Clipboard.idl
@@ -0,0 +1,14 @@ +// Copyright 2017 The Chromium Authors. All rights reserved. +// Use of this source code is governed by a BSD-style license that can be +// found in the LICENSE file. + +// https://w3c.github.io/clipboard-apis/#clipboard-interface + +[SecureContext] +interface Clipboard : EventTarget { + [CallWith=ScriptState] Promise<DataTransfer> read(); + [CallWith=ScriptState] Promise<DOMString> readText(); + + [CallWith=ScriptState] Promise<void> write(DataTransfer data); + [CallWith=ScriptState] Promise<void> writeText(DOMString data); +};
diff --git a/third_party/WebKit/Source/core/clipboard/ClipboardPromise.cpp b/third_party/WebKit/Source/core/clipboard/ClipboardPromise.cpp new file mode 100644 index 0000000..4a0739a --- /dev/null +++ b/third_party/WebKit/Source/core/clipboard/ClipboardPromise.cpp
@@ -0,0 +1,115 @@ +// Copyright 2017 The Chromium Authors. All rights reserved. +// Use of this source code is governed by a BSD-style license that can be +// found in the LICENSE file. + +#include "core/clipboard/ClipboardPromise.h" + +#include "bindings/core/v8/ScriptPromiseResolver.h" +#include "core/clipboard/DataObject.h" +#include "core/clipboard/DataTransfer.h" +#include "core/clipboard/DataTransferItem.h" +#include "core/clipboard/DataTransferItemList.h" +#include "core/dom/TaskRunnerHelper.h" +#include "platform/CrossThreadFunctional.h" +#include "platform/clipboard/ClipboardMimeTypes.h" +#include "public/platform/Platform.h" + +namespace blink { + +ScriptPromise ClipboardPromise::CreateForRead(ScriptState* script_state) { + ClipboardPromise* clipboard_promise = new ClipboardPromise(script_state); + clipboard_promise->GetTaskRunner()->PostTask( + BLINK_FROM_HERE, WTF::Bind(&ClipboardPromise::HandleRead, + WrapPersistent(clipboard_promise))); + return clipboard_promise->script_promise_resolver_->Promise(); +} + +ScriptPromise ClipboardPromise::CreateForReadText(ScriptState* script_state) { + ClipboardPromise* clipboard_promise = new ClipboardPromise(script_state); + clipboard_promise->GetTaskRunner()->PostTask( + BLINK_FROM_HERE, WTF::Bind(&ClipboardPromise::HandleReadText, + WrapPersistent(clipboard_promise))); + return clipboard_promise->script_promise_resolver_->Promise(); +} + +ScriptPromise ClipboardPromise::CreateForWrite(ScriptState* script_state, + DataTransfer* data) { + ClipboardPromise* clipboard_promise = new ClipboardPromise(script_state); + clipboard_promise->GetTaskRunner()->PostTask( + BLINK_FROM_HERE, + WTF::Bind(&ClipboardPromise::HandleWrite, + WrapPersistent(clipboard_promise), WrapPersistent(data))); + return clipboard_promise->script_promise_resolver_->Promise(); +} + +ScriptPromise ClipboardPromise::CreateForWriteText(ScriptState* script_state, + const String& data) { + ClipboardPromise* clipboard_promise = new ClipboardPromise(script_state); + clipboard_promise->GetTaskRunner()->PostTask( + BLINK_FROM_HERE, WTF::Bind(&ClipboardPromise::HandleWriteText, + WrapPersistent(clipboard_promise), data)); + return clipboard_promise->script_promise_resolver_->Promise(); +} + +ClipboardPromise::ClipboardPromise(ScriptState* script_state) + : ContextLifecycleObserver(blink::ExecutionContext::From(script_state)), + script_promise_resolver_(ScriptPromiseResolver::Create(script_state)), + buffer_(WebClipboard::kBufferStandard) {} + +WebTaskRunner* ClipboardPromise::GetTaskRunner() { + // TODO(garykac): Replace MiscPlatformAPI with TaskType specific to clipboard. + return TaskRunnerHelper::Get(TaskType::kMiscPlatformAPI, + GetExecutionContext()) + .Get(); +} + +// TODO(garykac): This currently only handles plain text. +void ClipboardPromise::HandleRead() { + DCHECK(script_promise_resolver_); + String plain_text = Platform::Current()->Clipboard()->ReadPlainText(buffer_); + + const DataTransfer::DataTransferType type = + DataTransfer::DataTransferType::kCopyAndPaste; + const DataTransferAccessPolicy access = + DataTransferAccessPolicy::kDataTransferReadable; + DataObject* data = DataObject::CreateFromString(plain_text); + DataTransfer* dt = DataTransfer::Create(type, access, data); + script_promise_resolver_->Resolve(dt); +} + +void ClipboardPromise::HandleReadText() { + DCHECK(script_promise_resolver_); + String text = Platform::Current()->Clipboard()->ReadPlainText(buffer_); + script_promise_resolver_->Resolve(text); +} + +// TODO(garykac): This currently only handles plain text. +void ClipboardPromise::HandleWrite(DataTransfer* data) { + DCHECK(script_promise_resolver_); + size_t num_items = data->items()->length(); + for (unsigned long i = 0; i < num_items; i++) { + DataTransferItem* item = data->items()->item(i); + DataObjectItem* objectItem = item->GetDataObjectItem(); + if (objectItem->Kind() == DataObjectItem::kStringKind && + objectItem->GetType() == kMimeTypeTextPlain) { + String text = objectItem->GetAsString(); + Platform::Current()->Clipboard()->WritePlainText(text); + script_promise_resolver_->Resolve(); + return; + } + } + script_promise_resolver_->Reject(); +} + +void ClipboardPromise::HandleWriteText(const String& data) { + DCHECK(script_promise_resolver_); + Platform::Current()->Clipboard()->WritePlainText(data); + script_promise_resolver_->Resolve(); +} + +DEFINE_TRACE(ClipboardPromise) { + visitor->Trace(script_promise_resolver_); + ContextLifecycleObserver::Trace(visitor); +} + +} // namespace blink
diff --git a/third_party/WebKit/Source/core/clipboard/ClipboardPromise.h b/third_party/WebKit/Source/core/clipboard/ClipboardPromise.h new file mode 100644 index 0000000..1cfd0e3 --- /dev/null +++ b/third_party/WebKit/Source/core/clipboard/ClipboardPromise.h
@@ -0,0 +1,52 @@ +// Copyright 2017 The Chromium Authors. All rights reserved. +// Use of this source code is governed by a BSD-style license that can be +// found in the LICENSE file. + +#ifndef ClipboardPromise_h +#define ClipboardPromise_h + +#include "bindings/core/v8/ScriptPromise.h" +#include "core/CoreExport.h" +#include "core/dom/ContextLifecycleObserver.h" +#include "public/platform/WebClipboard.h" + +namespace blink { + +class DataTransfer; +class ScriptPromiseResolver; + +class ClipboardPromise final + : public GarbageCollectedFinalized<ClipboardPromise>, + public ContextLifecycleObserver { + USING_GARBAGE_COLLECTED_MIXIN(ClipboardPromise); + WTF_MAKE_NONCOPYABLE(ClipboardPromise); + + public: + virtual ~ClipboardPromise(){}; + + static ScriptPromise CreateForRead(ScriptState*); + static ScriptPromise CreateForReadText(ScriptState*); + static ScriptPromise CreateForWrite(ScriptState*, DataTransfer*); + static ScriptPromise CreateForWriteText(ScriptState*, const String&); + + DECLARE_VIRTUAL_TRACE(); + + private: + ClipboardPromise(ScriptState*); + + WebTaskRunner* GetTaskRunner(); + + void HandleRead(); + void HandleReadText(); + + void HandleWrite(DataTransfer*); + void HandleWriteText(const String&); + + Member<ScriptPromiseResolver> script_promise_resolver_; + + WebClipboard::Buffer buffer_; +}; + +} // namespace blink + +#endif // ClipboardPromise_h
diff --git a/third_party/WebKit/Source/core/core_idl_files.gni b/third_party/WebKit/Source/core/core_idl_files.gni index c8c5ae7..f6cc9e7 100644 --- a/third_party/WebKit/Source/core/core_idl_files.gni +++ b/third_party/WebKit/Source/core/core_idl_files.gni
@@ -35,6 +35,7 @@ "animation/KeyframeEffect.idl", "animation/KeyframeEffectReadOnly.idl", "animation/ScrollTimeline.idl", + "clipboard/Clipboard.idl", "clipboard/DataTransfer.idl", "clipboard/DataTransferItemList.idl", "css/CSS.idl", @@ -470,6 +471,7 @@ "events/EventListener.idl", "events/NavigatorEvents.idl", "fileapi/URLFileAPI.idl", + "frame/NavigatorClipboard.idl", "frame/NavigatorConcurrentHardware.idl", "frame/NavigatorCookies.idl", "frame/NavigatorID.idl",
diff --git a/third_party/WebKit/Source/core/css/BUILD.gn b/third_party/WebKit/Source/core/css/BUILD.gn index ca13f0d..1fb11927 100644 --- a/third_party/WebKit/Source/core/css/BUILD.gn +++ b/third_party/WebKit/Source/core/css/BUILD.gn
@@ -381,7 +381,6 @@ "properties/CSSPropertyAPIAnimationIterationCount.cpp", "properties/CSSPropertyAPIAnimationName.cpp", "properties/CSSPropertyAPIAnimationPlayState.cpp", - "properties/CSSPropertyAPIBackgroundColor.cpp", "properties/CSSPropertyAPIBaselineShift.cpp", "properties/CSSPropertyAPIBorderImageOutset.cpp", "properties/CSSPropertyAPIBorderImageRepeat.cpp", @@ -394,6 +393,7 @@ "properties/CSSPropertyAPIClip.cpp", "properties/CSSPropertyAPIClipPath.cpp", "properties/CSSPropertyAPIColor.cpp", + "properties/CSSPropertyAPIColorNoQuirks.cpp", "properties/CSSPropertyAPIColumnCount.cpp", "properties/CSSPropertyAPIColumnGap.cpp", "properties/CSSPropertyAPIColumnRuleWidth.cpp",
diff --git a/third_party/WebKit/Source/core/css/CSSCrossfadeValue.cpp b/third_party/WebKit/Source/core/css/CSSCrossfadeValue.cpp index ec23b00..83231bb 100644 --- a/third_party/WebKit/Source/core/css/CSSCrossfadeValue.cpp +++ b/third_party/WebKit/Source/core/css/CSSCrossfadeValue.cpp
@@ -33,6 +33,7 @@ #include "platform/wtf/text/StringBuilder.h" namespace blink { +namespace cssvalue { static bool SubimageIsPending(CSSValue* value) { if (value->IsImageValue()) @@ -302,4 +303,5 @@ CSSImageGeneratorValue::TraceAfterDispatch(visitor); } +} // namespace cssvalue } // namespace blink
diff --git a/third_party/WebKit/Source/core/css/CSSCrossfadeValue.h b/third_party/WebKit/Source/core/css/CSSCrossfadeValue.h index 580551c..5c4eb01 100644 --- a/third_party/WebKit/Source/core/css/CSSCrossfadeValue.h +++ b/third_party/WebKit/Source/core/css/CSSCrossfadeValue.h
@@ -37,8 +37,10 @@ class CrossfadeSubimageObserverProxy; +namespace cssvalue { + class CORE_EXPORT CSSCrossfadeValue final : public CSSImageGeneratorValue { - friend class CrossfadeSubimageObserverProxy; + friend class blink::CrossfadeSubimageObserverProxy; USING_PRE_FINALIZER(CSSCrossfadeValue, Dispose); public: @@ -116,6 +118,7 @@ DEFINE_CSS_VALUE_TYPE_CASTS(CSSCrossfadeValue, IsCrossfadeValue()); +} // namespace cssvalue } // namespace blink #endif // CSSCrossfadeValue_h
diff --git a/third_party/WebKit/Source/core/css/CSSHelper.h b/third_party/WebKit/Source/core/css/CSSHelper.h index 30e5313..4cf135e 100644 --- a/third_party/WebKit/Source/core/css/CSSHelper.h +++ b/third_party/WebKit/Source/core/css/CSSHelper.h
@@ -26,12 +26,19 @@ namespace blink { +const double kMillimetersPerCentimeter = 10; +const double kCentimetersPerInch = 2.54; +const double kMillimetersPerInch = 25.4; +const double kPointsPerInch = 72; +const double kPicasPerInch = 6; + // These conversions are defined in css-values const double kCssPixelsPerInch = 96; -const double kCssPixelsPerCentimeter = kCssPixelsPerInch / 2.54; // 2.54 cm/in -const double kCssPixelsPerMillimeter = kCssPixelsPerCentimeter / 10; -const double kCssPixelsPerPoint = kCssPixelsPerInch / 72; -const double kCssPixelsPerPica = kCssPixelsPerInch / 6; +const double kCssPixelsPerCentimeter = kCssPixelsPerInch / kCentimetersPerInch; +const double kCssPixelsPerMillimeter = + kCssPixelsPerCentimeter / kMillimetersPerCentimeter; +const double kCssPixelsPerPoint = kCssPixelsPerInch / kPointsPerInch; +const double kCssPixelsPerPica = kCssPixelsPerInch / kPicasPerInch; } // namespace blink
diff --git a/third_party/WebKit/Source/core/css/CSSImageGeneratorValue.cpp b/third_party/WebKit/Source/core/css/CSSImageGeneratorValue.cpp index b0f68e4..59fbd88 100644 --- a/third_party/WebKit/Source/core/css/CSSImageGeneratorValue.cpp +++ b/third_party/WebKit/Source/core/css/CSSImageGeneratorValue.cpp
@@ -33,6 +33,8 @@ namespace blink { +using cssvalue::ToCSSCrossfadeValue; + CSSImageGeneratorValue::CSSImageGeneratorValue(ClassType class_type) : CSSValue(class_type) {}
diff --git a/third_party/WebKit/Source/core/css/CSSProperties.json5 b/third_party/WebKit/Source/core/css/CSSProperties.json5 index 6ad074c4..6ccbd6fd 100644 --- a/third_party/WebKit/Source/core/css/CSSProperties.json5 +++ b/third_party/WebKit/Source/core/css/CSSProperties.json5
@@ -398,6 +398,8 @@ // Other properties can depend upon high priority properties (e.g. font-size / ems) { name: "color", + api_class: "CSSPropertyAPIColor", + api_methods: ["parseSingleValue"], custom_all: true, inherited: true, interpolable: true, @@ -690,7 +692,7 @@ }, { name: "background-color", - api_class: true, + api_class: "CSSPropertyAPIColor", api_methods: ["parseSingleValue"], custom_all: true, interpolable: true, @@ -1302,7 +1304,7 @@ }, { name: "flood-color", - api_class: "CSSPropertyAPIColor", + api_class: "CSSPropertyAPIColorNoQuirks", api_methods: ["parseSingleValue"], converter: "ConvertColor", interpolable: true, @@ -1547,7 +1549,7 @@ }, { name: "lighting-color", - api_class: "CSSPropertyAPIColor", + api_class: "CSSPropertyAPIColorNoQuirks", api_methods: ["parseSingleValue"], converter: "ConvertColor", interpolable: true, @@ -2360,7 +2362,7 @@ }, { name: "stop-color", - api_class: "CSSPropertyAPIColor", + api_class: "CSSPropertyAPIColorNoQuirks", api_methods: ["parseSingleValue"], converter: "ConvertColor", interpolable: true, @@ -2954,7 +2956,7 @@ }, { name: "column-rule-color", - api_class: "CSSPropertyAPIColor", + api_class: "CSSPropertyAPIColorNoQuirks", api_methods: ["parseSingleValue"], custom_all: true, interpolable: true, @@ -3190,7 +3192,7 @@ }, { name: "-webkit-tap-highlight-color", - api_class: "CSSPropertyAPIColor", + api_class: "CSSPropertyAPIColorNoQuirks", api_methods: ["parseSingleValue"], converter: "ConvertColor", inherited: true, @@ -3207,7 +3209,7 @@ }, { name: "-webkit-text-emphasis-color", - api_class: "CSSPropertyAPIColor", + api_class: "CSSPropertyAPIColorNoQuirks", api_methods: ["parseSingleValue"], custom_all: true, inherited: true, @@ -3235,7 +3237,7 @@ }, { name: "-webkit-text-fill-color", - api_class: "CSSPropertyAPIColor", + api_class: "CSSPropertyAPIColorNoQuirks", api_methods: ["parseSingleValue"], custom_all: true, inherited: true, @@ -3255,7 +3257,7 @@ }, { name: "-webkit-text-stroke-color", - api_class: "CSSPropertyAPIColor", + api_class: "CSSPropertyAPIColorNoQuirks", api_methods: ["parseSingleValue"], custom_all: true, inherited: true, @@ -3427,7 +3429,7 @@ { name: "-webkit-border-end-color", - api_class: "CSSPropertyAPIColor", + api_class: "CSSPropertyAPIColorNoQuirks", api_methods: ["parseSingleValue"], direction_aware: true, }, @@ -3443,7 +3445,7 @@ }, { name: "-webkit-border-start-color", - api_class: "CSSPropertyAPIColor", + api_class: "CSSPropertyAPIColorNoQuirks", api_methods: ["parseSingleValue"], direction_aware: true, }, @@ -3459,7 +3461,7 @@ }, { name: "-webkit-border-before-color", - api_class: "CSSPropertyAPIColor", + api_class: "CSSPropertyAPIColorNoQuirks", api_methods: ["parseSingleValue"], direction_aware: true, }, @@ -3475,7 +3477,7 @@ }, { name: "-webkit-border-after-color", - api_class: "CSSPropertyAPIColor", + api_class: "CSSPropertyAPIColorNoQuirks", api_methods: ["parseSingleValue"], direction_aware: true, },
diff --git a/third_party/WebKit/Source/core/css/cssom/CSSUnitValue.cpp b/third_party/WebKit/Source/core/css/cssom/CSSUnitValue.cpp index f6fe21ab..547c553 100644 --- a/third_party/WebKit/Source/core/css/cssom/CSSUnitValue.cpp +++ b/third_party/WebKit/Source/core/css/cssom/CSSUnitValue.cpp
@@ -5,6 +5,7 @@ #include "core/css/cssom/CSSUnitValue.h" #include "bindings/core/v8/ExceptionState.h" +#include "core/css/CSSHelper.h" #include "platform/wtf/MathExtras.h" namespace blink { @@ -84,13 +85,125 @@ if (unit_ == unit) return Create(value_, unit_); - // TODO(meade): Implement other types. + // TODO(meade): Implement other types: time, frequency and resolution. + if (CSSPrimitiveValue::IsLength(unit_) && CSSPrimitiveValue::IsLength(unit)) { + // Only fixed lengths can be converted. + if (CSSPrimitiveValue::IsRelativeUnit(unit_) || + CSSPrimitiveValue::IsRelativeUnit(unit)) + return nullptr; + return Create(ConvertFixedLength(unit), unit); + } if (CSSPrimitiveValue::IsAngle(unit_) && CSSPrimitiveValue::IsAngle(unit)) return Create(ConvertAngle(unit), unit); return nullptr; } +double CSSUnitValue::ConvertFixedLength( + CSSPrimitiveValue::UnitType unit) const { + switch (unit_) { + case CSSPrimitiveValue::UnitType::kPixels: + switch (unit) { + case CSSPrimitiveValue::UnitType::kCentimeters: + return value_ / kCssPixelsPerCentimeter; + case CSSPrimitiveValue::UnitType::kMillimeters: + return value_ / kCssPixelsPerMillimeter; + case CSSPrimitiveValue::UnitType::kInches: + return value_ / kCssPixelsPerInch; + case CSSPrimitiveValue::UnitType::kPoints: + return value_ / kCssPixelsPerPoint; + case CSSPrimitiveValue::UnitType::kPicas: + return value_ / kCssPixelsPerPica; + default: + NOTREACHED(); + return 0; + } + case CSSPrimitiveValue::UnitType::kCentimeters: + switch (unit) { + case CSSPrimitiveValue::UnitType::kPixels: + return value_ * kCssPixelsPerCentimeter; + case CSSPrimitiveValue::UnitType::kMillimeters: + return value_ * kMillimetersPerCentimeter; + case CSSPrimitiveValue::UnitType::kInches: + return value_ / kCentimetersPerInch; + case CSSPrimitiveValue::UnitType::kPoints: + return value_ * (kPointsPerInch / kCentimetersPerInch); + case CSSPrimitiveValue::UnitType::kPicas: + return value_ * (kPicasPerInch / kCentimetersPerInch); + default: + NOTREACHED(); + return 0; + } + case CSSPrimitiveValue::UnitType::kMillimeters: + switch (unit) { + case CSSPrimitiveValue::UnitType::kPixels: + return value_ * kCssPixelsPerMillimeter; + case CSSPrimitiveValue::UnitType::kCentimeters: + return value_ / kMillimetersPerCentimeter; + case CSSPrimitiveValue::UnitType::kInches: + return value_ / (kMillimetersPerCentimeter * kCentimetersPerInch); + case CSSPrimitiveValue::UnitType::kPoints: + return value_ * (kPointsPerInch / kMillimetersPerInch); + case CSSPrimitiveValue::UnitType::kPicas: + return value_ * (kPicasPerInch / kMillimetersPerInch); + default: + NOTREACHED(); + return 0; + } + case CSSPrimitiveValue::UnitType::kInches: + switch (unit) { + case CSSPrimitiveValue::UnitType::kPixels: + return value_ * kCssPixelsPerInch; + case CSSPrimitiveValue::UnitType::kMillimeters: + return value_ * kCentimetersPerInch * kMillimetersPerCentimeter; + case CSSPrimitiveValue::UnitType::kCentimeters: + return value_ * kCentimetersPerInch; + case CSSPrimitiveValue::UnitType::kPoints: + return value_ * kPointsPerInch; + case CSSPrimitiveValue::UnitType::kPicas: + return value_ * kPicasPerInch; + default: + NOTREACHED(); + return 0; + } + case CSSPrimitiveValue::UnitType::kPoints: + switch (unit) { + case CSSPrimitiveValue::UnitType::kPixels: + return value_ * kCssPixelsPerPoint; + case CSSPrimitiveValue::UnitType::kMillimeters: + return value_ * (kMillimetersPerInch / kPointsPerInch); + case CSSPrimitiveValue::UnitType::kCentimeters: + return value_ * (kCentimetersPerInch / kPointsPerInch); + case CSSPrimitiveValue::UnitType::kInches: + return value_ / kPointsPerInch; + case CSSPrimitiveValue::UnitType::kPicas: + return value_ * (kPicasPerInch / kPointsPerInch); + default: + NOTREACHED(); + return 0; + } + case CSSPrimitiveValue::UnitType::kPicas: + switch (unit) { + case CSSPrimitiveValue::UnitType::kPixels: + return value_ * kCssPixelsPerPica; + case CSSPrimitiveValue::UnitType::kMillimeters: + return value_ * (kMillimetersPerInch / kPicasPerInch); + case CSSPrimitiveValue::UnitType::kCentimeters: + return value_ * (kCentimetersPerInch / kPicasPerInch); + case CSSPrimitiveValue::UnitType::kInches: + return value_ / kPicasPerInch; + case CSSPrimitiveValue::UnitType::kPoints: + return value_ * (kPointsPerInch / kPicasPerInch); + default: + NOTREACHED(); + return 0; + } + default: + NOTREACHED(); + return 0; + } +} + double CSSUnitValue::ConvertAngle(CSSPrimitiveValue::UnitType unit) const { switch (unit_) { case CSSPrimitiveValue::UnitType::kDegrees:
diff --git a/third_party/WebKit/Source/core/css/cssom/CSSUnitValue.h b/third_party/WebKit/Source/core/css/cssom/CSSUnitValue.h index 4187bd174..ee35aea 100644 --- a/third_party/WebKit/Source/core/css/cssom/CSSUnitValue.h +++ b/third_party/WebKit/Source/core/css/cssom/CSSUnitValue.h
@@ -52,6 +52,7 @@ CSSUnitValue(double value, CSSPrimitiveValue::UnitType unit) : CSSNumericValue(), value_(value), unit_(unit) {} + double ConvertFixedLength(CSSPrimitiveValue::UnitType) const; double ConvertAngle(CSSPrimitiveValue::UnitType) const; double value_;
diff --git a/third_party/WebKit/Source/core/css/parser/CSSPropertyParser.cpp b/third_party/WebKit/Source/core/css/parser/CSSPropertyParser.cpp index f968a92..17ed878 100644 --- a/third_party/WebKit/Source/core/css/parser/CSSPropertyParser.cpp +++ b/third_party/WebKit/Source/core/css/parser/CSSPropertyParser.cpp
@@ -1186,91 +1186,26 @@ column_count); } -static void CountKeywordOnlyPropertyUsage(CSSPropertyID property, - const CSSParserContext* context, - CSSValueID value_id) { - if (!context->IsUseCounterRecordingEnabled()) - return; - switch (property) { - case CSSPropertyWebkitAppearance: { - WebFeature feature; - if (value_id == CSSValueNone) { - feature = WebFeature::kCSSValueAppearanceNone; - } else { - feature = WebFeature::kCSSValueAppearanceNotNone; - if (value_id == CSSValueButton) - feature = WebFeature::kCSSValueAppearanceButton; - else if (value_id == CSSValueCaret) - feature = WebFeature::kCSSValueAppearanceCaret; - else if (value_id == CSSValueCheckbox) - feature = WebFeature::kCSSValueAppearanceCheckbox; - else if (value_id == CSSValueMenulist) - feature = WebFeature::kCSSValueAppearanceMenulist; - else if (value_id == CSSValueMenulistButton) - feature = WebFeature::kCSSValueAppearanceMenulistButton; - else if (value_id == CSSValueListbox) - feature = WebFeature::kCSSValueAppearanceListbox; - else if (value_id == CSSValueRadio) - feature = WebFeature::kCSSValueAppearanceRadio; - else if (value_id == CSSValueSearchfield) - feature = WebFeature::kCSSValueAppearanceSearchField; - else if (value_id == CSSValueTextfield) - feature = WebFeature::kCSSValueAppearanceTextField; - else - feature = WebFeature::kCSSValueAppearanceOthers; - } - context->Count(feature); - break; - } - - case CSSPropertyWebkitUserModify: { - switch (value_id) { - case CSSValueReadOnly: - context->Count(WebFeature::kCSSValueUserModifyReadOnly); - break; - case CSSValueReadWrite: - context->Count(WebFeature::kCSSValueUserModifyReadWrite); - break; - case CSSValueReadWritePlaintextOnly: - context->Count(WebFeature::kCSSValueUserModifyReadWritePlaintextOnly); - break; - default: - NOTREACHED(); - } - break; - } - - default: - break; - } -} const CSSValue* CSSPropertyParser::ParseSingleValue( CSSPropertyID unresolved_property, CSSPropertyID current_shorthand) { DCHECK(context_); - CSSPropertyID property = resolveCSSPropertyID(unresolved_property); - if (CSSParserFastPaths::IsKeywordPropertyID(property)) { - if (!CSSParserFastPaths::IsValidKeywordPropertyAndValue( - property, range_.Peek().Id(), context_->Mode())) - return nullptr; - CountKeywordOnlyPropertyUsage(property, context_, range_.Peek().Id()); - return ConsumeIdent(range_); - } // Gets the parsing method for our current property from the property API. // If it has been implemented, we call this method, otherwise we manually // parse this value in the switch statement below. As we implement APIs for // other properties, those properties will be taken out of the switch // statement. - const CSSPropertyDescriptor& css_property_desc = - CSSPropertyDescriptor::Get(property); - if (css_property_desc.parseSingleValue) { - return css_property_desc.parseSingleValue( - range_, *context_, - CSSParserLocalContext(isPropertyAlias(unresolved_property))); - } + bool needs_legacy_parsing = false; + const CSSValue* const parsed_value = + CSSPropertyParserHelpers::ParseLonghandViaAPI( + unresolved_property, current_shorthand, *context_, range_, + needs_legacy_parsing); + if (!needs_legacy_parsing) + return parsed_value; + CSSPropertyID property = resolveCSSPropertyID(unresolved_property); switch (property) { case CSSPropertyMaxWidth: case CSSPropertyMaxHeight: @@ -1308,7 +1243,6 @@ case CSSPropertyGridRowGap: return ConsumeLengthOrPercent(range_, context_->Mode(), kValueRangeNonNegative); - case CSSPropertyColor: case CSSPropertyBorderBottomColor: case CSSPropertyBorderLeftColor: case CSSPropertyBorderRightColor:
diff --git a/third_party/WebKit/Source/core/css/parser/CSSPropertyParserHelpers.cpp b/third_party/WebKit/Source/core/css/parser/CSSPropertyParserHelpers.cpp index 24e8241..00fc88d 100644 --- a/third_party/WebKit/Source/core/css/parser/CSSPropertyParserHelpers.cpp +++ b/third_party/WebKit/Source/core/css/parser/CSSPropertyParserHelpers.cpp
@@ -18,7 +18,9 @@ #include "core/css/CSSVariableData.h" #include "core/css/StyleColor.h" #include "core/css/parser/CSSParserContext.h" +#include "core/css/parser/CSSParserFastPaths.h" #include "core/css/parser/CSSParserLocalContext.h" +#include "core/css/properties/CSSPropertyDescriptor.h" #include "core/css/properties/CSSPropertyTransformUtils.h" #include "core/frame/UseCounter.h" #include "platform/RuntimeEnabledFeatures.h" @@ -1493,6 +1495,144 @@ range, context, CSSParserLocalContext()); } +void CountKeywordOnlyPropertyUsage(CSSPropertyID property, + const CSSParserContext& context, + CSSValueID value_id) { + if (!context.IsUseCounterRecordingEnabled()) + return; + switch (property) { + case CSSPropertyWebkitAppearance: { + WebFeature feature; + if (value_id == CSSValueNone) { + feature = WebFeature::kCSSValueAppearanceNone; + } else { + feature = WebFeature::kCSSValueAppearanceNotNone; + if (value_id == CSSValueButton) + feature = WebFeature::kCSSValueAppearanceButton; + else if (value_id == CSSValueCaret) + feature = WebFeature::kCSSValueAppearanceCaret; + else if (value_id == CSSValueCheckbox) + feature = WebFeature::kCSSValueAppearanceCheckbox; + else if (value_id == CSSValueMenulist) + feature = WebFeature::kCSSValueAppearanceMenulist; + else if (value_id == CSSValueMenulistButton) + feature = WebFeature::kCSSValueAppearanceMenulistButton; + else if (value_id == CSSValueListbox) + feature = WebFeature::kCSSValueAppearanceListbox; + else if (value_id == CSSValueRadio) + feature = WebFeature::kCSSValueAppearanceRadio; + else if (value_id == CSSValueSearchfield) + feature = WebFeature::kCSSValueAppearanceSearchField; + else if (value_id == CSSValueTextfield) + feature = WebFeature::kCSSValueAppearanceTextField; + else + feature = WebFeature::kCSSValueAppearanceOthers; + } + context.Count(feature); + break; + } + + case CSSPropertyWebkitUserModify: { + switch (value_id) { + case CSSValueReadOnly: + context.Count(WebFeature::kCSSValueUserModifyReadOnly); + break; + case CSSValueReadWrite: + context.Count(WebFeature::kCSSValueUserModifyReadWrite); + break; + case CSSValueReadWritePlaintextOnly: + context.Count(WebFeature::kCSSValueUserModifyReadWritePlaintextOnly); + break; + default: + NOTREACHED(); + } + break; + } + + default: + break; + } +} + +const CSSValue* ParseLonghandViaAPI(CSSPropertyID unresolved_property, + CSSPropertyID current_shorthand, + const CSSParserContext& context, + CSSParserTokenRange& range, + bool& needs_legacy_parsing) { + DCHECK(!isShorthandProperty(unresolved_property)); + needs_legacy_parsing = false; + CSSPropertyID property = resolveCSSPropertyID(unresolved_property); + if (CSSParserFastPaths::IsKeywordPropertyID(property)) { + if (!CSSParserFastPaths::IsValidKeywordPropertyAndValue( + property, range.Peek().Id(), context.Mode())) + return nullptr; + CountKeywordOnlyPropertyUsage(property, context, range.Peek().Id()); + return ConsumeIdent(range); + } + + const CSSPropertyDescriptor& css_property_desc = + CSSPropertyDescriptor::Get(property); + if (css_property_desc.parseSingleValue) { + return css_property_desc.parseSingleValue( + range, context, + CSSParserLocalContext(isPropertyAlias(unresolved_property))); + } + needs_legacy_parsing = true; + return nullptr; +} + +bool ConsumeShorthandVia4LonghandsAPI( + const StylePropertyShorthand& shorthand, + bool important, + const CSSParserContext& context, + CSSParserTokenRange& range, + HeapVector<CSSProperty, 256>& properties) { + DCHECK_EQ(shorthand.length(), 4u); + const CSSPropertyID* longhands = shorthand.properties(); + bool needs_legacy_parsing = false; + const CSSValue* top = ParseLonghandViaAPI( + longhands[0], shorthand.id(), context, range, needs_legacy_parsing); + DCHECK(!needs_legacy_parsing); + + if (!top) + return false; + + const CSSValue* right = ParseLonghandViaAPI( + longhands[1], shorthand.id(), context, range, needs_legacy_parsing); + DCHECK(!needs_legacy_parsing); + + const CSSValue* bottom = nullptr; + const CSSValue* left = nullptr; + if (right) { + bottom = ParseLonghandViaAPI(longhands[2], shorthand.id(), context, range, + needs_legacy_parsing); + DCHECK(!needs_legacy_parsing); + if (bottom) { + left = ParseLonghandViaAPI(longhands[3], shorthand.id(), context, range, + needs_legacy_parsing); + DCHECK(!needs_legacy_parsing); + } + } + + if (!right) + right = top; + if (!bottom) + bottom = top; + if (!left) + left = right; + + AddProperty(longhands[0], shorthand.id(), *top, important, + IsImplicitProperty::kNotImplicit, properties); + AddProperty(longhands[1], shorthand.id(), *right, important, + IsImplicitProperty::kNotImplicit, properties); + AddProperty(longhands[2], shorthand.id(), *bottom, important, + IsImplicitProperty::kNotImplicit, properties); + AddProperty(longhands[3], shorthand.id(), *left, important, + IsImplicitProperty::kNotImplicit, properties); + + return range.AtEnd(); +} + } // namespace CSSPropertyParserHelpers } // namespace blink
diff --git a/third_party/WebKit/Source/core/css/parser/CSSPropertyParserHelpers.h b/third_party/WebKit/Source/core/css/parser/CSSPropertyParserHelpers.h index ef4e81bc..a2b6a6a 100644 --- a/third_party/WebKit/Source/core/css/parser/CSSPropertyParserHelpers.h +++ b/third_party/WebKit/Source/core/css/parser/CSSPropertyParserHelpers.h
@@ -23,6 +23,7 @@ class CSSStringValue; class CSSURIValue; class CSSValuePair; +class StylePropertyShorthand; // When these functions are successful, they will consume all the relevant // tokens from the range and also consume any whitespace which follows. When @@ -120,6 +121,22 @@ IsImplicitProperty, HeapVector<CSSProperty, 256>& properties); +void CountKeywordOnlyPropertyUsage(CSSPropertyID, + const CSSParserContext&, + CSSValueID); + +const CSSValue* ParseLonghandViaAPI(CSSPropertyID unresolved_property, + CSSPropertyID current_shorthand, + const CSSParserContext&, + CSSParserTokenRange&, + bool& needs_legacy_parsing); + +bool ConsumeShorthandVia4LonghandsAPI(const StylePropertyShorthand&, + bool important, + const CSSParserContext&, + CSSParserTokenRange&, + HeapVector<CSSProperty, 256>& properties); + // Template implementations are at the bottom of the file for readability. template <typename... emptyBaseCase>
diff --git a/third_party/WebKit/Source/core/css/properties/CSSPropertyAPIBackgroundColor.cpp b/third_party/WebKit/Source/core/css/properties/CSSPropertyAPIBackgroundColor.cpp deleted file mode 100644 index 6254c51..0000000 --- a/third_party/WebKit/Source/core/css/properties/CSSPropertyAPIBackgroundColor.cpp +++ /dev/null
@@ -1,21 +0,0 @@ -// Copyright 2017 The Chromium Authors. All rights reserved. -// Use of this source code is governed by a BSD-style license that can be -// found in the LICENSE file. - -#include "core/css/properties/CSSPropertyAPIBackgroundColor.h" - -#include "core/css/parser/CSSParserContext.h" -#include "core/css/parser/CSSParserMode.h" -#include "core/css/parser/CSSPropertyParserHelpers.h" - -namespace blink { - -const CSSValue* CSSPropertyAPIBackgroundColor::parseSingleValue( - CSSParserTokenRange& range, - const CSSParserContext& context, - const CSSParserLocalContext&) { - return CSSPropertyParserHelpers::ConsumeColor( - range, context.Mode(), IsQuirksModeBehavior(context.Mode())); -} - -} // namespace blink
diff --git a/third_party/WebKit/Source/core/css/properties/CSSPropertyAPIColor.cpp b/third_party/WebKit/Source/core/css/properties/CSSPropertyAPIColor.cpp index f4e299cf..a234938b 100644 --- a/third_party/WebKit/Source/core/css/properties/CSSPropertyAPIColor.cpp +++ b/third_party/WebKit/Source/core/css/properties/CSSPropertyAPIColor.cpp
@@ -5,16 +5,17 @@ #include "core/css/properties/CSSPropertyAPIColor.h" #include "core/css/parser/CSSParserContext.h" +#include "core/css/parser/CSSParserMode.h" #include "core/css/parser/CSSPropertyParserHelpers.h" -class CSSParserLocalContext; namespace blink { const CSSValue* CSSPropertyAPIColor::parseSingleValue( CSSParserTokenRange& range, const CSSParserContext& context, const CSSParserLocalContext&) { - return CSSPropertyParserHelpers::ConsumeColor(range, context.Mode()); + return CSSPropertyParserHelpers::ConsumeColor( + range, context.Mode(), IsQuirksModeBehavior(context.Mode())); } } // namespace blink
diff --git a/third_party/WebKit/Source/core/css/properties/CSSPropertyAPIColorNoQuirks.cpp b/third_party/WebKit/Source/core/css/properties/CSSPropertyAPIColorNoQuirks.cpp new file mode 100644 index 0000000..42662bc --- /dev/null +++ b/third_party/WebKit/Source/core/css/properties/CSSPropertyAPIColorNoQuirks.cpp
@@ -0,0 +1,20 @@ +// Copyright 2017 The Chromium Authors. All rights reserved. +// Use of this source code is governed by a BSD-style license that can be +// found in the LICENSE file. + +#include "core/css/properties/CSSPropertyAPIColorNoQuirks.h" + +#include "core/css/parser/CSSParserContext.h" +#include "core/css/parser/CSSPropertyParserHelpers.h" + +class CSSParserLocalContext; +namespace blink { + +const CSSValue* CSSPropertyAPIColorNoQuirks::parseSingleValue( + CSSParserTokenRange& range, + const CSSParserContext& context, + const CSSParserLocalContext&) { + return CSSPropertyParserHelpers::ConsumeColor(range, context.Mode()); +} + +} // namespace blink
diff --git a/third_party/WebKit/Source/core/dom/ClassicPendingScript.cpp b/third_party/WebKit/Source/core/dom/ClassicPendingScript.cpp index 39ebbfa..34a8c234 100644 --- a/third_party/WebKit/Source/core/dom/ClassicPendingScript.cpp +++ b/third_party/WebKit/Source/core/dom/ClassicPendingScript.cpp
@@ -210,6 +210,8 @@ } bool ClassicPendingScript::WasCanceled() const { + if (!GetResource()) + return false; return GetResource()->WasCanceled(); }
diff --git a/third_party/WebKit/Source/core/dom/Document.cpp b/third_party/WebKit/Source/core/dom/Document.cpp index 24d6081..8295d60 100644 --- a/third_party/WebKit/Source/core/dom/Document.cpp +++ b/third_party/WebKit/Source/core/dom/Document.cpp
@@ -254,12 +254,12 @@ #include "platform/wtf/text/CharacterNames.h" #include "platform/wtf/text/StringBuffer.h" #include "platform/wtf/text/TextEncodingRegistry.h" -#include "public/platform/InterfaceProvider.h" #include "public/platform/Platform.h" #include "public/platform/WebAddressSpace.h" #include "public/platform/WebPrerenderingSupport.h" #include "public/platform/modules/sensitive_input_visibility/sensitive_input_visibility_service.mojom-blink.h" #include "public/platform/site_engagement.mojom-blink.h" +#include "services/service_manager/public/cpp/interface_provider.h" #include <memory> @@ -4718,7 +4718,7 @@ return; mojom::blink::SensitiveInputVisibilityServicePtr sensitive_input_service_ptr; - GetFrame()->GetInterfaceProvider()->GetInterface( + GetFrame()->GetInterfaceProvider().GetInterface( mojo::MakeRequest(&sensitive_input_service_ptr)); if (password_count_ > 0) { sensitive_input_service_ptr->PasswordFieldVisibleInInsecureContext();
diff --git a/third_party/WebKit/Source/core/dom/ElementVisibilityObserverTest.cpp b/third_party/WebKit/Source/core/dom/ElementVisibilityObserverTest.cpp index 4abca33..8785685 100644 --- a/third_party/WebKit/Source/core/dom/ElementVisibilityObserverTest.cpp +++ b/third_party/WebKit/Source/core/dom/ElementVisibilityObserverTest.cpp
@@ -41,8 +41,8 @@ protected: void SetUp() override { local_frame_client_ = new StubLocalFrameClient(); - dummy_page_holder_ = DummyPageHolder::Create( - IntSize(), nullptr, local_frame_client_, nullptr, nullptr); + dummy_page_holder_ = DummyPageHolder::Create(IntSize(), nullptr, + local_frame_client_, nullptr); } void TearDown() override {
diff --git a/third_party/WebKit/Source/core/dom/README.md b/third_party/WebKit/Source/core/dom/README.md index a9b8175..b627458 100644 --- a/third_party/WebKit/Source/core/dom/README.md +++ b/third_party/WebKit/Source/core/dom/README.md
@@ -136,7 +136,7 @@ - PseudoElementData - VisitedLinkState (HTMLLinkElement) -## fullscreen (-> core/fullscreen or core/html) +## [Fullscreen](https://fullscreen.spec.whatwg.org/) (-> core/fullscreen) - DocumentFullscreen - ElementFullscreen
diff --git a/third_party/WebKit/Source/core/dom/ScriptLoader.cpp b/third_party/WebKit/Source/core/dom/ScriptLoader.cpp index b947258..82d5fa7d 100644 --- a/third_party/WebKit/Source/core/dom/ScriptLoader.cpp +++ b/third_party/WebKit/Source/core/dom/ScriptLoader.cpp
@@ -676,22 +676,8 @@ ? element_document.Url() : KURL(); - switch (ExecuteScript(ClassicScript::Create( - ScriptSourceCode(element_->TextFromChildren(), script_url, position)))) { - case ExecuteScriptResult::kShouldFireLoadEvent: - // The load event is not fired because this is an inline script. - return true; - - case ExecuteScriptResult::kShouldFireErrorEvent: - DispatchErrorEvent(); - return false; - - case ExecuteScriptResult::kShouldFireNone: - return true; - } - - NOTREACHED(); - return false; + return ExecuteScriptBlock(ClassicPendingScript::Create(element_, position), + script_url); } bool ScriptLoader::FetchClassicScript( @@ -910,31 +896,58 @@ DCHECK(!will_be_parser_executed_); DCHECK(async_exec_type_ != ScriptRunner::kNone); DCHECK(pending_script_->IsExternalOrModule()); - DCHECK_EQ(pending_script_->IsExternal(), is_external_script_); - bool error_occurred = false; - Script* script = pending_script_->GetSource(NullURL(), error_occurred); - const bool wasCanceled = pending_script_->WasCanceled(); - const bool is_external = pending_script_->IsExternal(); - DetachPendingScript(); - if (error_occurred) { - DispatchErrorEvent(); - } else if (!wasCanceled) { - switch (ExecuteScript(script)) { - case ExecuteScriptResult::kShouldFireLoadEvent: - if (is_external) - DispatchLoadEvent(); - break; - case ExecuteScriptResult::kShouldFireErrorEvent: - DispatchErrorEvent(); - break; - case ExecuteScriptResult::kShouldFireNone: - break; - } - } + PendingScript* pending_script = pending_script_; + pending_script_ = nullptr; + ExecuteScriptBlock(pending_script, NullURL()); resource_ = nullptr; module_tree_client_ = nullptr; } +// https://html.spec.whatwg.org/#execute-the-script-block +bool ScriptLoader::ExecuteScriptBlock(PendingScript* pending_script, + const KURL& document_url) { + DCHECK(pending_script); + DCHECK_EQ(pending_script->IsExternal(), is_external_script_); + + bool error_occurred = false; + Script* script = pending_script->GetSource(document_url, error_occurred); + const bool was_canceled = pending_script->WasCanceled(); + const bool is_external = pending_script->IsExternal(); + pending_script->Dispose(); + + // 2. "If the script's script is null, fire an event named error at the + // element, and abort these steps." + if (error_occurred) { + DispatchErrorEvent(); + return false; + } + + if (was_canceled) + return false; + + // Steps 3--7 are in ExecuteScript(). + switch (ExecuteScript(script)) { + case ExecuteScriptResult::kShouldFireLoadEvent: + // 8. "If the script is from an external file, then fire an event named + // load at the script element." + if (is_external) + DispatchLoadEvent(); + return true; + + case ExecuteScriptResult::kShouldFireErrorEvent: + // Consider as if "the script's script is null" retrospectively, + // due to CSP check failures etc., which are considered as load failure. + DispatchErrorEvent(); + return false; + + case ExecuteScriptResult::kShouldFireNone: + return true; + } + + NOTREACHED(); + return false; +} + void ScriptLoader::PendingScriptFinished(PendingScript* pending_script) { DCHECK(!will_be_parser_executed_); DCHECK_EQ(pending_script_, pending_script);
diff --git a/third_party/WebKit/Source/core/dom/ScriptLoader.h b/third_party/WebKit/Source/core/dom/ScriptLoader.h index a3171bc..678a63f 100644 --- a/third_party/WebKit/Source/core/dom/ScriptLoader.h +++ b/third_party/WebKit/Source/core/dom/ScriptLoader.h
@@ -81,6 +81,16 @@ TextPosition::MinimumPosition(), LegacyTypeSupport = kDisallowLegacyTypeInTypeAttribute); + // https://html.spec.whatwg.org/#execute-the-script-block + // The single entry point of script execution. + // PendingScript::Dispose() is called in ExecuteScriptBlock(). + // + // TODO(hiroshige): Replace ExecuteScript() calls with ExecuteScriptBlock(). + // + // TODO(hiroshige): Currently this returns bool (true if success) only to + // preserve existing code structure around PrepareScript(). Clean up this. + bool ExecuteScriptBlock(PendingScript*, const KURL&); + // Creates a PendingScript for external script whose fetch is started in // FetchClassicScript()/FetchModuleScriptTree(). PendingScript* CreatePendingScript(); @@ -91,6 +101,8 @@ kShouldFireNone }; WARN_UNUSED_RESULT ExecuteScriptResult ExecuteScript(const Script*); + + // The entry point only for ScriptRunner that wraps ExecuteScriptBlock(). virtual void Execute(); // XML parser calls these
diff --git a/third_party/WebKit/Source/core/editing/FrameSelection.cpp b/third_party/WebKit/Source/core/editing/FrameSelection.cpp index a80dfd1..be6bbd7 100644 --- a/third_party/WebKit/Source/core/editing/FrameSelection.cpp +++ b/third_party/WebKit/Source/core/editing/FrameSelection.cpp
@@ -947,10 +947,23 @@ return LayoutRect(layout_selection_->SelectionBounds()); } -static IntRect AbsoluteSelectionBoundsOf( - const VisibleSelectionInFlatTree& selection) { - return ComputeTextRect( - EphemeralRangeInFlatTree(selection.Start(), selection.End())); +IntRect FrameSelection::ComputeRectToScroll( + RevealExtentOption reveal_extent_option) { + const VisibleSelection& selection = ComputeVisibleSelectionInDOMTree(); + LayoutRect rect; + switch (selection.GetSelectionType()) { + case kCaretSelection: + return AbsoluteCaretBounds(); + case kRangeSelection: { + if (reveal_extent_option == kRevealExtent) + return AbsoluteCaretBoundsOf(CreateVisiblePosition(selection.Extent())); + layout_selection_->SetHasPendingSelection(); + return layout_selection_->SelectionBounds(); + } + default: + NOTREACHED(); + return {}; + } } // TODO(editing-dev): This should be done in FlatTree world. @@ -967,23 +980,6 @@ if (selection.GetSelectionType() == kNoSelection) return; - LayoutRect rect; - switch (selection.GetSelectionType()) { - case kCaretSelection: - rect = LayoutRect(AbsoluteCaretBounds()); - break; - case kRangeSelection: { - rect = LayoutRect( - reveal_extent_option == kRevealExtent - ? AbsoluteCaretBoundsOf(CreateVisiblePosition(selection.Extent())) - : AbsoluteSelectionBoundsOf(ComputeVisibleSelectionInFlatTree())); - break; - } - default: - NOTREACHED(); - break; - } - // FIXME: This code only handles scrolling the startContainer's layer, but // the selection rect could intersect more than just that. if (DocumentLoader* document_loader = frame_->Loader().GetDocumentLoader()) @@ -992,7 +988,8 @@ DCHECK(start.AnchorNode()); DCHECK(start.AnchorNode()->GetLayoutObject()); if (!start.AnchorNode()->GetLayoutObject()->ScrollRectToVisible( - rect, alignment, alignment)) + LayoutRect(ComputeRectToScroll(reveal_extent_option)), alignment, + alignment)) return; UpdateAppearance();
diff --git a/third_party/WebKit/Source/core/editing/FrameSelection.h b/third_party/WebKit/Source/core/editing/FrameSelection.h index cccc742e..2dcf720 100644 --- a/third_party/WebKit/Source/core/editing/FrameSelection.h +++ b/third_party/WebKit/Source/core/editing/FrameSelection.h
@@ -280,6 +280,8 @@ GranularityStrategy* GetGranularityStrategy(); + IntRect ComputeRectToScroll(RevealExtentOption); + // Implementation of |SynchronousMutationObserver| member functions. void ContextDestroyed(Document*) final; void NodeChildrenWillBeRemoved(ContainerNode&) final;
diff --git a/third_party/WebKit/Source/core/editing/LayoutSelection.cpp b/third_party/WebKit/Source/core/editing/LayoutSelection.cpp index bde815039..7585134d 100644 --- a/third_party/WebKit/Source/core/editing/LayoutSelection.cpp +++ b/third_party/WebKit/Source/core/editing/LayoutSelection.cpp
@@ -322,6 +322,8 @@ DCHECK(start_layout_object); DCHECK(end_layout_object); DCHECK(start_layout_object->View() == end_layout_object->View()); + if (!start_layout_object || !end_layout_object) + return SelectionPaintRange(); return SelectionPaintRange(start_layout_object, start_pos.ComputeEditingOffset(),
diff --git a/third_party/WebKit/Source/core/editing/SelectionModifier.cpp b/third_party/WebKit/Source/core/editing/SelectionModifier.cpp index 36b7d35..dbb85e8 100644 --- a/third_party/WebKit/Source/core/editing/SelectionModifier.cpp +++ b/third_party/WebKit/Source/core/editing/SelectionModifier.cpp
@@ -179,7 +179,7 @@ } static VisiblePosition AdjustForwardPositionForUserSelectAll( - VisiblePosition& position) { + const VisiblePosition& position) { Node* const root_user_select_all = EditingStrategy::RootUserSelectAllForNode( position.DeepEquivalent().AnchorNode()); if (!root_user_select_all) @@ -189,7 +189,7 @@ } static VisiblePosition AdjustBackwardPositionForUserSelectAll( - VisiblePosition& position) { + const VisiblePosition& position) { Node* const root_user_select_all = EditingStrategy::RootUserSelectAllForNode( position.DeepEquivalent().AnchorNode()); if (!root_user_select_all) @@ -258,12 +258,13 @@ pos = NextSentencePosition(pos); break; case kLineGranularity: - pos = NextLinePosition( - pos, LineDirectionPointForBlockDirectionNavigation(EXTENT)); + pos = NextLinePosition(pos, LineDirectionPointForBlockDirectionNavigation( + selection_.Extent())); break; case kParagraphGranularity: pos = NextParagraphPosition( - pos, LineDirectionPointForBlockDirectionNavigation(EXTENT)); + pos, + LineDirectionPointForBlockDirectionNavigation(selection_.Extent())); break; case kSentenceBoundary: pos = EndOfSentence(EndForPlatform()); @@ -348,15 +349,17 @@ // needs to leave the selection at that line start (no need to call // nextLinePosition!) pos = EndForPlatform(); - if (!selection_.IsRange() || !IsStartOfLine(pos)) + if (!selection_.IsRange() || !IsStartOfLine(pos)) { pos = NextLinePosition( - pos, LineDirectionPointForBlockDirectionNavigation(START)); + pos, + LineDirectionPointForBlockDirectionNavigation(selection_.Start())); + } break; } case kParagraphGranularity: pos = NextParagraphPosition( EndForPlatform(), - LineDirectionPointForBlockDirectionNavigation(START)); + LineDirectionPointForBlockDirectionNavigation(selection_.Start())); break; case kSentenceBoundary: pos = EndOfSentence(EndForPlatform()); @@ -443,11 +446,13 @@ break; case kLineGranularity: pos = PreviousLinePosition( - pos, LineDirectionPointForBlockDirectionNavigation(EXTENT)); + pos, + LineDirectionPointForBlockDirectionNavigation(selection_.Extent())); break; case kParagraphGranularity: pos = PreviousParagraphPosition( - pos, LineDirectionPointForBlockDirectionNavigation(EXTENT)); + pos, + LineDirectionPointForBlockDirectionNavigation(selection_.Extent())); break; case kSentenceBoundary: pos = StartOfSentence(StartForPlatform()); @@ -529,12 +534,12 @@ case kLineGranularity: pos = PreviousLinePosition( StartForPlatform(), - LineDirectionPointForBlockDirectionNavigation(START)); + LineDirectionPointForBlockDirectionNavigation(selection_.Start())); break; case kParagraphGranularity: pos = PreviousParagraphPosition( StartForPlatform(), - LineDirectionPointForBlockDirectionNavigation(START)); + LineDirectionPointForBlockDirectionNavigation(selection_.Start())); break; case kSentenceBoundary: pos = StartOfSentence(StartForPlatform()); @@ -617,7 +622,8 @@ // Note: the START position type is arbitrary because it is unused, it would // be the requested position type if there were no // xPosForVerticalArrowNavigation set. - LayoutUnit x = LineDirectionPointForBlockDirectionNavigation(START); + LayoutUnit x = + LineDirectionPointForBlockDirectionNavigation(selection_.Start()); switch (alter) { case FrameSelection::kAlterationMove: @@ -737,11 +743,13 @@ : selection_.End(), selection_.Affinity()); x_pos = LineDirectionPointForBlockDirectionNavigation( - direction == FrameSelection::kDirectionUp ? START : END); + direction == FrameSelection::kDirectionUp ? selection_.Start() + : selection_.End()); break; case FrameSelection::kAlterationExtend: pos = CreateVisiblePosition(selection_.Extent(), selection_.Affinity()); - x_pos = LineDirectionPointForBlockDirectionNavigation(EXTENT); + x_pos = + LineDirectionPointForBlockDirectionNavigation(selection_.Extent()); break; } @@ -830,28 +838,12 @@ } LayoutUnit SelectionModifier::LineDirectionPointForBlockDirectionNavigation( - EPositionType type) { + const Position& pos) { LayoutUnit x; if (selection_.IsNone()) return x; - Position pos; - switch (type) { - case START: - pos = selection_.Start(); - break; - case END: - pos = selection_.End(); - break; - case BASE: - pos = selection_.Base(); - break; - case EXTENT: - pos = selection_.Extent(); - break; - } - LocalFrame* frame = pos.GetDocument()->GetFrame(); if (!frame) return x;
diff --git a/third_party/WebKit/Source/core/editing/SelectionModifier.h b/third_party/WebKit/Source/core/editing/SelectionModifier.h index 50a0b1d..6d7b336 100644 --- a/third_party/WebKit/Source/core/editing/SelectionModifier.h +++ b/third_party/WebKit/Source/core/editing/SelectionModifier.h
@@ -58,11 +58,6 @@ VerticalDirection); private: - // TODO(yosin): We should move |EPositionType| to "SelectionModifier.cpp", - // it is only used for implementing |modify()|. - // TODO(yosin) We should use capitalized name for |EPositionType|. - enum EPositionType { START, END, BASE, EXTENT }; // NOLINT - LocalFrame* GetFrame() const { return frame_; } static bool ShouldAlwaysUseDirectionalSelection(LocalFrame*); @@ -71,7 +66,7 @@ VisiblePosition PositionForPlatform(bool is_get_start) const; VisiblePosition StartForPlatform() const; VisiblePosition EndForPlatform() const; - LayoutUnit LineDirectionPointForBlockDirectionNavigation(EPositionType); + LayoutUnit LineDirectionPointForBlockDirectionNavigation(const Position&); VisiblePosition ModifyExtendingRight(TextGranularity); VisiblePosition ModifyExtendingForward(TextGranularity); VisiblePosition ModifyMovingRight(TextGranularity);
diff --git a/third_party/WebKit/Source/core/editing/VisibleSelection.cpp b/third_party/WebKit/Source/core/editing/VisibleSelection.cpp index 1c71047e9..d7f32ba 100644 --- a/third_party/WebKit/Source/core/editing/VisibleSelection.cpp +++ b/third_party/WebKit/Source/core/editing/VisibleSelection.cpp
@@ -478,19 +478,20 @@ AdjustSelectionToAvoidCrossingEditingBoundaries(); UpdateSelectionType(); - if (GetSelectionType() == kRangeSelection) { - // "Constrain" the selection to be the smallest equivalent range of - // nodes. This is a somewhat arbitrary choice, but experience shows that - // it is useful to make to make the selection "canonical" (if only for - // purposes of comparing selections). This is an ideal point of the code - // to do this operation, since all selection changes that result in a - // RANGE come through here before anyone uses it. - // TODO(yosin) Canonicalizing is good, but haven't we already done it - // (when we set these two positions to |VisiblePosition| - // |deepEquivalent()|s above)? - start_ = MostForwardCaretPosition(start_); - end_ = MostBackwardCaretPosition(end_); - } + if (GetSelectionType() != kRangeSelection) + return; + + // "Constrain" the selection to be the smallest equivalent range of + // nodes. This is a somewhat arbitrary choice, but experience shows that + // it is useful to make to make the selection "canonical" (if only for + // purposes of comparing selections). This is an ideal point of the code + // to do this operation, since all selection changes that result in a + // RANGE come through here before anyone uses it. + // TODO(yosin) Canonicalizing is good, but haven't we already done it + // (when we set these two positions to |VisiblePosition| + // |deepEquivalent()|s above)? + start_ = MostForwardCaretPosition(start_); + end_ = MostBackwardCaretPosition(end_); } template <typename Strategy>
diff --git a/third_party/WebKit/Source/core/editing/VisibleSelectionTest.cpp b/third_party/WebKit/Source/core/editing/VisibleSelectionTest.cpp index c9e5b882..2132da9 100644 --- a/third_party/WebKit/Source/core/editing/VisibleSelectionTest.cpp +++ b/third_party/WebKit/Source/core/editing/VisibleSelectionTest.cpp
@@ -219,6 +219,24 @@ EXPECT_EQ(PositionInFlatTree(five, 5), selection_in_flat_tree.End()); } +// For http://wkb.ug/32622 +TEST_F(VisibleSelectionTest, ExpandUsingGranularityWithEmptyCell) { + SetBodyContent( + "<div contentEditable><table cellspacing=0><tr>" + "<td id='first' width='50' height='25pt'></td>" + "<td id='second' width='50' height='25pt'></td>" + "</tr></table></div>"); + Element* const first = GetDocument().getElementById("first"); + const VisibleSelectionInFlatTree& selection = + CreateVisibleSelectionWithGranularity( + SelectionInFlatTree::Builder() + .Collapse(PositionInFlatTree(first, 0)) + .Build(), + kWordGranularity); + EXPECT_EQ(PositionInFlatTree(first, 0), selection.Start()); + EXPECT_EQ(PositionInFlatTree(first, 0), selection.End()); +} + TEST_F(VisibleSelectionTest, Initialisation) { SetBodyContent(LOREM_IPSUM);
diff --git a/third_party/WebKit/Source/core/editing/VisibleUnitsLine.cpp b/third_party/WebKit/Source/core/editing/VisibleUnitsLine.cpp index 9ed1faa..0c90856 100644 --- a/third_party/WebKit/Source/core/editing/VisibleUnitsLine.cpp +++ b/third_party/WebKit/Source/core/editing/VisibleUnitsLine.cpp
@@ -140,9 +140,10 @@ return nullptr; } -Node* PreviousLeafWithSameEditability(Node* node, EditableType editable_type) { - const bool editable = HasEditableStyle(*node, editable_type); - for (Node* runner = PreviousAtomicLeafNode(*node); runner; +Node* PreviousLeafWithSameEditability(const Node& node, + EditableType editable_type) { + const bool editable = HasEditableStyle(node, editable_type); + for (Node* runner = PreviousAtomicLeafNode(node); runner; runner = PreviousAtomicLeafNode(*runner)) { if (editable == HasEditableStyle(*runner, editable_type)) return runner; @@ -270,12 +271,10 @@ Node* FindNodeInPreviousLine(const Node& start_node, const VisiblePosition& visible_position, EditableType editable_type) { - // TODO(editing-dev): We should make |PreviousLeafWithSameEditability()| to - // take |const Node&|. - for (Node* runner = PreviousLeafWithSameEditability( - const_cast<Node*>(&start_node), editable_type); + for (Node* runner = + PreviousLeafWithSameEditability(start_node, editable_type); runner; - runner = PreviousLeafWithSameEditability(runner, editable_type)) { + runner = PreviousLeafWithSameEditability(*runner, editable_type)) { if (!InSameLine(*runner, visible_position)) return runner; } @@ -295,7 +294,7 @@ Node* const previous_node = FindNodeInPreviousLine(*node, visible_position, editable_type); for (Node* runner = previous_node; runner && !runner->IsShadowRoot(); - runner = PreviousLeafWithSameEditability(runner, editable_type)) { + runner = PreviousLeafWithSameEditability(*runner, editable_type)) { if (HighestEditableRootOfNode(*runner, editable_type) != highest_root) break;
diff --git a/third_party/WebKit/Source/core/events/EventTargetFactory.json5 b/third_party/WebKit/Source/core/events/EventTargetFactory.json5 index b9dcfb58..fe22a3cc 100644 --- a/third_party/WebKit/Source/core/events/EventTargetFactory.json5 +++ b/third_party/WebKit/Source/core/events/EventTargetFactory.json5
@@ -6,6 +6,7 @@ data: [ "core/animation/AnimationPlayer", + "core/clipboard/Clipboard", "core/css/FontFaceSet", "core/css/MediaQueryList", "core/dom/BroadcastChannel",
diff --git a/third_party/WebKit/Source/core/exported/WebDataSourceImpl.cpp b/third_party/WebKit/Source/core/exported/WebDataSourceImpl.cpp index d2db829..0fee7de 100644 --- a/third_party/WebKit/Source/core/exported/WebDataSourceImpl.cpp +++ b/third_party/WebKit/Source/core/exported/WebDataSourceImpl.cpp
@@ -32,6 +32,7 @@ #include <memory> #include "core/dom/Document.h" +#include "core/frame/LocalFrame.h" #include "core/loader/SubresourceFilter.h" #include "platform/wtf/PtrUtil.h" #include "public/platform/WebDocumentSubresourceFilter.h" @@ -159,8 +160,8 @@ void WebDataSourceImpl::SetSubresourceFilter( WebDocumentSubresourceFilter* subresource_filter) { - DocumentLoader::SetSubresourceFilter( - SubresourceFilter::Create(this, WTF::WrapUnique(subresource_filter))); + DocumentLoader::SetSubresourceFilter(SubresourceFilter::Create( + *GetFrame()->GetDocument(), WTF::WrapUnique(subresource_filter))); } void WebDataSourceImpl::SetServiceWorkerNetworkProvider(
diff --git a/third_party/WebKit/Source/core/exported/WebFactory.h b/third_party/WebKit/Source/core/exported/WebFactory.h index 448bfa2..07e6208a 100644 --- a/third_party/WebKit/Source/core/exported/WebFactory.h +++ b/third_party/WebKit/Source/core/exported/WebFactory.h
@@ -17,7 +17,6 @@ class WebLocalFrameBase; class WebViewClient; class WebFrameClient; -class InterfaceProvider; class InterfaceRegistry; class WebFrame; enum class WebTreeScopeType; @@ -35,12 +34,10 @@ virtual WebLocalFrameBase* CreateMainWebLocalFrameBase( WebView*, WebFrameClient*, - InterfaceProvider*, InterfaceRegistry*) const = 0; virtual WebLocalFrameBase* CreateWebLocalFrameBase( WebTreeScopeType, WebFrameClient*, - InterfaceProvider*, InterfaceRegistry*, WebFrame* opener) const = 0;
diff --git a/third_party/WebKit/Source/core/exported/WebRemoteFrameImpl.cpp b/third_party/WebKit/Source/core/exported/WebRemoteFrameImpl.cpp index 6c10fbd..4cc9915 100644 --- a/third_party/WebKit/Source/core/exported/WebRemoteFrameImpl.cpp +++ b/third_party/WebKit/Source/core/exported/WebRemoteFrameImpl.cpp
@@ -150,14 +150,13 @@ const WebString& name, WebSandboxFlags sandbox_flags, WebFrameClient* client, - blink::InterfaceProvider* interface_provider, blink::InterfaceRegistry* interface_registry, WebFrame* previous_sibling, const WebParsedFeaturePolicy& container_policy, const WebFrameOwnerProperties& frame_owner_properties, WebFrame* opener) { WebLocalFrameBase* child = WebFactory::GetInstance().CreateWebLocalFrameBase( - scope, client, interface_provider, interface_registry, opener); + scope, client, interface_registry, opener); InsertAfter(child, previous_sibling); RemoteFrameOwner* owner = RemoteFrameOwner::Create(static_cast<SandboxFlags>(sandbox_flags),
diff --git a/third_party/WebKit/Source/core/exported/WebRemoteFrameImpl.h b/third_party/WebKit/Source/core/exported/WebRemoteFrameImpl.h index a3b0466..dfda3013 100644 --- a/third_party/WebKit/Source/core/exported/WebRemoteFrameImpl.h +++ b/third_party/WebKit/Source/core/exported/WebRemoteFrameImpl.h
@@ -47,7 +47,6 @@ const WebString& name, WebSandboxFlags, WebFrameClient*, - blink::InterfaceProvider*, blink::InterfaceRegistry*, WebFrame* previous_sibling, const WebParsedFeaturePolicy&,
diff --git a/third_party/WebKit/Source/core/exported/WebSharedWorkerImpl.cpp b/third_party/WebKit/Source/core/exported/WebSharedWorkerImpl.cpp index 066bca9..eaadbaa2 100644 --- a/third_party/WebKit/Source/core/exported/WebSharedWorkerImpl.cpp +++ b/third_party/WebKit/Source/core/exported/WebSharedWorkerImpl.cpp
@@ -63,7 +63,6 @@ #include "platform/weborigin/SecurityOrigin.h" #include "platform/wtf/Functional.h" #include "platform/wtf/PtrUtil.h" -#include "public/platform/Platform.h" #include "public/platform/WebContentSettingsClient.h" #include "public/platform/WebMessagePortChannel.h" #include "public/platform/WebString.h" @@ -140,7 +139,7 @@ // Browser process when the worker is created (similar to // RenderThread::OnCreateNewView). main_frame_ = WebFactory::GetInstance().CreateMainWebLocalFrameBase( - web_view_, this, Platform::Current()->GetInterfaceProvider(), nullptr); + web_view_, this, nullptr); main_frame_->SetDevToolsAgentClient(this); // If we were asked to pause worker context on start and wait for debugger
diff --git a/third_party/WebKit/Source/core/frame/BUILD.gn b/third_party/WebKit/Source/core/frame/BUILD.gn index 4c1d4d7b..71ba42e 100644 --- a/third_party/WebKit/Source/core/frame/BUILD.gn +++ b/third_party/WebKit/Source/core/frame/BUILD.gn
@@ -68,6 +68,8 @@ "Location.h", "Navigator.cpp", "Navigator.h", + "NavigatorClipboard.cpp", + "NavigatorClipboard.h", "NavigatorConcurrentHardware.cpp", "NavigatorConcurrentHardware.h", "NavigatorID.cpp",
diff --git a/third_party/WebKit/Source/core/frame/FrameTestHelpers.cpp b/third_party/WebKit/Source/core/frame/FrameTestHelpers.cpp index c4f6b68..ca3c3783 100644 --- a/third_party/WebKit/Source/core/frame/FrameTestHelpers.cpp +++ b/third_party/WebKit/Source/core/frame/FrameTestHelpers.cpp
@@ -151,8 +151,8 @@ WebTreeScopeType scope, TestWebFrameClient* client) { auto owned_client = CreateDefaultClientIfNeeded(client); - WebLocalFrameBase* frame = ToWebLocalFrameBase(parent.CreateLocalChild( - scope, client, client->GetInterfaceProviderForTesting(), nullptr)); + WebLocalFrameBase* frame = + ToWebLocalFrameBase(parent.CreateLocalChild(scope, client, nullptr)); client->Bind(frame, std::move(owned_client)); return frame; } @@ -163,8 +163,8 @@ std::unique_ptr<TestWebFrameClient> self_owned) { DCHECK(self_owned); TestWebFrameClient* client = self_owned.get(); - WebLocalFrameBase* frame = ToWebLocalFrameBase(parent.CreateLocalChild( - scope, client, self_owned->GetInterfaceProviderForTesting(), nullptr)); + WebLocalFrameBase* frame = + ToWebLocalFrameBase(parent.CreateLocalChild(scope, client, nullptr)); client->Bind(frame, std::move(self_owned)); return frame; } @@ -174,8 +174,8 @@ auto owned_client = CreateDefaultClientIfNeeded(client); WebLocalFrameBase* frame = ToWebLocalFrameBase(WebLocalFrame::CreateProvisional( - client, client->GetInterfaceProviderForTesting(), nullptr, &old_frame, - WebSandboxFlags::kNone, WebParsedFeaturePolicy())); + client, nullptr, &old_frame, WebSandboxFlags::kNone, + WebParsedFeaturePolicy())); client->Bind(frame, std::move(owned_client)); // Create a local root, if necessary. std::unique_ptr<TestWebWidgetClient> owned_widget_client; @@ -210,8 +210,8 @@ auto owned_client = CreateDefaultClientIfNeeded(client); auto* frame = ToWebLocalFrameBase(parent.CreateLocalChild( WebTreeScopeType::kDocument, name, WebSandboxFlags::kNone, client, - client->GetInterfaceProviderForTesting(), nullptr, previous_sibling, - WebParsedFeaturePolicy(), properties, nullptr)); + nullptr, previous_sibling, WebParsedFeaturePolicy(), properties, + nullptr)); client->Bind(frame, std::move(owned_client)); auto owned_widget_client = CreateDefaultClientIfNeeded(widget_client); @@ -256,8 +256,7 @@ auto owned_web_frame_client = CreateDefaultClientIfNeeded(web_frame_client); WebLocalFrame* frame = WebLocalFrame::CreateMainFrame( - web_view_, web_frame_client, - web_frame_client->GetInterfaceProviderForTesting(), nullptr, opener); + web_view_, web_frame_client, nullptr, opener); web_frame_client->Bind(frame, std::move(owned_web_frame_client)); // TODO(dcheng): The main frame widget currently has a special case. @@ -362,7 +361,8 @@ int TestWebFrameClient::loads_in_progress_ = 0; -TestWebFrameClient::TestWebFrameClient() {} +TestWebFrameClient::TestWebFrameClient() + : interface_provider_(new service_manager::InterfaceProvider()) {} void TestWebFrameClient::Bind(WebLocalFrame* frame, std::unique_ptr<TestWebFrameClient> self_owned) {
diff --git a/third_party/WebKit/Source/core/frame/FrameTestHelpers.h b/third_party/WebKit/Source/core/frame/FrameTestHelpers.h index cfd52ced8..f9c1e9a 100644 --- a/third_party/WebKit/Source/core/frame/FrameTestHelpers.h +++ b/third_party/WebKit/Source/core/frame/FrameTestHelpers.h
@@ -51,6 +51,7 @@ #include "public/web/WebRemoteFrameClient.h" #include "public/web/WebSettings.h" #include "public/web/WebViewClient.h" +#include "services/service_manager/public/cpp/interface_provider.h" namespace blink { @@ -308,9 +309,8 @@ static bool IsLoading() { return loads_in_progress_ > 0; } - // Tests can override the virtual method below to mock the interface provider. - virtual blink::InterfaceProvider* GetInterfaceProviderForTesting() { - return nullptr; + service_manager::InterfaceProvider* GetInterfaceProvider() override { + return interface_provider_.get(); } std::unique_ptr<blink::WebURLLoader> CreateURLLoader( @@ -326,6 +326,10 @@ // If set to a non-null value, self-deletes on frame detach. std::unique_ptr<TestWebFrameClient> self_owned_; + // Use service_manager::InterfaceProvider::TestApi to provide test interfaces + // through this client. + std::unique_ptr<service_manager::InterfaceProvider> interface_provider_; + // This is null from when the client is created until it is initialized with // Bind(). WebLocalFrame* frame_ = nullptr;
diff --git a/third_party/WebKit/Source/core/frame/LocalFrame.cpp b/third_party/WebKit/Source/core/frame/LocalFrame.cpp index 390f313..470ef9e 100644 --- a/third_party/WebKit/Source/core/frame/LocalFrame.cpp +++ b/third_party/WebKit/Source/core/frame/LocalFrame.cpp
@@ -131,12 +131,9 @@ LocalFrame* LocalFrame::Create(LocalFrameClient* client, Page& page, FrameOwner* owner, - InterfaceProvider* interface_provider, InterfaceRegistry* interface_registry) { LocalFrame* frame = new LocalFrame( client, page, owner, - interface_provider ? interface_provider - : InterfaceProvider::GetEmptyInterfaceProvider(), interface_registry ? interface_registry : InterfaceRegistry::GetEmptyInterfaceRegistry()); probe::frameAttachedToParent(frame); @@ -745,7 +742,6 @@ inline LocalFrame::LocalFrame(LocalFrameClient* client, Page& page, FrameOwner* owner, - InterfaceProvider* interface_provider, InterfaceRegistry* interface_registry) : Frame(client, page, owner, LocalWindowProxyManager::Create(*this)), frame_scheduler_(page.GetChromeClient().CreateFrameScheduler( @@ -765,11 +761,10 @@ page_zoom_factor_(ParentPageZoomFactor(this)), text_zoom_factor_(ParentTextZoomFactor(this)), in_view_source_mode_(false), - interface_provider_(interface_provider), interface_registry_(interface_registry) { if (FrameResourceCoordinator::IsEnabled()) { frame_resource_coordinator_ = - FrameResourceCoordinator::Create(interface_provider); + FrameResourceCoordinator::Create(client->GetInterfaceProvider()); } if (IsLocalRoot()) { probe_sink_ = new CoreProbeSink(); @@ -1001,6 +996,11 @@ return false; } +service_manager::InterfaceProvider& LocalFrame::GetInterfaceProvider() { + DCHECK(Client()); + return *Client()->GetInterfaceProvider(); +} + LocalFrameClient* LocalFrame::Client() const { return static_cast<LocalFrameClient*>(Frame::Client()); }
diff --git a/third_party/WebKit/Source/core/frame/LocalFrame.h b/third_party/WebKit/Source/core/frame/LocalFrame.h index 76a9adbf..7903d86 100644 --- a/third_party/WebKit/Source/core/frame/LocalFrame.h +++ b/third_party/WebKit/Source/core/frame/LocalFrame.h
@@ -43,6 +43,10 @@ #include "platform/scroll/ScrollTypes.h" #include "platform/wtf/HashSet.h" +namespace service_manager { +class InterfaceProvider; +} + namespace blink { class Color; @@ -62,7 +66,6 @@ class FrameSelection; class InputMethodController; class CoreProbeSink; -class InterfaceProvider; class InterfaceRegistry; class IntPoint; class IntSize; @@ -96,7 +99,6 @@ static LocalFrame* Create(LocalFrameClient*, Page&, FrameOwner*, - InterfaceProvider* = nullptr, InterfaceRegistry* = nullptr); void Init(); @@ -225,12 +227,7 @@ bool CanNavigate(const Frame&); - // This method is deprecated. Please use - // LocalFrameClient::GetInterfaceProvider() instead. - // - // TODO(crbug.com/726943): Remove this method. - InterfaceProvider* GetInterfaceProvider() { return interface_provider_; } - + service_manager::InterfaceProvider& GetInterfaceProvider(); InterfaceRegistry* GetInterfaceRegistry() { return interface_registry_; } LocalFrameClient* Client() const; @@ -282,7 +279,6 @@ LocalFrame(LocalFrameClient*, Page&, FrameOwner*, - InterfaceProvider*, InterfaceRegistry*); // Intentionally private to prevent redundant checks when the type is @@ -326,7 +322,6 @@ Member<CoreProbeSink> probe_sink_; Member<PerformanceMonitor> performance_monitor_; - InterfaceProvider* const interface_provider_; InterfaceRegistry* const interface_registry_; IntRect remote_viewport_intersection_;
diff --git a/third_party/WebKit/Source/core/frame/NavigatorClipboard.cpp b/third_party/WebKit/Source/core/frame/NavigatorClipboard.cpp new file mode 100644 index 0000000..df12ca8 --- /dev/null +++ b/third_party/WebKit/Source/core/frame/NavigatorClipboard.cpp
@@ -0,0 +1,42 @@ +// Copyright 2017 The Chromium Authors. All rights reserved. +// Use of this source code is governed by a BSD-style license that can be +// found in the LICENSE file. + +#include "core/frame/NavigatorClipboard.h" + +#include "core/clipboard/Clipboard.h" +#include "core/dom/Document.h" +#include "core/frame/LocalFrame.h" + +namespace blink { + +Clipboard* NavigatorClipboard::clipboard(ScriptState* script_state, + Navigator& navigator) { + NavigatorClipboard* supplement = static_cast<NavigatorClipboard*>( + Supplement<Navigator>::From(navigator, SupplementName())); + if (!supplement) { + supplement = new NavigatorClipboard(navigator); + ProvideTo(navigator, SupplementName(), supplement); + } + + return supplement->clipboard_; +} + +DEFINE_TRACE(NavigatorClipboard) { + visitor->Trace(clipboard_); + Supplement<Navigator>::Trace(visitor); +} + +NavigatorClipboard::NavigatorClipboard(Navigator& navigator) + : Supplement<Navigator>(navigator) { + clipboard_ = + new Clipboard(GetSupplementable()->GetFrame() + ? GetSupplementable()->GetFrame()->GetDocument() + : nullptr); +} + +const char* NavigatorClipboard::SupplementName() { + return "NavigatorClipboard"; +} + +} // namespace blink
diff --git a/third_party/WebKit/Source/core/frame/NavigatorClipboard.h b/third_party/WebKit/Source/core/frame/NavigatorClipboard.h new file mode 100644 index 0000000..1d17ab4 --- /dev/null +++ b/third_party/WebKit/Source/core/frame/NavigatorClipboard.h
@@ -0,0 +1,38 @@ +// Copyright 2017 The Chromium Authors. All rights reserved. +// Use of this source code is governed by a BSD-style license that can be +// found in the LICENSE file. + +#ifndef NavigatorClipboard_h +#define NavigatorClipboard_h + +#include "core/CoreExport.h" +#include "core/frame/Navigator.h" +#include "platform/Supplementable.h" +#include "platform/heap/Handle.h" +#include "platform/wtf/Noncopyable.h" + +namespace blink { + +class Clipboard; +class ScriptState; + +class NavigatorClipboard final : public GarbageCollected<NavigatorClipboard>, + public Supplement<Navigator> { + USING_GARBAGE_COLLECTED_MIXIN(NavigatorClipboard); + WTF_MAKE_NONCOPYABLE(NavigatorClipboard); + + public: + static Clipboard* clipboard(ScriptState*, Navigator&); + + DECLARE_TRACE(); + + private: + explicit NavigatorClipboard(Navigator&); + static const char* SupplementName(); + + Member<Clipboard> clipboard_; +}; + +} // namespace blink + +#endif // NavigatorClipboard.h
diff --git a/third_party/WebKit/Source/core/frame/NavigatorClipboard.idl b/third_party/WebKit/Source/core/frame/NavigatorClipboard.idl new file mode 100644 index 0000000..a1ee432 --- /dev/null +++ b/third_party/WebKit/Source/core/frame/NavigatorClipboard.idl
@@ -0,0 +1,11 @@ +// Copyright 2017 The Chromium Authors. All rights reserved. +// Use of this source code is governed by a BSD-style license that can be +// found in the LICENSE file. + +// https://w3c.github.io/clipboard-apis/#navigator-interface + +[RuntimeEnabled=AsyncClipboard] +partial interface Navigator { + [CallWith=ScriptState, SecureContext, SameObject] + readonly attribute Clipboard clipboard; +};
diff --git a/third_party/WebKit/Source/core/frame/PerformanceMonitor.cpp b/third_party/WebKit/Source/core/frame/PerformanceMonitor.cpp index db90fa05..c7f566cc 100644 --- a/third_party/WebKit/Source/core/frame/PerformanceMonitor.cpp +++ b/third_party/WebKit/Source/core/frame/PerformanceMonitor.cpp
@@ -226,8 +226,7 @@ InnerReportGenericViolation(document, kBlockedParser, text, 0, nullptr); } -void PerformanceMonitor::WillProcessTask(scheduler::TaskQueue*, - double start_time) { +void PerformanceMonitor::WillProcessTask(double start_time) { // Reset m_taskExecutionContext. We don't clear this in didProcessTask // as it is needed in ReportTaskTime which occurs after didProcessTask. task_execution_context_ = nullptr; @@ -243,9 +242,7 @@ user_callback_ = nullptr; } -void PerformanceMonitor::DidProcessTask(scheduler::TaskQueue*, - double start_time, - double end_time) { +void PerformanceMonitor::DidProcessTask(double start_time, double end_time) { if (!enabled_) return; double layout_threshold = thresholds_[kLongLayout];
diff --git a/third_party/WebKit/Source/core/frame/PerformanceMonitor.h b/third_party/WebKit/Source/core/frame/PerformanceMonitor.h index 7679eb1..62b7601f 100644 --- a/third_party/WebKit/Source/core/frame/PerformanceMonitor.h +++ b/third_party/WebKit/Source/core/frame/PerformanceMonitor.h
@@ -116,10 +116,8 @@ std::unique_ptr<SourceLocation>); // scheduler::TaskTimeObserver implementation - void WillProcessTask(scheduler::TaskQueue*, double start_time) override; - void DidProcessTask(scheduler::TaskQueue*, - double start_time, - double end_time) override; + void WillProcessTask(double start_time) override; + void DidProcessTask(double start_time, double end_time) override; void OnBeginNestedRunLoop() override {} void WillExecuteScript(ExecutionContext*); void DidExecuteScript();
diff --git a/third_party/WebKit/Source/core/frame/PerformanceMonitorTest.cpp b/third_party/WebKit/Source/core/frame/PerformanceMonitorTest.cpp index 79303670..07b6f8f7 100644 --- a/third_party/WebKit/Source/core/frame/PerformanceMonitorTest.cpp +++ b/third_party/WebKit/Source/core/frame/PerformanceMonitorTest.cpp
@@ -36,14 +36,12 @@ } // scheduler::TaskTimeObserver implementation - void WillProcessTask(scheduler::TaskQueue* queue, double start_time) { - monitor_->WillProcessTask(queue, start_time); + void WillProcessTask(double start_time) { + monitor_->WillProcessTask(start_time); } - void DidProcessTask(scheduler::TaskQueue* queue, - double start_time, - double end_time) { - monitor_->DidProcessTask(queue, start_time, end_time); + void DidProcessTask(double start_time, double end_time) { + monitor_->DidProcessTask(start_time, end_time); } String FrameContextURL(); @@ -87,17 +85,17 @@ } TEST_F(PerformanceMonitorTest, SingleScriptInTask) { - WillProcessTask(nullptr, 3719349.445172); + WillProcessTask(3719349.445172); EXPECT_EQ(0, NumUniqueFrameContextsSeen()); WillExecuteScript(GetExecutionContext()); EXPECT_EQ(1, NumUniqueFrameContextsSeen()); - DidProcessTask(nullptr, 3719349.445172, 3719349.5561923); // Long task + DidProcessTask(3719349.445172, 3719349.5561923); // Long task EXPECT_EQ(1, NumUniqueFrameContextsSeen()); EXPECT_EQ("https://example.com/foo", FrameContextURL()); } TEST_F(PerformanceMonitorTest, MultipleScriptsInTask_SingleContext) { - WillProcessTask(nullptr, 3719349.445172); + WillProcessTask(3719349.445172); EXPECT_EQ(0, NumUniqueFrameContextsSeen()); WillExecuteScript(GetExecutionContext()); EXPECT_EQ(1, NumUniqueFrameContextsSeen()); @@ -105,13 +103,13 @@ WillExecuteScript(GetExecutionContext()); EXPECT_EQ(1, NumUniqueFrameContextsSeen()); - DidProcessTask(nullptr, 3719349.445172, 3719349.5561923); // Long task + DidProcessTask(3719349.445172, 3719349.5561923); // Long task EXPECT_EQ(1, NumUniqueFrameContextsSeen()); EXPECT_EQ("https://example.com/foo", FrameContextURL()); } TEST_F(PerformanceMonitorTest, MultipleScriptsInTask_MultipleContexts) { - WillProcessTask(nullptr, 3719349.445172); + WillProcessTask(3719349.445172); EXPECT_EQ(0, NumUniqueFrameContextsSeen()); WillExecuteScript(GetExecutionContext()); EXPECT_EQ(1, NumUniqueFrameContextsSeen()); @@ -119,18 +117,18 @@ WillExecuteScript(AnotherExecutionContext()); EXPECT_EQ(2, NumUniqueFrameContextsSeen()); - DidProcessTask(nullptr, 3719349.445172, 3719349.5561923); // Long task + DidProcessTask(3719349.445172, 3719349.5561923); // Long task EXPECT_EQ(2, NumUniqueFrameContextsSeen()); EXPECT_EQ("", FrameContextURL()); } TEST_F(PerformanceMonitorTest, NoScriptInLongTask) { - WillProcessTask(nullptr, 3719349.445172); + WillProcessTask(3719349.445172); WillExecuteScript(GetExecutionContext()); - DidProcessTask(nullptr, 3719349.445172, 3719349.445182); + DidProcessTask(3719349.445172, 3719349.445182); - WillProcessTask(nullptr, 3719349.445172); - DidProcessTask(nullptr, 3719349.445172, 3719349.5561923); // Long task + WillProcessTask(3719349.445172); + DidProcessTask(3719349.445172, 3719349.5561923); // Long task // Without presence of Script, FrameContext URL is not available EXPECT_EQ(0, NumUniqueFrameContextsSeen()); }
diff --git a/third_party/WebKit/Source/core/html/BUILD.gn b/third_party/WebKit/Source/core/html/BUILD.gn index 5a97aad..97ea827 100644 --- a/third_party/WebKit/Source/core/html/BUILD.gn +++ b/third_party/WebKit/Source/core/html/BUILD.gn
@@ -487,6 +487,10 @@ "media/MediaError.h", "media/MediaFragmentURIParser.cpp", "media/MediaFragmentURIParser.h", + "media/MediaRemotingElements.cpp", + "media/MediaRemotingElements.h", + "media/MediaRemotingInterstitial.cpp", + "media/MediaRemotingInterstitial.h", "parser/AtomicHTMLToken.cpp", "parser/AtomicHTMLToken.h", "parser/BackgroundHTMLInputStream.cpp", @@ -562,12 +566,6 @@ "parser/XSSAuditorDelegate.h", "shadow/DetailsMarkerControl.cpp", "shadow/DetailsMarkerControl.h", - "shadow/MediaControlElementTypes.cpp", - "shadow/MediaControlElementTypes.h", - "shadow/MediaRemotingElements.cpp", - "shadow/MediaRemotingElements.h", - "shadow/MediaRemotingInterstitial.cpp", - "shadow/MediaRemotingInterstitial.h", "shadow/ProgressShadowElement.cpp", "shadow/ProgressShadowElement.h", "shadow/ShadowElementNames.cpp",
diff --git a/third_party/WebKit/Source/core/html/HTMLVideoElement.cpp b/third_party/WebKit/Source/core/html/HTMLVideoElement.cpp index 6c28957..cb5bd7d 100644 --- a/third_party/WebKit/Source/core/html/HTMLVideoElement.cpp +++ b/third_party/WebKit/Source/core/html/HTMLVideoElement.cpp
@@ -38,8 +38,8 @@ #include "core/frame/LocalDOMWindow.h" #include "core/frame/Settings.h" #include "core/html/media/MediaCustomControlsFullscreenDetector.h" +#include "core/html/media/MediaRemotingInterstitial.h" #include "core/html/parser/HTMLParserIdioms.h" -#include "core/html/shadow/MediaRemotingInterstitial.h" #include "core/imagebitmap/ImageBitmap.h" #include "core/imagebitmap/ImageBitmapOptions.h" #include "core/layout/LayoutImage.h"
diff --git a/third_party/WebKit/Source/core/html/forms/PasswordInputTypeTest.cpp b/third_party/WebKit/Source/core/html/forms/PasswordInputTypeTest.cpp index 860b0b0..88d0348f 100644 --- a/third_party/WebKit/Source/core/html/forms/PasswordInputTypeTest.cpp +++ b/third_party/WebKit/Source/core/html/forms/PasswordInputTypeTest.cpp
@@ -8,97 +8,76 @@ #include "core/html/HTMLInputElement.h" #include "core/testing/DummyPageHolder.h" #include "mojo/public/cpp/bindings/binding_set.h" -#include "mojo/public/cpp/bindings/interface_request.h" #include "platform/testing/UnitTestHelpers.h" -#include "public/platform/InterfaceProvider.h" #include "public/platform/modules/sensitive_input_visibility/sensitive_input_visibility_service.mojom-blink.h" +#include "services/service_manager/public/cpp/interface_provider.h" #include "testing/gtest/include/gtest/gtest.h" namespace blink { -class MockInterfaceProvider : public blink::InterfaceProvider { +class MockSensitiveInputVisibilityService + : public mojom::blink::SensitiveInputVisibilityService { public: - MockInterfaceProvider() - : mock_sensitive_input_visibility_service_(this), - password_field_visible_called_(false), - num_password_fields_invisible_calls_(0) {} - - virtual ~MockInterfaceProvider() {} - - void GetInterface(const char* name, - mojo::ScopedMessagePipeHandle handle) override { - mock_sensitive_input_visibility_service_.BindRequest( - mojom::blink::SensitiveInputVisibilityServiceRequest( - std::move(handle))); + MockSensitiveInputVisibilityService(LocalFrame& frame) { + service_manager::InterfaceProvider::TestApi test_api( + &frame.GetInterfaceProvider()); + test_api.SetBinderForName( + mojom::blink::SensitiveInputVisibilityService::Name_, + ConvertToBaseCallback( + WTF::Bind(&MockSensitiveInputVisibilityService::BindRequest, + WTF::Unretained(this)))); } - void SetPasswordFieldVisibleCalled() { - password_field_visible_called_ = true; + ~MockSensitiveInputVisibilityService() override {} + + void BindRequest(mojo::ScopedMessagePipeHandle handle) { + binding_set_.AddBinding( + this, mojom::blink::SensitiveInputVisibilityServiceRequest( + std::move(handle))); } bool PasswordFieldVisibleCalled() const { return password_field_visible_called_; } - void IncrementPasswordFieldsInvisibleCalled() { - ++num_password_fields_invisible_calls_; - } - unsigned NumPasswordFieldsInvisibleCalls() const { return num_password_fields_invisible_calls_; } private: - class MockSensitiveInputVisibilityService - : public mojom::blink::SensitiveInputVisibilityService { - public: - explicit MockSensitiveInputVisibilityService( - MockInterfaceProvider* registry) - : registry_(registry) {} - ~MockSensitiveInputVisibilityService() override {} + // mojom::SensitiveInputVisibilityService + void PasswordFieldVisibleInInsecureContext() override { + password_field_visible_called_ = true; + } - void BindRequest( - mojom::blink::SensitiveInputVisibilityServiceRequest request) { - binding_set_.AddBinding(this, std::move(request)); - } + void AllPasswordFieldsInInsecureContextInvisible() override { + ++num_password_fields_invisible_calls_; + } - private: - // mojom::SensitiveInputVisibilityService - void PasswordFieldVisibleInInsecureContext() override { - registry_->SetPasswordFieldVisibleCalled(); - } + mojo::BindingSet<SensitiveInputVisibilityService> binding_set_; - void AllPasswordFieldsInInsecureContextInvisible() override { - registry_->IncrementPasswordFieldsInvisibleCalled(); - } - - mojo::BindingSet<SensitiveInputVisibilityService> binding_set_; - MockInterfaceProvider* const registry_; - }; - - MockSensitiveInputVisibilityService mock_sensitive_input_visibility_service_; - bool password_field_visible_called_; - unsigned num_password_fields_invisible_calls_; + bool password_field_visible_called_ = false; + unsigned num_password_fields_invisible_calls_ = 0; }; // Tests that a Mojo message is sent when a visible password field // appears on the page. TEST(PasswordInputTypeTest, PasswordVisibilityEvent) { - MockInterfaceProvider interface_provider; - std::unique_ptr<DummyPageHolder> page_holder = DummyPageHolder::Create( - IntSize(2000, 2000), nullptr, nullptr, nullptr, &interface_provider); + std::unique_ptr<DummyPageHolder> page_holder = + DummyPageHolder::Create(IntSize(2000, 2000), nullptr, nullptr, nullptr); + MockSensitiveInputVisibilityService mock_service(page_holder->GetFrame()); page_holder->GetDocument().body()->setInnerHTML("<input type='password'>"); page_holder->GetDocument().View()->UpdateAllLifecyclePhases(); blink::testing::RunPendingTasks(); - EXPECT_TRUE(interface_provider.PasswordFieldVisibleCalled()); + EXPECT_TRUE(mock_service.PasswordFieldVisibleCalled()); } // Tests that a Mojo message is not sent when a visible password field // appears in a secure context. TEST(PasswordInputTypeTest, PasswordVisibilityEventInSecureContext) { - MockInterfaceProvider interface_provider; - std::unique_ptr<DummyPageHolder> page_holder = DummyPageHolder::Create( - IntSize(2000, 2000), nullptr, nullptr, nullptr, &interface_provider); + std::unique_ptr<DummyPageHolder> page_holder = + DummyPageHolder::Create(IntSize(2000, 2000), nullptr, nullptr, nullptr); + MockSensitiveInputVisibilityService mock_service(page_holder->GetFrame()); page_holder->GetDocument().SetURL(KURL(NullURL(), "https://example.test")); page_holder->GetDocument().SetSecurityOrigin( SecurityOrigin::Create(KURL(NullURL(), "https://example.test"))); @@ -106,21 +85,21 @@ page_holder->GetDocument().View()->UpdateAllLifecyclePhases(); // No message should have been sent from a secure context. blink::testing::RunPendingTasks(); - EXPECT_FALSE(interface_provider.PasswordFieldVisibleCalled()); + EXPECT_FALSE(mock_service.PasswordFieldVisibleCalled()); } // Tests that a Mojo message is sent when a previously invisible password field // becomes visible. TEST(PasswordInputTypeTest, InvisiblePasswordFieldBecomesVisible) { - MockInterfaceProvider interface_provider; - std::unique_ptr<DummyPageHolder> page_holder = DummyPageHolder::Create( - IntSize(2000, 2000), nullptr, nullptr, nullptr, &interface_provider); + std::unique_ptr<DummyPageHolder> page_holder = + DummyPageHolder::Create(IntSize(2000, 2000), nullptr, nullptr, nullptr); + MockSensitiveInputVisibilityService mock_service(page_holder->GetFrame()); page_holder->GetDocument().body()->setInnerHTML( "<input type='password' style='display:none;'>"); page_holder->GetDocument().View()->UpdateAllLifecyclePhases(); blink::testing::RunPendingTasks(); // The message should not be sent for a hidden password field. - EXPECT_FALSE(interface_provider.PasswordFieldVisibleCalled()); + EXPECT_FALSE(mock_service.PasswordFieldVisibleCalled()); // Now make the input visible. HTMLInputElement* input = @@ -128,20 +107,20 @@ input->setAttribute("style", "", ASSERT_NO_EXCEPTION); page_holder->GetDocument().View()->UpdateAllLifecyclePhases(); blink::testing::RunPendingTasks(); - EXPECT_TRUE(interface_provider.PasswordFieldVisibleCalled()); + EXPECT_TRUE(mock_service.PasswordFieldVisibleCalled()); } // Tests that a Mojo message is sent when a previously non-password field // becomes a password. TEST(PasswordInputTypeTest, NonPasswordFieldBecomesPassword) { - MockInterfaceProvider interface_provider; - std::unique_ptr<DummyPageHolder> page_holder = DummyPageHolder::Create( - IntSize(2000, 2000), nullptr, nullptr, nullptr, &interface_provider); + std::unique_ptr<DummyPageHolder> page_holder = + DummyPageHolder::Create(IntSize(2000, 2000), nullptr, nullptr, nullptr); + MockSensitiveInputVisibilityService mock_service(page_holder->GetFrame()); page_holder->GetDocument().body()->setInnerHTML("<input type='text'>"); page_holder->GetDocument().View()->UpdateAllLifecyclePhases(); // The message should not be sent for a non-password field. blink::testing::RunPendingTasks(); - EXPECT_FALSE(interface_provider.PasswordFieldVisibleCalled()); + EXPECT_FALSE(mock_service.PasswordFieldVisibleCalled()); // Now make the input a password field. HTMLInputElement* input = @@ -149,22 +128,22 @@ input->setType("password"); page_holder->GetDocument().View()->UpdateAllLifecyclePhases(); blink::testing::RunPendingTasks(); - EXPECT_TRUE(interface_provider.PasswordFieldVisibleCalled()); + EXPECT_TRUE(mock_service.PasswordFieldVisibleCalled()); } // Tests that a Mojo message is *not* sent when a previously invisible password // field becomes a visible non-password field. TEST(PasswordInputTypeTest, InvisiblePasswordFieldBecomesVisibleNonPasswordField) { - MockInterfaceProvider interface_provider; - std::unique_ptr<DummyPageHolder> page_holder = DummyPageHolder::Create( - IntSize(2000, 2000), nullptr, nullptr, nullptr, &interface_provider); + std::unique_ptr<DummyPageHolder> page_holder = + DummyPageHolder::Create(IntSize(2000, 2000), nullptr, nullptr, nullptr); + MockSensitiveInputVisibilityService mock_service(page_holder->GetFrame()); page_holder->GetDocument().body()->setInnerHTML( "<input type='password' style='display:none;'>"); page_holder->GetDocument().View()->UpdateAllLifecyclePhases(); blink::testing::RunPendingTasks(); // The message should not be sent for a hidden password field. - EXPECT_FALSE(interface_provider.PasswordFieldVisibleCalled()); + EXPECT_FALSE(mock_service.PasswordFieldVisibleCalled()); // Now make the input a visible non-password field. HTMLInputElement* input = @@ -173,20 +152,20 @@ input->setAttribute("style", "", ASSERT_NO_EXCEPTION); page_holder->GetDocument().View()->UpdateAllLifecyclePhases(); blink::testing::RunPendingTasks(); - EXPECT_FALSE(interface_provider.PasswordFieldVisibleCalled()); + EXPECT_FALSE(mock_service.PasswordFieldVisibleCalled()); } // Tests that a Mojo message is sent when the only visible password // field becomes invisible. TEST(PasswordInputTypeTest, VisiblePasswordFieldBecomesInvisible) { - MockInterfaceProvider interface_provider; - std::unique_ptr<DummyPageHolder> page_holder = DummyPageHolder::Create( - IntSize(2000, 2000), nullptr, nullptr, nullptr, &interface_provider); + std::unique_ptr<DummyPageHolder> page_holder = + DummyPageHolder::Create(IntSize(2000, 2000), nullptr, nullptr, nullptr); + MockSensitiveInputVisibilityService mock_service(page_holder->GetFrame()); page_holder->GetDocument().body()->setInnerHTML("<input type='password'>"); page_holder->GetDocument().View()->UpdateAllLifecyclePhases(); blink::testing::RunPendingTasks(); - EXPECT_TRUE(interface_provider.PasswordFieldVisibleCalled()); - EXPECT_EQ(0u, interface_provider.NumPasswordFieldsInvisibleCalls()); + EXPECT_TRUE(mock_service.PasswordFieldVisibleCalled()); + EXPECT_EQ(0u, mock_service.NumPasswordFieldsInvisibleCalls()); // Now make the input invisible. HTMLInputElement* input = @@ -194,20 +173,20 @@ input->setAttribute("style", "display:none;", ASSERT_NO_EXCEPTION); page_holder->GetDocument().View()->UpdateAllLifecyclePhases(); blink::testing::RunPendingTasks(); - EXPECT_EQ(1u, interface_provider.NumPasswordFieldsInvisibleCalls()); + EXPECT_EQ(1u, mock_service.NumPasswordFieldsInvisibleCalls()); } // Tests that a Mojo message is sent when all visible password fields // become invisible. TEST(PasswordInputTypeTest, AllVisiblePasswordFieldBecomeInvisible) { - MockInterfaceProvider interface_provider; - std::unique_ptr<DummyPageHolder> page_holder = DummyPageHolder::Create( - IntSize(2000, 2000), nullptr, nullptr, nullptr, &interface_provider); + std::unique_ptr<DummyPageHolder> page_holder = + DummyPageHolder::Create(IntSize(2000, 2000), nullptr, nullptr, nullptr); + MockSensitiveInputVisibilityService mock_service(page_holder->GetFrame()); page_holder->GetDocument().body()->setInnerHTML( "<input type='password'><input type='password'>"); page_holder->GetDocument().View()->UpdateAllLifecyclePhases(); blink::testing::RunPendingTasks(); - EXPECT_EQ(0u, interface_provider.NumPasswordFieldsInvisibleCalls()); + EXPECT_EQ(0u, mock_service.NumPasswordFieldsInvisibleCalls()); // Make the first input invisible. There should be no message because // there is still a visible input. @@ -216,38 +195,38 @@ input->setAttribute("style", "display:none;", ASSERT_NO_EXCEPTION); page_holder->GetDocument().View()->UpdateAllLifecyclePhases(); blink::testing::RunPendingTasks(); - EXPECT_EQ(0u, interface_provider.NumPasswordFieldsInvisibleCalls()); + EXPECT_EQ(0u, mock_service.NumPasswordFieldsInvisibleCalls()); // When all inputs are invisible, then a message should be sent. input = toHTMLInputElement(page_holder->GetDocument().body()->lastChild()); input->setAttribute("style", "display:none;", ASSERT_NO_EXCEPTION); page_holder->GetDocument().View()->UpdateAllLifecyclePhases(); blink::testing::RunPendingTasks(); - EXPECT_EQ(1u, interface_provider.NumPasswordFieldsInvisibleCalls()); + EXPECT_EQ(1u, mock_service.NumPasswordFieldsInvisibleCalls()); // If the count of visible inputs goes positive again and then back to // zero, a message should be sent again. input->setAttribute("style", "", ASSERT_NO_EXCEPTION); page_holder->GetDocument().View()->UpdateAllLifecyclePhases(); blink::testing::RunPendingTasks(); - EXPECT_EQ(1u, interface_provider.NumPasswordFieldsInvisibleCalls()); + EXPECT_EQ(1u, mock_service.NumPasswordFieldsInvisibleCalls()); input->setAttribute("style", "display:none;", ASSERT_NO_EXCEPTION); page_holder->GetDocument().View()->UpdateAllLifecyclePhases(); blink::testing::RunPendingTasks(); - EXPECT_EQ(2u, interface_provider.NumPasswordFieldsInvisibleCalls()); + EXPECT_EQ(2u, mock_service.NumPasswordFieldsInvisibleCalls()); } // Tests that a Mojo message is sent when the containing element of a // visible password field becomes invisible. TEST(PasswordInputTypeTest, PasswordFieldContainerBecomesInvisible) { - MockInterfaceProvider interface_provider; - std::unique_ptr<DummyPageHolder> page_holder = DummyPageHolder::Create( - IntSize(2000, 2000), nullptr, nullptr, nullptr, &interface_provider); + std::unique_ptr<DummyPageHolder> page_holder = + DummyPageHolder::Create(IntSize(2000, 2000), nullptr, nullptr, nullptr); + MockSensitiveInputVisibilityService mock_service(page_holder->GetFrame()); page_holder->GetDocument().body()->setInnerHTML( "<div><input type='password'></div>"); page_holder->GetDocument().View()->UpdateAllLifecyclePhases(); blink::testing::RunPendingTasks(); - EXPECT_EQ(0u, interface_provider.NumPasswordFieldsInvisibleCalls()); + EXPECT_EQ(0u, mock_service.NumPasswordFieldsInvisibleCalls()); // If the containing div becomes invisible, a message should be sent. HTMLElement* div = @@ -255,31 +234,31 @@ div->setAttribute("style", "display:none;", ASSERT_NO_EXCEPTION); page_holder->GetDocument().View()->UpdateAllLifecyclePhases(); blink::testing::RunPendingTasks(); - EXPECT_EQ(1u, interface_provider.NumPasswordFieldsInvisibleCalls()); + EXPECT_EQ(1u, mock_service.NumPasswordFieldsInvisibleCalls()); // If the containing div becomes visible and then invisible again, a message // should be sent. div->setAttribute("style", "", ASSERT_NO_EXCEPTION); page_holder->GetDocument().View()->UpdateAllLifecyclePhases(); blink::testing::RunPendingTasks(); - EXPECT_EQ(1u, interface_provider.NumPasswordFieldsInvisibleCalls()); + EXPECT_EQ(1u, mock_service.NumPasswordFieldsInvisibleCalls()); div->setAttribute("style", "display:none;", ASSERT_NO_EXCEPTION); page_holder->GetDocument().View()->UpdateAllLifecyclePhases(); blink::testing::RunPendingTasks(); - EXPECT_EQ(2u, interface_provider.NumPasswordFieldsInvisibleCalls()); + EXPECT_EQ(2u, mock_service.NumPasswordFieldsInvisibleCalls()); } // Tests that a Mojo message is sent when all visible password fields // become non-password fields. TEST(PasswordInputTypeTest, PasswordFieldsBecomeNonPasswordFields) { - MockInterfaceProvider interface_provider; - std::unique_ptr<DummyPageHolder> page_holder = DummyPageHolder::Create( - IntSize(2000, 2000), nullptr, nullptr, nullptr, &interface_provider); + std::unique_ptr<DummyPageHolder> page_holder = + DummyPageHolder::Create(IntSize(2000, 2000), nullptr, nullptr, nullptr); + MockSensitiveInputVisibilityService mock_service(page_holder->GetFrame()); page_holder->GetDocument().body()->setInnerHTML( "<input type='password'><input type='password'>"); page_holder->GetDocument().View()->UpdateAllLifecyclePhases(); blink::testing::RunPendingTasks(); - EXPECT_EQ(0u, interface_provider.NumPasswordFieldsInvisibleCalls()); + EXPECT_EQ(0u, mock_service.NumPasswordFieldsInvisibleCalls()); // Make the first input a non-password input. There should be no // message because there is still a visible password input. @@ -288,22 +267,22 @@ input->setType("text"); page_holder->GetDocument().View()->UpdateAllLifecyclePhases(); blink::testing::RunPendingTasks(); - EXPECT_EQ(0u, interface_provider.NumPasswordFieldsInvisibleCalls()); + EXPECT_EQ(0u, mock_service.NumPasswordFieldsInvisibleCalls()); // When all inputs are no longer passwords, then a message should be sent. input = toHTMLInputElement(page_holder->GetDocument().body()->lastChild()); input->setType("text"); page_holder->GetDocument().View()->UpdateAllLifecyclePhases(); blink::testing::RunPendingTasks(); - EXPECT_EQ(1u, interface_provider.NumPasswordFieldsInvisibleCalls()); + EXPECT_EQ(1u, mock_service.NumPasswordFieldsInvisibleCalls()); } // Tests that only one Mojo message is sent for multiple password // visibility events within the same task. TEST(PasswordInputTypeTest, MultipleEventsInSameTask) { - MockInterfaceProvider interface_provider; - std::unique_ptr<DummyPageHolder> page_holder = DummyPageHolder::Create( - IntSize(2000, 2000), nullptr, nullptr, nullptr, &interface_provider); + std::unique_ptr<DummyPageHolder> page_holder = + DummyPageHolder::Create(IntSize(2000, 2000), nullptr, nullptr, nullptr); + MockSensitiveInputVisibilityService mock_service(page_holder->GetFrame()); page_holder->GetDocument().body()->setInnerHTML("<input type='password'>"); page_holder->GetDocument().View()->UpdateAllLifecyclePhases(); // Make the password field invisible in the same task. @@ -314,8 +293,8 @@ blink::testing::RunPendingTasks(); // Only a single Mojo message should have been sent, with the latest state of // the page (which is that no password fields are visible). - EXPECT_EQ(1u, interface_provider.NumPasswordFieldsInvisibleCalls()); - EXPECT_FALSE(interface_provider.PasswordFieldVisibleCalled()); + EXPECT_EQ(1u, mock_service.NumPasswordFieldsInvisibleCalls()); + EXPECT_FALSE(mock_service.PasswordFieldVisibleCalled()); } } // namespace blink
diff --git a/third_party/WebKit/Source/core/html/media/MediaControls.h b/third_party/WebKit/Source/core/html/media/MediaControls.h index b2b00db..cc5ed6c 100644 --- a/third_party/WebKit/Source/core/html/media/MediaControls.h +++ b/third_party/WebKit/Source/core/html/media/MediaControls.h
@@ -11,7 +11,6 @@ namespace blink { -class Document; class HTMLDivElement; class HTMLMediaElement; class LayoutObject; @@ -66,7 +65,6 @@ // implementation and could be removed when the full implementation has moved // to modules. virtual HTMLDivElement* PanelElement() = 0; - virtual Document& OwnerDocument() = 0; virtual void OnMediaControlsEnabledChange() = 0; DECLARE_VIRTUAL_TRACE();
diff --git a/third_party/WebKit/Source/core/html/shadow/MediaRemotingElements.cpp b/third_party/WebKit/Source/core/html/media/MediaRemotingElements.cpp similarity index 98% rename from third_party/WebKit/Source/core/html/shadow/MediaRemotingElements.cpp rename to third_party/WebKit/Source/core/html/media/MediaRemotingElements.cpp index 5f774b1..4e491648 100644 --- a/third_party/WebKit/Source/core/html/shadow/MediaRemotingElements.cpp +++ b/third_party/WebKit/Source/core/html/media/MediaRemotingElements.cpp
@@ -2,7 +2,7 @@ // Use of this source code is governed by a BSD-style license that can be // found in the LICENSE file. -#include "core/html/shadow/MediaRemotingElements.h" +#include "core/html/media/MediaRemotingElements.h" #include "core/dom/ClientRect.h" #include "core/dom/ShadowRoot.h"
diff --git a/third_party/WebKit/Source/core/html/shadow/MediaRemotingElements.h b/third_party/WebKit/Source/core/html/media/MediaRemotingElements.h similarity index 96% rename from third_party/WebKit/Source/core/html/shadow/MediaRemotingElements.h rename to third_party/WebKit/Source/core/html/media/MediaRemotingElements.h index 605678e..45ac577b8 100644 --- a/third_party/WebKit/Source/core/html/shadow/MediaRemotingElements.h +++ b/third_party/WebKit/Source/core/html/media/MediaRemotingElements.h
@@ -5,7 +5,7 @@ #ifndef MediaRemotingElements_h #define MediaRemotingElements_h -#include "core/html/shadow/MediaRemotingInterstitial.h" +#include "core/html/media/MediaRemotingInterstitial.h" namespace blink {
diff --git a/third_party/WebKit/Source/core/html/shadow/MediaRemotingInterstitial.cpp b/third_party/WebKit/Source/core/html/media/MediaRemotingInterstitial.cpp similarity index 96% rename from third_party/WebKit/Source/core/html/shadow/MediaRemotingInterstitial.cpp rename to third_party/WebKit/Source/core/html/media/MediaRemotingInterstitial.cpp index f38296b..073fed8 100644 --- a/third_party/WebKit/Source/core/html/shadow/MediaRemotingInterstitial.cpp +++ b/third_party/WebKit/Source/core/html/media/MediaRemotingInterstitial.cpp
@@ -2,12 +2,12 @@ // Use of this source code is governed by a BSD-style license that can be // found in the LICENSE file. -#include "core/html/shadow/MediaRemotingInterstitial.h" +#include "core/html/media/MediaRemotingInterstitial.h" #include "core/dom/TaskRunnerHelper.h" #include "core/html/HTMLImageElement.h" #include "core/html/HTMLVideoElement.h" -#include "core/html/shadow/MediaRemotingElements.h" +#include "core/html/media/MediaRemotingElements.h" namespace {
diff --git a/third_party/WebKit/Source/core/html/shadow/MediaRemotingInterstitial.h b/third_party/WebKit/Source/core/html/media/MediaRemotingInterstitial.h similarity index 98% rename from third_party/WebKit/Source/core/html/shadow/MediaRemotingInterstitial.h rename to third_party/WebKit/Source/core/html/media/MediaRemotingInterstitial.h index 75a0d4d4..96624dc 100644 --- a/third_party/WebKit/Source/core/html/shadow/MediaRemotingInterstitial.h +++ b/third_party/WebKit/Source/core/html/media/MediaRemotingInterstitial.h
@@ -60,6 +60,6 @@ Member<MediaRemotingCastMessageElement> cast_text_message_; }; -} // namespace +} // namespace blink #endif // MediaRemotingInterstitial_h
diff --git a/third_party/WebKit/Source/core/html/parser/HTMLParserScriptRunner.cpp b/third_party/WebKit/Source/core/html/parser/HTMLParserScriptRunner.cpp index 4ecbf7a..0be309118 100644 --- a/third_party/WebKit/Source/core/html/parser/HTMLParserScriptRunner.cpp +++ b/third_party/WebKit/Source/core/html/parser/HTMLParserScriptRunner.cpp
@@ -79,16 +79,19 @@ return value; } -WARN_UNUSED_RESULT ScriptLoader::ExecuteScriptResult DoExecuteScript( - ScriptElementBase* element, - const Script* script, - const TextPosition& text_position) { +void DoExecuteScript(PendingScript* pending_script, const KURL& document_url) { + ScriptElementBase* element = pending_script->GetElement(); ScriptLoader* script_loader = element->Loader(); DCHECK(script_loader); - TRACE_EVENT_WITH_FLOW1("blink", "HTMLParserScriptRunner ExecuteScript", - element, TRACE_EVENT_FLAG_FLOW_IN, "data", - GetTraceArgsForScriptElement(element, text_position)); - return script_loader->ExecuteScript(script); + const char* const trace_event_name = + pending_script->ErrorOccurred() + ? "HTMLParserScriptRunner ExecuteScriptFailed" + : "HTMLParserScriptRunner ExecuteScript"; + TRACE_EVENT_WITH_FLOW1("blink", trace_event_name, element, + TRACE_EVENT_FLAG_FLOW_IN, "data", + GetTraceArgsForScriptElement( + element, pending_script->StartingPosition())); + script_loader->ExecuteScriptBlock(pending_script, document_url); } void TraceParserBlockingScript(const PendingScript* pending_script, @@ -202,10 +205,6 @@ void HTMLParserScriptRunner::ExecutePendingScriptAndDispatchEvent( PendingScript* pending_script, ScriptStreamer::Type pending_script_type) { - bool error_occurred = false; - Script* script = pending_script->GetSource( - DocumentURLForScriptExecution(document_), error_occurred); - // Stop watching loads before executeScript to prevent recursion if the script // reloads itself. // TODO(kouhei): Consider merging this w/ pendingScript->dispose() after the @@ -222,17 +221,12 @@ } } - TextPosition script_start_position = pending_script->StartingPosition(); double script_parser_blocking_time = pending_script->ParserBlockingLoadStartTime(); ScriptElementBase* element = pending_script->GetElement(); // 1. "Let the script be the pending parsing-blocking script. // There is no longer a pending parsing-blocking script." - // Clear the pending script before possible re-entrancy from executeScript() - pending_script->Dispose(); - pending_script = nullptr; - if (pending_script_type == ScriptStreamer::kParsingBlocking) { parser_blocking_script_ = nullptr; } @@ -248,31 +242,14 @@ ignore_destructive_write_count_incrementer(document_); // 8. "Execute the script." - if (error_occurred) { - TRACE_EVENT_WITH_FLOW1( - "blink", "HTMLParserScriptRunner ExecuteScriptFailed", element, - TRACE_EVENT_FLAG_FLOW_IN, "data", - GetTraceArgsForScriptElement(element, script_start_position)); - script_loader->DispatchErrorEvent(); - } else { - DCHECK(IsExecutingScript()); - if (script_parser_blocking_time > 0.0) { - DocumentParserTiming::From(*document_) - .RecordParserBlockedOnScriptLoadDuration( - MonotonicallyIncreasingTime() - script_parser_blocking_time, - script_loader->WasCreatedDuringDocumentWrite()); - } - switch (DoExecuteScript(element, script, script_start_position)) { - case ScriptLoader::ExecuteScriptResult::kShouldFireErrorEvent: - script_loader->DispatchErrorEvent(); - break; - case ScriptLoader::ExecuteScriptResult::kShouldFireLoadEvent: - element->DispatchLoadEvent(); - break; - case ScriptLoader::ExecuteScriptResult::kShouldFireNone: - break; - } + DCHECK(IsExecutingScript()); + if (!pending_script->ErrorOccurred() && script_parser_blocking_time > 0.0) { + DocumentParserTiming::From(*document_) + .RecordParserBlockedOnScriptLoadDuration( + MonotonicallyIncreasingTime() - script_parser_blocking_time, + script_loader->WasCreatedDuringDocumentWrite()); } + DoExecuteScript(pending_script, DocumentURLForScriptExecution(document_)); // 9. "Decrement the parser's script nesting level by one. // If the parser's script nesting level is zero @@ -660,22 +637,9 @@ if (parser_blocking_script_) parser_blocking_script_->Dispose(); parser_blocking_script_ = nullptr; - ScriptSourceCode source_code(element->TextFromChildren(), - DocumentURLForScriptExecution(document_), - script_start_position); - switch (DoExecuteScript(element, ClassicScript::Create(source_code), - script_start_position)) { - case ScriptLoader::ExecuteScriptResult::kShouldFireLoadEvent: - // The load event is not fired because this is an inline script. - break; - - case ScriptLoader::ExecuteScriptResult::kShouldFireErrorEvent: - script_loader->DispatchErrorEvent(); - break; - - case ScriptLoader::ExecuteScriptResult::kShouldFireNone: - break; - } + DoExecuteScript( + ClassicPendingScript::Create(element, script_start_position), + DocumentURLForScriptExecution(document_)); } } else { // 2nd Clause of Step 23.
diff --git a/third_party/WebKit/Source/core/html/shadow/MediaControlElementTypes.cpp b/third_party/WebKit/Source/core/html/shadow/MediaControlElementTypes.cpp deleted file mode 100644 index d78c84d..0000000 --- a/third_party/WebKit/Source/core/html/shadow/MediaControlElementTypes.cpp +++ /dev/null
@@ -1,201 +0,0 @@ -/* - * Copyright (C) 2008, 2009, 2010, 2011 Apple Inc. All rights reserved. - * Copyright (C) 2012 Google Inc. All rights reserved. - * - * Redistribution and use in source and binary forms, with or without - * modification, are permitted provided that the following conditions - * are met: - * - * 1. Redistributions of source code must retain the above copyright - * notice, this list of conditions and the following disclaimer. - * 2. Redistributions in binary form must reproduce the above copyright - * notice, this list of conditions and the following disclaimer in the - * documentation and/or other materials provided with the distribution. - * 3. Neither the name of Apple Computer, Inc. ("Apple") nor the names of - * its contributors may be used to endorse or promote products derived - * from this software without specific prior written permission. - * - * THIS SOFTWARE IS PROVIDED BY APPLE AND ITS CONTRIBUTORS "AS IS" AND ANY - * EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED - * WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE - * DISCLAIMED. IN NO EVENT SHALL APPLE OR ITS CONTRIBUTORS BE LIABLE FOR ANY - * DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES - * (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; - * LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND - * ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT - * (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF - * THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. - */ - -#include "core/html/shadow/MediaControlElementTypes.h" - -#include "bindings/core/v8/ExceptionState.h" -#include "core/CSSValueKeywords.h" -#include "core/HTMLNames.h" -#include "core/css/StylePropertySet.h" -#include "core/dom/Text.h" -#include "core/events/MouseEvent.h" -#include "core/html/HTMLLabelElement.h" -#include "core/html/HTMLMediaElement.h" -#include "core/html/media/MediaControls.h" -#include "core/layout/LayoutObject.h" -#include "platform/text/PlatformLocale.h" - -namespace blink { - -using namespace HTMLNames; - -class Event; - -const HTMLMediaElement* ToParentMediaElement(const Node* node) { - if (!node) - return nullptr; - const Node* media_node = node->OwnerShadowHost(); - if (!media_node) - return nullptr; - if (!IsHTMLMediaElement(media_node)) - return nullptr; - - return ToHTMLMediaElement(media_node); -} - -const HTMLMediaElement* ToParentMediaElement( - const LayoutObject& layout_object) { - return ToParentMediaElement(layout_object.GetNode()); -} - -MediaControlElementType GetMediaControlElementType(const Node* node) { - SECURITY_DCHECK(node->IsMediaControlElement()); - const HTMLElement* element = ToHTMLElement(node); - if (isHTMLInputElement(*element)) - return static_cast<const MediaControlInputElement*>(element)->DisplayType(); - return static_cast<const MediaControlDivElement*>(element)->DisplayType(); -} - -MediaControlElement::MediaControlElement(MediaControls& media_controls, - MediaControlElementType display_type, - HTMLElement* element) - : media_controls_(&media_controls), - display_type_(display_type), - element_(element), - is_wanted_(true), - does_fit_(true) {} - -HTMLMediaElement& MediaControlElement::MediaElement() const { - return GetMediaControls().MediaElement(); -} - -void MediaControlElement::UpdateShownState() { - if (is_wanted_ && does_fit_) - element_->RemoveInlineStyleProperty(CSSPropertyDisplay); - else - element_->SetInlineStyleProperty(CSSPropertyDisplay, CSSValueNone); -} - -void MediaControlElement::SetDoesFit(bool fits) { - does_fit_ = fits; - UpdateShownState(); -} - -void MediaControlElement::SetIsWanted(bool wanted) { - if (is_wanted_ == wanted) - return; - is_wanted_ = wanted; - UpdateShownState(); -} - -bool MediaControlElement::IsWanted() { - return is_wanted_; -} - -void MediaControlElement::SetDisplayType(MediaControlElementType display_type) { - if (display_type == display_type_) - return; - - display_type_ = display_type; - if (LayoutObject* object = element_->GetLayoutObject()) - object->SetShouldDoFullPaintInvalidation(); -} - -void MediaControlElement::ShouldShowButtonInOverflowMenu(bool should_show) { - if (!HasOverflowButton()) - return; - if (should_show) { - overflow_menu_element_->RemoveInlineStyleProperty(CSSPropertyDisplay); - } else { - overflow_menu_element_->SetInlineStyleProperty(CSSPropertyDisplay, - CSSValueNone); - } -} - -String MediaControlElement::GetOverflowMenuString() { - return MediaElement().GetLocale().QueryString(GetOverflowStringName()); -} - -void MediaControlElement::UpdateOverflowString() { - if (overflow_menu_element_ && overflow_menu_text_) - overflow_menu_text_->ReplaceWholeText(GetOverflowMenuString()); -} - -DEFINE_TRACE(MediaControlElement) { - visitor->Trace(media_controls_); - visitor->Trace(element_); - visitor->Trace(overflow_menu_element_); - visitor->Trace(overflow_menu_text_); -} - -// ---------------------------- - -MediaControlDivElement::MediaControlDivElement( - MediaControls& media_controls, - MediaControlElementType display_type) - : HTMLDivElement(media_controls.OwnerDocument()), - MediaControlElement(media_controls, display_type, this) {} - -DEFINE_TRACE(MediaControlDivElement) { - MediaControlElement::Trace(visitor); - HTMLDivElement::Trace(visitor); -} - -// ---------------------------- - -MediaControlInputElement::MediaControlInputElement( - MediaControls& media_controls, - MediaControlElementType display_type) - : HTMLInputElement(media_controls.OwnerDocument(), false), - MediaControlElement(media_controls, display_type, this) {} - -bool MediaControlInputElement::IsMouseFocusable() const { - return false; -} - -HTMLElement* MediaControlInputElement::CreateOverflowElement( - MediaControls& media_controls, - MediaControlInputElement* button) { - if (!button) - return nullptr; - - // We don't want the button visible within the overflow menu. - button->SetIsWanted(false); - - overflow_menu_text_ = Text::Create(media_controls.OwnerDocument(), - button->GetOverflowMenuString()); - - HTMLLabelElement* element = - HTMLLabelElement::Create(media_controls.OwnerDocument()); - element->SetShadowPseudoId( - AtomicString("-internal-media-controls-overflow-menu-list-item")); - // Appending a button to a label element ensures that clicks on the label - // are passed down to the button, performing the action we'd expect. - element->AppendChild(button); - element->AppendChild(overflow_menu_text_); - overflow_menu_element_ = element; - return element; -} - -DEFINE_TRACE(MediaControlInputElement) { - MediaControlElement::Trace(visitor); - HTMLInputElement::Trace(visitor); -} - -} // namespace blink
diff --git a/third_party/WebKit/Source/core/html/shadow/MediaControlElementTypes.h b/third_party/WebKit/Source/core/html/shadow/MediaControlElementTypes.h deleted file mode 100644 index 798efbb..0000000 --- a/third_party/WebKit/Source/core/html/shadow/MediaControlElementTypes.h +++ /dev/null
@@ -1,196 +0,0 @@ -/* - * Copyright (C) 2008, 2009, 2010, 2011 Apple Inc. All rights reserved. - * Copyright (C) 2012 Google Inc. All rights reserved. - * - * Redistribution and use in source and binary forms, with or without - * modification, are permitted provided that the following conditions - * are met: - * - * 1. Redistributions of source code must retain the above copyright - * notice, this list of conditions and the following disclaimer. - * 2. Redistributions in binary form must reproduce the above copyright - * notice, this list of conditions and the following disclaimer in the - * documentation and/or other materials provided with the distribution. - * 3. Neither the name of Apple Computer, Inc. ("Apple") nor the names of - * its contributors may be used to endorse or promote products derived - * from this software without specific prior written permission. - * - * THIS SOFTWARE IS PROVIDED BY APPLE AND ITS CONTRIBUTORS "AS IS" AND ANY - * EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED - * WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE - * DISCLAIMED. IN NO EVENT SHALL APPLE OR ITS CONTRIBUTORS BE LIABLE FOR ANY - * DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES - * (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; - * LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND - * ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT - * (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF - * THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. - */ - -#ifndef MediaControlElementTypes_h -#define MediaControlElementTypes_h - -#include "core/CoreExport.h" -#include "core/html/HTMLDivElement.h" -#include "core/html/HTMLInputElement.h" -#include "public/platform/WebLocalizedString.h" - -namespace blink { - -class HTMLMediaElement; -class MediaControls; - -enum MediaControlElementType { - kMediaEnterFullscreenButton = 0, - kMediaMuteButton, - kMediaPlayButton, - kMediaSlider, - kMediaSliderThumb, - kMediaShowClosedCaptionsButton, - kMediaHideClosedCaptionsButton, - kMediaTextTrackList, - kMediaUnMuteButton, - kMediaPauseButton, - kMediaTimelineContainer, - kMediaCurrentTimeDisplay, - kMediaTimeRemainingDisplay, - kMediaTrackSelectionCheckmark, - kMediaControlsPanel, - kMediaVolumeSliderContainer, - kMediaVolumeSlider, - kMediaVolumeSliderThumb, - kMediaExitFullscreenButton, - kMediaOverlayPlayButton, - kMediaCastOffButton, - kMediaCastOnButton, - kMediaOverlayCastOffButton, - kMediaOverlayCastOnButton, - kMediaOverflowButton, - kMediaOverflowList, - kMediaDownloadButton, -}; - -CORE_EXPORT const HTMLMediaElement* ToParentMediaElement(const Node*); -CORE_EXPORT const HTMLMediaElement* ToParentMediaElement(const LayoutObject&); - -CORE_EXPORT MediaControlElementType GetMediaControlElementType(const Node*); - -// ---------------------------- - -// TODO(mustaq): The Media control elements that use MouseEvents should be -// ported to use PointerEvents instead. -class CORE_EXPORT MediaControlElement : public GarbageCollectedMixin { - public: - // These hold the state about whether this control should be shown if - // space permits. These will also show / hide as needed. - virtual void SetIsWanted(bool); - bool IsWanted(); - - // Tell us whether we fit or not. This will hide / show the control as - // needed, also. - void SetDoesFit(bool); - - MediaControlElementType DisplayType() const { return display_type_; } - - // By default, media controls elements are not added to the overflow menu. - // Controls that can be added to the overflow menu should override this - // function and return true. - virtual bool HasOverflowButton() { return false; } - - // If true, shows the overflow menu item if it exists. Hides it if false. - void ShouldShowButtonInOverflowMenu(bool); - - // Returns a string representation of the media control element. Used for - // the overflow menu. - String GetOverflowMenuString(); - - // Updates the value of the Text string shown in the overflow menu. - void UpdateOverflowString(); - - DECLARE_VIRTUAL_TRACE(); - - protected: - MediaControlElement(MediaControls&, MediaControlElementType, HTMLElement*); - - MediaControls& GetMediaControls() const { - DCHECK(media_controls_); - return *media_controls_; - } - HTMLMediaElement& MediaElement() const; - - void SetDisplayType(MediaControlElementType); - - // Represents the overflow menu element for this media control. - // The Element contains the button that the user can click on, but having - // the button within an Element enables us to style the overflow menu. - // Setting this pointer is optional so it may be null. - Member<Element> overflow_menu_element_; - - // The text representation of the button within the overflow menu. - Member<Text> overflow_menu_text_; - - private: - // Hide or show based on our fits / wanted state. We want to show - // if and only if we're wanted and we fit. - void UpdateShownState(); - - // Returns a string representation of the media control element. - // Subclasses should override this method to return the string representation - // of the overflow button. - virtual WebLocalizedString::Name GetOverflowStringName() { - NOTREACHED(); - return WebLocalizedString::kAXAMPMFieldText; - } - - Member<MediaControls> media_controls_; - MediaControlElementType display_type_; - Member<HTMLElement> element_; - bool is_wanted_ : 1; - bool does_fit_ : 1; -}; - -// ---------------------------- - -class CORE_EXPORT MediaControlDivElement : public HTMLDivElement, - public MediaControlElement { - USING_GARBAGE_COLLECTED_MIXIN(MediaControlDivElement); - - public: - DECLARE_VIRTUAL_TRACE(); - - protected: - MediaControlDivElement(MediaControls&, MediaControlElementType); - - private: - bool IsMediaControlElement() const final { return true; } -}; - -// ---------------------------- - -class CORE_EXPORT MediaControlInputElement : public HTMLInputElement, - public MediaControlElement { - USING_GARBAGE_COLLECTED_MIXIN(MediaControlInputElement); - - public: - DECLARE_VIRTUAL_TRACE(); - - // Creates an overflow menu element with the given button as a child. - HTMLElement* CreateOverflowElement(MediaControls&, MediaControlInputElement*); - - protected: - MediaControlInputElement(MediaControls&, MediaControlElementType); - - private: - virtual void UpdateDisplayType() {} - bool IsMediaControlElement() const final { return true; } - bool IsMouseFocusable() const override; - - // Creates an overflow menu HTML element. - virtual MediaControlInputElement* CreateOverflowButton(MediaControls&) { - return nullptr; - } -}; - -} // namespace blink - -#endif // MediaControlElementTypes_h
diff --git a/third_party/WebKit/Source/core/html/shadow/OWNERS b/third_party/WebKit/Source/core/html/shadow/OWNERS deleted file mode 100644 index c774e98..0000000 --- a/third_party/WebKit/Source/core/html/shadow/OWNERS +++ /dev/null
@@ -1 +0,0 @@ -per-file Media*=mlamouri@chromium.org
diff --git a/third_party/WebKit/Source/core/inspector/DOMPatchSupport.cpp b/third_party/WebKit/Source/core/inspector/DOMPatchSupport.cpp index afb5e8c6..c406897 100644 --- a/third_party/WebKit/Source/core/inspector/DOMPatchSupport.cpp +++ b/third_party/WebKit/Source/core/inspector/DOMPatchSupport.cpp
@@ -56,13 +56,6 @@ namespace blink { -void DOMPatchSupport::PatchDocument(Document& document, const String& markup) { - InspectorHistory history; - DOMEditor dom_editor(&history); - DOMPatchSupport patch_support(&dom_editor, document); - patch_support.PatchDocument(markup); -} - DOMPatchSupport::DOMPatchSupport(DOMEditor* dom_editor, Document& document) : dom_editor_(dom_editor), document_(document) {}
diff --git a/third_party/WebKit/Source/core/inspector/DOMPatchSupport.h b/third_party/WebKit/Source/core/inspector/DOMPatchSupport.h index 26fd66e..2e4a2ba 100644 --- a/third_party/WebKit/Source/core/inspector/DOMPatchSupport.h +++ b/third_party/WebKit/Source/core/inspector/DOMPatchSupport.h
@@ -49,8 +49,6 @@ WTF_MAKE_NONCOPYABLE(DOMPatchSupport); public: - static void PatchDocument(Document&, const String& markup); - DOMPatchSupport(DOMEditor*, Document&); void PatchDocument(const String& markup);
diff --git a/third_party/WebKit/Source/core/inspector/InspectorPageAgent.cpp b/third_party/WebKit/Source/core/inspector/InspectorPageAgent.cpp index a15af9a..8932083 100644 --- a/third_party/WebKit/Source/core/inspector/InspectorPageAgent.cpp +++ b/third_party/WebKit/Source/core/inspector/InspectorPageAgent.cpp
@@ -49,7 +49,6 @@ #include "core/html/imports/HTMLImportLoader.h" #include "core/html/imports/HTMLImportsController.h" #include "core/html/parser/TextResourceDecoder.h" -#include "core/inspector/DOMPatchSupport.h" #include "core/inspector/IdentifiersFactory.h" #include "core/inspector/InspectedFrames.h" #include "core/inspector/InspectorCSSAgent.h" @@ -655,7 +654,7 @@ Document* document = frame->GetDocument(); if (!document) return Response::Error("No Document instance to set HTML for"); - DOMPatchSupport::PatchDocument(*document, html); + document->SetContent(html); return Response::OK(); }
diff --git a/third_party/WebKit/Source/core/layout/ng/inline/ng_inline_node.cc b/third_party/WebKit/Source/core/layout/ng/inline/ng_inline_node.cc index 67957ae..596b4ee 100644 --- a/third_party/WebKit/Source/core/layout/ng/inline/ng_inline_node.cc +++ b/third_party/WebKit/Source/core/layout/ng/inline/ng_inline_node.cc
@@ -8,6 +8,7 @@ #include "core/layout/LayoutBlockFlow.h" #include "core/layout/LayoutObject.h" #include "core/layout/LayoutText.h" +#include "core/layout/api/LineLayoutAPIShim.h" #include "core/layout/line/LineInfo.h" #include "core/layout/line/RootInlineBox.h" #include "core/layout/ng/inline/ng_bidi_paragraph.h" @@ -148,6 +149,10 @@ if (inline_box->GetLineLayoutItem().IsBox()) { LineLayoutBox box(inline_box->GetLineLayoutItem()); box.SetLocation(inline_box->Location()); + + LayoutObject* layout_object = LineLayoutAPIShim::LayoutObjectFrom(box); + if (layout_object->IsAtomicInlineLevel()) + ToLayoutBox(layout_object)->SetInlineBoxWrapper(inline_box); } }
diff --git a/third_party/WebKit/Source/core/loader/EmptyClients.h b/third_party/WebKit/Source/core/loader/EmptyClients.h index a2ae83f..d6918dd 100644 --- a/third_party/WebKit/Source/core/loader/EmptyClients.h +++ b/third_party/WebKit/Source/core/loader/EmptyClients.h
@@ -57,6 +57,7 @@ #include "public/platform/WebScreenInfo.h" #include "public/platform/WebSpellCheckPanelHostClient.h" #include "public/platform/WebURLLoader.h" +#include "services/service_manager/public/cpp/interface_provider.h" #include "v8/include/v8.h" /* @@ -347,6 +348,10 @@ WebCookieJar* CookieJar() const override { return 0; } + service_manager::InterfaceProvider* GetInterfaceProvider() { + return &interface_provider_; + } + WebSpellCheckPanelHostClient* SpellCheckPanelHostClient() const override { return nullptr; } @@ -373,6 +378,7 @@ EmptyLocalFrameClient() {} ContentSettingsClient content_settings_client_; + service_manager::InterfaceProvider interface_provider_; }; class CORE_EXPORT EmptyTextCheckerClient : public TextCheckerClient {
diff --git a/third_party/WebKit/Source/core/loader/FrameFetchContextTest.cpp b/third_party/WebKit/Source/core/loader/FrameFetchContextTest.cpp index 730549d2..0776e3b 100644 --- a/third_party/WebKit/Source/core/loader/FrameFetchContextTest.cpp +++ b/third_party/WebKit/Source/core/loader/FrameFetchContextTest.cpp
@@ -178,8 +178,8 @@ void SetFilterPolicy(WebDocumentSubresourceFilter::LoadPolicy policy) { document->Loader()->SetSubresourceFilter(SubresourceFilter::Create( - document->Loader(), WTF::MakeUnique<FixedPolicySubresourceFilter>( - policy, &filtered_load_callback_counter_))); + *document, WTF::MakeUnique<FixedPolicySubresourceFilter>( + policy, &filtered_load_callback_counter_))); } ResourceRequestBlockedReason CanRequest() {
diff --git a/third_party/WebKit/Source/core/loader/SubresourceFilter.cpp b/third_party/WebKit/Source/core/loader/SubresourceFilter.cpp index a5798747..3c622e9 100644 --- a/third_party/WebKit/Source/core/loader/SubresourceFilter.cpp +++ b/third_party/WebKit/Source/core/loader/SubresourceFilter.cpp
@@ -10,6 +10,8 @@ #include "core/dom/TaskRunnerHelper.h" #include "core/frame/LocalFrame.h" #include "core/inspector/ConsoleMessage.h" +#include "core/loader/DocumentLoader.h" +#include "core/workers/WorkerOrWorkletGlobalScope.h" #include "platform/WebTaskRunner.h" #include "platform/weborigin/KURL.h" #include "platform/wtf/text/StringBuilder.h" @@ -34,15 +36,15 @@ // static SubresourceFilter* SubresourceFilter::Create( - DocumentLoader* loader, + ExecutionContext& execution_context, std::unique_ptr<WebDocumentSubresourceFilter> filter) { - return new SubresourceFilter(loader, std::move(filter)); + return new SubresourceFilter(&execution_context, std::move(filter)); } SubresourceFilter::SubresourceFilter( - DocumentLoader* document_loader, + ExecutionContext* execution_context, std::unique_ptr<WebDocumentSubresourceFilter> subresource_filter) - : document_loader_(document_loader), + : execution_context_(execution_context), subresource_filter_(std::move(subresource_filter)) {} SubresourceFilter::~SubresourceFilter() {} @@ -62,6 +64,9 @@ } bool SubresourceFilter::AllowWebSocketConnection(const KURL& url) { + // Currently WebSocket is handled via document on the main thread. + DCHECK(execution_context_->IsDocument()); + WebDocumentSubresourceFilter::LoadPolicy load_policy = subresource_filter_->GetLoadPolicyForWebSocketConnect(url); @@ -69,8 +74,8 @@ // thread. Note that this unconditionally calls reportLoad unlike allowLoad, // because there aren't developer-invisible connections (like speculative // preloads) happening here. - RefPtr<WebTaskRunner> task_runner = TaskRunnerHelper::Get( - TaskType::kNetworking, document_loader_->GetFrame()); + RefPtr<WebTaskRunner> task_runner = + TaskRunnerHelper::Get(TaskType::kNetworking, execution_context_); DCHECK(task_runner->RunsTasksInCurrentSequence()); task_runner->PostTask(BLINK_FROM_HERE, WTF::Bind(&SubresourceFilter::ReportLoad, @@ -81,9 +86,6 @@ void SubresourceFilter::ReportLoad( const KURL& resource_url, WebDocumentSubresourceFilter::LoadPolicy load_policy) { - Document* document = document_loader_->GetFrame() - ? document_loader_->GetFrame()->GetDocument() - : nullptr; switch (load_policy) { case WebDocumentSubresourceFilter::kAllow: break; @@ -95,17 +97,28 @@ // document wide console message, so no need to log it here. // TODO: Consider logging this as a kInterventionMessageSource for showing // warning in Lighthouse. - if (document && subresource_filter_->ShouldLogToConsole()) { - document->AddConsoleMessage(ConsoleMessage::Create( + if (subresource_filter_->ShouldLogToConsole()) { + execution_context_->AddConsoleMessage(ConsoleMessage::Create( kOtherMessageSource, kErrorMessageLevel, GetErrorStringForDisallowedLoad(resource_url))); } // fall through case WebDocumentSubresourceFilter::kWouldDisallow: - document_loader_->DidObserveLoadingBehavior( - kWebLoadingBehaviorSubresourceFilterMatch); + // TODO(csharrison): Consider posting a task to the main thread from + // worker thread, or adding support for DidObserveLoadingBehavior to + // ExecutionContext. + if (execution_context_->IsDocument()) { + if (DocumentLoader* loader = ToDocument(execution_context_)->Loader()) { + loader->DidObserveLoadingBehavior( + kWebLoadingBehaviorSubresourceFilterMatch); + } + } break; } } +DEFINE_TRACE(SubresourceFilter) { + visitor->Trace(execution_context_); +} + } // namespace blink
diff --git a/third_party/WebKit/Source/core/loader/SubresourceFilter.h b/third_party/WebKit/Source/core/loader/SubresourceFilter.h index 53c0bf3..1ee6c3d7 100644 --- a/third_party/WebKit/Source/core/loader/SubresourceFilter.h +++ b/third_party/WebKit/Source/core/loader/SubresourceFilter.h
@@ -8,7 +8,6 @@ #include <memory> #include "core/CoreExport.h" -#include "core/loader/DocumentLoader.h" #include "platform/heap/Handle.h" #include "platform/weborigin/SecurityViolationReportingPolicy.h" #include "public/platform/WebDocumentSubresourceFilter.h" @@ -16,6 +15,7 @@ namespace blink { +class ExecutionContext; class KURL; // Wrapper around a WebDocumentSubresourceFilter. This class will make it easier @@ -25,7 +25,7 @@ : public GarbageCollectedFinalized<SubresourceFilter> { public: static SubresourceFilter* Create( - DocumentLoader*, + ExecutionContext&, std::unique_ptr<WebDocumentSubresourceFilter>); ~SubresourceFilter(); @@ -34,16 +34,16 @@ SecurityViolationReportingPolicy); bool AllowWebSocketConnection(const KURL&); - DEFINE_INLINE_TRACE() { visitor->Trace(document_loader_); } + DECLARE_VIRTUAL_TRACE(); private: - SubresourceFilter(DocumentLoader*, + SubresourceFilter(ExecutionContext*, std::unique_ptr<WebDocumentSubresourceFilter>); void ReportLoad(const KURL& resource_url, WebDocumentSubresourceFilter::LoadPolicy); - Member<DocumentLoader> document_loader_; + Member<ExecutionContext> execution_context_; std::unique_ptr<WebDocumentSubresourceFilter> subresource_filter_; };
diff --git a/third_party/WebKit/Source/core/loader/WorkerFetchContext.cpp b/third_party/WebKit/Source/core/loader/WorkerFetchContext.cpp index 4160cfa2..815a9957 100644 --- a/third_party/WebKit/Source/core/loader/WorkerFetchContext.cpp +++ b/third_party/WebKit/Source/core/loader/WorkerFetchContext.cpp
@@ -8,6 +8,7 @@ #include "core/frame/Deprecation.h" #include "core/frame/UseCounter.h" #include "core/loader/MixedContentChecker.h" +#include "core/loader/SubresourceFilter.h" #include "core/probe/CoreProbes.h" #include "core/timing/WorkerGlobalScopePerformance.h" #include "core/workers/WorkerClients.h" @@ -87,6 +88,12 @@ TaskRunnerHelper::Get(TaskType::kUnspecedLoading, global_scope_)) { web_context_->InitializeOnWorkerThread( loading_task_runner_->ToSingleThreadTaskRunner()); + std::unique_ptr<blink::WebDocumentSubresourceFilter> web_filter = + web_context_->TakeSubresourceFilter(); + if (web_filter) { + subresource_filter_ = + SubresourceFilter::Create(global_scope, std::move(web_filter)); + } } KURL WorkerFetchContext::GetFirstPartyForCookies() const { @@ -104,8 +111,7 @@ } SubresourceFilter* WorkerFetchContext::GetSubresourceFilter() const { - // TODO(horo): Implement this. (https://crbug.com/739597) - return nullptr; + return subresource_filter_.Get(); } bool WorkerFetchContext::ShouldBlockRequestByInspector( @@ -336,6 +342,7 @@ DEFINE_TRACE(WorkerFetchContext) { visitor->Trace(global_scope_); + visitor->Trace(subresource_filter_); visitor->Trace(resource_fetcher_); BaseFetchContext::Trace(visitor); }
diff --git a/third_party/WebKit/Source/core/loader/WorkerFetchContext.h b/third_party/WebKit/Source/core/loader/WorkerFetchContext.h index 6cd9bea4..aef3b71 100644 --- a/third_party/WebKit/Source/core/loader/WorkerFetchContext.h +++ b/third_party/WebKit/Source/core/loader/WorkerFetchContext.h
@@ -13,6 +13,7 @@ namespace blink { class ResourceFetcher; +class SubresourceFilter; class WebTaskRunner; class WebURLLoader; class WebWorkerFetchContext; @@ -111,6 +112,7 @@ Member<WorkerOrWorkletGlobalScope> global_scope_; std::unique_ptr<WebWorkerFetchContext> web_context_; + Member<SubresourceFilter> subresource_filter_; Member<ResourceFetcher> resource_fetcher_; RefPtr<WebTaskRunner> loading_task_runner_; };
diff --git a/third_party/WebKit/Source/core/loader/resource/ImageResource.cpp b/third_party/WebKit/Source/core/loader/resource/ImageResource.cpp index f698bae..9169c14 100644 --- a/third_party/WebKit/Source/core/loader/resource/ImageResource.cpp +++ b/third_party/WebKit/Source/core/loader/resource/ImageResource.cpp
@@ -48,11 +48,22 @@ #include "v8/include/v8.h" namespace blink { + namespace { + // The amount of time to wait before informing the clients that the image has // been updated (in seconds). This effectively throttles invalidations that // result from new data arriving for this image. constexpr double kFlushDelaySeconds = 1.; + +bool HasServerLoFiResponseHeaders(const ResourceResponse& response) { + return response.HttpHeaderField("chrome-proxy-content-transform") + .Contains("empty-image") || + // Check for the legacy Server Lo-Fi response headers, since it's + // possible that an old Lo-Fi image could be served from the cache. + response.HttpHeaderField("chrome-proxy").Contains("q=low"); +} + } // namespace class ImageResource::ImageResourceInfoImpl final @@ -429,10 +440,17 @@ multipart_parser_ = new MultipartImageResourceParser( response, response.MultipartBoundary(), this); } + + // Notify the base class that a response has been received. Note that after + // this call, |GetResponse()| will represent the full effective + // ResourceResponse, while |response| might just be a revalidation response + // (e.g. a 304) with a partial set of updated headers that were folded into + // the cached response. Resource::ResponseReceived(response, std::move(handle)); + if (RuntimeEnabledFeatures::ClientHintsEnabled()) { device_pixel_ratio_header_value_ = - this->GetResponse() + GetResponse() .HttpHeaderField(HTTPNames::Content_DPR) .ToFloat(&has_device_pixel_ratio_header_value_); if (!has_device_pixel_ratio_header_value_ || @@ -444,9 +462,9 @@ if (placeholder_option_ == PlaceholderOption::kShowAndReloadPlaceholderAlways && - IsEntireResource(this->GetResponse())) { - if (this->GetResponse().HttpStatusCode() < 400 || - this->GetResponse().HttpStatusCode() >= 600) { + IsEntireResource(GetResponse())) { + if (GetResponse().HttpStatusCode() < 400 || + GetResponse().HttpStatusCode() >= 600) { // Don't treat a complete and broken image as a placeholder if the // response code is something other than a 4xx or 5xx error. // This is done to prevent reissuing the request in cases like @@ -457,9 +475,44 @@ placeholder_option_ = PlaceholderOption::kReloadPlaceholderOnDecodeError; } } + + if (HasServerLoFiResponseHeaders(GetResponse())) { + // Ensure that the PreviewsState bit for Server Lo-Fi is set iff Chrome + // received the appropriate Server Lo-Fi response headers for this image. + // + // Normally, the |kServerLoFiOn| bit should already be set if Server Lo-Fi + // response headers are coming back, but it's possible for legacy Lo-Fi + // images to be served from the cache even if Chrome isn't in Lo-Fi mode. + // This also serves as a nice last line of defence to ensure that Server + // Lo-Fi images can be reloaded to show the original even if e.g. a server + // bug causes Lo-Fi images to be sent when they aren't expected. + SetPreviewsState(GetResourceRequest().GetPreviewsState() | + WebURLRequest::kServerLoFiOn); + } else if (GetResourceRequest().GetPreviewsState() & + WebURLRequest::kServerLoFiOn) { + // If Chrome expects a Lo-Fi response, but the server decided to send the + // full image, then clear the Server Lo-Fi Previews state bit. + WebURLRequest::PreviewsState new_previews_state = + GetResourceRequest().GetPreviewsState(); + + new_previews_state &= ~WebURLRequest::kServerLoFiOn; + if (new_previews_state == WebURLRequest::kPreviewsUnspecified) + new_previews_state = WebURLRequest::kPreviewsOff; + + SetPreviewsState(new_previews_state); + } } bool ImageResource::ShouldShowPlaceholder() const { + if (RuntimeEnabledFeatures::ClientPlaceholdersForServerLoFiEnabled() && + (GetResourceRequest().GetPreviewsState() & + WebURLRequest::kServerLoFiOn)) { + // If the runtime feature is enabled, show Client Lo-Fi placeholder images + // in place of Server Lo-Fi responses. This is done so that all Lo-Fi images + // have a consistent appearance. + return true; + } + switch (placeholder_option_) { case PlaceholderOption::kShowAndReloadPlaceholderAlways: case PlaceholderOption::kShowAndDoNotReloadPlaceholder: @@ -486,27 +539,21 @@ return false; } -static bool IsLoFiImage(const ImageResource& resource) { - if (resource.IsLoaded()) { - return resource.GetResponse() - .HttpHeaderField("chrome-proxy-content-transform") - .Contains("empty-image") || - resource.GetResponse() - .HttpHeaderField("chrome-proxy") - .Contains("q=low"); - } - return resource.GetResourceRequest().GetPreviewsState() & - WebURLRequest::kServerLoFiOn; -} - void ImageResource::ReloadIfLoFiOrPlaceholderImage( ResourceFetcher* fetcher, ReloadLoFiOrPlaceholderPolicy policy) { if (policy == kReloadIfNeeded && !ShouldReloadBrokenPlaceholder()) return; + // If the image is loaded, then the |PreviewsState::kServerLoFiOn| bit should + // be set iff the image has Server Lo-Fi response headers. + DCHECK(!IsLoaded() || + HasServerLoFiResponseHeaders(GetResponse()) == + static_cast<bool>(GetResourceRequest().GetPreviewsState() & + WebURLRequest::kServerLoFiOn)); + if (placeholder_option_ == PlaceholderOption::kDoNotReloadPlaceholder && - !IsLoFiImage(*this)) + !(GetResourceRequest().GetPreviewsState() & WebURLRequest::kServerLoFiOn)) return; // Prevent clients and observers from being notified of completion while the
diff --git a/third_party/WebKit/Source/core/loader/resource/ImageResourceTest.cpp b/third_party/WebKit/Source/core/loader/resource/ImageResourceTest.cpp index 1d00e49..50f4449 100644 --- a/third_party/WebKit/Source/core/loader/resource/ImageResourceTest.cpp +++ b/third_party/WebKit/Source/core/loader/resource/ImageResourceTest.cpp
@@ -32,6 +32,7 @@ #include <memory> #include "core/loader/resource/MockImageResourceObserver.h" +#include "platform/RuntimeEnabledFeatures.h" #include "platform/SharedBuffer.h" #include "platform/exported/WrappedResourceResponse.h" #include "platform/graphics/BitmapImage.h" @@ -45,6 +46,7 @@ #include "platform/loader/testing/MockFetchContext.h" #include "platform/loader/testing/MockResourceClient.h" #include "platform/scheduler/test/fake_web_task_runner.h" +#include "platform/testing/RuntimeEnabledFeaturesTestHelpers.h" #include "platform/testing/ScopedMockedURL.h" #include "platform/testing/TestingPlatformSupport.h" #include "platform/testing/UnitTestHelpers.h" @@ -343,6 +345,11 @@ return ResourceFetcher::Create(context, context->GetTaskRunner()); } +using ScopedClientPlaceholderForServerLoFiForTest = + ScopedRuntimeEnabledFeatureForTest< + RuntimeEnabledFeatures::ClientPlaceholdersForServerLoFiEnabled, + RuntimeEnabledFeatures::SetClientPlaceholdersForServerLoFiEnabled>; + TEST(ImageResourceTest, MultipartImage) { ResourceFetcher* fetcher = CreateFetcher(); KURL test_url(kParsedURLString, kTestURL); @@ -560,7 +567,23 @@ EXPECT_TRUE(image_resource->GetContent()->GetImage()->IsBitmapImage()); } -TEST(ImageResourceTest, ReloadIfLoFiOrPlaceholderAfterFinished) { +class ImageResourceReloadTest : public ::testing::TestWithParam<bool> { + public: + ~ImageResourceReloadTest() override {} + + bool IsClientPlaceholderForServerLoFiEnabled() const { return GetParam(); } + + void SetUp() override { + scoped_show_placeholder_.reset( + new ScopedClientPlaceholderForServerLoFiForTest(GetParam())); + } + + private: + std::unique_ptr<ScopedClientPlaceholderForServerLoFiForTest> + scoped_show_placeholder_; +}; + +TEST_P(ImageResourceReloadTest, ReloadIfLoFiOrPlaceholderAfterFinished) { KURL test_url(kParsedURLString, kTestURL); ScopedMockedURLLoad scoped_mocked_url_load(test_url, GetTestFilePath()); ImageResource* image_resource = ImageResource::CreateForTest(test_url); @@ -589,7 +612,10 @@ // The observer should have been notified that the image load completed. EXPECT_TRUE(observer->ImageNotifyFinishedCalled()); EXPECT_EQ(kJpegImageWidth, observer->ImageWidthOnImageNotifyFinished()); - EXPECT_TRUE(image_resource->GetContent()->GetImage()->IsBitmapImage()); + EXPECT_NE(IsClientPlaceholderForServerLoFiEnabled(), + image_resource->GetContent()->GetImage()->IsBitmapImage()); + EXPECT_EQ(IsClientPlaceholderForServerLoFiEnabled(), + image_resource->ShouldShowPlaceholder()); EXPECT_EQ(kJpegImageWidth, image_resource->GetContent()->GetImage()->width()); EXPECT_EQ(kJpegImageHeight, image_resource->GetContent()->GetImage()->height()); @@ -604,7 +630,8 @@ WebCachePolicy::kBypassingCache, false); } -TEST(ImageResourceTest, ReloadIfLoFiOrPlaceholderAfterFinishedWithOldHeaders) { +TEST_P(ImageResourceReloadTest, + ReloadIfLoFiOrPlaceholderAfterFinishedWithOldHeaders) { KURL test_url(kParsedURLString, kTestURL); ScopedMockedURLLoad scoped_mocked_url_load(test_url, GetTestFilePath()); ImageResource* image_resource = ImageResource::CreateForTest(test_url); @@ -632,7 +659,10 @@ // The observer should have been notified that the image load completed. EXPECT_TRUE(observer->ImageNotifyFinishedCalled()); EXPECT_EQ(kJpegImageWidth, observer->ImageWidthOnImageNotifyFinished()); - EXPECT_TRUE(image_resource->GetContent()->GetImage()->IsBitmapImage()); + EXPECT_NE(IsClientPlaceholderForServerLoFiEnabled(), + image_resource->GetContent()->GetImage()->IsBitmapImage()); + EXPECT_EQ(IsClientPlaceholderForServerLoFiEnabled(), + image_resource->ShouldShowPlaceholder()); EXPECT_EQ(kJpegImageWidth, image_resource->GetContent()->GetImage()->width()); EXPECT_EQ(kJpegImageHeight, image_resource->GetContent()->GetImage()->height()); @@ -647,8 +677,8 @@ WebCachePolicy::kBypassingCache, false); } -TEST(ImageResourceTest, - ReloadIfLoFiOrPlaceholderAfterFinishedWithoutLoFiHeaders) { +TEST_P(ImageResourceReloadTest, + ReloadIfLoFiOrPlaceholderAfterFinishedWithoutLoFiHeaders) { KURL test_url(kParsedURLString, kTestURL); ScopedMockedURLLoad scoped_mocked_url_load(test_url, GetTestFilePath()); ResourceRequest request(test_url); @@ -693,7 +723,7 @@ EXPECT_TRUE(image_resource->IsLoaded()); } -TEST(ImageResourceTest, ReloadIfLoFiOrPlaceholderViaResourceFetcher) { +TEST_P(ImageResourceReloadTest, ReloadIfLoFiOrPlaceholderViaResourceFetcher) { ResourceFetcher* fetcher = CreateFetcher(); KURL test_url(kParsedURLString, kTestURL); @@ -735,7 +765,39 @@ GetMemoryCache()->Remove(image_resource); } -TEST(ImageResourceTest, ReloadIfLoFiOrPlaceholderDuringFetch) { +TEST_P(ImageResourceReloadTest, ReloadIfLoFiOrPlaceholderBeforeResponse) { + KURL test_url(kParsedURLString, kTestURL); + ScopedMockedURLLoad scoped_mocked_url_load(test_url, GetTestFilePath()); + + ResourceRequest request(test_url); + request.SetPreviewsState(WebURLRequest::kServerLoFiOn); + FetchParameters fetch_params(request); + ResourceFetcher* fetcher = CreateFetcher(); + + ImageResource* image_resource = ImageResource::Fetch(fetch_params, fetcher); + std::unique_ptr<MockImageResourceObserver> observer = + MockImageResourceObserver::Create(image_resource->GetContent()); + + EXPECT_FALSE(image_resource->ErrorOccurred()); + EXPECT_EQ(IsClientPlaceholderForServerLoFiEnabled(), + image_resource->ShouldShowPlaceholder()); + + // Call reloadIfLoFiOrPlaceholderImage() while the image is still loading. + image_resource->ReloadIfLoFiOrPlaceholderImage(fetcher, + Resource::kReloadAlways); + + EXPECT_EQ(1, observer->ImageChangedCount()); + EXPECT_EQ(0, observer->ImageWidthOnLastImageChanged()); + // The observer should not have been notified of completion yet, since the + // image is still loading. + EXPECT_FALSE(observer->ImageNotifyFinishedCalled()); + + TestThatReloadIsStartedThenServeReload( + test_url, image_resource, image_resource->GetContent(), observer.get(), + WebCachePolicy::kBypassingCache, false); +} + +TEST_P(ImageResourceReloadTest, ReloadIfLoFiOrPlaceholderDuringResponse) { KURL test_url(kParsedURLString, kTestURL); ScopedMockedURLLoad scoped_mocked_url_load(test_url, GetTestFilePath()); @@ -749,9 +811,13 @@ MockImageResourceObserver::Create(image_resource->GetContent()); // Send the image response. + ResourceResponse resource_response(test_url, "image/jpeg", sizeof(kJpegImage), + g_null_atom); + resource_response.AddHTTPHeaderField("chrome-proxy-content-transform", + "empty-image"); + image_resource->Loader()->DidReceiveResponse( - WrappedResourceResponse(ResourceResponse( - test_url, "image/jpeg", sizeof(kJpegImage), g_null_atom))); + WrappedResourceResponse(resource_response)); image_resource->Loader()->DidReceiveData( reinterpret_cast<const char*>(kJpegImage), sizeof(kJpegImage)); @@ -761,7 +827,8 @@ EXPECT_EQ(1, observer->ImageChangedCount()); EXPECT_EQ(kJpegImageWidth, observer->ImageWidthOnLastImageChanged()); EXPECT_FALSE(observer->ImageNotifyFinishedCalled()); - EXPECT_TRUE(image_resource->GetContent()->GetImage()->IsBitmapImage()); + EXPECT_EQ(IsClientPlaceholderForServerLoFiEnabled(), + image_resource->ShouldShowPlaceholder()); EXPECT_EQ(kJpegImageWidth, image_resource->GetContent()->GetImage()->width()); EXPECT_EQ(kJpegImageHeight, image_resource->GetContent()->GetImage()->height()); @@ -781,7 +848,7 @@ WebCachePolicy::kBypassingCache, false); } -TEST(ImageResourceTest, ReloadIfLoFiOrPlaceholderForPlaceholder) { +TEST_P(ImageResourceReloadTest, ReloadIfLoFiOrPlaceholderForPlaceholder) { KURL test_url(kParsedURLString, kTestURL); ScopedMockedURLLoad scoped_mocked_url_load(test_url, GetTestFilePath()); @@ -805,6 +872,10 @@ WebCachePolicy::kBypassingCache, false); } +INSTANTIATE_TEST_CASE_P(/* no prefix */, + ImageResourceReloadTest, + ::testing::Bool()); + TEST(ImageResourceTest, SVGImage) { KURL url(kParsedURLString, "http://127.0.0.1:8000/foo"); ImageResource* image_resource = ImageResource::CreateForTest(url); @@ -1696,7 +1767,6 @@ // Send the image response. ResourceResponse resource_response(NullURL(), "image/jpeg", sizeof(kJpegImage2), g_null_atom); - resource_response.AddHTTPHeaderField("chrome-proxy", "q=low"); image_resource->ResponseReceived(resource_response, nullptr);
diff --git a/third_party/WebKit/Source/core/mojo/DEPS b/third_party/WebKit/Source/core/mojo/DEPS index e6eb1f8..a3ad469 100644 --- a/third_party/WebKit/Source/core/mojo/DEPS +++ b/third_party/WebKit/Source/core/mojo/DEPS
@@ -1,4 +1,3 @@ include_rules = [ "+mojo/public/cpp/system", - "+services/service_manager/public/cpp", ]
diff --git a/third_party/WebKit/Source/core/page/PagePopupClient.cpp b/third_party/WebKit/Source/core/page/PagePopupClient.cpp index c3debeb..a805691 100644 --- a/third_party/WebKit/Source/core/page/PagePopupClient.cpp +++ b/third_party/WebKit/Source/core/page/PagePopupClient.cpp
@@ -75,6 +75,25 @@ addLiteral("\"", data); } +void PagePopupClient::AddHTMLString(const String& str, SharedBuffer* data) { + StringBuilder builder; + builder.ReserveCapacity(str.length()); + for (unsigned i = 0; i < str.length(); ++i) { + if (str[i] == '&') { + builder.Append("&"); + } else if (str[i] == '<') { + builder.Append("<"); + } else if (str[i] == '\'') { + builder.Append("'"); + } else if (str[i] == '"') { + builder.Append("""); + } else { + builder.Append(str[i]); + } + } + AddString(builder.ToString(), data); +} + void PagePopupClient::AddProperty(const char* name, const String& value, SharedBuffer* data) {
diff --git a/third_party/WebKit/Source/core/page/PagePopupClient.h b/third_party/WebKit/Source/core/page/PagePopupClient.h index eacfa99..7a51d09a 100644 --- a/third_party/WebKit/Source/core/page/PagePopupClient.h +++ b/third_party/WebKit/Source/core/page/PagePopupClient.h
@@ -82,6 +82,7 @@ // Helper functions to be used in PagePopupClient::writeDocument(). static void AddString(const String&, SharedBuffer*); static void AddJavaScriptString(const String&, SharedBuffer*); + static void AddHTMLString(const String&, SharedBuffer*); static void AddProperty(const char* name, const String& value, SharedBuffer*); static void AddProperty(const char* name, int value, SharedBuffer*); static void AddProperty(const char* name, unsigned value, SharedBuffer*);
diff --git a/third_party/WebKit/Source/core/page/ValidationMessageOverlayDelegate.cpp b/third_party/WebKit/Source/core/page/ValidationMessageOverlayDelegate.cpp index a18f19f..0f69ad2 100644 --- a/third_party/WebKit/Source/core/page/ValidationMessageOverlayDelegate.cpp +++ b/third_party/WebKit/Source/core/page/ValidationMessageOverlayDelegate.cpp
@@ -163,12 +163,12 @@ ? "<div dir=ltr id=main-message>" : "<div dir=rtl id=main-message>", data); - PagePopupClient::AddString(message_, data); + PagePopupClient::AddHTMLString(message_, data); PagePopupClient::AddString(sub_message_dir_ == TextDirection::kLtr ? "</div><div dir=ltr id=sub-message>" : "</div><div dir=rtl id=sub-message>", data); - PagePopupClient::AddString(sub_message_, data); + PagePopupClient::AddHTMLString(sub_message_, data); PagePopupClient::AddString( "</div></main>" "<div id=outer-arrow-bottom></div>"
diff --git a/third_party/WebKit/Source/core/paint/FilterPainter.cpp b/third_party/WebKit/Source/core/paint/FilterPainter.cpp index c86f1a6..410ceea 100644 --- a/third_party/WebKit/Source/core/paint/FilterPainter.cpp +++ b/third_party/WebKit/Source/core/paint/FilterPainter.cpp
@@ -57,8 +57,9 @@ if (clip_rect.Rect() != painting_info.paint_dirty_rect || clip_rect.HasRadius()) { clip_recorder_ = WTF::WrapUnique(new LayerClipRecorder( - context, layer.GetLayoutObject(), DisplayItem::kClipLayerFilter, - clip_rect, painting_info.root_layer, LayoutPoint(), paint_flags)); + context, layer, DisplayItem::kClipLayerFilter, clip_rect, + painting_info.root_layer, LayoutPoint(), paint_flags, + layer.GetLayoutObject())); } if (!context.GetPaintController().DisplayItemConstructionIsDisabled()) {
diff --git a/third_party/WebKit/Source/core/paint/LayerClipRecorder.cpp b/third_party/WebKit/Source/core/paint/LayerClipRecorder.cpp index 9befa968..ddb33be 100644 --- a/third_party/WebKit/Source/core/paint/LayerClipRecorder.cpp +++ b/third_party/WebKit/Source/core/paint/LayerClipRecorder.cpp
@@ -16,15 +16,16 @@ namespace blink { LayerClipRecorder::LayerClipRecorder(GraphicsContext& graphics_context, - const LayoutBoxModelObject& layout_object, + const PaintLayer& paint_layer, DisplayItem::Type clip_type, const ClipRect& clip_rect, const PaintLayer* clip_root, const LayoutPoint& fragment_offset, PaintLayerFlags paint_flags, + const DisplayItemClient& client, BorderRadiusClippingRule rule) : graphics_context_(graphics_context), - layout_object_(layout_object), + client_(client), clip_type_(clip_type) { if (RuntimeEnabledFeatures::SlimmingPaintV2Enabled()) return; @@ -34,16 +35,16 @@ paint_flags & kPaintLayerPaintingAncestorClippingMaskPhase); Vector<FloatRoundedRect> rounded_rects; if (clip_root && (clip_rect.HasRadius() || painting_masks)) { - CollectRoundedRectClips(*layout_object.Layer(), clip_root, fragment_offset, + CollectRoundedRectClips(paint_layer, clip_root, fragment_offset, painting_masks, rule, rounded_rects); } graphics_context_.GetPaintController().CreateAndAppend<ClipDisplayItem>( - layout_object, clip_type_, snapped_clip_rect, rounded_rects); + client_, clip_type_, snapped_clip_rect, rounded_rects); } -static bool InContainingBlockChain(PaintLayer* start_layer, - PaintLayer* end_layer) { +static bool InContainingBlockChain(const PaintLayer* start_layer, + const PaintLayer* end_layer) { if (start_layer == end_layer) return true; @@ -60,7 +61,7 @@ } void LayerClipRecorder::CollectRoundedRectClips( - PaintLayer& paint_layer, + const PaintLayer& paint_layer, const PaintLayer* clip_root, const LayoutPoint& offset_within_layer, bool cross_composited_scrollers, @@ -70,9 +71,9 @@ // up our layer chain applying the clips from any layers with overflow. The // condition for being able to apply these clips is that the overflow object // be in our containing block chain so we check that also. - for (PaintLayer* layer = rule == kIncludeSelfForBorderRadius - ? &paint_layer - : paint_layer.Parent(); + for (const PaintLayer* layer = rule == kIncludeSelfForBorderRadius + ? &paint_layer + : paint_layer.Parent(); layer; layer = layer->Parent()) { // Composited scrolling layers handle border-radius clip in the compositor // via a mask layer. We do not want to apply a border-radius clip to the @@ -109,7 +110,7 @@ if (RuntimeEnabledFeatures::SlimmingPaintV2Enabled()) return; graphics_context_.GetPaintController().EndItem<EndClipDisplayItem>( - layout_object_, DisplayItem::ClipTypeToEndClipType(clip_type_)); + client_, DisplayItem::ClipTypeToEndClipType(clip_type_)); } } // namespace blink
diff --git a/third_party/WebKit/Source/core/paint/LayerClipRecorder.h b/third_party/WebKit/Source/core/paint/LayerClipRecorder.h index 0a435ed3..62f33fd 100644 --- a/third_party/WebKit/Source/core/paint/LayerClipRecorder.h +++ b/third_party/WebKit/Source/core/paint/LayerClipRecorder.h
@@ -16,7 +16,6 @@ class ClipRect; class GraphicsContext; -class LayoutBoxModelObject; class CORE_EXPORT LayerClipRecorder { USING_FAST_MALLOC(LayerClipRecorder); @@ -43,12 +42,13 @@ // Would be nice to clean up this. explicit LayerClipRecorder( GraphicsContext&, - const LayoutBoxModelObject&, + const PaintLayer&, DisplayItem::Type, const ClipRect&, const PaintLayer* clip_root, const LayoutPoint& fragment_offset, PaintLayerFlags, + const DisplayItemClient&, BorderRadiusClippingRule = kIncludeSelfForBorderRadius); ~LayerClipRecorder(); @@ -64,7 +64,7 @@ // The BorderRadiusClippingRule defines whether clips on the PaintLayer itself // are included. Output is appended to rounded_rect_clips. static void CollectRoundedRectClips( - PaintLayer&, + const PaintLayer&, const PaintLayer* clip_root, const LayoutPoint& offset_within_layer, bool cross_composited_scrollers, @@ -73,7 +73,7 @@ private: GraphicsContext& graphics_context_; - const LayoutBoxModelObject& layout_object_; + const DisplayItemClient& client_; DisplayItem::Type clip_type_; };
diff --git a/third_party/WebKit/Source/core/paint/LayerClipRecorderTest.cpp b/third_party/WebKit/Source/core/paint/LayerClipRecorderTest.cpp index 46032cf..18c0a91 100644 --- a/third_party/WebKit/Source/core/paint/LayerClipRecorderTest.cpp +++ b/third_party/WebKit/Source/core/paint/LayerClipRecorderTest.cpp
@@ -31,9 +31,10 @@ LayoutRect rect(1, 1, 9, 9); ClipRect clip_rect(rect); LayerClipRecorder layer_clip_recorder( - context, layout_view.Compositor()->RootLayer()->GetLayoutObject(), + context, *layout_view.Compositor()->RootLayer(), DisplayItem::kClipLayerForeground, clip_rect, 0, LayoutPoint(), - PaintLayerFlags()); + PaintLayerFlags(), + layout_view.Compositor()->RootLayer()->GetLayoutObject()); } void DrawRectInClip(GraphicsContext& context, @@ -43,9 +44,10 @@ IntRect rect(1, 1, 9, 9); ClipRect clip_rect((LayoutRect(rect))); LayerClipRecorder layer_clip_recorder( - context, layout_view.Compositor()->RootLayer()->GetLayoutObject(), + context, *layout_view.Compositor()->RootLayer(), DisplayItem::kClipLayerForeground, clip_rect, 0, LayoutPoint(), - PaintLayerFlags()); + PaintLayerFlags(), + layout_view.Compositor()->RootLayer()->GetLayoutObject()); if (!LayoutObjectDrawingRecorder::UseCachedDrawingIfPossible( context, layout_view, phase)) { LayoutObjectDrawingRecorder drawing_recorder(context, layout_view, phase,
diff --git a/third_party/WebKit/Source/core/paint/PaintLayerPainter.cpp b/third_party/WebKit/Source/core/paint/PaintLayerPainter.cpp index 4ba3f1d..163f586 100644 --- a/third_party/WebKit/Source/core/paint/PaintLayerPainter.cpp +++ b/third_party/WebKit/Source/core/paint/PaintLayerPainter.cpp
@@ -6,6 +6,7 @@ #include "core/frame/LocalFrameView.h" #include "core/layout/LayoutView.h" +#include "core/layout/compositing/CompositedLayerMapping.h" #include "core/paint/ClipPathClipper.h" #include "core/paint/FilterPainter.h" #include "core/paint/LayerClipRecorder.h" @@ -780,10 +781,11 @@ clip_rect_for_fragment.MoveBy(fragment.pagination_offset); clip_rect_for_fragment.Intersect(fragment.background_rect); if (NeedsToClip(painting_info, clip_rect_for_fragment, paint_flags)) { - clip_recorder.emplace(context, parent_layer->GetLayoutObject(), + clip_recorder.emplace(context, *parent_layer, DisplayItem::kClipLayerParent, clip_rect_for_fragment, painting_info.root_layer, - fragment.pagination_offset, paint_flags); + fragment.pagination_offset, paint_flags, + parent_layer->GetLayoutObject()); } } if (PaintFragmentByApplyingTransform(context, painting_info, paint_flags, @@ -924,11 +926,11 @@ Optional<LayerClipRecorder> clip_recorder; if (NeedsToClip(local_painting_info, fragment.background_rect, paint_flags)) { - clip_recorder.emplace(context, paint_layer_.GetLayoutObject(), - DisplayItem::kClipLayerOverflowControls, - fragment.background_rect, - local_painting_info.root_layer, - fragment.pagination_offset, paint_flags); + clip_recorder.emplace( + context, paint_layer_, DisplayItem::kClipLayerOverflowControls, + fragment.background_rect, local_painting_info.root_layer, + fragment.pagination_offset, paint_flags, + paint_layer_.GetLayoutObject()); } Optional<ScrollRecorder> scroll_recorder; @@ -959,6 +961,7 @@ ClipState clip_state) { DCHECK(paint_layer_.IsSelfPaintingLayer()); + DisplayItemClient* client = &paint_layer_.GetLayoutObject(); Optional<LayerClipRecorder> clip_recorder; if (clip_state != kHasClipped && painting_info.clip_to_dirty_rect && (NeedsToClip(painting_info, clip_rect, paint_flags) || @@ -978,6 +981,10 @@ // The ancestor is the thing that needs to clip, so do not include // this layer's clips. clipping_rule = LayerClipRecorder::kDoNotIncludeSelfForBorderRadius; + // The ancestor clipping mask may have a larger visual rect than + // paint_layer_, since it includes ancestor clips. + client = paint_layer_.GetCompositedLayerMapping() + ->AncestorClippingMaskLayer(); break; } default: @@ -985,10 +992,9 @@ break; } - clip_recorder.emplace(context, paint_layer_.GetLayoutObject(), clip_type, - clip_rect, painting_info.root_layer, - fragment.pagination_offset, paint_flags, - clipping_rule); + clip_recorder.emplace(context, paint_layer_, clip_type, clip_rect, + painting_info.root_layer, fragment.pagination_offset, + paint_flags, *client, clipping_rule); } // If we are painting a mask for any reason and we have already processed the @@ -996,7 +1002,7 @@ // We know that the mask just needs the area bounded by the clip rects to be // filled with black. if (clip_recorder && phase == kPaintPhaseClippingMask) { - FillMaskingFragment(context, clip_rect); + FillMaskingFragment(context, clip_rect, *client); return; } @@ -1063,11 +1069,11 @@ if (should_clip && NeedsToClip(local_painting_info, layer_fragments[0].foreground_rect, paint_flags)) { - clip_recorder.emplace(context, paint_layer_.GetLayoutObject(), - DisplayItem::kClipLayerForeground, - layer_fragments[0].foreground_rect, - local_painting_info.root_layer, - layer_fragments[0].pagination_offset, paint_flags); + clip_recorder.emplace( + context, paint_layer_, DisplayItem::kClipLayerForeground, + layer_fragments[0].foreground_rect, local_painting_info.root_layer, + layer_fragments[0].pagination_offset, paint_flags, + paint_layer_.GetLayoutObject()); clip_state = kHasClipped; } @@ -1226,15 +1232,15 @@ } void PaintLayerPainter::FillMaskingFragment(GraphicsContext& context, - const ClipRect& clip_rect) { - const LayoutObject& layout_object = paint_layer_.GetLayoutObject(); - if (LayoutObjectDrawingRecorder::UseCachedDrawingIfPossible( - context, layout_object, kPaintPhaseClippingMask)) + const ClipRect& clip_rect, + const DisplayItemClient& client) { + DisplayItem::Type type = + DisplayItem::PaintPhaseToDrawingType(kPaintPhaseClippingMask); + if (DrawingRecorder::UseCachedDrawingIfPossible(context, client, type)) return; IntRect snapped_clip_rect = PixelSnappedIntRect(clip_rect.Rect()); - LayoutObjectDrawingRecorder drawing_recorder( - context, layout_object, kPaintPhaseClippingMask, snapped_clip_rect); + DrawingRecorder drawing_recorder(context, client, type, snapped_clip_rect); context.FillRect(snapped_clip_rect, Color::kBlack); }
diff --git a/third_party/WebKit/Source/core/paint/PaintLayerPainter.h b/third_party/WebKit/Source/core/paint/PaintLayerPainter.h index 771aaaa4..be10a76 100644 --- a/third_party/WebKit/Source/core/paint/PaintLayerPainter.h +++ b/third_party/WebKit/Source/core/paint/PaintLayerPainter.h
@@ -14,6 +14,7 @@ namespace blink { class ClipRect; +class DisplayItemClient; class PaintLayer; class GraphicsContext; class LayoutPoint; @@ -136,7 +137,9 @@ const PaintLayerPaintingInfo&, PaintLayerFlags); - void FillMaskingFragment(GraphicsContext&, const ClipRect&); + void FillMaskingFragment(GraphicsContext&, + const ClipRect&, + const DisplayItemClient&); static bool NeedsToClip(const PaintLayerPaintingInfo& local_painting_info, const ClipRect&,
diff --git a/third_party/WebKit/Source/core/testing/DummyPageHolder.cpp b/third_party/WebKit/Source/core/testing/DummyPageHolder.cpp index d2a9797..0a20520 100644 --- a/third_party/WebKit/Source/core/testing/DummyPageHolder.cpp +++ b/third_party/WebKit/Source/core/testing/DummyPageHolder.cpp
@@ -46,18 +46,16 @@ const IntSize& initial_view_size, Page::PageClients* page_clients, LocalFrameClient* local_frame_client, - FrameSettingOverrideFunction setting_overrider, - InterfaceProvider* interface_provider) { - return WTF::WrapUnique( - new DummyPageHolder(initial_view_size, page_clients, local_frame_client, - setting_overrider, interface_provider)); + FrameSettingOverrideFunction setting_overrider) { + return WTF::WrapUnique(new DummyPageHolder( + initial_view_size, page_clients, local_frame_client, setting_overrider)); } -DummyPageHolder::DummyPageHolder(const IntSize& initial_view_size, - Page::PageClients* page_clients_argument, - LocalFrameClient* local_frame_client, - FrameSettingOverrideFunction setting_overrider, - InterfaceProvider* interface_provider) { +DummyPageHolder::DummyPageHolder( + const IntSize& initial_view_size, + Page::PageClients* page_clients_argument, + LocalFrameClient* local_frame_client, + FrameSettingOverrideFunction setting_overrider) { Page::PageClients page_clients; if (!page_clients_argument) { FillWithEmptyClients(page_clients); @@ -81,8 +79,7 @@ if (!local_frame_client_) local_frame_client_ = EmptyLocalFrameClient::Create(); - frame_ = LocalFrame::Create(local_frame_client_.Get(), *page_, nullptr, - interface_provider); + frame_ = LocalFrame::Create(local_frame_client_.Get(), *page_, nullptr); frame_->SetView(LocalFrameView::Create(*frame_, initial_view_size)); frame_->View()->GetPage()->GetVisualViewport().SetSize(initial_view_size); frame_->Init();
diff --git a/third_party/WebKit/Source/core/testing/DummyPageHolder.h b/third_party/WebKit/Source/core/testing/DummyPageHolder.h index 6c90565..b43f93d 100644 --- a/third_party/WebKit/Source/core/testing/DummyPageHolder.h +++ b/third_party/WebKit/Source/core/testing/DummyPageHolder.h
@@ -42,7 +42,6 @@ namespace blink { class Document; -class InterfaceProvider; class IntSize; class LocalFrame; class LocalFrameView; @@ -72,8 +71,7 @@ const IntSize& initial_view_size = IntSize(), Page::PageClients* = 0, LocalFrameClient* = nullptr, - FrameSettingOverrideFunction = nullptr, - InterfaceProvider* = nullptr); + FrameSettingOverrideFunction = nullptr); ~DummyPageHolder(); Page& GetPage() const; @@ -85,8 +83,7 @@ DummyPageHolder(const IntSize& initial_view_size, Page::PageClients*, LocalFrameClient*, - FrameSettingOverrideFunction setting_overrider, - InterfaceProvider* = nullptr); + FrameSettingOverrideFunction setting_overrider); Persistent<Page> page_;
diff --git a/third_party/WebKit/Source/core/testing/Internals.cpp b/third_party/WebKit/Source/core/testing/Internals.cpp index 7f678f2..73fae78a 100644 --- a/third_party/WebKit/Source/core/testing/Internals.cpp +++ b/third_party/WebKit/Source/core/testing/Internals.cpp
@@ -3414,4 +3414,8 @@ MemoryCoordinator::SetIsLowEndDeviceForTesting(is_low_end_device); } +bool Internals::isLowEndDevice() const { + return MemoryCoordinator::IsLowEndDevice(); +} + } // namespace blink
diff --git a/third_party/WebKit/Source/core/testing/Internals.h b/third_party/WebKit/Source/core/testing/Internals.h index ca564bf9..ebbf5ca 100644 --- a/third_party/WebKit/Source/core/testing/Internals.h +++ b/third_party/WebKit/Source/core/testing/Internals.h
@@ -567,6 +567,8 @@ // Overrides if the device is low-end (low on memory). void setIsLowEndDevice(bool); + // Returns if the device is low-end. + bool isLowEndDevice() const; private: explicit Internals(ExecutionContext*);
diff --git a/third_party/WebKit/Source/core/testing/Internals.idl b/third_party/WebKit/Source/core/testing/Internals.idl index 5a9ef15..1a30806 100644 --- a/third_party/WebKit/Source/core/testing/Internals.idl +++ b/third_party/WebKit/Source/core/testing/Internals.idl
@@ -394,4 +394,5 @@ void crash(); void setIsLowEndDevice(boolean isLowEndDevice); + boolean isLowEndDevice(); };
diff --git a/third_party/WebKit/Source/core/timing/PerformanceTest.cpp b/third_party/WebKit/Source/core/timing/PerformanceTest.cpp index c26eb671..b1d87166 100644 --- a/third_party/WebKit/Source/core/timing/PerformanceTest.cpp +++ b/third_party/WebKit/Source/core/timing/PerformanceTest.cpp
@@ -45,7 +45,7 @@ auto* monitor = GetFrame()->GetPerformanceMonitor(); monitor->WillExecuteScript(GetDocument()); monitor->DidExecuteScript(); - monitor->DidProcessTask(nullptr, 0, 1); + monitor->DidProcessTask(0, 1); } LocalFrame* GetFrame() const { return &page_holder_->GetFrame(); }
diff --git a/third_party/WebKit/Source/core/xml/parser/XMLDocumentParser.cpp b/third_party/WebKit/Source/core/xml/parser/XMLDocumentParser.cpp index 448d3ce..267fb29 100644 --- a/third_party/WebKit/Source/core/xml/parser/XMLDocumentParser.cpp +++ b/third_party/WebKit/Source/core/xml/parser/XMLDocumentParser.cpp
@@ -36,7 +36,7 @@ #include "core/HTMLNames.h" #include "core/XMLNSNames.h" #include "core/dom/CDATASection.h" -#include "core/dom/ClassicScript.h" +#include "core/dom/ClassicPendingScript.h" #include "core/dom/Comment.h" #include "core/dom/Document.h" #include "core/dom/DocumentFragment.h" @@ -1136,18 +1136,10 @@ if (script_loader->ReadyToBeParserExecuted()) { // 5th Clause, Step 23 of https://html.spec.whatwg.org/#prepare-a-script - switch (script_loader->ExecuteScript(ClassicScript::Create( - ScriptSourceCode(script_element_base->TextFromChildren(), - GetDocument()->Url(), script_start_position_)))) { - case ScriptLoader::ExecuteScriptResult::kShouldFireErrorEvent: - script_loader->DispatchErrorEvent(); - return; - case ScriptLoader::ExecuteScriptResult::kShouldFireLoadEvent: - // The load event is not fired because this is an inline script. - break; - case ScriptLoader::ExecuteScriptResult::kShouldFireNone: - break; - } + script_loader->ExecuteScriptBlock( + ClassicPendingScript::Create(script_element_base, + script_start_position_), + GetDocument()->Url()); } else if (script_loader->WillBeParserExecuted()) { // 1st/2nd Clauses, Step 23 of // https://html.spec.whatwg.org/#prepare-a-script
diff --git a/third_party/WebKit/Source/devtools/front_end/accessibility/ARIAConfig.js b/third_party/WebKit/Source/devtools/front_end/accessibility/ARIAConfig.js index 217f6e7..909b0136 100644 --- a/third_party/WebKit/Source/devtools/front_end/accessibility/ARIAConfig.js +++ b/third_party/WebKit/Source/devtools/front_end/accessibility/ARIAConfig.js
@@ -1,3 +1,7 @@ +// Copyright 2017 The Chromium Authors. All rights reserved. +// Use of this source code is governed by a BSD-style license that can be +// found in the LICENSE file. + Accessibility.ARIAMetadata._config = { 'attributes': { 'aria-activedescendant': {'type': 'IDREF'}, @@ -5,31 +9,46 @@ 'aria-autocomplete': {'default': 'none', 'enum': ['inline', 'list', 'both', 'none'], 'type': 'token'}, 'aria-busy': {'default': 'false', 'type': 'boolean'}, 'aria-checked': {'default': 'undefined', 'enum': ['true', 'false', 'mixed', 'undefined'], 'type': 'token'}, + 'aria-colcount': {'type': 'integer'}, + 'aria-colindex': {'type': 'integer'}, + 'aria-colspan': {'type': 'integer'}, 'aria-controls': {'type': 'IDREF_list'}, + 'aria-current': + {'default': 'false', 'enum': ['page', 'step', 'location', 'date', 'time', 'true', 'false'], 'type': 'token'}, 'aria-describedby': {'type': 'IDREF_list'}, + 'aria-details': {'type': 'IDREF'}, 'aria-disabled': {'default': 'false', 'type': 'boolean'}, 'aria-dropeffect': {'default': 'none', 'enum': ['copy', 'move', 'link', 'execute', 'popup', 'none'], 'type': 'token_list'}, + 'aria-errormessage': {'type': 'IDREF'}, 'aria-expanded': {'default': 'undefined', 'enum': ['true', 'false', 'undefined'], 'type': 'token'}, 'aria-flowto': {'type': 'IDREF_list'}, 'aria-grabbed': {'default': 'undefined', 'enum': ['true', 'false', 'undefined'], 'type': 'token'}, - 'aria-haspopup': {'default': 'false', 'type': 'boolean'}, - 'aria-hidden': {'default': 'false', 'type': 'boolean'}, + 'aria-haspopup': + {'default': 'false', 'enum': ['false', 'true', 'menu', 'listbox', 'tree', 'grid', 'dialog'], 'type': 'token'}, + 'aria-hidden': {'default': 'undefined', 'enum': ['true', 'false', 'undefined'], 'type': 'token'}, 'aria-invalid': {'default': 'false', 'enum': ['grammar', 'false', 'spelling', 'true'], 'type': 'token'}, + 'aria-keyshortcuts': {'type': 'string'}, 'aria-label': {'type': 'string'}, 'aria-labelledby': {'type': 'IDREF_list'}, 'aria-level': {'type': 'integer'}, 'aria-live': {'default': 'off', 'enum': ['off', 'polite', 'assertive'], 'type': 'token'}, + 'aria-modal': {'default': 'false', 'type': 'boolean'}, 'aria-multiline': {'default': 'false', 'type': 'boolean'}, 'aria-multiselectable': {'default': 'false', 'type': 'boolean'}, - 'aria-orientation': {'default': 'vertical', 'enum': ['horizontal', 'vertical'], 'type': 'token'}, + 'aria-orientation': {'default': 'undefined', 'enum': ['horizontal', 'undefined', 'vertical'], 'type': 'token'}, 'aria-owns': {'type': 'IDREF_list'}, + 'aria-placeholder': {'type': 'string'}, 'aria-posinset': {'type': 'integer'}, 'aria-pressed': {'default': 'undefined', 'enum': ['true', 'false', 'mixed', 'undefined'], 'type': 'token'}, 'aria-readonly': {'default': 'false', 'type': 'boolean'}, 'aria-relevant': {'default': 'additions text', 'enum': ['additions', 'removals', 'text', 'all'], 'type': 'token_list'}, 'aria-required': {'default': 'false', 'type': 'boolean'}, + 'aria-roledescription': {'type': 'string'}, + 'aria-rowcount': {'type': 'integer'}, + 'aria-rowindex': {'type': 'integer'}, + 'aria-rowspan': {'type': 'integer'}, 'aria-selected': {'default': 'undefined', 'enum': ['true', 'false', 'undefined'], 'type': 'token'}, 'aria-setsize': {'type': 'integer'}, 'aria-sort': {'default': 'none', 'enum': ['ascending', 'descending', 'none', 'other'], 'type': 'token'}, @@ -40,29 +59,56 @@ 'tabindex': {'type': 'integer'} }, 'roles': { - 'alert': {'nameFrom': ['author'], 'superclasses': ['region']}, - 'alertdialog': {'nameFrom': ['author'], 'superclasses': ['alert', 'dialog']}, - 'application': {'nameFrom': ['author'], 'superclasses': ['landmark']}, - 'article': {'nameFrom': ['author'], 'superclasses': ['document', 'region']}, + 'alert': { + 'nameFrom': ['author'], + 'superclasses': ['section'], + 'implicitValues': {'aria-live': 'assertive', 'aria-atomic': 'true'} + }, + 'alertdialog': {'nameFrom': ['author'], 'superclasses': ['alert', 'dialog'], 'nameRequired': true}, + 'application': {'nameFrom': ['author'], 'superclasses': ['structure'], 'nameRequired': true}, + 'article': { + 'nameFrom': ['author'], + 'superclasses': ['document'], + 'supportedAttributes': ['aria-posinset', 'aria-setsize'] + }, 'banner': {'nameFrom': ['author'], 'superclasses': ['landmark']}, 'button': { 'nameFrom': ['contents', 'author'], 'superclasses': ['command'], - 'supportedAttributes': ['aria-expanded', 'aria-pressed'] + 'supportedAttributes': ['aria-expanded', 'aria-pressed'], + 'nameRequired': true, + 'childrenPresentational': true }, - 'checkbox': {'nameFrom': ['contents', 'author'], 'requiredAttributes': ['aria-checked'], 'superclasses': ['input']}, + 'cell': { + 'namefrom': ['contents', 'author'], + 'scope': 'row', + 'superclasses': ['section'], + 'supportedAttributes': ['aria-colindex', 'aria-colspan', 'aria-rowindex', 'aria-rowspan'] + }, + 'checkbox': { + 'nameFrom': ['contents', 'author'], + 'requiredAttributes': ['aria-checked'], + 'superclasses': ['input'], + 'supportedAttributes': ['aria-readonly'], + 'nameRequired': true, + 'implicitValues': {'aria-checked': false} + }, 'columnheader': { 'nameFrom': ['contents', 'author'], 'scope': ['row'], 'superclasses': ['gridcell', 'sectionhead', 'widget'], - 'supportedAttributes': ['aria-sort'] + 'supportedAttributes': ['aria-sort'], + 'nameRequired': true }, 'combobox': { - 'mustContain': ['listbox', 'textbox'], + // TODO(aboxhall): Follow up with Nektarios and Aaron regarding role on textbox + 'mustContain': ['textbox'], 'nameFrom': ['author'], - 'requiredAttributes': ['aria-expanded'], + 'requiredAttributes': ['aria-controls', 'aria-expanded'], 'superclasses': ['select'], - 'supportedAttributes': ['aria-autocomplete', 'aria-required'] + 'supportedAttributes': ['aria-autocomplete', 'aria-readonly', 'aria-required'], + 'nameRequired': true, + 'implicitValues': {'aria-expanded': 'false', 'aria-haspopup': 'listbox'} }, 'command': {'abstract': true, 'nameFrom': ['author'], 'superclasses': ['widget']}, 'complementary': {'nameFrom': ['author'], 'superclasses': ['landmark']}, @@ -74,74 +120,151 @@ }, 'contentinfo': {'nameFrom': ['author'], 'superclasses': ['landmark']}, 'definition': {'nameFrom': ['author'], 'superclasses': ['section']}, - 'dialog': {'nameFrom': ['author'], 'superclasses': ['window']}, - 'directory': {'nameFrom': ['contents', 'author'], 'superclasses': ['list']}, - 'document': {'nameFrom': ['author'], 'superclasses': ['structure'], 'supportedAttributes': ['aria-expanded']}, + 'dialog': {'nameFrom': ['author'], 'superclasses': ['window'], 'nameRequired': true}, + 'directory': {'nameFrom': ['author'], 'superclasses': ['list']}, + 'document': { + 'nameFrom': ['author'], + 'superclasses': ['structure'], + 'supportedAttributes': ['aria-expanded'], + 'nameRequired': false + }, + 'feed': {'nameFrom': ['author'], 'superclasses': ['list'], 'mustContain': ['article'], 'nameRequired': false}, + 'figure': {'namefrom': ['author'], 'superclasses': ['section'], 'nameRequired': false}, 'form': {'nameFrom': ['author'], 'superclasses': ['landmark']}, 'grid': { - 'mustContain': ['row', 'rowgroup', 'row'], 'nameFrom': ['author'], - 'superclasses': ['composite', 'region'], - 'supportedAttributes': ['aria-level', 'aria-multiselectable', 'aria-readonly'] + 'superclasses': ['composite', 'table'], + // TODO(aboxhall): Figure out how to express "rowgroup --> row" here. + 'mustContain': ['row'], + 'supportedAttributes': ['aria-level', 'aria-multiselectable', 'aria-readonly'], + 'nameRequired': true }, 'gridcell': { 'nameFrom': ['contents', 'author'], 'scope': ['row'], - 'superclasses': ['section', 'widget'], - 'supportedAttributes': ['aria-readonly', 'aria-required', 'aria-selected'] + 'superclasses': ['cell', 'widget'], + 'supportedAttributes': ['aria-readonly', 'aria-required', 'aria-selected'], + 'nameRequired': true }, 'group': {'nameFrom': ['author'], 'superclasses': ['section'], 'supportedAttributes': ['aria-activedescendant']}, - 'heading': {'superclasses': ['sectionhead'], 'supportedAttributes': ['aria-level']}, - 'img': {'nameFrom': ['author'], 'superclasses': ['section']}, + 'heading': { + 'namefrom': ['contents', 'author'], + 'superclasses': ['sectionhead'], + 'supportedAttributes': ['aria-level'], + 'nameRequired': true, + 'implicitValues': {'aria-level': '2'} + }, + 'img': {'nameFrom': ['author'], 'superclasses': ['section'], 'nameRequired': true, 'childrenPresentational': true}, 'input': {'abstract': true, 'nameFrom': ['author'], 'superclasses': ['widget']}, - 'landmark': {'abstract': true, 'nameFrom': ['contents', 'author'], 'superclasses': ['region']}, - 'link': {'nameFrom': ['contents', 'author'], 'superclasses': ['command'], 'supportedAttributes': ['aria-expanded']}, - 'list': {'mustContain': ['group', 'listitem', 'listitem'], 'nameFrom': ['author'], 'superclasses': ['region']}, - 'listbox': { - 'mustContain': ['option'], + 'landmark': {'abstract': true, 'nameFrom': ['author'], 'superclasses': ['section'], 'nameRequired': false}, + 'link': { + 'nameFrom': ['contents', 'author'], + 'superclasses': ['command'], + 'supportedAttributes': ['aria-expanded'], + 'nameRequired': true + }, + 'list': { + // TODO(aboxhall): Figure out how to express "group --> listitem" + 'mustContain': ['listitem'], 'nameFrom': ['author'], - 'superclasses': ['list', 'select'], - 'supportedAttributes': ['aria-multiselectable', 'aria-required'] + 'superclasses': ['section'], + 'implicitValues': {'aria-orientation': 'vertical'} + }, + 'listbox': { + 'nameFrom': ['author'], + 'superclasses': ['select'], + 'mustContain': ['option'], + 'supportedAttributes': ['aria-multiselectable', 'aria-readonly', 'aria-required'], + 'nameRequired': true, + 'implicitValues': {'aria-orientation': 'vertical'}, }, 'listitem': { - 'nameFrom': ['contents', 'author'], - 'scope': ['list'], + 'nameFrom': ['author'], 'superclasses': ['section'], + 'scope': ['group', 'list'], 'supportedAttributes': ['aria-level', 'aria-posinset', 'aria-setsize'] }, - 'log': {'nameFrom': ['author'], 'superclasses': ['region']}, + 'log': { + 'nameFrom': ['author'], + 'superclasses': ['section'], + 'nameRequired': true, + 'implicitValues': {'aria-live': 'polite'} + }, 'main': {'nameFrom': ['author'], 'superclasses': ['landmark']}, - 'marquee': {'superclasses': ['section']}, - 'math': {'nameFrom': ['author'], 'superclasses': ['section']}, + 'marquee': {'nameFrom': ['author'], 'superclasses': ['section'], 'nameRequired': true}, + 'math': { + 'nameFrom': ['author'], + 'superclasses': ['section'], + 'nameRequired': true, + // TODO(aboxhall/aleventhal): this is what the spec says, but seems wrong. + childrenPresentational: true + }, 'menu': { 'mustContain': ['group', 'menuitemradio', 'menuitem', 'menuitemcheckbox', 'menuitemradio'], 'nameFrom': ['author'], - 'superclasses': ['list', 'select'] + 'superclasses': ['select'], + 'implicitValues': {'aria-orientation': 'vertical'} }, - 'menubar': {'nameFrom': ['author'], 'superclasses': ['menu']}, - 'menuitem': {'nameFrom': ['contents', 'author'], 'scope': ['menu', 'menubar'], 'superclasses': ['command']}, - 'menuitemcheckbox': - {'nameFrom': ['contents', 'author'], 'scope': ['menu', 'menubar'], 'superclasses': ['checkbox', 'menuitem']}, - 'menuitemradio': { + 'menubar': { + 'nameFrom': ['author'], + 'superclasses': ['menu'], + // TODO(aboxhall): figure out how to express "group --> {menuitem, menuitemradio, menuitemcheckbox}" + 'mustContain': ['menuitem', 'menuitemradio', 'menuitemcheckbox'], + 'implicitValues': {'aria-orientation': 'horizontal'} + }, + 'menuitem': { + 'nameFrom': ['contents', 'author'], + 'scope': ['group', 'menu', 'menubar'], + 'superclasses': ['command'], + 'nameRequired': true + }, + 'menuitemcheckbox': { 'nameFrom': ['contents', 'author'], 'scope': ['menu', 'menubar'], - 'superclasses': ['menuitemcheckbox', 'radio'] + 'superclasses': ['checkbox', 'menuitem'], + 'nameRequired': true, + 'childrenPresentational': true, + 'implicitValues': {'aria-checked': false} + }, + 'menuitemradio': { + 'nameFrom': ['contents', 'author'], + 'scope': ['menu', 'menubar', 'group'], + 'superclasses': ['menuitemcheckbox', 'radio'], + 'nameRequired': true, + 'childrenPresentational': true, + 'implicitValues': {'aria-checked': false} }, 'navigation': {'nameFrom': ['author'], 'superclasses': ['landmark']}, + 'none': {'superclasses': ['structure']}, 'note': {'nameFrom': ['author'], 'superclasses': ['section']}, 'option': { 'nameFrom': ['contents', 'author'], + 'scope': ['listbox'], 'superclasses': ['input'], - 'supportedAttributes': ['aria-checked', 'aria-posinset', 'aria-selected', 'aria-setsize'] + 'requiredAttributes': ['aria-selected'], + 'supportedAttributes': ['aria-checked', 'aria-posinset', 'aria-setsize'], + 'nameRequired': true, + 'childrenPresentational': true, + 'implicitValues': {'aria-selected': 'false'} }, 'presentation': {'superclasses': ['structure']}, - 'progressbar': {'nameFrom': ['author'], 'superclasses': ['range']}, - 'radio': {'nameFrom': ['contents', 'author'], 'superclasses': ['checkbox', 'option']}, + 'progressbar': + {'nameFrom': ['author'], 'superclasses': ['range'], 'nameRequired': true, 'childrenPresentational': true}, + 'radio': { + 'nameFrom': ['contents', 'author'], + 'superclasses': ['input'], + 'requiredAttributes': ['aria-checked'], + 'supportedAttributes': ['aria-posinset', 'aria-setsize'], + 'nameRequired': true, + 'childrenPresentational': true, + 'implicitValues': {'aria-checked': 'false'} + }, 'radiogroup': { - 'mustContain': ['radio'], 'nameFrom': ['author'], 'superclasses': ['select'], - 'supportedAttributes': ['aria-required'] + 'mustContain': ['radio'], + 'supportedAttributes': ['aria-readonly', 'aria-required'], + 'nameRequired': true }, 'range': { 'abstract': true, @@ -149,105 +272,169 @@ 'superclasses': ['widget'], 'supportedAttributes': ['aria-valuemax', 'aria-valuemin', 'aria-valuenow', 'aria-valuetext'] }, - 'region': {'nameFrom': ['author'], 'superclasses': ['section']}, + 'region': {'nameFrom': ['author'], 'superclasses': ['landmark'], 'nameRequired': true}, 'roletype': { 'abstract': true, 'supportedAttributes': [ - 'aria-atomic', 'aria-busy', 'aria-controls', 'aria-describedby', 'aria-disabled', 'aria-dropeffect', - 'aria-flowto', 'aria-grabbed', 'aria-haspopup', 'aria-hidden', 'aria-invalid', 'aria-label', 'aria-labelledby', - 'aria-live', 'aria-owns', 'aria-relevant' + 'aria-atomic', 'aria-busy', 'aria-controls', 'aria-current', 'aria-describedby', 'aria-details', + 'aria-disabled', 'aria-dropeffect', 'aria-errormessage', 'aria-flowto', 'aria-grabbed', 'aria-haspopup', + 'aria-hidden', 'aria-invalid', 'aria-keyshortcuts', 'aria-label', 'aria-labelledby', 'aria-live', + 'aria-owns', 'aria-relevant', 'aria-roledescription' ] }, 'row': { - 'mustContain': ['columnheader', 'gridcell', 'rowheader'], 'nameFrom': ['contents', 'author'], - 'scope': ['grid', 'rowgroup', 'treegrid'], 'superclasses': ['group', 'widget'], - 'supportedAttributes': ['aria-level', 'aria-selected'] + 'mustContain': ['cell', 'columnheader', 'gridcell', 'rowheader'], + 'scope': ['grid', 'rowgroup', 'table', 'treegrid'], + // TODO(aboxhall/aleventhal): This is not in the spec yet, but + // setsize and posinset are included here for treegrid + // purposes. Issue already filed on spec. Remove this comment + // when spec updated. + 'supportedAttributes': + ['aria-colindex', 'aria-level', 'aria-rowindex', 'aria-selected', 'aria-setsize', 'aria-posinset'] }, - 'rowgroup': - {'mustContain': ['row'], 'nameFrom': ['contents', 'author'], 'scope': ['grid'], 'superclasses': ['group']}, + 'rowgroup': { + 'nameFrom': ['contents', 'author'], + 'superclasses': ['structure'], + 'mustContain': ['row'], + 'scope': ['grid', 'table', 'treegrid'], + }, 'rowheader': { 'nameFrom': ['contents', 'author'], 'scope': ['row'], - 'superclasses': ['gridcell', 'sectionhead', 'widget'], - 'supportedAttributes': ['aria-sort'] + 'superclasses': ['cell', 'gridcell', 'sectionhead'], + 'supportedAttributes': ['aria-sort'], + 'nameRequired': true }, 'scrollbar': { 'nameFrom': ['author'], 'requiredAttributes': ['aria-controls', 'aria-orientation', 'aria-valuemax', 'aria-valuemin', 'aria-valuenow'], - 'superclasses': ['input', 'range'] + 'superclasses': ['range'], + 'nameRequired': false, + 'childrenPresentational': true, + 'implicitValues': {'aria-orientation': 'vertical', 'aria-valuemin': '0', 'aria-valuemax': '100'} }, 'search': {'nameFrom': ['author'], 'superclasses': ['landmark']}, - 'section': { - 'abstract': true, - 'nameFrom': ['contents', 'author'], - 'superclasses': ['structure'], - 'supportedAttributes': ['aria-expanded'] - }, + 'searchbox': {'nameFrom': ['author'], 'superclasses': ['textbox'], 'nameRequired': true}, + 'section': {'abstract': true, 'superclasses': ['structure'], 'supportedAttributes': ['aria-expanded']}, 'sectionhead': { 'abstract': true, 'nameFrom': ['contents', 'author'], 'superclasses': ['structure'], 'supportedAttributes': ['aria-expanded'] }, - 'select': {'abstract': true, 'nameFrom': ['author'], 'superclasses': ['composite', 'group', 'input']}, + 'select': {'abstract': true, 'nameFrom': ['author'], 'superclasses': ['composite', 'group']}, 'separator': { 'nameFrom': ['author'], + // TODO(aboxhall): superclass depends on focusability, but + // doesn't affect required/supported attributes 'superclasses': ['structure'], - 'supportedAttributes': ['aria-expanded', 'aria-orientation'] + // TODO(aboxhall): required attributes depend on focusability + 'supportedAttributes': ['aria-orientation', 'aria-valuemin', 'aria-valuemax', 'aria-valuenow', 'aria-valuetext'] }, 'slider': { 'nameFrom': ['author'], 'requiredAttributes': ['aria-valuemax', 'aria-valuemin', 'aria-valuenow'], 'superclasses': ['input', 'range'], - 'supportedAttributes': ['aria-orientation'] + 'supportedAttributes': ['aria-orientation'], + 'nameRequired': true, + 'childrenPresentational': true, + // TODO(aboxhall): aria-valuenow default is halfway between + // aria-valuemin and aria-valuemax + 'implicitValues': {'aria-orientation': 'horizontal', 'aria-valuemin': '0', 'aria-valuemax': '100'} }, 'spinbutton': { 'nameFrom': ['author'], 'requiredAttributes': ['aria-valuemax', 'aria-valuemin', 'aria-valuenow'], - 'superclasses': ['input', 'range'], - 'supportedAttributes': ['aria-required'] + 'superclasses': ['composite', 'input', 'range'], + 'supportedAttributes': ['aria-required', 'aria-readonly'], + 'nameRequired': true, + 'implicitValues': {'aria-valuenow': '0'} }, - 'status': {'superclasses': ['region']}, + 'status': { + 'nameFrom': ['author'], + 'superclasses': ['section'], + 'implicitValues': {'aria-live': 'polite', 'aria-atomic': 'true'} + }, 'structure': {'abstract': true, 'superclasses': ['roletype']}, + 'switch': { + 'nameFrom': ['contents', 'author'], + 'superclasses': ['checkbox'], + 'requiredAttributes': ['aria-checked'], + 'nameRequired': true, + 'childrenPresentational': true, + 'implicitValues': {'aria-checked': 'false'} + }, 'tab': { 'nameFrom': ['contents', 'author'], 'scope': ['tablist'], 'superclasses': ['sectionhead', 'widget'], - 'supportedAttributes': ['aria-selected'] + 'supportedAttributes': ['aria-selected'], + 'childrenPresentational': true, + 'implicitValues': {'aria-selected': 'false'} + }, + 'table': { + 'nameFrom': ['author'], + 'superclasses': ['section'], + // TODO(aboxhall): Figure out how to express "rowgroup --> row" + 'mustContain': ['row'], + 'supportedAttributes': ['aria-colcount', 'aria-rowcount'], + 'nameRequired': true }, 'tablist': { - 'mustContain': ['tab'], 'nameFrom': ['author'], - 'superclasses': ['composite', 'directory'], - 'supportedAttributes': ['aria-level'] + 'superclasses': ['composite'], + 'mustContain': ['tab'], + 'supportedAttributes': ['aria-level', 'aria-multiselectable', 'aria-orientation'], + 'implicitValues': {'aria-orientation': 'horizontal'} }, - 'tabpanel': {'nameFrom': ['author'], 'superclasses': ['region']}, + 'tabpanel': {'nameFrom': ['author'], 'superclasses': ['section'], 'nameRequired': true}, + 'term': {'nameFrom': ['author'], 'superclasses': ['section']}, 'textbox': { 'nameFrom': ['author'], 'superclasses': ['input'], - 'supportedAttributes': - ['aria-activedescendant', 'aria-autocomplete', 'aria-multiline', 'aria-readonly', 'aria-required'] + 'supportedAttributes': [ + 'aria-activedescendant', 'aria-autocomplete', 'aria-multiline', 'aria-placeholder', 'aria-readonly', + 'aria-required' + ], + 'nameRequired': true }, 'timer': {'nameFrom': ['author'], 'superclasses': ['status']}, - 'toolbar': {'nameFrom': ['author'], 'superclasses': ['group']}, - 'tooltip': {'superclasses': ['section']}, - 'tree': { - 'mustContain': ['group', 'treeitem', 'treeitem'], + 'toolbar': { 'nameFrom': ['author'], - 'superclasses': ['select'], - 'supportedAttributes': ['aria-multiselectable', 'aria-required'] + 'superclasses': ['group'], + 'supportedAttributes': ['aria-orientation'], + 'implicitValues': {'aria-orientation': 'horizontal'} }, - 'treegrid': {'mustContain': ['row'], 'nameFrom': ['author'], 'superclasses': ['grid', 'tree']}, - 'treeitem': - {'nameFrom': ['contents', 'author'], 'scope': ['group', 'tree'], 'superclasses': ['listitem', 'option']}, + 'tooltip': {'nameFrom': ['contents', 'author'], 'superclasses': ['section'], 'nameRequired': true}, + 'tree': { + 'nameFrom': ['author'], + 'mustContain': ['group', 'treeitem'], + 'superclasses': ['select'], + 'supportedAttributes': ['aria-multiselectable', 'aria-required'], + 'nameRequired': true, + 'implicitValues': {'aria-orientation': 'vertical'} + }, + 'treegrid': { + // TODO(aboxhall): Figure out how to express "rowgroup --> row" + 'mustContain': ['row'], + 'nameFrom': ['author'], + 'superclasses': ['grid', 'tree'], + 'nameRequired': true + }, + 'treeitem': { + 'nameFrom': ['contents', 'author'], + 'scope': ['group', 'tree'], + 'superclasses': ['listitem', 'option'], + 'nameRequired': true + }, 'widget': {'abstract': true, 'superclasses': ['roletype']}, 'window': { 'abstract': true, 'nameFrom': ['author'], 'superclasses': ['roletype'], - 'supportedAttributes': ['aria-expanded'] + 'supportedAttributes': ['aria-expanded', 'aria-modal'] } } };
diff --git a/third_party/WebKit/Source/devtools/front_end/accessibility/AXBreadcrumbsPane.js b/third_party/WebKit/Source/devtools/front_end/accessibility/AXBreadcrumbsPane.js index 72de23e..054cef0a 100644 --- a/third_party/WebKit/Source/devtools/front_end/accessibility/AXBreadcrumbsPane.js +++ b/third_party/WebKit/Source/devtools/front_end/accessibility/AXBreadcrumbsPane.js
@@ -10,6 +10,7 @@ super(Common.UIString('Accessibility Tree')); this.element.classList.add('ax-subpane'); + UI.ARIAUtils.markAsTree(this.element); this._axSidebarView = axSidebarView; @@ -53,11 +54,14 @@ var depth = 0; var breadcrumb = null; + var parent = null; for (ancestor of ancestorChain) { breadcrumb = new Accessibility.AXBreadcrumb(ancestor, depth, (ancestor === axNode)); - if (ancestor.children().length) - breadcrumb.element().classList.add('parent'); - this._rootElement.appendChild(breadcrumb.element()); + if (parent) + parent.appendChild(breadcrumb); + else + this._rootElement.appendChild(breadcrumb.element()); + parent = breadcrumb; depth++; } @@ -68,7 +72,7 @@ for (var child of axNode.children()) { var childBreadcrumb = new Accessibility.AXBreadcrumb(child, depth, false); - this._rootElement.appendChild(childBreadcrumb.element()); + inspectedNodeBreadcrumb.appendChild(childBreadcrumb); } this._selectedByUser = false; @@ -115,11 +119,11 @@ * @return {boolean} */ _preselectPrevious() { - var previousElement = this._preselectedBreadcrumb.element().previousSibling; - if (!previousElement) + var previousBreadcrumb = this._preselectedBreadcrumb.previousBreadcrumb(); + if (!previousBreadcrumb) return false; this._selectedByUser = true; - this._setPreselectedBreadcrumb(previousElement.breadcrumb); + this._setPreselectedBreadcrumb(previousBreadcrumb); return true; } @@ -127,11 +131,11 @@ * @return {boolean} */ _preselectNext() { - var nextElement = this._preselectedBreadcrumb.element().nextSibling; - if (!nextElement) + var nextBreadcrumb = this._preselectedBreadcrumb.nextBreadcrumb(); + if (!nextBreadcrumb) return false; this._selectedByUser = true; - this._setPreselectedBreadcrumb(nextElement.breadcrumb); + this._setPreselectedBreadcrumb(nextBreadcrumb); return true; } @@ -161,7 +165,7 @@ * @param {!Event} event */ _onMouseMove(event) { - var breadcrumbElement = event.target.enclosingNodeOrSelfWithClass('ax-node'); + var breadcrumbElement = event.target.enclosingNodeOrSelfWithClass('ax-breadcrumb'); if (!breadcrumbElement) { this._setHoveredBreadcrumb(null); return; @@ -176,7 +180,7 @@ * @param {!Event} event */ _onClick(event) { - var breadcrumbElement = event.target.enclosingNodeOrSelfWithClass('ax-node'); + var breadcrumbElement = event.target.enclosingNodeOrSelfWithClass('ax-breadcrumb'); if (!breadcrumbElement) { this._setHoveredBreadcrumb(null); return; @@ -274,22 +278,32 @@ /** @type {!Accessibility.AccessibilityNode} */ this._axNode = axNode; - this._element = createElementWithClass('div', 'ax-node'); + this._element = createElementWithClass('div', 'ax-breadcrumb'); + UI.ARIAUtils.markAsTreeitem(this._element); this._element.breadcrumb = this; + this._nodeElement = createElementWithClass('div', 'ax-node'); + this._element.appendChild(this._nodeElement); + this._nodeWrapper = createElementWithClass('div', 'wrapper'); + this._nodeElement.appendChild(this._nodeWrapper); + this._selectionElement = createElementWithClass('div', 'selection fill'); - this._element.appendChild(this._selectionElement); + this._nodeElement.appendChild(this._selectionElement); - this._nodeWrapper = createElementWithClass('span', 'wrapper'); - this._element.appendChild(this._nodeWrapper); + this._childrenGroupElement = createElementWithClass('div', 'children'); + UI.ARIAUtils.markAsGroup(this._childrenGroupElement); + this._element.appendChild(this._childrenGroupElement); + /** @type !Array<!Accessibility.AXBreadcrumb> */ + this._children = []; this._hovered = false; this._preselected = false; + this._parent = null; this._inspected = inspected; - this.element().classList.toggle('inspected', inspected); + this._nodeElement.classList.toggle('inspected', inspected); - this._element.style.paddingLeft = (16 * depth + 4) + 'px'; + this._nodeElement.style.paddingLeft = (16 * depth + 4) + 'px'; if (this._axNode.ignored()) { this._appendIgnoredNodeElement(); @@ -302,10 +316,10 @@ } if (this._axNode.hasOnlyUnloadedChildren()) - this._element.classList.add('children-unloaded'); + this._nodeElement.classList.add('children-unloaded'); if (!this._axNode.isDOMNode()) - this._element.classList.add('no-dom-node'); + this._nodeElement.classList.add('no-dom-node'); } /** @@ -316,6 +330,24 @@ } /** + * @param {!Accessibility.AXBreadcrumb} breadcrumb + */ + appendChild(breadcrumb) { + this._children.push(breadcrumb); + breadcrumb.setParent(this); + this._nodeElement.classList.add('parent'); + UI.ARIAUtils.setExpanded(this._element, true); + this._childrenGroupElement.appendChild(breadcrumb.element()); + } + + /** + * @param {!Accessibility.AXBreadcrumb} breadcrumb + */ + setParent(breadcrumb) { + this._parent = breadcrumb; + } + + /** * @return {boolean} */ preselected() { @@ -330,14 +362,14 @@ if (this._preselected === preselected) return; this._preselected = preselected; - this.element().classList.toggle('preselected', preselected); + this._nodeElement.classList.toggle('preselected', preselected); if (preselected) - this.element().setAttribute('tabIndex', 0); + this._nodeElement.setAttribute('tabIndex', 0); else - this.element().removeAttribute('tabIndex'); + this._nodeElement.removeAttribute('tabIndex'); if (this._preselected) { if (selectedByUser) - this.element().focus(); + this._nodeElement.focus(); if (!this._inspected) this._axNode.highlightDOMNode(); else @@ -352,9 +384,9 @@ if (this._hovered === hovered) return; this._hovered = hovered; - this.element().classList.toggle('hovered', hovered); + this._nodeElement.classList.toggle('hovered', hovered); if (this._hovered) { - this.element().classList.toggle('hovered', true); + this._nodeElement.classList.toggle('hovered', true); this._axNode.highlightDOMNode(); } } @@ -381,6 +413,29 @@ } /** + * @return {?Accessibility.AXBreadcrumb} + */ + nextBreadcrumb() { + if (this._children.length) + return this._children[0]; + var nextSibling = this.element().nextSibling; + if (nextSibling) + return nextSibling.breadcrumb; + return null; + } + + /** + * @return {?Accessibility.AXBreadcrumb} + */ + previousBreadcrumb() { + var previousSibling = this.element().previousSibling; + if (previousSibling) + return previousSibling.breadcrumb; + + return this._parent; + } + + /** * @param {string} name */ _appendNameElement(name) {
diff --git a/third_party/WebKit/Source/devtools/front_end/bindings/FileUtils.js b/third_party/WebKit/Source/devtools/front_end/bindings/FileUtils.js index 454bdc8..69b9524 100644 --- a/third_party/WebKit/Source/devtools/front_end/bindings/FileUtils.js +++ b/third_party/WebKit/Source/devtools/front_end/bindings/FileUtils.js
@@ -27,27 +27,6 @@ * (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE * OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. */ -/** - * @interface - */ -Bindings.OutputStreamDelegate = function() {}; - -Bindings.OutputStreamDelegate.prototype = { - onTransferStarted() {}, - - onTransferFinished() {}, - - /** - * @param {!Bindings.ChunkedReader} reader - */ - onChunkTransferred(reader) {}, - - /** - * @param {!Bindings.ChunkedReader} reader - * @param {!Event} event - */ - onError(reader, event) {}, -}; /** * @interface @@ -70,7 +49,12 @@ */ fileName() {}, - cancel() {} + cancel() {}, + + /** + * @return {?FileError} + */ + error() {} }; /** @@ -81,29 +65,33 @@ /** * @param {!File} file * @param {number} chunkSize - * @param {!Bindings.OutputStreamDelegate} delegate + * @param {function(!Bindings.ChunkedReader)=} chunkTransferredCallback */ - constructor(file, chunkSize, delegate) { + constructor(file, chunkSize, chunkTransferredCallback) { this._file = file; this._fileSize = file.size; this._loadedSize = 0; this._chunkSize = chunkSize; - this._delegate = delegate; + this._chunkTransferredCallback = chunkTransferredCallback; this._decoder = new TextDecoder(); this._isCanceled = false; + /** @type {?FileError} */ + this._error = null; } /** * @param {!Common.OutputStream} output + * @return {!Promise<boolean>} */ - start(output) { + read(output) { + if (this._chunkTransferredCallback) + this._chunkTransferredCallback(this); this._output = output; - this._reader = new FileReader(); this._reader.onload = this._onChunkLoaded.bind(this); - this._reader.onerror = this._delegate.onError.bind(this._delegate, this); - this._delegate.onTransferStarted(); + this._reader.onerror = this._onError.bind(this); this._loadChunk(); + return new Promise(resolve => this._transferFinished = resolve); } /** @@ -138,6 +126,14 @@ } /** + * @override + * @return {?FileError} + */ + error() { + return this._error; + } + + /** * @param {!Event} event */ _onChunkLoaded(event) { @@ -154,13 +150,14 @@ this._output.write(decodedString); if (this._isCanceled) return; - this._delegate.onChunkTransferred(this); + if (this._chunkTransferredCallback) + this._chunkTransferredCallback(this); if (endOfFile) { this._file = null; this._reader = null; this._output.close(); - this._delegate.onTransferFinished(); + this._transferFinished(!this._error); return; } @@ -173,6 +170,14 @@ var nextPart = this._file.slice(chunkStart, chunkEnd); this._reader.readAsArrayBuffer(nextPart); } + + /** + * @param {!Event} event + */ + _onError(event) { + this._error = event.target.error; + this._transferFinished(false); + } }; /**
diff --git a/third_party/WebKit/Source/devtools/front_end/bindings/TempFile.js b/third_party/WebKit/Source/devtools/front_end/bindings/TempFile.js index 682b71e..1ab0e33 100644 --- a/third_party/WebKit/Source/devtools/front_end/bindings/TempFile.js +++ b/third_party/WebKit/Source/devtools/front_end/bindings/TempFile.js
@@ -143,23 +143,31 @@ /** * @param {!Common.OutputStream} outputStream - * @param {!Bindings.OutputStreamDelegate} delegate + * @param {function(!Bindings.ChunkedReader)=} progress + * @return {!Promise<?FileError>} */ - copyToOutputStream(outputStream, delegate) { - /** - * @param {!File} file - */ - function didGetFile(file) { - var reader = new Bindings.ChunkedFileReader(file, 10 * 1000 * 1000, delegate); - reader.start(outputStream); - } + copyToOutputStream(outputStream, progress) { + return new Promise(resolve => { + this._fileEntry.file(didGetFile, didFailToGetFile); - function didFailToGetFile(error) { - Common.console.error('Failed to load temp file: ' + error.message); - outputStream.close(); - } + /** + * @param {!File} file + */ + async function didGetFile(file) { + var reader = new Bindings.ChunkedFileReader(file, 10 * 1000 * 1000, progress); + var success = await reader.read(outputStream); + resolve(success ? null : reader.error()); + } - this._fileEntry.file(didGetFile, didFailToGetFile); + /** + * @param {!FileError} error + */ + function didFailToGetFile(error) { + Common.console.error('Failed to load temp file: ' + error.message); + outputStream.close(); + resolve(error); + } + }); } remove() { @@ -232,12 +240,12 @@ /** * @param {!Common.OutputStream} outputStream - * @param {!Bindings.OutputStreamDelegate} delegate + * @param {function()=} progress + * @return {!Promise<?FileError>} */ - async copyToOutputStream(outputStream, delegate) { + async copyToOutputStream(outputStream, progress) { await this._writeFinishedPromise; - if (this._tempFile) - this._tempFile.copyToOutputStream(outputStream, delegate); + return this._tempFile ? await this._tempFile.copyToOutputStream(outputStream, progress) : null; } async remove() { @@ -364,11 +372,10 @@ /** * @param {!Common.OutputStream} outputStream - * @param {!Bindings.OutputStreamDelegate} delegate + * @return {!Promise<?FileError>} */ - writeToStream(outputStream, delegate) { - if (this._file) - this._file.copyToOutputStream(outputStream, delegate); + writeToStream(outputStream) { + return this._file ? this._file.copyToOutputStream(outputStream) : Promise.resolve(null); } };
diff --git a/third_party/WebKit/Source/devtools/front_end/network/NetworkPanel.js b/third_party/WebKit/Source/devtools/front_end/network/NetworkPanel.js index 343b688..f490923 100644 --- a/third_party/WebKit/Source/devtools/front_end/network/NetworkPanel.js +++ b/third_party/WebKit/Source/devtools/front_end/network/NetworkPanel.js
@@ -30,7 +30,6 @@ /** * @implements {UI.ContextMenu.Provider} * @implements {UI.Searchable} - * @unrestricted */ Network.NetworkPanel = class extends UI.Panel { constructor() { @@ -42,6 +41,10 @@ this._networkRecordFilmStripSetting = Common.settings.createSetting('networkRecordFilmStripSetting', false); this._toggleRecordAction = /** @type {!UI.Action }*/ (UI.actionRegistry.action('network.toggle-recording')); + /** @type {number|undefined} */ + this._pendingStopTimer; + /** @type {?Network.NetworkItemView} */ + this._networkItemView = null; /** @type {?PerfUI.FilmStripView} */ this._filmStripView = null; /** @type {?Network.NetworkPanel.FilmStripRecorder} */ @@ -93,7 +96,11 @@ this._networkLogLargeRowsSetting.addChangeListener(this._toggleLargerRequests, this); this._networkRecordFilmStripSetting.addChangeListener(this._toggleRecordFilmStrip, this); - this._createToolbarButtons(); + this._preserveLogSetting = Common.moduleSetting('network_log.preserve-log'); + + this._offlineCheckbox = MobileThrottling.throttlingManager().createOfflineToolbarCheckbox(); + this._throttlingSelect = this._createThrottlingConditionsSelect(); + this._setupToolbarButtons(); this._toggleRecord(true); this._toggleShowOverview(); @@ -136,6 +143,20 @@ } /** + * @return {!UI.ToolbarCheckbox} + */ + offlineCheckboxForTest() { + return this._offlineCheckbox; + } + + /** + * @return {!UI.ToolbarComboBox} + */ + throttlingSelectForTest() { + return this._throttlingSelect; + } + + /** * @param {!Common.Event} event */ _onWindowChanged(event) { @@ -144,12 +165,12 @@ this._networkLogView.setWindow(startTime, endTime); } - _createToolbarButtons() { + _setupToolbarButtons() { this._panelToolbar.appendToolbarItem(UI.Toolbar.createActionButton(this._toggleRecordAction)); - this._clearButton = new UI.ToolbarButton(Common.UIString('Clear'), 'largeicon-clear'); - this._clearButton.addEventListener(UI.ToolbarButton.Events.Click, () => NetworkLog.networkLog.reset(), this); - this._panelToolbar.appendToolbarItem(this._clearButton); + var clearButton = new UI.ToolbarButton(Common.UIString('Clear'), 'largeicon-clear'); + clearButton.addEventListener(UI.ToolbarButton.Events.Click, () => NetworkLog.networkLog.reset(), this); + this._panelToolbar.appendToolbarItem(clearButton); this._panelToolbar.appendSeparator(); var recordFilmStripButton = new UI.ToolbarSettingToggle( this._networkRecordFilmStripSetting, 'largeicon-camera', Common.UIString('Capture screenshots')); @@ -176,20 +197,17 @@ } this._panelToolbar.appendSeparator(); - this._preserveLogSetting = Common.moduleSetting('network_log.preserve-log'); this._panelToolbar.appendToolbarItem(new UI.ToolbarSettingCheckbox( this._preserveLogSetting, Common.UIString('Do not clear log on page reload / navigation'), Common.UIString('Preserve log'))); - this._disableCacheCheckbox = new UI.ToolbarSettingCheckbox( + var disableCacheCheckbox = new UI.ToolbarSettingCheckbox( Common.moduleSetting('cacheDisabled'), Common.UIString('Disable cache (while DevTools is open)'), Common.UIString('Disable cache')); - this._panelToolbar.appendToolbarItem(this._disableCacheCheckbox); + this._panelToolbar.appendToolbarItem(disableCacheCheckbox); this._panelToolbar.appendSeparator(); - this._offlineCheckbox = MobileThrottling.throttlingManager().createOfflineToolbarCheckbox(); this._panelToolbar.appendToolbarItem(this._offlineCheckbox); - this._throttlingSelect = this._createThrottlingConditionsSelect(); this._panelToolbar.appendToolbarItem(this._throttlingSelect); this._panelToolbar.appendToolbarItem(new UI.ToolbarItem(this._progressBarContainer)); @@ -609,7 +627,6 @@ /** * @implements {SDK.TracingManagerClient} - * @unrestricted */ Network.NetworkPanel.FilmStripRecorder = class { /** @@ -623,6 +640,10 @@ this._resourceTreeModel = null; this._timeCalculator = timeCalculator; this._filmStripView = filmStripView; + /** @type {?SDK.TracingModel} */ + this._tracingModel = null; + /** @type {?function(?SDK.FilmStripModel)} */ + this._callback = null; } /** @@ -643,7 +664,7 @@ this._tracingModel.tracingComplete(); this._tracingManager = null; this._callback(new SDK.FilmStripModel(this._tracingModel, this._timeCalculator.minimumBoundary() * 1000)); - delete this._callback; + this._callback = null; if (this._resourceTreeModel) this._resourceTreeModel.resumeReload(); this._resourceTreeModel = null; @@ -672,9 +693,8 @@ this._tracingManager = tracingManagers[0]; this._resourceTreeModel = this._tracingManager.target().model(SDK.ResourceTreeModel); if (this._tracingModel) - this._tracingModel.reset(); - else - this._tracingModel = new SDK.TracingModel(new Bindings.TempFileBackingStorage('tracing')); + this._tracingModel.dispose(); + this._tracingModel = new SDK.TracingModel(new Bindings.TempFileBackingStorage('tracing')); this._tracingManager.start(this, '-*,disabled-by-default-devtools.screenshot', ''); } @@ -702,7 +722,6 @@ /** * @implements {UI.ActionDelegate} - * @unrestricted */ Network.NetworkPanel.RecordActionDelegate = class { /**
diff --git a/third_party/WebKit/Source/devtools/front_end/perf_ui/ChartViewport.js b/third_party/WebKit/Source/devtools/front_end/perf_ui/ChartViewport.js index 21633d5..c0678642 100644 --- a/third_party/WebKit/Source/devtools/front_end/perf_ui/ChartViewport.js +++ b/third_party/WebKit/Source/devtools/front_end/perf_ui/ChartViewport.js
@@ -325,6 +325,13 @@ } /** + * @return {number} + */ + timeToPixel() { + return this._offsetWidth / (this._timeWindowRight - this._timeWindowLeft); + } + + /** * @param {boolean} visible */ _showCursor(visible) {
diff --git a/third_party/WebKit/Source/devtools/front_end/perf_ui/FlameChart.js b/third_party/WebKit/Source/devtools/front_end/perf_ui/FlameChart.js index 4efe917..c99673d 100644 --- a/third_party/WebKit/Source/devtools/front_end/perf_ui/FlameChart.js +++ b/third_party/WebKit/Source/devtools/front_end/perf_ui/FlameChart.js
@@ -642,6 +642,7 @@ var entryTotalTimes = timelineData.entryTotalTimes; var entryStartTimes = timelineData.entryStartTimes; var entryLevels = timelineData.entryLevels; + var timeToPixel = this._chartViewport.timeToPixel(); var titleIndices = []; var markerIndices = []; @@ -745,7 +746,7 @@ var unclippedBarX = this._chartViewport.timeToPosition(entryStartTime); var barHeight = this._levelHeight(barLevel); if (this._dataProvider.decorateEntry( - entryIndex, context, text, barX, barY, barWidth, barHeight, unclippedBarX, this._timeToPixel)) + entryIndex, context, text, barX, barY, barWidth, barHeight, unclippedBarX, timeToPixel)) continue; if (!text || !text.length) continue; @@ -935,6 +936,7 @@ var barHeight = group.style.height; var entryStartTimes = this._rawTimelineData.entryStartTimes; var entryTotalTimes = this._rawTimelineData.entryTotalTimes; + var timeToPixel = this._chartViewport.timeToPixel(); for (var level = group.startLevel; level < endLevel; ++level) { var levelIndexes = this._timelineLevels[level]; @@ -961,7 +963,7 @@ context.fillStyle = color; context.fillRect(barX, y, barWidth, barHeight - 1); this._dataProvider.decorateEntry( - entryIndex, context, '', barX, y, barWidth, barHeight, unclippedBarX, this._timeToPixel); + entryIndex, context, '', barX, y, barWidth, barHeight, unclippedBarX, timeToPixel); continue; } range.append(new Common.Segment(barX, endBarX, color)); @@ -1065,6 +1067,7 @@ var markers = this._timelineData().markers; var left = this._markerIndexBeforeTime(this._calculator.minimumBoundary()); var rightBoundary = this._calculator.maximumBoundary(); + var timeToPixel = this._chartViewport.timeToPixel(); var context = /** @type {!CanvasRenderingContext2D} */ (this._canvas.getContext('2d')); context.save(); @@ -1076,7 +1079,7 @@ var timestamp = markers[i].startTime(); if (timestamp > rightBoundary) break; - markers[i].draw(context, this._calculator.computePosition(timestamp), height, this._timeToPixel); + markers[i].draw(context, this._calculator.computePosition(timestamp), height, timeToPixel); } context.restore(); } @@ -1306,9 +1309,6 @@ var totalPixels = Math.floor(this._offsetWidth / windowWidth); this._pixelWindowLeft = Math.floor(totalPixels * this._windowLeft); - this._timeToPixel = totalPixels / this._totalTime; - this._pixelToTime = this._totalTime / totalPixels; - this._chartViewport.setBoundaries(this._minimumBoundary, this._totalTime); } @@ -1487,10 +1487,10 @@ * @param {number} barWidth * @param {number} barHeight * @param {number} unclippedBarX - * @param {number} timeToPixels + * @param {number} timeToPixelRatio * @return {boolean} */ - decorateEntry(entryIndex, context, text, barX, barY, barWidth, barHeight, unclippedBarX, timeToPixels) {}, + decorateEntry(entryIndex, context, text, barX, barY, barWidth, barHeight, unclippedBarX, timeToPixelRatio) {}, /** * @param {number} entryIndex
diff --git a/third_party/WebKit/Source/devtools/front_end/profiler/HeapSnapshotView.js b/third_party/WebKit/Source/devtools/front_end/profiler/HeapSnapshotView.js index b4ba48f..04707a9 100644 --- a/third_party/WebKit/Source/devtools/front_end/profiler/HeapSnapshotView.js +++ b/third_party/WebKit/Source/devtools/front_end/profiler/HeapSnapshotView.js
@@ -1316,6 +1316,8 @@ this._loadPromise = new Promise(resolve => this._fulfillLoad = resolve); this._totalNumberOfChunks = 0; this._bufferedWriter = null; + /** @type {?Bindings.TempFile} */ + this._tempFile = null; } /** @@ -1359,6 +1361,9 @@ this._didWriteToTempFile(file); } + /** + * @param {!Bindings.TempFile} tempFile + */ _didWriteToTempFile(tempFile) { if (this._wasDisposed) { if (tempFile) @@ -1470,25 +1475,39 @@ * @param {boolean} accepted * @this {Profiler.HeapProfileHeader} */ - function onOpen(accepted) { + async function onOpen(accepted) { if (!accepted) return; - if (this._failedToCreateTempFile) { Common.console.error('Failed to open temp file with heap snapshot'); fileOutputStream.close(); - } else if (this._tempFile) { - var delegate = new Profiler.SaveSnapshotOutputStreamDelegate(this); - this._tempFile.copyToOutputStream(fileOutputStream, delegate); - } else { - this._onTempFileReady = onOpen.bind(this, accepted); - this._updateSaveProgress(0, 1); + return; } + if (this._tempFile) { + var error = await this._tempFile.copyToOutputStream(fileOutputStream, this._onChunkTransferred.bind(this)); + if (error) + Common.console.error('Failed to read heap snapshot from temp file: ' + error.message); + this._didCompleteSnapshotTransfer(); + return; + } + this._onTempFileReady = onOpen.bind(this, accepted); + this._updateSaveProgress(0, 1); } } + /** + * @param {!Bindings.ChunkedReader} reader + */ + _onChunkTransferred(reader) { + this._updateSaveProgress(reader.loadedSize(), reader.fileSize()); + } + + /** + * @param {number} value + * @param {number} total + */ _updateSaveProgress(value, total) { - var percentValue = ((total ? (value / total) : 0) * 100).toFixed(0); + var percentValue = ((total && value / total) * 100).toFixed(0); this.updateStatus(Common.UIString('Saving\u2026 %d%%', percentValue)); } @@ -1496,119 +1515,13 @@ * @override * @param {!File} file */ - loadFromFile(file) { + async loadFromFile(file) { this.updateStatus(Common.UIString('Loading\u2026'), true); this._setupWorker(); - var delegate = new Profiler.HeapSnapshotLoadFromFileDelegate(this); - var fileReader = this._createFileReader(file, delegate); - fileReader.start(/** @type {!Common.OutputStream} */ (this._receiver)); - } - - /** - * @param {!File} file - * @param {!Profiler.HeapSnapshotLoadFromFileDelegate} delegate - * @return {!Bindings.ChunkedFileReader} - */ - _createFileReader(file, delegate) { - return new Bindings.ChunkedFileReader(file, 10000000, delegate); - } -}; - -/** - * @implements {Bindings.OutputStreamDelegate} - * @unrestricted - */ -Profiler.HeapSnapshotLoadFromFileDelegate = class { - /** - * @param {!Profiler.HeapProfileHeader} snapshotHeader - */ - constructor(snapshotHeader) { - this._snapshotHeader = snapshotHeader; - } - - /** - * @override - */ - onTransferStarted() { - } - - /** - * @override - * @param {!Bindings.ChunkedReader} reader - */ - onChunkTransferred(reader) { - } - - /** - * @override - */ - onTransferFinished() { - } - - /** - * @override - * @param {!Bindings.ChunkedReader} reader - * @param {!Event} e - */ - onError(reader, e) { - var subtitle; - switch (e.target.error.code) { - case e.target.error.NOT_FOUND_ERR: - subtitle = Common.UIString('\'%s\' not found.', reader.fileName()); - break; - case e.target.error.NOT_READABLE_ERR: - subtitle = Common.UIString('\'%s\' is not readable', reader.fileName()); - break; - case e.target.error.ABORT_ERR: - return; - default: - subtitle = Common.UIString('\'%s\' error %d', reader.fileName(), e.target.error.code); - } - this._snapshotHeader.updateStatus(subtitle); - } -}; - -/** - * @implements {Bindings.OutputStreamDelegate} - */ -Profiler.SaveSnapshotOutputStreamDelegate = class { - /** - * @param {!Profiler.HeapProfileHeader} profileHeader - */ - constructor(profileHeader) { - this._profileHeader = profileHeader; - } - - /** - * @override - */ - onTransferStarted() { - this._profileHeader._updateSaveProgress(0, 1); - } - - /** - * @override - */ - onTransferFinished() { - this._profileHeader._didCompleteSnapshotTransfer(); - } - - /** - * @override - * @param {!Bindings.ChunkedReader} reader - */ - onChunkTransferred(reader) { - this._profileHeader._updateSaveProgress(reader.loadedSize(), reader.fileSize()); - } - - /** - * @override - * @param {!Bindings.ChunkedReader} reader - * @param {!Event} event - */ - onError(reader, event) { - Common.console.error('Failed to read heap snapshot from temp file: ' + /** @type {!ErrorEvent} */ (event).message); - this.onTransferFinished(); + var reader = new Bindings.ChunkedFileReader(file, 10000000); + var success = await reader.read(/** @type {!Common.OutputStream} */ (this._receiver)); + if (!success) + this.updateStatus(reader.error().message); } };
diff --git a/third_party/WebKit/Source/devtools/front_end/profiler/ProfileHeader.js b/third_party/WebKit/Source/devtools/front_end/profiler/ProfileHeader.js index 6dd2a45..08f9dd0 100644 --- a/third_party/WebKit/Source/devtools/front_end/profiler/ProfileHeader.js +++ b/third_party/WebKit/Source/devtools/front_end/profiler/ProfileHeader.js
@@ -40,7 +40,7 @@ * @return {!Profiler.ProfileSidebarTreeElement} */ createSidebarTreeElement(dataDisplayDelegate) { - throw new Error('Needs implemented.'); + throw new Error('Not implemented.'); } /** @@ -67,14 +67,14 @@ } saveToFile() { - throw new Error('Needs implemented'); + throw new Error('Not implemented'); } /** * @param {!File} file */ loadFromFile(file) { - throw new Error('Needs implemented'); + throw new Error('Not implemented'); } /**
diff --git a/third_party/WebKit/Source/devtools/front_end/profiler/ProfileView.js b/third_party/WebKit/Source/devtools/front_end/profiler/ProfileView.js index 9f7df63..66840ef 100644 --- a/third_party/WebKit/Source/devtools/front_end/profiler/ProfileView.js +++ b/third_party/WebKit/Source/devtools/front_end/profiler/ProfileView.js
@@ -383,7 +383,6 @@ /** * @implements {Common.OutputStream} - * @implements {Bindings.OutputStreamDelegate} * @unrestricted */ Profiler.WritableProfileHeader = class extends Profiler.ProfileHeader { @@ -399,54 +398,17 @@ } /** - * @override - */ - onTransferStarted() { - this._jsonifiedProfile = ''; - this.updateStatus(Common.UIString('Loading\u2026 %s', Number.bytesToString(this._jsonifiedProfile.length)), true); - } - - /** - * @override * @param {!Bindings.ChunkedReader} reader */ - onChunkTransferred(reader) { + _onChunkTransferred(reader) { this.updateStatus(Common.UIString('Loading\u2026 %d%%', Number.bytesToString(this._jsonifiedProfile.length))); } /** - * @override - */ - onTransferFinished() { - this.updateStatus(Common.UIString('Parsing\u2026'), true); - this._profile = JSON.parse(this._jsonifiedProfile); - this._jsonifiedProfile = null; - this.updateStatus(Common.UIString('Loaded'), false); - - if (this.profileType().profileBeingRecorded() === this) - this.profileType().setProfileBeingRecorded(null); - } - - /** - * @override * @param {!Bindings.ChunkedReader} reader - * @param {!Event} e */ - onError(reader, e) { - var subtitle; - switch (e.target.error.code) { - case e.target.error.NOT_FOUND_ERR: - subtitle = Common.UIString('\'%s\' not found.', reader.fileName()); - break; - case e.target.error.NOT_READABLE_ERR: - subtitle = Common.UIString('\'%s\' is not readable', reader.fileName()); - break; - case e.target.error.ABORT_ERR: - return; - default: - subtitle = Common.UIString('\'%s\' error %d', reader.fileName(), e.target.error.code); - } - this.updateStatus(subtitle); + _onError(reader) { + this.updateStatus(Common.UIString(`File '%s' read error: %s`, reader.fileName(), reader.error().message)); } /** @@ -522,10 +484,24 @@ * @override * @param {!File} file */ - loadFromFile(file) { + async loadFromFile(file) { this.updateStatus(Common.UIString('Loading\u2026'), true); - var fileReader = new Bindings.ChunkedFileReader(file, 10000000, this); - fileReader.start(this); + var fileReader = new Bindings.ChunkedFileReader(file, 10000000, this._onChunkTransferred.bind(this)); + this._jsonifiedProfile = ''; + + var success = await fileReader.read(this); + if (!success) { + this._onError(fileReader); + return; + } + + this.updateStatus(Common.UIString('Parsing\u2026'), true); + this._profile = JSON.parse(this._jsonifiedProfile); + this._jsonifiedProfile = null; + this.updateStatus(Common.UIString('Loaded'), false); + + if (this.profileType().profileBeingRecorded() === this) + this.profileType().setProfileBeingRecorded(null); } /**
diff --git a/third_party/WebKit/Source/devtools/front_end/profiler/ProfilesPanel.js b/third_party/WebKit/Source/devtools/front_end/profiler/ProfilesPanel.js index 5829c1f..29059af 100644 --- a/third_party/WebKit/Source/devtools/front_end/profiler/ProfilesPanel.js +++ b/third_party/WebKit/Source/devtools/front_end/profiler/ProfilesPanel.js
@@ -159,13 +159,13 @@ continue; extensions.push(extension); } - Common.console.error(Common.UIString( - 'Can\'t load file. Only files with extensions \'%s\' can be loaded.', extensions.join('\', \''))); + Common.console.error( + Common.UIString(`Can't load file. Only files with extensions '%s' can be loaded.`, extensions.join(`', '`))); return; } if (!!profileType.profileBeingRecorded()) { - Common.console.error(Common.UIString('Can\'t load profile while another profile is recording.')); + Common.console.error(Common.UIString(`Can't load profile while another profile is being recorded.`)); return; }
diff --git a/third_party/WebKit/Source/devtools/front_end/timeline/PerformanceModel.js b/third_party/WebKit/Source/devtools/front_end/timeline/PerformanceModel.js index e9139e4..14a1fa12 100644 --- a/third_party/WebKit/Source/devtools/front_end/timeline/PerformanceModel.js +++ b/third_party/WebKit/Source/devtools/front_end/timeline/PerformanceModel.js
@@ -154,11 +154,11 @@ /** * @param {!Common.OutputStream} stream - * @param {!Bindings.OutputStreamDelegate} delegate + * @return {!Promise<?FileError>} */ - save(stream, delegate) { + save(stream) { var backingStorage = /** @type {!Bindings.TempFileBackingStorage} */ (this._tracingModel.backingStorage()); - backingStorage.writeToStream(stream, delegate); + return backingStorage.writeToStream(stream); } };
diff --git a/third_party/WebKit/Source/devtools/front_end/timeline/TimelineLoader.js b/third_party/WebKit/Source/devtools/front_end/timeline/TimelineLoader.js index 3f0e016..2c4ae84 100644 --- a/third_party/WebKit/Source/devtools/front_end/timeline/TimelineLoader.js +++ b/third_party/WebKit/Source/devtools/front_end/timeline/TimelineLoader.js
@@ -1,9 +1,9 @@ // Copyright 2016 The Chromium Authors. All rights reserved. // Use of this source code is governed by a BSD-style license that can be // found in the LICENSE file. + /** * @implements {Common.OutputStream} - * @implements {Bindings.OutputStreamDelegate} * @unrestricted */ Timeline.TimelineLoader = class { @@ -22,7 +22,6 @@ this._buffer = ''; this._firstRawChunk = true; this._firstChunk = true; - this._loadedBytes = 0; /** @type {number} */ this._totalSize; @@ -36,10 +35,13 @@ */ static loadFromFile(file, client) { var loader = new Timeline.TimelineLoader(client); - var fileReader = Timeline.TimelineLoader._createFileReader(file, loader); + var fileReader = new Bindings.ChunkedFileReader(file, Timeline.TimelineLoader.TransferChunkLengthBytes); loader._canceledCallback = fileReader.cancel.bind(fileReader); loader._totalSize = file.size; - fileReader.start(loader); + fileReader.read(loader).then(success => { + if (!success) + this._reportErrorAndCancelLoading(fileReader.error().message); + }); return loader; } @@ -49,18 +51,9 @@ * @return {!Timeline.TimelineLoader} */ static loadFromURL(url, client) { - var stream = new Timeline.TimelineLoader(client); - Host.ResourceLoader.loadAsStream(url, null, stream); - return stream; - } - - /** - * @param {!File} file - * @param {!Bindings.OutputStreamDelegate} delegate - * @return {!Bindings.ChunkedReader} - */ - static _createFileReader(file, delegate) { - return new Bindings.ChunkedFileReader(file, Timeline.TimelineLoader.TransferChunkLengthBytes, delegate); + var loader = new Timeline.TimelineLoader(client); + Host.ResourceLoader.loadAsStream(url, null, loader); + return loader; } cancel() { @@ -199,46 +192,6 @@ } /** - * @override - */ - onTransferStarted() { - } - - /** - * @override - * @param {!Bindings.ChunkedReader} reader - */ - onChunkTransferred(reader) { - } - - /** - * @override - */ - onTransferFinished() { - } - - /** - * @override - * @param {!Bindings.ChunkedReader} reader - * @param {!Event} event - */ - onError(reader, event) { - switch (event.target.error.name) { - case 'NotFoundError': - this._reportErrorAndCancelLoading(Common.UIString('File "%s" not found.', reader.fileName())); - break; - case 'NotReadableError': - this._reportErrorAndCancelLoading(Common.UIString('File "%s" is not readable', reader.fileName())); - break; - case 'AbortError': - break; - default: - this._reportErrorAndCancelLoading( - Common.UIString('An error occurred while reading the file "%s"', reader.fileName())); - } - } - - /** * @param {string} text */ _parseCPUProfileFormat(text) { @@ -288,39 +241,3 @@ SkippingTail: Symbol('SkippingTail'), LoadingCPUProfileFormat: Symbol('LoadingCPUProfileFormat') }; - -/** - * @implements {Bindings.OutputStreamDelegate} - * @unrestricted - */ -Timeline.TracingTimelineSaver = class { - /** - * @override - */ - onTransferStarted() { - } - - /** - * @override - */ - onTransferFinished() { - } - - /** - * @override - * @param {!Bindings.ChunkedReader} reader - */ - onChunkTransferred(reader) { - } - - /** - * @override - * @param {!Bindings.ChunkedReader} reader - * @param {!Event} event - */ - onError(reader, event) { - var error = event.target.error; - Common.console.error( - Common.UIString('Failed to save timeline: %s (%s, %s)', error.message, error.name, error.code)); - } -};
diff --git a/third_party/WebKit/Source/devtools/front_end/timeline/TimelinePanel.js b/third_party/WebKit/Source/devtools/front_end/timeline/TimelinePanel.js index efd952c7..5a66f66f 100644 --- a/third_party/WebKit/Source/devtools/front_end/timeline/TimelinePanel.js +++ b/third_party/WebKit/Source/devtools/front_end/timeline/TimelinePanel.js
@@ -365,7 +365,11 @@ if (!accepted) return; - performanceModel.save(stream, new Timeline.TracingTimelineSaver()); + var error = await performanceModel.save(stream); + if (!error) + return; + Common.console.error( + Common.UIString('Failed to save timeline: %s (%s, %s)', error.message, error.name, error.code)); } async _showHistory() { @@ -387,12 +391,8 @@ return true; } - /** - * @return {boolean} - */ _selectFileToLoad() { this._fileSelectorElement.click(); - return true; } /**
diff --git a/third_party/WebKit/Source/devtools/front_end/timeline_model/TimelineJSProfile.js b/third_party/WebKit/Source/devtools/front_end/timeline_model/TimelineJSProfile.js index 0d15c58..d664afff 100644 --- a/third_party/WebKit/Source/devtools/front_end/timeline_model/TimelineJSProfile.js +++ b/third_party/WebKit/Source/devtools/front_end/timeline_model/TimelineJSProfile.js
@@ -143,18 +143,21 @@ function filterStackFrames(stack) { if (showAllEvents) return; - var isPreviousFrameNative = false; + var previousNativeFrameName = null; for (var i = 0, j = 0; i < stack.length; ++i) { const frame = stack[i]; const url = frame.url; const isNativeFrame = url && url.startsWith('native '); if (!showNativeFunctions && isNativeFrame) continue; - if (TimelineModel.TimelineJSProfileProcessor.isNativeRuntimeFrame(frame) && !showNativeName(frame.functionName)) + var isNativeRuntimeFrame = TimelineModel.TimelineJSProfileProcessor.isNativeRuntimeFrame(frame); + if (isNativeRuntimeFrame && !showNativeName(frame.functionName)) continue; - if (isPreviousFrameNative && isNativeFrame) + var nativeFrameName = + isNativeRuntimeFrame ? TimelineModel.TimelineJSProfileProcessor.nativeGroup(frame.functionName) : null; + if (previousNativeFrameName && previousNativeFrameName === nativeFrameName) continue; - isPreviousFrameNative = isNativeFrame; + previousNativeFrameName = nativeFrameName; stack[j++] = frame; } stack.length = j; @@ -214,22 +217,11 @@ * @return {?TimelineModel.TimelineJSProfileProcessor.NativeGroups} */ static nativeGroup(nativeName) { - var map = TimelineModel.TimelineJSProfileProcessor.nativeGroup._map; - if (!map) { - const nativeGroups = TimelineModel.TimelineJSProfileProcessor.NativeGroups; - map = new Map([ - ['Compile', nativeGroups.Compile], ['CompileCode', nativeGroups.Compile], - ['CompileCodeLazy', nativeGroups.Compile], ['CompileDeserialize', nativeGroups.Compile], - ['CompileEval', nativeGroups.Compile], ['CompileFullCode', nativeGroups.Compile], - ['CompileIgnition', nativeGroups.Compile], ['CompilerDispatcher', nativeGroups.Compile], - ['CompileSerialize', nativeGroups.Compile], ['ParseProgram', nativeGroups.Parse], - ['ParseFunction', nativeGroups.Parse], ['RecompileConcurrent', nativeGroups.Compile], - ['RecompileSynchronous', nativeGroups.Compile], ['ParseLazy', nativeGroups.Parse] - ]); - /** @type {!Map<string, !TimelineModel.TimelineJSProfileProcessor.NativeGroups>} */ - TimelineModel.TimelineJSProfileProcessor.nativeGroup._map = map; - } - return map.get(nativeName) || null; + if (nativeName.startsWith('Parse')) + return TimelineModel.TimelineJSProfileProcessor.NativeGroups.Parse; + if (nativeName.startsWith('Compile') || nativeName.startsWith('Recompile')) + return TimelineModel.TimelineJSProfileProcessor.NativeGroups.Compile; + return null; } /**
diff --git a/third_party/WebKit/Source/devtools/front_end/ui/textButton.css b/third_party/WebKit/Source/devtools/front_end/ui/textButton.css index 0cb514c..2d40651 100644 --- a/third_party/WebKit/Source/devtools/front_end/ui/textButton.css +++ b/third_party/WebKit/Source/devtools/front_end/ui/textButton.css
@@ -10,7 +10,7 @@ font-size: 12px; border: 1px solid rgba(0, 0, 0, 0.2); border-radius: 2px; - padding: 3px 12px; + padding: 0px 12px; font-weight: 500; color: #333; background-color: #fff;
diff --git a/third_party/WebKit/Source/modules/accessibility/AXMediaControls.cpp b/third_party/WebKit/Source/modules/accessibility/AXMediaControls.cpp index 4446167..7058ede 100644 --- a/third_party/WebKit/Source/modules/accessibility/AXMediaControls.cpp +++ b/third_party/WebKit/Source/modules/accessibility/AXMediaControls.cpp
@@ -28,8 +28,10 @@ #include "modules/accessibility/AXMediaControls.h" +#include "core/html/HTMLInputElement.h" #include "core/layout/LayoutObject.h" #include "modules/accessibility/AXObjectCacheImpl.h" +#include "modules/media_controls/elements/MediaControlElementsHelper.h" #include "modules/media_controls/elements/MediaControlTimeDisplayElement.h" #include "platform/text/PlatformLocale.h" @@ -52,7 +54,8 @@ AXObjectCacheImpl& ax_object_cache) { DCHECK(layout_object->GetNode()); - switch (GetMediaControlElementType(layout_object->GetNode())) { + switch (MediaControlElementsHelper::GetMediaControlElementType( + layout_object->GetNode())) { case kMediaSlider: return AccessibilityMediaTimeline::Create(layout_object, ax_object_cache); @@ -98,7 +101,8 @@ if (!GetLayoutObject() || !GetLayoutObject()->GetNode()) return kMediaTimelineContainer; // Timeline container is not accessible. - return GetMediaControlElementType(GetLayoutObject()->GetNode()); + return MediaControlElementsHelper::GetMediaControlElementType( + GetLayoutObject()->GetNode()); } String AccessibilityMediaControl::TextAlternative(
diff --git a/third_party/WebKit/Source/modules/accessibility/AXMediaControls.h b/third_party/WebKit/Source/modules/accessibility/AXMediaControls.h index 07b70bf..10324d4 100644 --- a/third_party/WebKit/Source/modules/accessibility/AXMediaControls.h +++ b/third_party/WebKit/Source/modules/accessibility/AXMediaControls.h
@@ -29,8 +29,8 @@ #ifndef AXMediaControls_h #define AXMediaControls_h -#include "core/html/shadow/MediaControlElementTypes.h" #include "modules/accessibility/AXSlider.h" +#include "modules/media_controls/elements/MediaControlElementType.h" namespace blink {
diff --git a/third_party/WebKit/Source/modules/accessibility/AXNodeObject.cpp b/third_party/WebKit/Source/modules/accessibility/AXNodeObject.cpp index b806d32..54059b9 100644 --- a/third_party/WebKit/Source/modules/accessibility/AXNodeObject.cpp +++ b/third_party/WebKit/Source/modules/accessibility/AXNodeObject.cpp
@@ -63,11 +63,11 @@ #include "core/html/TextControlElement.h" #include "core/html/forms/RadioInputType.h" #include "core/html/parser/HTMLParserIdioms.h" -#include "core/html/shadow/MediaControlElementTypes.h" #include "core/layout/LayoutBlockFlow.h" #include "core/layout/LayoutObject.h" #include "core/svg/SVGElement.h" #include "modules/accessibility/AXObjectCacheImpl.h" +#include "modules/media_controls/elements/MediaControlElementsHelper.h" #include "platform/text/PlatformLocale.h" #include "platform/weborigin/KURL.h" #include "platform/wtf/text/StringBuilder.h" @@ -1076,7 +1076,8 @@ if (!node) return true; - return isHTMLVideoElement(ToParentMediaElement(node)); + return isHTMLVideoElement( + MediaControlElementsHelper::ToParentMediaElement(node)); } bool AXNodeObject::IsEmbeddedObject() const {
diff --git a/third_party/WebKit/Source/modules/bluetooth/Bluetooth.cpp b/third_party/WebKit/Source/modules/bluetooth/Bluetooth.cpp index 4b5f89b..dd2ba69 100644 --- a/third_party/WebKit/Source/modules/bluetooth/Bluetooth.cpp +++ b/third_party/WebKit/Source/modules/bluetooth/Bluetooth.cpp
@@ -20,8 +20,8 @@ #include "modules/bluetooth/BluetoothRemoteGATTCharacteristic.h" #include "modules/bluetooth/BluetoothUUID.h" #include "modules/bluetooth/RequestDeviceOptions.h" -#include "public/platform/InterfaceProvider.h" #include "public/platform/Platform.h" +#include "services/service_manager/public/cpp/interface_provider.h" namespace blink { @@ -171,16 +171,11 @@ "Must be handling a user gesture to show a permission request.")); } - if (!service_) { - InterfaceProvider* interface_provider = nullptr; - if (context->IsDocument()) { - Document* document = ToDocument(context); - if (document->GetFrame()) - interface_provider = document->GetFrame()->GetInterfaceProvider(); + if (!service_ && context->IsDocument()) { + LocalFrame* frame = ToDocument(context)->GetFrame(); + if (frame) { + frame->GetInterfaceProvider().GetInterface(mojo::MakeRequest(&service_)); } - - if (interface_provider) - interface_provider->GetInterface(mojo::MakeRequest(&service_)); } if (!service_) {
diff --git a/third_party/WebKit/Source/modules/canvas2d/CanvasRenderingContext2DTest.cpp b/third_party/WebKit/Source/modules/canvas2d/CanvasRenderingContext2DTest.cpp index af5bee2..6eef0d9e 100644 --- a/third_party/WebKit/Source/modules/canvas2d/CanvasRenderingContext2DTest.cpp +++ b/third_party/WebKit/Source/modules/canvas2d/CanvasRenderingContext2DTest.cpp
@@ -199,9 +199,8 @@ void CanvasRenderingContext2DTest::SetUp() { Page::PageClients page_clients; FillWithEmptyClients(page_clients); - dummy_page_holder_ = - DummyPageHolder::Create(IntSize(800, 600), &page_clients, nullptr, - override_settings_function_, nullptr); + dummy_page_holder_ = DummyPageHolder::Create( + IntSize(800, 600), &page_clients, nullptr, override_settings_function_); document_ = &dummy_page_holder_->GetDocument(); document_->documentElement()->setInnerHTML( "<body><canvas id='c'></canvas></body>");
diff --git a/third_party/WebKit/Source/modules/exported/WebEmbeddedWorkerImpl.cpp b/third_party/WebKit/Source/modules/exported/WebEmbeddedWorkerImpl.cpp index 48ea22b2..1e29852 100644 --- a/third_party/WebKit/Source/modules/exported/WebEmbeddedWorkerImpl.cpp +++ b/third_party/WebKit/Source/modules/exported/WebEmbeddedWorkerImpl.cpp
@@ -68,7 +68,6 @@ #include "platform/weborigin/SecurityOrigin.h" #include "platform/wtf/Functional.h" #include "platform/wtf/PtrUtil.h" -#include "public/platform/Platform.h" #include "public/platform/WebContentSettingsClient.h" #include "public/platform/WebURLRequest.h" #include "public/platform/WebWorkerFetchContext.h" @@ -298,7 +297,7 @@ settings->SetAllowRunningOfInsecureContent(false); settings->SetDataSaverEnabled(worker_start_data_.data_saver_enabled); main_frame_ = WebFactory::GetInstance().CreateMainWebLocalFrameBase( - web_view_, this, nullptr, nullptr); + web_view_, this, nullptr); main_frame_->SetDevToolsAgentClient(this); // If we were asked to wait for debugger then it is the good time to do that.
diff --git a/third_party/WebKit/Source/modules/geolocation/Geolocation.cpp b/third_party/WebKit/Source/modules/geolocation/Geolocation.cpp index a49fea9..fba227d 100644 --- a/third_party/WebKit/Source/modules/geolocation/Geolocation.cpp +++ b/third_party/WebKit/Source/modules/geolocation/Geolocation.cpp
@@ -40,8 +40,8 @@ #include "modules/permissions/PermissionUtils.h" #include "platform/wtf/Assertions.h" #include "platform/wtf/CurrentTime.h" -#include "public/platform/InterfaceProvider.h" #include "public/platform/Platform.h" +#include "services/service_manager/public/cpp/interface_provider.h" namespace blink { namespace { @@ -446,7 +446,7 @@ return; geolocation_permission_ = kPermissionRequested; - frame->GetInterfaceProvider()->GetInterface( + frame->GetInterfaceProvider().GetInterface( mojo::MakeRequest(&permission_service_)); permission_service_.set_connection_error_handler( ConvertToBaseCallback(WTF::Bind(&Geolocation::OnPermissionConnectionError, @@ -518,7 +518,7 @@ if (geolocation_service_) return; - GetFrame()->GetInterfaceProvider()->GetInterface( + GetFrame()->GetInterfaceProvider().GetInterface( mojo::MakeRequest(&geolocation_service_)); geolocation_service_.set_connection_error_handler(ConvertToBaseCallback( WTF::Bind(&Geolocation::OnGeolocationConnectionError,
diff --git a/third_party/WebKit/Source/modules/imagecapture/ImageCapture.cpp b/third_party/WebKit/Source/modules/imagecapture/ImageCapture.cpp index 00f836c1..fea051f 100644 --- a/third_party/WebKit/Source/modules/imagecapture/ImageCapture.cpp +++ b/third_party/WebKit/Source/modules/imagecapture/ImageCapture.cpp
@@ -24,6 +24,7 @@ #include "public/platform/Platform.h" #include "public/platform/WebImageCaptureFrameGrabber.h" #include "public/platform/WebMediaStreamTrack.h" +#include "services/service_manager/public/cpp/interface_provider.h" namespace blink { @@ -623,8 +624,7 @@ DCHECK(stream_track_); DCHECK(!service_.is_bound()); - GetFrame()->GetInterfaceProvider()->GetInterface( - mojo::MakeRequest(&service_)); + GetFrame()->GetInterfaceProvider().GetInterface(mojo::MakeRequest(&service_)); service_.set_connection_error_handler(ConvertToBaseCallback(WTF::Bind( &ImageCapture::OnServiceConnectionError, WrapWeakPersistent(this))));
diff --git a/third_party/WebKit/Source/modules/installedapp/InstalledAppController.cpp b/third_party/WebKit/Source/modules/installedapp/InstalledAppController.cpp index a42d2e0..0348980 100644 --- a/third_party/WebKit/Source/modules/installedapp/InstalledAppController.cpp +++ b/third_party/WebKit/Source/modules/installedapp/InstalledAppController.cpp
@@ -7,7 +7,7 @@ #include "core/dom/Document.h" #include "core/frame/LocalFrame.h" #include "platform/wtf/Functional.h" -#include "public/platform/InterfaceProvider.h" +#include "services/service_manager/public/cpp/interface_provider.h" #include <utility> @@ -105,7 +105,7 @@ } if (!provider_) { - GetSupplementable()->GetInterfaceProvider()->GetInterface( + GetSupplementable()->GetInterfaceProvider().GetInterface( mojo::MakeRequest(&provider_)); // TODO(mgiuca): Set a connection error handler. This requires a refactor to // work like NavigatorShare.cpp (retain a persistent list of clients to
diff --git a/third_party/WebKit/Source/modules/keyboard_lock/NavigatorKeyboardLock.cpp b/third_party/WebKit/Source/modules/keyboard_lock/NavigatorKeyboardLock.cpp index 887f9b6..d4718b0 100644 --- a/third_party/WebKit/Source/modules/keyboard_lock/NavigatorKeyboardLock.cpp +++ b/third_party/WebKit/Source/modules/keyboard_lock/NavigatorKeyboardLock.cpp
@@ -11,7 +11,7 @@ #include "platform/heap/Persistent.h" #include "platform/wtf/Assertions.h" #include "platform/wtf/Functional.h" -#include "public/platform/InterfaceProvider.h" +#include "services/service_manager/public/cpp/interface_provider.h" namespace blink { @@ -82,7 +82,7 @@ if (!frame) { return false; } - frame->GetInterfaceProvider()->GetInterface(mojo::MakeRequest(&service_)); + frame->GetInterfaceProvider().GetInterface(mojo::MakeRequest(&service_)); } DCHECK(service_);
diff --git a/third_party/WebKit/Source/modules/media_controls/BUILD.gn b/third_party/WebKit/Source/modules/media_controls/BUILD.gn index 77f7560..8b2e1c59 100644 --- a/third_party/WebKit/Source/modules/media_controls/BUILD.gn +++ b/third_party/WebKit/Source/modules/media_controls/BUILD.gn
@@ -20,12 +20,19 @@ "elements/MediaControlCastButtonElement.h", "elements/MediaControlCurrentTimeDisplayElement.cpp", "elements/MediaControlCurrentTimeDisplayElement.h", + "elements/MediaControlDivElement.cpp", + "elements/MediaControlDivElement.h", "elements/MediaControlDownloadButtonElement.cpp", "elements/MediaControlDownloadButtonElement.h", + "elements/MediaControlElementBase.cpp", + "elements/MediaControlElementBase.h", + "elements/MediaControlElementType.h", "elements/MediaControlElementsHelper.cpp", "elements/MediaControlElementsHelper.h", "elements/MediaControlFullscreenButtonElement.cpp", "elements/MediaControlFullscreenButtonElement.h", + "elements/MediaControlInputElement.cpp", + "elements/MediaControlInputElement.h", "elements/MediaControlMuteButtonElement.cpp", "elements/MediaControlMuteButtonElement.h", "elements/MediaControlOverflowMenuButtonElement.cpp",
diff --git a/third_party/WebKit/Source/modules/media_controls/MediaControlsImpl.cpp b/third_party/WebKit/Source/modules/media_controls/MediaControlsImpl.cpp index 9bf2b7bd7..cabbe8b 100644 --- a/third_party/WebKit/Source/modules/media_controls/MediaControlsImpl.cpp +++ b/third_party/WebKit/Source/modules/media_controls/MediaControlsImpl.cpp
@@ -1062,7 +1062,7 @@ // won't benefit from that anwyay, we just do it here like JS will. // Controls that we'll hide / show, in order of decreasing priority. - MediaControlElement* elements[] = { + MediaControlElementBase* elements[] = { // Exclude m_overflowMenu; we handle it specially. play_button_.Get(), fullscreen_button_.Get(), @@ -1085,7 +1085,7 @@ // This prevents the wrong controls from being shown briefly // immediately after the first layout and paint, but before we have // a chance to revise them. - for (MediaControlElement* element : elements) { + for (MediaControlElementBase* element : elements) { if (element) element->SetDoesFit(false); } @@ -1115,10 +1115,10 @@ overflow_menu_->SetIsWanted(true); int used_width = minimum_width; - std::list<MediaControlElement*> overflow_elements; - MediaControlElement* first_displaced_element = nullptr; + std::list<MediaControlElementBase*> overflow_elements; + MediaControlElementBase* first_displaced_element = nullptr; // For each control that fits, enable it in order of decreasing priority. - for (MediaControlElement* element : elements) { + for (MediaControlElementBase* element : elements) { if (!element) continue; int width = minimum_width;
diff --git a/third_party/WebKit/Source/modules/media_controls/MediaControlsImpl.h b/third_party/WebKit/Source/modules/media_controls/MediaControlsImpl.h index c8bba03..530b863 100644 --- a/third_party/WebKit/Source/modules/media_controls/MediaControlsImpl.h +++ b/third_party/WebKit/Source/modules/media_controls/MediaControlsImpl.h
@@ -98,7 +98,6 @@ // There is no update because only the overlay is expected to change. RefreshCastButtonVisibilityWithoutUpdate(); } - Document& OwnerDocument() { return GetDocument(); } // Called by the fullscreen buttons to toggle fulllscreen on/off. void EnterFullscreen();
diff --git a/third_party/WebKit/Source/modules/media_controls/MediaControlsImplTest.cpp b/third_party/WebKit/Source/modules/media_controls/MediaControlsImplTest.cpp index 5745aca5..6dc7898d 100644 --- a/third_party/WebKit/Source/modules/media_controls/MediaControlsImplTest.cpp +++ b/third_party/WebKit/Source/modules/media_controls/MediaControlsImplTest.cpp
@@ -18,7 +18,6 @@ #include "core/frame/Settings.h" #include "core/html/HTMLElement.h" #include "core/html/HTMLVideoElement.h" -#include "core/html/shadow/MediaControlElementTypes.h" #include "core/input/EventHandler.h" #include "core/layout/LayoutObject.h" #include "core/loader/EmptyClients.h"
diff --git a/third_party/WebKit/Source/modules/media_controls/MediaControlsMediaEventListener.cpp b/third_party/WebKit/Source/modules/media_controls/MediaControlsMediaEventListener.cpp index 093d15c..c51a3c1 100644 --- a/third_party/WebKit/Source/modules/media_controls/MediaControlsMediaEventListener.cpp +++ b/third_party/WebKit/Source/modules/media_controls/MediaControlsMediaEventListener.cpp
@@ -66,12 +66,12 @@ // TODO(avayvod, mlamouri): Attach can be called twice. See // https://crbug.com/713275. - if (remote_playback_availability_callback_id_ == -1) { - remote_playback_availability_callback_id_ = + if (!remote_playback_availability_callback_id_.has_value()) { + remote_playback_availability_callback_id_ = WTF::make_optional( remote->WatchAvailabilityInternal(new AvailabilityCallbackWrapper( WTF::Bind(&MediaControlsMediaEventListener:: OnRemotePlaybackAvailabilityChanged, - WrapWeakPersistent(this)))); + WrapWeakPersistent(this))))); } } } @@ -100,10 +100,12 @@ // TODO(avayvod): apparently Detach() can be called without a previous // Attach() call. See https://crbug.com/713275 for more details. - if (remote_playback_availability_callback_id_ != -1) { + if (remote_playback_availability_callback_id_.has_value() && + remote_playback_availability_callback_id_.value() != + RemotePlayback::kWatchAvailabilityNotSupported) { remote->CancelWatchAvailabilityInternal( - remote_playback_availability_callback_id_); - remote_playback_availability_callback_id_ = -1; + remote_playback_availability_callback_id_.value()); + remote_playback_availability_callback_id_.reset(); } } }
diff --git a/third_party/WebKit/Source/modules/media_controls/MediaControlsMediaEventListener.h b/third_party/WebKit/Source/modules/media_controls/MediaControlsMediaEventListener.h index 530d746..8c4a239 100644 --- a/third_party/WebKit/Source/modules/media_controls/MediaControlsMediaEventListener.h +++ b/third_party/WebKit/Source/modules/media_controls/MediaControlsMediaEventListener.h
@@ -6,6 +6,7 @@ #define MediaControlsMediaEventListener_h #include "core/events/EventListener.h" +#include "platform/wtf/Optional.h" namespace blink { @@ -39,7 +40,7 @@ void OnRemotePlaybackAvailabilityChanged(); Member<MediaControlsImpl> media_controls_; - int remote_playback_availability_callback_id_ = -1; + WTF::Optional<int> remote_playback_availability_callback_id_; }; } // namespace blink
diff --git a/third_party/WebKit/Source/modules/media_controls/elements/MediaControlCastButtonElement.cpp b/third_party/WebKit/Source/modules/media_controls/elements/MediaControlCastButtonElement.cpp index fedd97f..bab9a01 100644 --- a/third_party/WebKit/Source/modules/media_controls/elements/MediaControlCastButtonElement.cpp +++ b/third_party/WebKit/Source/modules/media_controls/elements/MediaControlCastButtonElement.cpp
@@ -84,14 +84,14 @@ return true; } -WebLocalizedString::Name -MediaControlCastButtonElement::GetOverflowStringName() { +WebLocalizedString::Name MediaControlCastButtonElement::GetOverflowStringName() + const { if (IsPlayingRemotely()) return WebLocalizedString::kOverflowMenuStopCast; return WebLocalizedString::kOverflowMenuCast; } -bool MediaControlCastButtonElement::HasOverflowButton() { +bool MediaControlCastButtonElement::HasOverflowButton() const { return true; }
diff --git a/third_party/WebKit/Source/modules/media_controls/elements/MediaControlCastButtonElement.h b/third_party/WebKit/Source/modules/media_controls/elements/MediaControlCastButtonElement.h index 0d29cff..a2f859e9 100644 --- a/third_party/WebKit/Source/modules/media_controls/elements/MediaControlCastButtonElement.h +++ b/third_party/WebKit/Source/modules/media_controls/elements/MediaControlCastButtonElement.h
@@ -5,7 +5,7 @@ #ifndef MediaControlCastButtonElement_h #define MediaControlCastButtonElement_h -#include "core/html/shadow/MediaControlElementTypes.h" +#include "modules/media_controls/elements/MediaControlInputElement.h" namespace blink { @@ -26,8 +26,8 @@ // MediaControlInputElement overrides. bool WillRespondToMouseClickEvents() override; - WebLocalizedString::Name GetOverflowStringName() override; - bool HasOverflowButton() override; + WebLocalizedString::Name GetOverflowStringName() const override; + bool HasOverflowButton() const override; private: // This is used for UMA histogram (Cast.Sender.Overlay). New values should
diff --git a/third_party/WebKit/Source/modules/media_controls/elements/MediaControlDivElement.cpp b/third_party/WebKit/Source/modules/media_controls/elements/MediaControlDivElement.cpp new file mode 100644 index 0000000..92d5e4c90 --- /dev/null +++ b/third_party/WebKit/Source/modules/media_controls/elements/MediaControlDivElement.cpp
@@ -0,0 +1,26 @@ +// Copyright 2017 The Chromium Authors. All rights reserved. +// Use of this source code is governed by a BSD-style license that can be +// found in the LICENSE file. + +#include "modules/media_controls/elements/MediaControlDivElement.h" + +#include "modules/media_controls/MediaControlsImpl.h" + +namespace blink { + +MediaControlDivElement::MediaControlDivElement( + MediaControlsImpl& media_controls, + MediaControlElementType display_type) + : HTMLDivElement(media_controls.GetDocument()), + MediaControlElementBase(media_controls, display_type, this) {} + +bool MediaControlDivElement::IsMediaControlElement() const { + return true; +} + +DEFINE_TRACE(MediaControlDivElement) { + HTMLDivElement::Trace(visitor); + MediaControlElementBase::Trace(visitor); +} + +} // namespace blink
diff --git a/third_party/WebKit/Source/modules/media_controls/elements/MediaControlDivElement.h b/third_party/WebKit/Source/modules/media_controls/elements/MediaControlDivElement.h new file mode 100644 index 0000000..de305b6 --- /dev/null +++ b/third_party/WebKit/Source/modules/media_controls/elements/MediaControlDivElement.h
@@ -0,0 +1,32 @@ +// Copyright 2017 The Chromium Authors. All rights reserved. +// Use of this source code is governed by a BSD-style license that can be +// found in the LICENSE file. + +#ifndef MediaControlDivElement_h +#define MediaControlDivElement_h + +#include "core/html/HTMLDivElement.h" +#include "modules/media_controls/elements/MediaControlElementBase.h" + +namespace blink { + +class MediaControlsImpl; + +// MediaControlElementBase implementation based on a <div>. Used for panels, and +// floating UI. +class MediaControlDivElement : public HTMLDivElement, + public MediaControlElementBase { + USING_GARBAGE_COLLECTED_MIXIN(MediaControlDivElement); + + DECLARE_VIRTUAL_TRACE(); + + protected: + MediaControlDivElement(MediaControlsImpl&, MediaControlElementType); + + private: + bool IsMediaControlElement() const final; +}; + +} // namespace blink + +#endif // MediaControlDivElement_h
diff --git a/third_party/WebKit/Source/modules/media_controls/elements/MediaControlDownloadButtonElement.cpp b/third_party/WebKit/Source/modules/media_controls/elements/MediaControlDownloadButtonElement.cpp index 2007c5d..fc58f57 100644 --- a/third_party/WebKit/Source/modules/media_controls/elements/MediaControlDownloadButtonElement.cpp +++ b/third_party/WebKit/Source/modules/media_controls/elements/MediaControlDownloadButtonElement.cpp
@@ -77,16 +77,16 @@ } WebLocalizedString::Name -MediaControlDownloadButtonElement::GetOverflowStringName() { +MediaControlDownloadButtonElement::GetOverflowStringName() const { return WebLocalizedString::kOverflowMenuDownload; } -bool MediaControlDownloadButtonElement::HasOverflowButton() { +bool MediaControlDownloadButtonElement::HasOverflowButton() const { return true; } void MediaControlDownloadButtonElement::SetIsWanted(bool wanted) { - MediaControlElement::SetIsWanted(wanted); + MediaControlInputElement::SetIsWanted(wanted); if (!IsWanted()) return;
diff --git a/third_party/WebKit/Source/modules/media_controls/elements/MediaControlDownloadButtonElement.h b/third_party/WebKit/Source/modules/media_controls/elements/MediaControlDownloadButtonElement.h index da1f7e08..ca659182 100644 --- a/third_party/WebKit/Source/modules/media_controls/elements/MediaControlDownloadButtonElement.h +++ b/third_party/WebKit/Source/modules/media_controls/elements/MediaControlDownloadButtonElement.h
@@ -5,7 +5,7 @@ #ifndef MediaControlDownloadButtonElement_h #define MediaControlDownloadButtonElement_h -#include "core/html/shadow/MediaControlElementTypes.h" +#include "modules/media_controls/elements/MediaControlInputElement.h" namespace blink { @@ -23,8 +23,8 @@ // MediaControlInputElement overrides. // TODO(mlamouri): add WillRespondToMouseClickEvents - WebLocalizedString::Name GetOverflowStringName() override; - bool HasOverflowButton() override; + WebLocalizedString::Name GetOverflowStringName() const override; + bool HasOverflowButton() const override; void SetIsWanted(bool) override; DECLARE_VIRTUAL_TRACE();
diff --git a/third_party/WebKit/Source/modules/media_controls/elements/MediaControlElementBase.cpp b/third_party/WebKit/Source/modules/media_controls/elements/MediaControlElementBase.cpp new file mode 100644 index 0000000..d5352e8 --- /dev/null +++ b/third_party/WebKit/Source/modules/media_controls/elements/MediaControlElementBase.cpp
@@ -0,0 +1,109 @@ +// Copyright 2017 The Chromium Authors. All rights reserved. +// Use of this source code is governed by a BSD-style license that can be +// found in the LICENSE file. + +#include "modules/media_controls/elements/MediaControlElementBase.h" + +#include "core/html/HTMLMediaElement.h" +#include "core/layout/LayoutObject.h" +#include "modules/media_controls/MediaControlsImpl.h" +#include "platform/text/PlatformLocale.h" + +namespace blink { + +void MediaControlElementBase::SetIsWanted(bool wanted) { + if (is_wanted_ == wanted) + return; + + is_wanted_ = wanted; + UpdateShownState(); +} + +bool MediaControlElementBase::IsWanted() const { + return is_wanted_; +} + +void MediaControlElementBase::SetDoesFit(bool fits) { + does_fit_ = fits; + UpdateShownState(); +} + +MediaControlElementType MediaControlElementBase::DisplayType() const { + return display_type_; +} + +bool MediaControlElementBase::HasOverflowButton() const { + return false; +} + +void MediaControlElementBase::ShouldShowButtonInOverflowMenu(bool should_show) { + if (!HasOverflowButton()) + return; + + if (should_show) { + overflow_menu_element_->RemoveInlineStyleProperty(CSSPropertyDisplay); + } else { + overflow_menu_element_->SetInlineStyleProperty(CSSPropertyDisplay, + CSSValueNone); + } +} + +String MediaControlElementBase::GetOverflowMenuString() const { + return MediaElement().GetLocale().QueryString(GetOverflowStringName()); +} + +void MediaControlElementBase::UpdateOverflowString() { + if (overflow_menu_element_ && overflow_menu_text_) + overflow_menu_text_->ReplaceWholeText(GetOverflowMenuString()); +} + +MediaControlElementBase::MediaControlElementBase( + MediaControlsImpl& media_controls, + MediaControlElementType display_type, + HTMLElement* element) + : media_controls_(&media_controls), + display_type_(display_type), + element_(element), + is_wanted_(true), + does_fit_(true) {} + +MediaControlsImpl& MediaControlElementBase::GetMediaControls() const { + DCHECK(media_controls_); + return *media_controls_; +} + +HTMLMediaElement& MediaControlElementBase::MediaElement() const { + return GetMediaControls().MediaElement(); +} + +void MediaControlElementBase::SetDisplayType( + MediaControlElementType display_type) { + if (display_type == display_type_) + return; + + display_type_ = display_type; + if (LayoutObject* object = element_->GetLayoutObject()) + object->SetShouldDoFullPaintInvalidation(); +} + +void MediaControlElementBase::UpdateShownState() { + if (is_wanted_ && does_fit_) + element_->RemoveInlineStyleProperty(CSSPropertyDisplay); + else + element_->SetInlineStyleProperty(CSSPropertyDisplay, CSSValueNone); +} + +WebLocalizedString::Name MediaControlElementBase::GetOverflowStringName() + const { + NOTREACHED(); + return WebLocalizedString::kAXAMPMFieldText; +} + +DEFINE_TRACE(MediaControlElementBase) { + visitor->Trace(media_controls_); + visitor->Trace(element_); + visitor->Trace(overflow_menu_element_); + visitor->Trace(overflow_menu_text_); +} + +} // namespace blink
diff --git a/third_party/WebKit/Source/modules/media_controls/elements/MediaControlElementBase.h b/third_party/WebKit/Source/modules/media_controls/elements/MediaControlElementBase.h new file mode 100644 index 0000000..08c216a --- /dev/null +++ b/third_party/WebKit/Source/modules/media_controls/elements/MediaControlElementBase.h
@@ -0,0 +1,94 @@ +// Copyright 2017 The Chromium Authors. All rights reserved. +// Use of this source code is governed by a BSD-style license that can be +// found in the LICENSE file. + +#ifndef MediaControlElementBase_h +#define MediaControlElementBase_h + +#include "core/dom/Element.h" +#include "modules/media_controls/elements/MediaControlElementType.h" +#include "platform/heap/GarbageCollected.h" +#include "platform/heap/Visitor.h" +#include "public/platform/WebLocalizedString.h" + +namespace blink { + +class Element; +class HTMLElement; +class HTMLMediaElement; +class MediaControlsImpl; + +// MediaControlElementBase is the base class for all the media control elements. +// It is sub-classed by MediaControlInputElement and MediaControlDivElement +// which are then used by the final implementations. +class MediaControlElementBase : public GarbageCollectedMixin { + public: + // These hold the state about whether this control should be shown if + // space permits. These will also show / hide as needed. + virtual void SetIsWanted(bool); + bool IsWanted() const; + + // Tell us whether we fit or not. This will hide / show the control as + // needed, also. + void SetDoesFit(bool); + + // Returns the display type of the element that is set at creation. + MediaControlElementType DisplayType() const; + + // By default, media controls elements are not added to the overflow menu. + // Controls that can be added to the overflow menu should override this + // function and return true. + virtual bool HasOverflowButton() const; + + // If true, shows the overflow menu item if it exists. Hides it if false. + void ShouldShowButtonInOverflowMenu(bool); + + // Returns a string representation of the media control element. Used for + // the overflow menu. + String GetOverflowMenuString() const; + + // Updates the value of the Text string shown in the overflow menu. + void UpdateOverflowString(); + + DECLARE_VIRTUAL_TRACE(); + + protected: + MediaControlElementBase(MediaControlsImpl&, + MediaControlElementType, + HTMLElement*); + + MediaControlsImpl& GetMediaControls() const; + + HTMLMediaElement& MediaElement() const; + + void SetDisplayType(MediaControlElementType); + + // Represents the overflow menu element for this media control. + // The Element contains the button that the user can click on, but having + // the button within an Element enables us to style the overflow menu. + // Setting this pointer is optional so it may be null. + Member<Element> overflow_menu_element_; + + // The text representation of the button within the overflow menu. + Member<Text> overflow_menu_text_; + + private: + // Hide or show based on our fits / wanted state. We want to show + // if and only if we're wanted and we fit. + void UpdateShownState(); + + // Returns a string representation of the media control element. + // Subclasses should override this method to return the string representation + // of the overflow button. + virtual WebLocalizedString::Name GetOverflowStringName() const; + + Member<MediaControlsImpl> media_controls_; + MediaControlElementType display_type_; + Member<HTMLElement> element_; + bool is_wanted_ : 1; + bool does_fit_ : 1; +}; + +} // namespace blink + +#endif // MediaControlElementBase_h
diff --git a/third_party/WebKit/Source/modules/media_controls/elements/MediaControlElementType.h b/third_party/WebKit/Source/modules/media_controls/elements/MediaControlElementType.h new file mode 100644 index 0000000..3d0678f2 --- /dev/null +++ b/third_party/WebKit/Source/modules/media_controls/elements/MediaControlElementType.h
@@ -0,0 +1,41 @@ +// Copyright 2017 The Chromium Authors. All rights reserved. +// Use of this source code is governed by a BSD-style license that can be +// found in the LICENSE file. + +#ifndef MediaControlElementType_h +#define MediaControlElementType_h + +// Classes sub-classing MediaControlElementBase will all have a defined type +// from this list. It is used by code that need to know what type of media +// control element it is interacting with. +enum MediaControlElementType { + kMediaEnterFullscreenButton = 0, + kMediaMuteButton, + kMediaPlayButton, + kMediaSlider, + kMediaSliderThumb, + kMediaShowClosedCaptionsButton, + kMediaHideClosedCaptionsButton, + kMediaTextTrackList, + kMediaUnMuteButton, + kMediaPauseButton, + kMediaTimelineContainer, + kMediaCurrentTimeDisplay, + kMediaTimeRemainingDisplay, + kMediaTrackSelectionCheckmark, + kMediaControlsPanel, + kMediaVolumeSliderContainer, + kMediaVolumeSlider, + kMediaVolumeSliderThumb, + kMediaExitFullscreenButton, + kMediaOverlayPlayButton, + kMediaCastOffButton, + kMediaCastOnButton, + kMediaOverlayCastOffButton, + kMediaOverlayCastOnButton, + kMediaOverflowButton, + kMediaOverflowList, + kMediaDownloadButton, +}; + +#endif // MediaControlElementType_h
diff --git a/third_party/WebKit/Source/modules/media_controls/elements/MediaControlElementsHelper.cpp b/third_party/WebKit/Source/modules/media_controls/elements/MediaControlElementsHelper.cpp index 0771867..0aeb5cc 100644 --- a/third_party/WebKit/Source/modules/media_controls/elements/MediaControlElementsHelper.cpp +++ b/third_party/WebKit/Source/modules/media_controls/elements/MediaControlElementsHelper.cpp
@@ -5,8 +5,11 @@ #include "modules/media_controls/elements/MediaControlElementsHelper.h" #include "core/events/Event.h" +#include "core/html/HTMLMediaElement.h" #include "core/layout/LayoutSlider.h" #include "core/layout/api/LayoutSliderItem.h" +#include "modules/media_controls/elements/MediaControlDivElement.h" +#include "modules/media_controls/elements/MediaControlInputElement.h" namespace blink { @@ -47,4 +50,27 @@ type == EventTypeNames::pointermove; } +// static +MediaControlElementType MediaControlElementsHelper::GetMediaControlElementType( + const Node* node) { + SECURITY_DCHECK(node->IsMediaControlElement()); + const HTMLElement* element = ToHTMLElement(node); + if (isHTMLInputElement(*element)) + return static_cast<const MediaControlInputElement*>(element)->DisplayType(); + return static_cast<const MediaControlDivElement*>(element)->DisplayType(); +} + +// static +const HTMLMediaElement* MediaControlElementsHelper::ToParentMediaElement( + const Node* node) { + if (!node) + return nullptr; + const Node* shadow_host = node->OwnerShadowHost(); + if (!shadow_host) + return nullptr; + + return IsHTMLMediaElement(shadow_host) ? ToHTMLMediaElement(shadow_host) + : nullptr; +} + } // namespace blink
diff --git a/third_party/WebKit/Source/modules/media_controls/elements/MediaControlElementsHelper.h b/third_party/WebKit/Source/modules/media_controls/elements/MediaControlElementsHelper.h index 557ba729..d4f0f3f 100644 --- a/third_party/WebKit/Source/modules/media_controls/elements/MediaControlElementsHelper.h +++ b/third_party/WebKit/Source/modules/media_controls/elements/MediaControlElementsHelper.h
@@ -5,12 +5,16 @@ #ifndef MediaControlElementsHelper_h #define MediaControlElementsHelper_h +#include "modules/ModulesExport.h" +#include "modules/media_controls/elements/MediaControlElementType.h" #include "platform/wtf/Allocator.h" namespace blink { class Event; +class HTMLMediaElement; class LayoutObject; +class Node; // Helper class for media control elements. It contains methods, constants or // concepts shared by more than one element. @@ -23,6 +27,17 @@ // Sliders (the volume control and timeline) need to capture some additional // events used when dragging the thumb. static bool IsUserInteractionEventForSlider(Event*, LayoutObject*); + + // Returns the MediaControlElementType associated with a given |Node|. The + // |node| _must_ be a media control element. + // Exported to be used by the accessibility module. + MODULES_EXPORT static MediaControlElementType GetMediaControlElementType( + const Node*); + + // Returns the media element associated with a given |node|. + // Exported to be used by the accessibility module. + MODULES_EXPORT static const HTMLMediaElement* ToParentMediaElement( + const Node*); }; } // namespace blink
diff --git a/third_party/WebKit/Source/modules/media_controls/elements/MediaControlFullscreenButtonElement.cpp b/third_party/WebKit/Source/modules/media_controls/elements/MediaControlFullscreenButtonElement.cpp index d47c72f..1c3c169 100644 --- a/third_party/WebKit/Source/modules/media_controls/elements/MediaControlFullscreenButtonElement.cpp +++ b/third_party/WebKit/Source/modules/media_controls/elements/MediaControlFullscreenButtonElement.cpp
@@ -33,13 +33,13 @@ } WebLocalizedString::Name -MediaControlFullscreenButtonElement::GetOverflowStringName() { +MediaControlFullscreenButtonElement::GetOverflowStringName() const { if (MediaElement().IsFullscreen()) return WebLocalizedString::kOverflowMenuExitFullscreen; return WebLocalizedString::kOverflowMenuEnterFullscreen; } -bool MediaControlFullscreenButtonElement::HasOverflowButton() { +bool MediaControlFullscreenButtonElement::HasOverflowButton() const { return true; }
diff --git a/third_party/WebKit/Source/modules/media_controls/elements/MediaControlFullscreenButtonElement.h b/third_party/WebKit/Source/modules/media_controls/elements/MediaControlFullscreenButtonElement.h index ca4d990..edd6016 100644 --- a/third_party/WebKit/Source/modules/media_controls/elements/MediaControlFullscreenButtonElement.h +++ b/third_party/WebKit/Source/modules/media_controls/elements/MediaControlFullscreenButtonElement.h
@@ -5,7 +5,7 @@ #ifndef MediaControlFullscreenButtonElement_h #define MediaControlFullscreenButtonElement_h -#include "core/html/shadow/MediaControlElementTypes.h" +#include "modules/media_controls/elements/MediaControlInputElement.h" namespace blink { @@ -22,8 +22,8 @@ // MediaControlInputElement overrides. bool WillRespondToMouseClickEvents() override; - WebLocalizedString::Name GetOverflowStringName() override; - bool HasOverflowButton() override; + WebLocalizedString::Name GetOverflowStringName() const override; + bool HasOverflowButton() const override; private: void DefaultEventHandler(Event*) override;
diff --git a/third_party/WebKit/Source/modules/media_controls/elements/MediaControlInputElement.cpp b/third_party/WebKit/Source/modules/media_controls/elements/MediaControlInputElement.cpp new file mode 100644 index 0000000..595547c --- /dev/null +++ b/third_party/WebKit/Source/modules/media_controls/elements/MediaControlInputElement.cpp
@@ -0,0 +1,57 @@ +// Copyright 2017 The Chromium Authors. All rights reserved. +// Use of this source code is governed by a BSD-style license that can be +// found in the LICENSE file. + +#include "modules/media_controls/elements/MediaControlInputElement.h" + +#include "core/html/HTMLLabelElement.h" +#include "modules/media_controls/MediaControlsImpl.h" + +namespace blink { + +HTMLElement* MediaControlInputElement::CreateOverflowElement( + MediaControlsImpl& media_controls, + MediaControlInputElement* button) { + if (!button) + return nullptr; + + // We don't want the button visible within the overflow menu. + button->SetIsWanted(false); + + overflow_menu_text_ = Text::Create(media_controls.GetDocument(), + button->GetOverflowMenuString()); + + HTMLLabelElement* element = + HTMLLabelElement::Create(media_controls.GetDocument()); + element->SetShadowPseudoId( + AtomicString("-internal-media-controls-overflow-menu-list-item")); + // Appending a button to a label element ensures that clicks on the label + // are passed down to the button, performing the action we'd expect. + element->AppendChild(button); + element->AppendChild(overflow_menu_text_); + overflow_menu_element_ = element; + return element; +} + +MediaControlInputElement::MediaControlInputElement( + MediaControlsImpl& media_controls, + MediaControlElementType display_type) + : HTMLInputElement(media_controls.GetDocument(), false), + MediaControlElementBase(media_controls, display_type, this) {} + +void MediaControlInputElement::UpdateDisplayType() {} + +bool MediaControlInputElement::IsMediaControlElement() const { + return true; +} + +bool MediaControlInputElement::IsMouseFocusable() const { + return false; +} + +DEFINE_TRACE(MediaControlInputElement) { + HTMLInputElement::Trace(visitor); + MediaControlElementBase::Trace(visitor); +} + +} // namespace blink
diff --git a/third_party/WebKit/Source/modules/media_controls/elements/MediaControlInputElement.h b/third_party/WebKit/Source/modules/media_controls/elements/MediaControlInputElement.h new file mode 100644 index 0000000..a84a846 --- /dev/null +++ b/third_party/WebKit/Source/modules/media_controls/elements/MediaControlInputElement.h
@@ -0,0 +1,40 @@ +// Copyright 2017 The Chromium Authors. All rights reserved. +// Use of this source code is governed by a BSD-style license that can be +// found in the LICENSE file. + +#ifndef MediaControlInputElement_h +#define MediaControlInputElement_h + +#include "core/html/HTMLInputElement.h" +#include "modules/media_controls/elements/MediaControlElementBase.h" + +namespace blink { + +class MediaControlsImpl; + +// MediaControlElementBase implementation based on an <input> element. Used by +// buttons and sliders. +class MediaControlInputElement : public HTMLInputElement, + public MediaControlElementBase { + USING_GARBAGE_COLLECTED_MIXIN(MediaControlInputElement); + + public: + // Creates an overflow menu element with the given button as a child. + HTMLElement* CreateOverflowElement(MediaControlsImpl&, + MediaControlInputElement*); + + DECLARE_VIRTUAL_TRACE(); + + protected: + MediaControlInputElement(MediaControlsImpl&, MediaControlElementType); + + private: + virtual void UpdateDisplayType(); + + bool IsMouseFocusable() const override; + bool IsMediaControlElement() const final; +}; + +} // namespace blink + +#endif // MediaControlInputElement_h
diff --git a/third_party/WebKit/Source/modules/media_controls/elements/MediaControlMuteButtonElement.cpp b/third_party/WebKit/Source/modules/media_controls/elements/MediaControlMuteButtonElement.cpp index c4bc997..f0d352f1 100644 --- a/third_party/WebKit/Source/modules/media_controls/elements/MediaControlMuteButtonElement.cpp +++ b/third_party/WebKit/Source/modules/media_controls/elements/MediaControlMuteButtonElement.cpp
@@ -34,14 +34,14 @@ UpdateOverflowString(); } -WebLocalizedString::Name -MediaControlMuteButtonElement::GetOverflowStringName() { +WebLocalizedString::Name MediaControlMuteButtonElement::GetOverflowStringName() + const { if (MediaElement().muted()) return WebLocalizedString::kOverflowMenuUnmute; return WebLocalizedString::kOverflowMenuMute; } -bool MediaControlMuteButtonElement::HasOverflowButton() { +bool MediaControlMuteButtonElement::HasOverflowButton() const { return true; }
diff --git a/third_party/WebKit/Source/modules/media_controls/elements/MediaControlMuteButtonElement.h b/third_party/WebKit/Source/modules/media_controls/elements/MediaControlMuteButtonElement.h index c70fd28a..28c3d65 100644 --- a/third_party/WebKit/Source/modules/media_controls/elements/MediaControlMuteButtonElement.h +++ b/third_party/WebKit/Source/modules/media_controls/elements/MediaControlMuteButtonElement.h
@@ -5,7 +5,7 @@ #ifndef MediaControlMuteButtonElement_h #define MediaControlMuteButtonElement_h -#include "core/html/shadow/MediaControlElementTypes.h" +#include "modules/media_controls/elements/MediaControlInputElement.h" namespace blink { @@ -19,8 +19,8 @@ // MediaControlInputElement overrides. bool WillRespondToMouseClickEvents() override; void UpdateDisplayType() override; - WebLocalizedString::Name GetOverflowStringName() override; - bool HasOverflowButton() override; + WebLocalizedString::Name GetOverflowStringName() const override; + bool HasOverflowButton() const override; private: void DefaultEventHandler(Event*) override;
diff --git a/third_party/WebKit/Source/modules/media_controls/elements/MediaControlOverflowMenuButtonElement.h b/third_party/WebKit/Source/modules/media_controls/elements/MediaControlOverflowMenuButtonElement.h index 846e4f7..a296933 100644 --- a/third_party/WebKit/Source/modules/media_controls/elements/MediaControlOverflowMenuButtonElement.h +++ b/third_party/WebKit/Source/modules/media_controls/elements/MediaControlOverflowMenuButtonElement.h
@@ -5,7 +5,7 @@ #ifndef MediaControlOverflowMenuButtonElement_h #define MediaControlOverflowMenuButtonElement_h -#include "core/html/shadow/MediaControlElementTypes.h" +#include "modules/media_controls/elements/MediaControlInputElement.h" namespace blink {
diff --git a/third_party/WebKit/Source/modules/media_controls/elements/MediaControlOverflowMenuListElement.h b/third_party/WebKit/Source/modules/media_controls/elements/MediaControlOverflowMenuListElement.h index 2d3a9867..33ebc09 100644 --- a/third_party/WebKit/Source/modules/media_controls/elements/MediaControlOverflowMenuListElement.h +++ b/third_party/WebKit/Source/modules/media_controls/elements/MediaControlOverflowMenuListElement.h
@@ -5,7 +5,7 @@ #ifndef MediaControlOverflowMenuListElement_h #define MediaControlOverflowMenuListElement_h -#include "core/html/shadow/MediaControlElementTypes.h" +#include "modules/media_controls/elements/MediaControlDivElement.h" namespace blink {
diff --git a/third_party/WebKit/Source/modules/media_controls/elements/MediaControlOverlayEnclosureElement.h b/third_party/WebKit/Source/modules/media_controls/elements/MediaControlOverlayEnclosureElement.h index c9451c39..da808cce 100644 --- a/third_party/WebKit/Source/modules/media_controls/elements/MediaControlOverlayEnclosureElement.h +++ b/third_party/WebKit/Source/modules/media_controls/elements/MediaControlOverlayEnclosureElement.h
@@ -5,7 +5,7 @@ #ifndef MediaControlOverlayEnclosureElement_h #define MediaControlOverlayEnclosureElement_h -#include "core/html/shadow/MediaControlElementTypes.h" +#include "modules/media_controls/elements/MediaControlDivElement.h" namespace blink {
diff --git a/third_party/WebKit/Source/modules/media_controls/elements/MediaControlOverlayPlayButtonElement.h b/third_party/WebKit/Source/modules/media_controls/elements/MediaControlOverlayPlayButtonElement.h index 0e6b35f..f1b1ddf 100644 --- a/third_party/WebKit/Source/modules/media_controls/elements/MediaControlOverlayPlayButtonElement.h +++ b/third_party/WebKit/Source/modules/media_controls/elements/MediaControlOverlayPlayButtonElement.h
@@ -5,7 +5,7 @@ #ifndef MediaControlOverlayPlayButtonElement_h #define MediaControlOverlayPlayButtonElement_h -#include "core/html/shadow/MediaControlElementTypes.h" +#include "modules/media_controls/elements/MediaControlInputElement.h" namespace blink {
diff --git a/third_party/WebKit/Source/modules/media_controls/elements/MediaControlPanelElement.h b/third_party/WebKit/Source/modules/media_controls/elements/MediaControlPanelElement.h index ec9419d..3c2da324 100644 --- a/third_party/WebKit/Source/modules/media_controls/elements/MediaControlPanelElement.h +++ b/third_party/WebKit/Source/modules/media_controls/elements/MediaControlPanelElement.h
@@ -5,7 +5,7 @@ #ifndef MediaControlPanelElement_h #define MediaControlPanelElement_h -#include "core/html/shadow/MediaControlElementTypes.h" +#include "modules/media_controls/elements/MediaControlDivElement.h" #include "platform/Timer.h" namespace blink {
diff --git a/third_party/WebKit/Source/modules/media_controls/elements/MediaControlPanelEnclosureElement.h b/third_party/WebKit/Source/modules/media_controls/elements/MediaControlPanelEnclosureElement.h index df4b385..12563e3 100644 --- a/third_party/WebKit/Source/modules/media_controls/elements/MediaControlPanelEnclosureElement.h +++ b/third_party/WebKit/Source/modules/media_controls/elements/MediaControlPanelEnclosureElement.h
@@ -5,7 +5,7 @@ #ifndef MediaControlPanelEnclosureElement_h #define MediaControlPanelEnclosureElement_h -#include "core/html/shadow/MediaControlElementTypes.h" +#include "modules/media_controls/elements/MediaControlDivElement.h" namespace blink {
diff --git a/third_party/WebKit/Source/modules/media_controls/elements/MediaControlPlayButtonElement.cpp b/third_party/WebKit/Source/modules/media_controls/elements/MediaControlPlayButtonElement.cpp index d7e14b7..b1862a1 100644 --- a/third_party/WebKit/Source/modules/media_controls/elements/MediaControlPlayButtonElement.cpp +++ b/third_party/WebKit/Source/modules/media_controls/elements/MediaControlPlayButtonElement.cpp
@@ -31,14 +31,14 @@ UpdateOverflowString(); } -WebLocalizedString::Name -MediaControlPlayButtonElement::GetOverflowStringName() { +WebLocalizedString::Name MediaControlPlayButtonElement::GetOverflowStringName() + const { if (MediaElement().paused()) return WebLocalizedString::kOverflowMenuPlay; return WebLocalizedString::kOverflowMenuPause; } -bool MediaControlPlayButtonElement::HasOverflowButton() { +bool MediaControlPlayButtonElement::HasOverflowButton() const { return true; }
diff --git a/third_party/WebKit/Source/modules/media_controls/elements/MediaControlPlayButtonElement.h b/third_party/WebKit/Source/modules/media_controls/elements/MediaControlPlayButtonElement.h index ab42606..2d32521 100644 --- a/third_party/WebKit/Source/modules/media_controls/elements/MediaControlPlayButtonElement.h +++ b/third_party/WebKit/Source/modules/media_controls/elements/MediaControlPlayButtonElement.h
@@ -5,7 +5,7 @@ #ifndef MediaControlPlayButtonElement_h #define MediaControlPlayButtonElement_h -#include "core/html/shadow/MediaControlElementTypes.h" +#include "modules/media_controls/elements/MediaControlInputElement.h" namespace blink { @@ -19,8 +19,8 @@ // MediaControlInputElement overrides. bool WillRespondToMouseClickEvents() override; void UpdateDisplayType() override; - WebLocalizedString::Name GetOverflowStringName() override; - bool HasOverflowButton() override; + WebLocalizedString::Name GetOverflowStringName() const override; + bool HasOverflowButton() const override; void OnMediaKeyboardEvent(Event* event) { DefaultEventHandler(event); }
diff --git a/third_party/WebKit/Source/modules/media_controls/elements/MediaControlTextTrackListElement.cpp b/third_party/WebKit/Source/modules/media_controls/elements/MediaControlTextTrackListElement.cpp index 7dc7b8b..43f9c9b 100644 --- a/third_party/WebKit/Source/modules/media_controls/elements/MediaControlTextTrackListElement.cpp +++ b/third_party/WebKit/Source/modules/media_controls/elements/MediaControlTextTrackListElement.cpp
@@ -6,6 +6,7 @@ #include "core/InputTypeNames.h" #include "core/events/Event.h" +#include "core/html/HTMLInputElement.h" #include "core/html/HTMLLabelElement.h" #include "core/html/HTMLMediaElement.h" #include "core/html/HTMLSpanElement.h"
diff --git a/third_party/WebKit/Source/modules/media_controls/elements/MediaControlTextTrackListElement.h b/third_party/WebKit/Source/modules/media_controls/elements/MediaControlTextTrackListElement.h index 4d564539..7f168a7 100644 --- a/third_party/WebKit/Source/modules/media_controls/elements/MediaControlTextTrackListElement.h +++ b/third_party/WebKit/Source/modules/media_controls/elements/MediaControlTextTrackListElement.h
@@ -5,7 +5,7 @@ #ifndef MediaControlTextTrackListElement_h #define MediaControlTextTrackListElement_h -#include "core/html/shadow/MediaControlElementTypes.h" +#include "modules/media_controls/elements/MediaControlDivElement.h" namespace blink {
diff --git a/third_party/WebKit/Source/modules/media_controls/elements/MediaControlTimeDisplayElement.h b/third_party/WebKit/Source/modules/media_controls/elements/MediaControlTimeDisplayElement.h index 85ab767d..2c8e56fb 100644 --- a/third_party/WebKit/Source/modules/media_controls/elements/MediaControlTimeDisplayElement.h +++ b/third_party/WebKit/Source/modules/media_controls/elements/MediaControlTimeDisplayElement.h
@@ -5,8 +5,8 @@ #ifndef MediaControlTimeDisplayElement_h #define MediaControlTimeDisplayElement_h -#include "core/html/shadow/MediaControlElementTypes.h" #include "modules/ModulesExport.h" +#include "modules/media_controls/elements/MediaControlDivElement.h" namespace blink {
diff --git a/third_party/WebKit/Source/modules/media_controls/elements/MediaControlTimelineElement.h b/third_party/WebKit/Source/modules/media_controls/elements/MediaControlTimelineElement.h index 9f3034c..c797adb 100644 --- a/third_party/WebKit/Source/modules/media_controls/elements/MediaControlTimelineElement.h +++ b/third_party/WebKit/Source/modules/media_controls/elements/MediaControlTimelineElement.h
@@ -5,7 +5,7 @@ #ifndef MediaControlTimelineElement_h #define MediaControlTimelineElement_h -#include "core/html/shadow/MediaControlElementTypes.h" +#include "modules/media_controls/elements/MediaControlInputElement.h" #include "modules/media_controls/elements/MediaControlTimelineMetrics.h" namespace blink {
diff --git a/third_party/WebKit/Source/modules/media_controls/elements/MediaControlToggleClosedCaptionsButtonElement.cpp b/third_party/WebKit/Source/modules/media_controls/elements/MediaControlToggleClosedCaptionsButtonElement.cpp index e774df1..697f2dfe 100644 --- a/third_party/WebKit/Source/modules/media_controls/elements/MediaControlToggleClosedCaptionsButtonElement.cpp +++ b/third_party/WebKit/Source/modules/media_controls/elements/MediaControlToggleClosedCaptionsButtonElement.cpp
@@ -34,11 +34,11 @@ } WebLocalizedString::Name -MediaControlToggleClosedCaptionsButtonElement::GetOverflowStringName() { +MediaControlToggleClosedCaptionsButtonElement::GetOverflowStringName() const { return WebLocalizedString::kOverflowMenuCaptions; } -bool MediaControlToggleClosedCaptionsButtonElement::HasOverflowButton() { +bool MediaControlToggleClosedCaptionsButtonElement::HasOverflowButton() const { return true; }
diff --git a/third_party/WebKit/Source/modules/media_controls/elements/MediaControlToggleClosedCaptionsButtonElement.h b/third_party/WebKit/Source/modules/media_controls/elements/MediaControlToggleClosedCaptionsButtonElement.h index e648a95..0e7b33a 100644 --- a/third_party/WebKit/Source/modules/media_controls/elements/MediaControlToggleClosedCaptionsButtonElement.h +++ b/third_party/WebKit/Source/modules/media_controls/elements/MediaControlToggleClosedCaptionsButtonElement.h
@@ -5,7 +5,7 @@ #ifndef MediaControlToggleClosedCaptionsButtonElement_h #define MediaControlToggleClosedCaptionsButtonElement_h -#include "core/html/shadow/MediaControlElementTypes.h" +#include "modules/media_controls/elements/MediaControlInputElement.h" namespace blink { @@ -20,8 +20,8 @@ // MediaControlInputElement overrides. bool WillRespondToMouseClickEvents() override; void UpdateDisplayType() override; - WebLocalizedString::Name GetOverflowStringName() override; - bool HasOverflowButton() override; + WebLocalizedString::Name GetOverflowStringName() const override; + bool HasOverflowButton() const override; private: void DefaultEventHandler(Event*) override;
diff --git a/third_party/WebKit/Source/modules/media_controls/elements/MediaControlVolumeSliderElement.h b/third_party/WebKit/Source/modules/media_controls/elements/MediaControlVolumeSliderElement.h index 2e3c434..6b790b4 100644 --- a/third_party/WebKit/Source/modules/media_controls/elements/MediaControlVolumeSliderElement.h +++ b/third_party/WebKit/Source/modules/media_controls/elements/MediaControlVolumeSliderElement.h
@@ -5,7 +5,7 @@ #ifndef MediaControlVolumeSliderElement_h #define MediaControlVolumeSliderElement_h -#include "core/html/shadow/MediaControlElementTypes.h" +#include "modules/media_controls/elements/MediaControlInputElement.h" namespace blink {
diff --git a/third_party/WebKit/Source/modules/mediasession/MediaSession.cpp b/third_party/WebKit/Source/modules/mediasession/MediaSession.cpp index d1002243..2e650b0 100644 --- a/third_party/WebKit/Source/modules/mediasession/MediaSession.cpp +++ b/third_party/WebKit/Source/modules/mediasession/MediaSession.cpp
@@ -13,8 +13,8 @@ #include "modules/mediasession/MediaMetadata.h" #include "modules/mediasession/MediaMetadataSanitizer.h" #include "platform/wtf/Optional.h" -#include "public/platform/InterfaceProvider.h" #include "public/platform/Platform.h" +#include "services/service_manager/public/cpp/interface_provider.h" namespace blink { @@ -198,15 +198,11 @@ DCHECK(GetExecutionContext()->IsDocument()) << "MediaSession::getService() is only available from a frame"; Document* document = ToDocument(GetExecutionContext()); - if (!document->GetFrame()) + LocalFrame* frame = document->GetFrame(); + if (!frame) return nullptr; - InterfaceProvider* interface_provider = - document->GetFrame()->GetInterfaceProvider(); - if (!interface_provider) - return nullptr; - - interface_provider->GetInterface(mojo::MakeRequest(&service_)); + frame->GetInterfaceProvider().GetInterface(mojo::MakeRequest(&service_)); if (service_.get()) { // Record the eTLD+1 of the frame using the API. Platform::Current()->RecordRapporURL("Media.Session.APIUsage.Origin",
diff --git a/third_party/WebKit/Source/modules/nfc/NFC.cpp b/third_party/WebKit/Source/modules/nfc/NFC.cpp index fff6f4f..9d3e1aa 100644 --- a/third_party/WebKit/Source/modules/nfc/NFC.cpp +++ b/third_party/WebKit/Source/modules/nfc/NFC.cpp
@@ -18,8 +18,8 @@ #include "modules/nfc/NFCPushOptions.h" #include "modules/nfc/NFCWatchOptions.h" #include "platform/mojo/MojoHelper.h" -#include "public/platform/InterfaceProvider.h" #include "public/platform/Platform.h" +#include "services/service_manager/public/cpp/interface_provider.h" namespace { const char kJsonMimePostfix[] = "+json"; @@ -642,7 +642,7 @@ if (!IsSupportedInContext(GetExecutionContext(), error_message)) return; - frame->GetInterfaceProvider()->GetInterface(mojo::MakeRequest(&nfc_)); + frame->GetInterfaceProvider().GetInterface(mojo::MakeRequest(&nfc_)); nfc_.set_connection_error_handler(ConvertToBaseCallback( WTF::Bind(&NFC::OnConnectionError, WrapWeakPersistent(this)))); device::mojom::blink::NFCClientPtr client;
diff --git a/third_party/WebKit/Source/modules/payments/BUILD.gn b/third_party/WebKit/Source/modules/payments/BUILD.gn index 8dd3cc7..1a5de53 100644 --- a/third_party/WebKit/Source/modules/payments/BUILD.gn +++ b/third_party/WebKit/Source/modules/payments/BUILD.gn
@@ -8,6 +8,8 @@ sources = [ "CanMakePaymentEvent.cpp", "CanMakePaymentEvent.h", + "CanMakePaymentRespondWithObserver.cpp", + "CanMakePaymentRespondWithObserver.h", "HTMLIFrameElementPayments.cpp", "HTMLIFrameElementPayments.h", "PaymentAddress.cpp", @@ -18,6 +20,8 @@ "PaymentCompleter.h", "PaymentEventDataConversion.cpp", "PaymentEventDataConversion.h", + "PaymentHandlerUtils.cpp", + "PaymentHandlerUtils.h", "PaymentInstruments.cpp", "PaymentInstruments.h", "PaymentManager.cpp",
diff --git a/third_party/WebKit/Source/modules/payments/CanMakePaymentRespondWithObserver.cpp b/third_party/WebKit/Source/modules/payments/CanMakePaymentRespondWithObserver.cpp new file mode 100644 index 0000000..41c940c88 --- /dev/null +++ b/third_party/WebKit/Source/modules/payments/CanMakePaymentRespondWithObserver.cpp
@@ -0,0 +1,63 @@ +// Copyright 2017 The Chromium Authors. All rights reserved. +// Use of this source code is governed by a BSD-style license that can be +// found in the LICENSE file. + +#include "modules/payments/CanMakePaymentRespondWithObserver.h" + +#include <v8.h> +#include "bindings/core/v8/ScriptValue.h" +#include "bindings/core/v8/V8BindingForCore.h" +#include "bindings/modules/v8/V8PaymentAppResponse.h" +#include "core/dom/ExecutionContext.h" +#include "modules/payments/PaymentAppResponse.h" +#include "modules/payments/PaymentHandlerUtils.h" +#include "modules/serviceworkers/ServiceWorkerGlobalScopeClient.h" +#include "modules/serviceworkers/WaitUntilObserver.h" +#include "public/platform/modules/payments/WebPaymentAppResponse.h" + +namespace blink { + +CanMakePaymentRespondWithObserver::CanMakePaymentRespondWithObserver( + ExecutionContext* context, + int event_id, + WaitUntilObserver* observer) + : RespondWithObserver(context, event_id, observer) {} + +void CanMakePaymentRespondWithObserver::OnResponseRejected( + WebServiceWorkerResponseError error) { + PaymentHandlerUtils::ReportResponseError(GetExecutionContext(), + "CanMakePaymentEvent", error); + + ServiceWorkerGlobalScopeClient::From(GetExecutionContext()) + ->RespondToCanMakePaymentEvent(event_id_, false, event_dispatch_time_); +} + +void CanMakePaymentRespondWithObserver::OnResponseFulfilled( + const ScriptValue& value) { + DCHECK(GetExecutionContext()); + ExceptionState exception_state(value.GetIsolate(), + ExceptionState::kUnknownContext, + "PaymentRequestEvent", "respondWith"); + bool response = ToBoolean(ToIsolate(GetExecutionContext()), value.V8Value(), + exception_state); + if (exception_state.HadException()) { + exception_state.ClearException(); + OnResponseRejected(kWebServiceWorkerResponseErrorNoV8Instance); + return; + } + + ServiceWorkerGlobalScopeClient::From(GetExecutionContext()) + ->RespondToCanMakePaymentEvent(event_id_, response, event_dispatch_time_); +} + +void CanMakePaymentRespondWithObserver::OnNoResponse() { + DCHECK(GetExecutionContext()); + ServiceWorkerGlobalScopeClient::From(GetExecutionContext()) + ->RespondToCanMakePaymentEvent(event_id_, false, event_dispatch_time_); +} + +DEFINE_TRACE(CanMakePaymentRespondWithObserver) { + RespondWithObserver::Trace(visitor); +} + +} // namespace blink
diff --git a/third_party/WebKit/Source/modules/payments/CanMakePaymentRespondWithObserver.h b/third_party/WebKit/Source/modules/payments/CanMakePaymentRespondWithObserver.h new file mode 100644 index 0000000..f468f70 --- /dev/null +++ b/third_party/WebKit/Source/modules/payments/CanMakePaymentRespondWithObserver.h
@@ -0,0 +1,37 @@ +// Copyright 2017 The Chromium Authors. All rights reserved. +// Use of this source code is governed by a BSD-style license that can be +// found in the LICENSE file. + +#ifndef CanMakePaymentRespondWithObserver_h +#define CanMakePaymentRespondWithObserver_h + +#include "modules/ModulesExport.h" +#include "modules/serviceworkers/RespondWithObserver.h" +#include "public/platform/modules/serviceworker/WebServiceWorkerResponseError.h" + +namespace blink { + +class ExecutionContext; +class ScriptValue; +class WaitUntilObserver; + +// Implementation for CanMakePaymentEvent.respondWith(), which is used by the +// payment handler to indicate whether it can respond to a payment request. +class MODULES_EXPORT CanMakePaymentRespondWithObserver final + : public RespondWithObserver { + public: + CanMakePaymentRespondWithObserver(ExecutionContext*, + int event_id, + WaitUntilObserver*); + ~CanMakePaymentRespondWithObserver() override = default; + + void OnResponseRejected(WebServiceWorkerResponseError) override; + void OnResponseFulfilled(const ScriptValue&) override; + void OnNoResponse() override; + + DECLARE_VIRTUAL_TRACE(); +}; + +} // namespace blink + +#endif // CanMakePaymentRespondWithObserver_h
diff --git a/third_party/WebKit/Source/modules/payments/PaymentHandlerUtils.cpp b/third_party/WebKit/Source/modules/payments/PaymentHandlerUtils.cpp new file mode 100644 index 0000000..00e6b139 --- /dev/null +++ b/third_party/WebKit/Source/modules/payments/PaymentHandlerUtils.cpp
@@ -0,0 +1,57 @@ +// Copyright 2017 The Chromium Authors. All rights reserved. +// Use of this source code is governed by a BSD-style license that can be +// found in the LICENSE file. + +#include "modules/payments/PaymentHandlerUtils.h" + +#include "core/dom/ExecutionContext.h" +#include "core/inspector/ConsoleMessage.h" + +namespace blink { + +void PaymentHandlerUtils::ReportResponseError( + ExecutionContext* execution_context, + const String& event_name_prefix, + WebServiceWorkerResponseError error) { + String error_message = event_name_prefix + ".respondWith() failed: "; + switch (error) { + case kWebServiceWorkerResponseErrorPromiseRejected: + error_message = + error_message + "the promise passed to respondWith() was rejected."; + break; + case kWebServiceWorkerResponseErrorDefaultPrevented: + error_message = + error_message + + "preventDefault() was called without calling respondWith()."; + break; + case kWebServiceWorkerResponseErrorNoV8Instance: + error_message = error_message + + "an object that was not a PaymentResponse was passed to " + "respondWith()."; + break; + case kWebServiceWorkerResponseErrorUnknown: + error_message = error_message + "an unexpected error occurred."; + break; + case kWebServiceWorkerResponseErrorResponseTypeError: + case kWebServiceWorkerResponseErrorResponseTypeOpaque: + case kWebServiceWorkerResponseErrorResponseTypeNotBasicOrDefault: + case kWebServiceWorkerResponseErrorBodyUsed: + case kWebServiceWorkerResponseErrorResponseTypeOpaqueForClientRequest: + case kWebServiceWorkerResponseErrorResponseTypeOpaqueRedirect: + case kWebServiceWorkerResponseErrorBodyLocked: + case kWebServiceWorkerResponseErrorNoForeignFetchResponse: + case kWebServiceWorkerResponseErrorForeignFetchHeadersWithoutOrigin: + case kWebServiceWorkerResponseErrorForeignFetchMismatchedOrigin: + case kWebServiceWorkerResponseErrorRedirectedResponseForNotFollowRequest: + case kWebServiceWorkerResponseErrorDataPipeCreationFailed: + NOTREACHED(); + error_message = error_message + "an unexpected error occurred."; + break; + } + + DCHECK(execution_context); + execution_context->AddConsoleMessage(ConsoleMessage::Create( + kJSMessageSource, kWarningMessageLevel, error_message)); +} + +} // namespace blink
diff --git a/third_party/WebKit/Source/modules/payments/PaymentHandlerUtils.h b/third_party/WebKit/Source/modules/payments/PaymentHandlerUtils.h new file mode 100644 index 0000000..1327c8d3 --- /dev/null +++ b/third_party/WebKit/Source/modules/payments/PaymentHandlerUtils.h
@@ -0,0 +1,27 @@ +// Copyright 2017 The Chromium Authors. All rights reserved. +// Use of this source code is governed by a BSD-style license that can be +// found in the LICENSE file. + +#ifndef PaymentHandlerUtils_h +#define PaymentHandlerUtils_h + +#include "platform/wtf/Allocator.h" +#include "platform/wtf/text/WTFString.h" +#include "public/platform/modules/serviceworker/WebServiceWorkerResponseError.h" + +namespace blink { + +class ExecutionContext; + +class PaymentHandlerUtils { + STATIC_ONLY(PaymentHandlerUtils); + + public: + static void ReportResponseError(ExecutionContext*, + const String& event_name_prefix, + WebServiceWorkerResponseError); +}; + +} // namespace blink + +#endif // PaymentHandlerUtils_h
diff --git a/third_party/WebKit/Source/modules/payments/PaymentManager.cpp b/third_party/WebKit/Source/modules/payments/PaymentManager.cpp index 855c429..5d13a4b 100644 --- a/third_party/WebKit/Source/modules/payments/PaymentManager.cpp +++ b/third_party/WebKit/Source/modules/payments/PaymentManager.cpp
@@ -14,7 +14,6 @@ #include "modules/serviceworkers/ServiceWorkerRegistration.h" #include "platform/bindings/ScriptState.h" #include "platform/mojo/MojoHelper.h" -#include "public/platform/InterfaceProvider.h" #include "public/platform/Platform.h" namespace blink { @@ -44,7 +43,7 @@ if (context && context->IsDocument()) { LocalFrame* frame = ToDocument(context)->GetFrame(); if (frame) - frame->GetInterfaceProvider()->GetInterface(std::move(request)); + frame->GetInterfaceProvider().GetInterface(std::move(request)); } else if (context && context->IsWorkerGlobalScope()) { WorkerThread* thread = ToWorkerGlobalScope(context)->GetThread(); thread->GetInterfaceProvider().GetInterface(std::move(request));
diff --git a/third_party/WebKit/Source/modules/payments/PaymentRequest.cpp b/third_party/WebKit/Source/modules/payments/PaymentRequest.cpp index cd94eb74..c90050d 100644 --- a/third_party/WebKit/Source/modules/payments/PaymentRequest.cpp +++ b/third_party/WebKit/Source/modules/payments/PaymentRequest.cpp
@@ -45,9 +45,9 @@ #include "platform/feature_policy/FeaturePolicy.h" #include "platform/mojo/MojoHelper.h" #include "platform/wtf/HashSet.h" -#include "public/platform/InterfaceProvider.h" #include "public/platform/Platform.h" #include "public/platform/WebTraceLocation.h" +#include "services/service_manager/public/cpp/interface_provider.h" namespace { @@ -1033,7 +1033,7 @@ DCHECK(shipping_type_.IsNull() || shipping_type_ == "shipping" || shipping_type_ == "delivery" || shipping_type_ == "pickup"); - GetFrame()->GetInterfaceProvider()->GetInterface( + GetFrame()->GetInterfaceProvider().GetInterface( mojo::MakeRequest(&payment_provider_)); payment_provider_.set_connection_error_handler(ConvertToBaseCallback( WTF::Bind(&PaymentRequest::OnError, WrapWeakPersistent(this),
diff --git a/third_party/WebKit/Source/modules/payments/PaymentRequestRespondWithObserver.cpp b/third_party/WebKit/Source/modules/payments/PaymentRequestRespondWithObserver.cpp index a9643ee..4f41e36 100644 --- a/third_party/WebKit/Source/modules/payments/PaymentRequestRespondWithObserver.cpp +++ b/third_party/WebKit/Source/modules/payments/PaymentRequestRespondWithObserver.cpp
@@ -9,62 +9,13 @@ #include "bindings/core/v8/V8BindingForCore.h" #include "bindings/modules/v8/V8PaymentAppResponse.h" #include "core/dom/ExecutionContext.h" -#include "core/inspector/ConsoleMessage.h" #include "modules/payments/PaymentAppResponse.h" +#include "modules/payments/PaymentHandlerUtils.h" #include "modules/serviceworkers/ServiceWorkerGlobalScopeClient.h" #include "modules/serviceworkers/WaitUntilObserver.h" #include "public/platform/modules/payments/WebPaymentAppResponse.h" namespace blink { -namespace { - -// Returns the error message to let the developer know about the reason of the -// unusual failures. -const String GetMessageForResponseError(WebServiceWorkerResponseError error) { - String error_message = - "The respondWith() was rejected in PaymentRequestEvent: "; - switch (error) { - case kWebServiceWorkerResponseErrorPromiseRejected: - error_message = error_message + "the promise was rejected."; - break; - case kWebServiceWorkerResponseErrorDefaultPrevented: - error_message = - error_message + - "preventDefault() was called without calling respondWith()."; - break; - case kWebServiceWorkerResponseErrorNoV8Instance: - error_message = error_message + - "an object that was not a PaymentResponse was passed to " - "respondWith()."; - break; - case kWebServiceWorkerResponseErrorResponseTypeError: - error_message = error_message + - "the promise was resolved with an error response object."; - break; - case kWebServiceWorkerResponseErrorUnknown: - error_message = error_message + "an unexpected error occurred."; - break; - case kWebServiceWorkerResponseErrorResponseTypeOpaque: - case kWebServiceWorkerResponseErrorResponseTypeNotBasicOrDefault: - case kWebServiceWorkerResponseErrorBodyUsed: - case kWebServiceWorkerResponseErrorResponseTypeOpaqueForClientRequest: - case kWebServiceWorkerResponseErrorResponseTypeOpaqueRedirect: - case kWebServiceWorkerResponseErrorBodyLocked: - case kWebServiceWorkerResponseErrorNoForeignFetchResponse: - case kWebServiceWorkerResponseErrorForeignFetchHeadersWithoutOrigin: - case kWebServiceWorkerResponseErrorForeignFetchMismatchedOrigin: - case kWebServiceWorkerResponseErrorRedirectedResponseForNotFollowRequest: - case kWebServiceWorkerResponseErrorDataPipeCreationFailed: - NOTREACHED(); - error_message = error_message + "an unexpected error occurred."; - break; - } - return error_message; -} - -} // namespace - -PaymentRequestRespondWithObserver::~PaymentRequestRespondWithObserver() {} PaymentRequestRespondWithObserver* PaymentRequestRespondWithObserver::Create( ExecutionContext* context, @@ -75,10 +26,8 @@ void PaymentRequestRespondWithObserver::OnResponseRejected( WebServiceWorkerResponseError error) { - DCHECK(GetExecutionContext()); - GetExecutionContext()->AddConsoleMessage( - ConsoleMessage::Create(kJSMessageSource, kWarningMessageLevel, - GetMessageForResponseError(error))); + PaymentHandlerUtils::ReportResponseError(GetExecutionContext(), + "PaymentRequestEvent", error); WebPaymentAppResponse web_data; ServiceWorkerGlobalScopeClient::From(GetExecutionContext())
diff --git a/third_party/WebKit/Source/modules/payments/PaymentRequestRespondWithObserver.h b/third_party/WebKit/Source/modules/payments/PaymentRequestRespondWithObserver.h index 9e9158133..8504d80 100644 --- a/third_party/WebKit/Source/modules/payments/PaymentRequestRespondWithObserver.h +++ b/third_party/WebKit/Source/modules/payments/PaymentRequestRespondWithObserver.h
@@ -15,12 +15,13 @@ class ScriptValue; class WaitUntilObserver; -// This class observes the service worker's handling of a PaymentRequestEvent -// and notifies the client. +// Implementation for PaymentRequestEvent.respondWith(), which is used by the +// payment handler to provide a payment response when the payment successfully +// completes. class MODULES_EXPORT PaymentRequestRespondWithObserver final : public RespondWithObserver { public: - virtual ~PaymentRequestRespondWithObserver(); + ~PaymentRequestRespondWithObserver() override = default; static PaymentRequestRespondWithObserver* Create(ExecutionContext*, int event_id,
diff --git a/third_party/WebKit/Source/modules/permissions/PermissionUtils.cpp b/third_party/WebKit/Source/modules/permissions/PermissionUtils.cpp index 97a18f4..c2b0614d 100644 --- a/third_party/WebKit/Source/modules/permissions/PermissionUtils.cpp +++ b/third_party/WebKit/Source/modules/permissions/PermissionUtils.cpp
@@ -7,10 +7,8 @@ #include "core/dom/Document.h" #include "core/dom/ExecutionContext.h" #include "core/frame/LocalFrame.h" -#include "core/frame/LocalFrameClient.h" #include "core/workers/WorkerGlobalScope.h" #include "core/workers/WorkerThread.h" -#include "public/platform/InterfaceProvider.h" #include "services/service_manager/public/cpp/interface_provider.h" namespace blink { @@ -34,7 +32,7 @@ if (!frame) return false; - frame->GetInterfaceProvider()->GetInterface(std::move(request)); + frame->GetInterfaceProvider().GetInterface(std::move(request)); return true; }
diff --git a/third_party/WebKit/Source/modules/remoteplayback/RemotePlayback.cpp b/third_party/WebKit/Source/modules/remoteplayback/RemotePlayback.cpp index ffafadd..f5f0c8d 100644 --- a/third_party/WebKit/Source/modules/remoteplayback/RemotePlayback.cpp +++ b/third_party/WebKit/Source/modules/remoteplayback/RemotePlayback.cpp
@@ -73,6 +73,10 @@ return KURL(kParsedURLString, "remote-playback://" + encoded_source_info); } +bool IsBackgroundAvailabilityMonitoringDisabled() { + return MemoryCoordinator::IsLowEndDevice(); +} + } // anonymous namespace // static @@ -108,15 +112,14 @@ return promise; } - if (MemoryCoordinator::IsLowEndDevice()) { + int id = WatchAvailabilityInternal(new AvailabilityCallbackWrapper(callback)); + if (id == kWatchAvailabilityNotSupported) { resolver->Reject(DOMException::Create( kNotSupportedError, "Availability monitoring is not supported on this device.")); return promise; } - int id = WatchAvailabilityInternal(new AvailabilityCallbackWrapper(callback)); - // TODO(avayvod): Currently the availability is tracked for each media element // as soon as it's created, we probably want to limit that to when the // page/element is visible (see https://crbug.com/597281) and has default @@ -234,6 +237,11 @@ int RemotePlayback::WatchAvailabilityInternal( AvailabilityCallbackWrapper* callback) { + if (RuntimeEnabledFeatures::RemotePlaybackBackendEnabled() && + IsBackgroundAvailabilityMonitoringDisabled()) { + return kWatchAvailabilityNotSupported; + } + int id; do { id = GetExecutionContext()->CircularSequentialID(); @@ -352,6 +360,9 @@ void RemotePlayback::SourceChanged(const WebURL& source) { DCHECK(RuntimeEnabledFeatures::NewRemotePlaybackPipelineEnabled()); + if (IsBackgroundAvailabilityMonitoringDisabled()) + return; + WebURL current_url = availability_urls_.IsEmpty() ? WebURL() : availability_urls_[0]; WebURL new_url = GetAvailabilityUrl(source); @@ -377,6 +388,12 @@ } bool RemotePlayback::RemotePlaybackAvailable() const { + if (IsBackgroundAvailabilityMonitoringDisabled() && + RuntimeEnabledFeatures::RemotePlaybackBackendEnabled() && + !media_element_->currentSrc().IsEmpty()) { + return true; + } + return availability_ == WebRemotePlaybackAvailability::kDeviceAvailable; } @@ -450,6 +467,9 @@ } void RemotePlayback::MaybeStartListeningForAvailability() { + if (IsBackgroundAvailabilityMonitoringDisabled()) + return; + if (!RuntimeEnabledFeatures::RemotePlaybackBackendEnabled()) return;
diff --git a/third_party/WebKit/Source/modules/remoteplayback/RemotePlayback.h b/third_party/WebKit/Source/modules/remoteplayback/RemotePlayback.h index 70ac0b39..79f7b820 100644 --- a/third_party/WebKit/Source/modules/remoteplayback/RemotePlayback.h +++ b/third_party/WebKit/Source/modules/remoteplayback/RemotePlayback.h
@@ -39,6 +39,10 @@ USING_GARBAGE_COLLECTED_MIXIN(RemotePlayback); public: + // Result of WatchAvailabilityInternal that means availability is not + // supported. + static const int kWatchAvailabilityNotSupported = -1; + static RemotePlayback* Create(HTMLMediaElement&); // Notifies this object that disableRemotePlayback attribute was set on the @@ -72,6 +76,8 @@ void PromptInternal(); // The implementation of watchAvailability() and cancelWatchAvailability(). + // Can return kWatchAvailabilityNotSupported to indicate the availability + // monitoring is disabled. RemotePlaybackAvailable() will return true then. int WatchAvailabilityInternal(AvailabilityCallbackWrapper*); bool CancelWatchAvailabilityInternal(int id);
diff --git a/third_party/WebKit/Source/modules/serviceworkers/ServiceWorkerGlobalScopeClient.cpp b/third_party/WebKit/Source/modules/serviceworkers/ServiceWorkerGlobalScopeClient.cpp index 23f41f0..5b3178ae 100644 --- a/third_party/WebKit/Source/modules/serviceworkers/ServiceWorkerGlobalScopeClient.cpp +++ b/third_party/WebKit/Source/modules/serviceworkers/ServiceWorkerGlobalScopeClient.cpp
@@ -154,6 +154,13 @@ fetch_event_id, response, stream_handle, event_dispatch_time); } +void ServiceWorkerGlobalScopeClient::RespondToCanMakePaymentEvent( + int event_id, + bool response, + double event_dispatch_time) { + client_.RespondToCanMakePaymentEvent(event_id, response, event_dispatch_time); +} + void ServiceWorkerGlobalScopeClient::RespondToPaymentRequestEvent( int event_id, const WebPaymentAppResponse& response,
diff --git a/third_party/WebKit/Source/modules/serviceworkers/ServiceWorkerGlobalScopeClient.h b/third_party/WebKit/Source/modules/serviceworkers/ServiceWorkerGlobalScopeClient.h index 51eb4ad1..8718788 100644 --- a/third_party/WebKit/Source/modules/serviceworkers/ServiceWorkerGlobalScopeClient.h +++ b/third_party/WebKit/Source/modules/serviceworkers/ServiceWorkerGlobalScopeClient.h
@@ -107,6 +107,9 @@ const WebServiceWorkerResponse&, WebServiceWorkerStreamHandle*, double event_dispatch_time); + void RespondToCanMakePaymentEvent(int event_id, + bool can_make_payment, + double event_dispatch_time); void RespondToPaymentRequestEvent(int event_id, const WebPaymentAppResponse&, double event_dispatch_time);
diff --git a/third_party/WebKit/Source/modules/shapedetection/BarcodeDetector.cpp b/third_party/WebKit/Source/modules/shapedetection/BarcodeDetector.cpp index a4b60bb..c6864e1 100644 --- a/third_party/WebKit/Source/modules/shapedetection/BarcodeDetector.cpp +++ b/third_party/WebKit/Source/modules/shapedetection/BarcodeDetector.cpp
@@ -11,7 +11,6 @@ #include "core/workers/WorkerThread.h" #include "modules/imagecapture/Point2D.h" #include "modules/shapedetection/DetectedBarcode.h" -#include "public/platform/InterfaceProvider.h" #include "services/service_manager/public/cpp/interface_provider.h" namespace blink { @@ -25,7 +24,7 @@ if (context->IsDocument()) { LocalFrame* frame = ToDocument(context)->GetFrame(); if (frame) - frame->GetInterfaceProvider()->GetInterface(std::move(request)); + frame->GetInterfaceProvider().GetInterface(std::move(request)); } else { WorkerThread* thread = ToWorkerGlobalScope(context)->GetThread(); thread->GetInterfaceProvider().GetInterface(std::move(request));
diff --git a/third_party/WebKit/Source/modules/shapedetection/FaceDetector.cpp b/third_party/WebKit/Source/modules/shapedetection/FaceDetector.cpp index f14dc03..269b5eee 100644 --- a/third_party/WebKit/Source/modules/shapedetection/FaceDetector.cpp +++ b/third_party/WebKit/Source/modules/shapedetection/FaceDetector.cpp
@@ -13,7 +13,6 @@ #include "modules/shapedetection/DetectedFace.h" #include "modules/shapedetection/FaceDetectorOptions.h" #include "modules/shapedetection/Landmark.h" -#include "public/platform/InterfaceProvider.h" #include "public/platform/Platform.h" #include "services/service_manager/public/cpp/interface_provider.h" #include "services/shape_detection/public/interfaces/facedetection_provider.mojom-blink.h" @@ -38,7 +37,7 @@ if (context->IsDocument()) { LocalFrame* frame = ToDocument(context)->GetFrame(); if (frame) - frame->GetInterfaceProvider()->GetInterface(std::move(request)); + frame->GetInterfaceProvider().GetInterface(std::move(request)); } else { WorkerThread* thread = ToWorkerGlobalScope(context)->GetThread(); thread->GetInterfaceProvider().GetInterface(std::move(request));
diff --git a/third_party/WebKit/Source/modules/shapedetection/TextDetector.cpp b/third_party/WebKit/Source/modules/shapedetection/TextDetector.cpp index 09fb158..edb855a 100644 --- a/third_party/WebKit/Source/modules/shapedetection/TextDetector.cpp +++ b/third_party/WebKit/Source/modules/shapedetection/TextDetector.cpp
@@ -10,7 +10,6 @@ #include "core/html/canvas/CanvasImageSource.h" #include "core/workers/WorkerThread.h" #include "modules/shapedetection/DetectedText.h" -#include "public/platform/InterfaceProvider.h" #include "services/service_manager/public/cpp/interface_provider.h" namespace blink { @@ -24,7 +23,7 @@ if (context->IsDocument()) { LocalFrame* frame = ToDocument(context)->GetFrame(); if (frame) - frame->GetInterfaceProvider()->GetInterface(std::move(request)); + frame->GetInterfaceProvider().GetInterface(std::move(request)); } else { WorkerThread* thread = ToWorkerGlobalScope(context)->GetThread(); thread->GetInterfaceProvider().GetInterface(std::move(request));
diff --git a/third_party/WebKit/Source/modules/vr/VRController.cpp b/third_party/WebKit/Source/modules/vr/VRController.cpp index 5e4191e..c51cdd8 100644 --- a/third_party/WebKit/Source/modules/vr/VRController.cpp +++ b/third_party/WebKit/Source/modules/vr/VRController.cpp
@@ -10,9 +10,8 @@ #include "core/frame/LocalFrame.h" #include "modules/vr/NavigatorVR.h" #include "modules/vr/VRGetDevicesCallback.h" -#include "public/platform/InterfaceProvider.h" - #include "platform/wtf/Assertions.h" +#include "services/service_manager/public/cpp/interface_provider.h" namespace blink { @@ -21,7 +20,7 @@ navigator_vr_(navigator_vr), display_synced_(false), binding_(this) { - navigator_vr->GetDocument()->GetFrame()->GetInterfaceProvider()->GetInterface( + navigator_vr->GetDocument()->GetFrame()->GetInterfaceProvider().GetInterface( mojo::MakeRequest(&service_)); service_.set_connection_error_handler(ConvertToBaseCallback( WTF::Bind(&VRController::Dispose, WrapWeakPersistent(this))));
diff --git a/third_party/WebKit/Source/modules/wake_lock/ScreenWakeLock.cpp b/third_party/WebKit/Source/modules/wake_lock/ScreenWakeLock.cpp index 697ab8b0..231e83d 100644 --- a/third_party/WebKit/Source/modules/wake_lock/ScreenWakeLock.cpp +++ b/third_party/WebKit/Source/modules/wake_lock/ScreenWakeLock.cpp
@@ -9,7 +9,7 @@ #include "core/frame/Screen.h" #include "core/page/PageVisibilityState.h" #include "platform/RuntimeEnabledFeatures.h" -#include "public/platform/InterfaceProvider.h" +#include "services/service_manager/public/cpp/interface_provider.h" namespace blink { @@ -67,8 +67,7 @@ PageVisibilityObserver(frame.GetPage()), keep_awake_(false) { DCHECK(!service_.is_bound()); - DCHECK(frame.GetInterfaceProvider()); - frame.GetInterfaceProvider()->GetInterface(mojo::MakeRequest(&service_)); + frame.GetInterfaceProvider().GetInterface(mojo::MakeRequest(&service_)); } bool ScreenWakeLock::keepAwake() const {
diff --git a/third_party/WebKit/Source/modules/wake_lock/ScreenWakeLockTest.cpp b/third_party/WebKit/Source/modules/wake_lock/ScreenWakeLockTest.cpp index ed9eb27..43dbff2 100644 --- a/third_party/WebKit/Source/modules/wake_lock/ScreenWakeLockTest.cpp +++ b/third_party/WebKit/Source/modules/wake_lock/ScreenWakeLockTest.cpp
@@ -13,10 +13,10 @@ #include "mojo/public/cpp/bindings/strong_binding.h" #include "platform/testing/URLTestHelpers.h" #include "platform/testing/UnitTestHelpers.h" -#include "public/platform/InterfaceProvider.h" #include "public/platform/Platform.h" #include "public/platform/WebPageVisibilityState.h" #include "public/platform/WebURLLoaderMockFactory.h" +#include "services/service_manager/public/cpp/interface_provider.h" #include "testing/gtest/include/gtest/gtest.h" #include <memory> @@ -27,63 +27,41 @@ using device::mojom::blink::WakeLock; using device::mojom::blink::WakeLockRequest; -// This class allows binding interface requests to a MockWakeLock. -class MockInterfaceProvider : public InterfaceProvider { +// A mock WakeLock used to intercept calls to the mojo methods. +class MockWakeLock : public WakeLock { public: - MockInterfaceProvider() : wake_lock_status_(false) {} - ~MockInterfaceProvider() {} + MockWakeLock() : binding_(this) {} + ~MockWakeLock() = default; - void GetInterface(const char* name, mojo::ScopedMessagePipeHandle) override; - - bool WakeLockStatus() const { return wake_lock_status_; } - void SetWakeLockStatus(bool status) { wake_lock_status_ = status; } - - private: - // A mock WakeLock used to intercept calls to the mojo methods. - class MockWakeLock : public WakeLock { - public: - MockWakeLock(MockInterfaceProvider* registry, WakeLockRequest request) - : binding_(this, std::move(request)), registry_(registry) {} - ~MockWakeLock() {} - - private: - // mojom::WakeLock - void RequestWakeLock() override { registry_->SetWakeLockStatus(true); } - void CancelWakeLock() override { registry_->SetWakeLockStatus(false); } - void AddClient(device::mojom::blink::WakeLockRequest wake_lock) override {} - void ChangeType(device::mojom::WakeLockType type, - ChangeTypeCallback callback) override {} - void HasWakeLockForTests(HasWakeLockForTestsCallback callback) override {} - - mojo::Binding<WakeLock> binding_; - MockInterfaceProvider* const registry_; - }; - std::unique_ptr<MockWakeLock> mock_wake_lock_; - - bool wake_lock_status_; -}; - -void MockInterfaceProvider::GetInterface(const char* name, - mojo::ScopedMessagePipeHandle handle) { - mock_wake_lock_.reset( - new MockWakeLock(this, WakeLockRequest(std::move(handle)))); -} - -// A TestWebFrameClient to allow overriding the interfaceProvider() with a mock. -class TestWebFrameClient : public FrameTestHelpers::TestWebFrameClient { - public: - ~TestWebFrameClient() override = default; - InterfaceProvider* GetInterfaceProviderForTesting() override { - return &interface_provider_; + void Bind(mojo::ScopedMessagePipeHandle handle) { + binding_.Bind(WakeLockRequest(std::move(handle))); } + bool WakeLockStatus() { return wake_lock_status_; } + private: - MockInterfaceProvider interface_provider_; + // mojom::WakeLock + void RequestWakeLock() override { wake_lock_status_ = true; } + void CancelWakeLock() override { wake_lock_status_ = false; } + void AddClient(device::mojom::blink::WakeLockRequest wake_lock) override {} + void ChangeType(device::mojom::WakeLockType type, + ChangeTypeCallback callback) override {} + void HasWakeLockForTests(HasWakeLockForTestsCallback callback) override {} + + mojo::Binding<WakeLock> binding_; + bool wake_lock_status_ = false; }; class ScreenWakeLockTest : public ::testing::Test { protected: void SetUp() override { + service_manager::InterfaceProvider::TestApi test_api( + test_web_frame_client_.GetInterfaceProvider()); + test_api.SetBinderForName( + WakeLock::Name_, + ConvertToBaseCallback( + WTF::Bind(&MockWakeLock::Bind, WTF::Unretained(&mock_wake_lock_)))); + web_view_helper_.Initialize(&test_web_frame_client_); URLTestHelpers::RegisterMockedURLLoadFromBase( WebString::FromUTF8("http://example.com/"), testing::CoreTestDataPath(), @@ -106,8 +84,8 @@ LocalFrame* GetFrame() { DCHECK(web_view_helper_.WebView()); - DCHECK(web_view_helper_.LocalMainFrame()); - return web_view_helper_.LocalMainFrame()->GetFrame(); + DCHECK(web_view_helper_.WebView()->MainFrameImpl()); + return web_view_helper_.WebView()->MainFrameImpl()->GetFrame(); } Screen* GetScreen() { @@ -121,11 +99,7 @@ return ScreenWakeLock::keepAwake(*GetScreen()); } - bool ClientKeepScreenAwake() { - return static_cast<MockInterfaceProvider*>( - test_web_frame_client_.GetInterfaceProviderForTesting()) - ->WakeLockStatus(); - } + bool ClientKeepScreenAwake() { return mock_wake_lock_.WakeLockStatus(); } void SetKeepAwake(bool keepAwake) { DCHECK(GetScreen()); @@ -152,8 +126,10 @@ // Order of these members is important as we need to make sure that // test_web_frame_client_ outlives web_view_helper_ (destruction order) - TestWebFrameClient test_web_frame_client_; + FrameTestHelpers::TestWebFrameClient test_web_frame_client_; FrameTestHelpers::WebViewHelper web_view_helper_; + + MockWakeLock mock_wake_lock_; }; TEST_F(ScreenWakeLockTest, setAndReset) {
diff --git a/third_party/WebKit/Source/modules/webauth/WebAuthentication.cpp b/third_party/WebKit/Source/modules/webauth/WebAuthentication.cpp index b2f17e44..4ef1510 100644 --- a/third_party/WebKit/Source/modules/webauth/WebAuthentication.cpp +++ b/third_party/WebKit/Source/modules/webauth/WebAuthentication.cpp
@@ -16,7 +16,7 @@ #include "modules/webauth/ScopedCredential.h" #include "modules/webauth/ScopedCredentialOptions.h" #include "modules/webauth/ScopedCredentialParameters.h" -#include "public/platform/InterfaceProvider.h" +#include "services/service_manager/public/cpp/interface_provider.h" namespace { const char kNoAuthenticatorError[] = "Authenticator unavailable."; @@ -258,7 +258,7 @@ return ScriptPromise::RejectWithDOMException( script_state, DOMException::Create(kNotSupportedError)); } - GetFrame()->GetInterfaceProvider()->GetInterface( + GetFrame()->GetInterfaceProvider().GetInterface( mojo::MakeRequest(&authenticator_)); authenticator_.set_connection_error_handler(ConvertToBaseCallback(
diff --git a/third_party/WebKit/Source/modules/webshare/NavigatorShare.cpp b/third_party/WebKit/Source/modules/webshare/NavigatorShare.cpp index 667432a..d72ce8c 100644 --- a/third_party/WebKit/Source/modules/webshare/NavigatorShare.cpp +++ b/third_party/WebKit/Source/modules/webshare/NavigatorShare.cpp
@@ -14,8 +14,8 @@ #include "modules/webshare/ShareData.h" #include "platform/bindings/V8ThrowException.h" #include "platform/mojo/MojoHelper.h" -#include "public/platform/InterfaceProvider.h" #include "public/platform/Platform.h" +#include "services/service_manager/public/cpp/interface_provider.h" namespace blink { @@ -124,7 +124,7 @@ if (!service_) { LocalFrame* frame = doc->GetFrame(); DCHECK(frame); - frame->GetInterfaceProvider()->GetInterface(mojo::MakeRequest(&service_)); + frame->GetInterfaceProvider().GetInterface(mojo::MakeRequest(&service_)); service_.set_connection_error_handler(ConvertToBaseCallback(WTF::Bind( &NavigatorShare::OnConnectionError, WrapWeakPersistent(this)))); DCHECK(service_);
diff --git a/third_party/WebKit/Source/modules/websockets/DocumentWebSocketChannel.cpp b/third_party/WebKit/Source/modules/websockets/DocumentWebSocketChannel.cpp index 686b901..535ce3f 100644 --- a/third_party/WebKit/Source/modules/websockets/DocumentWebSocketChannel.cpp +++ b/third_party/WebKit/Source/modules/websockets/DocumentWebSocketChannel.cpp
@@ -36,7 +36,6 @@ #include "core/fileapi/FileReaderLoader.h" #include "core/fileapi/FileReaderLoaderClient.h" #include "core/frame/LocalFrame.h" -#include "core/frame/LocalFrameClient.h" #include "core/frame/WebLocalFrameBase.h" #include "core/inspector/ConsoleMessage.h" #include "core/loader/BaseFetchContext.h" @@ -61,11 +60,11 @@ #include "platform/weborigin/SecurityOrigin.h" #include "platform/wtf/Functional.h" #include "platform/wtf/PtrUtil.h" -#include "public/platform/InterfaceProvider.h" #include "public/platform/Platform.h" #include "public/platform/WebSocketHandshakeThrottle.h" #include "public/platform/WebTraceLocation.h" #include "public/platform/WebURL.h" +#include "services/service_manager/public/cpp/interface_provider.h" namespace blink { @@ -282,7 +281,7 @@ mojom::blink::WebSocketPtr socket_ptr; auto socket_request = mojo::MakeRequest(&socket_ptr); if (GetDocument() && GetDocument()->GetFrame()) { - GetDocument()->GetFrame()->GetInterfaceProvider()->GetInterface( + GetDocument()->GetFrame()->GetInterfaceProvider().GetInterface( std::move(socket_request)); }
diff --git a/third_party/WebKit/Source/modules/webusb/DEPS b/third_party/WebKit/Source/modules/webusb/DEPS index a455f6b..1e6ebea1 100644 --- a/third_party/WebKit/Source/modules/webusb/DEPS +++ b/third_party/WebKit/Source/modules/webusb/DEPS
@@ -1,5 +1,4 @@ include_rules = [ "+device/usb/public/interfaces", "+mojo/public/cpp/bindings", - "+services/service_manager/public/cpp", ]
diff --git a/third_party/WebKit/Source/modules/webusb/USB.cpp b/third_party/WebKit/Source/modules/webusb/USB.cpp index db85429..602dced 100644 --- a/third_party/WebKit/Source/modules/webusb/USB.cpp +++ b/third_party/WebKit/Source/modules/webusb/USB.cpp
@@ -10,7 +10,6 @@ #include "core/dom/Document.h" #include "core/dom/ExceptionCode.h" #include "core/dom/UserGestureIndicator.h" -#include "core/frame/LocalFrameClient.h" #include "device/usb/public/interfaces/device.mojom-blink.h" #include "modules/EventTargetModules.h" #include "modules/webusb/USBConnectionEvent.h" @@ -125,7 +124,7 @@ } if (!chooser_service_) { - GetFrame()->Client()->GetInterfaceProvider()->GetInterface( + GetFrame()->GetInterfaceProvider().GetInterface( mojo::MakeRequest(&chooser_service_)); chooser_service_.set_connection_error_handler( ConvertToBaseCallback(WTF::Bind(&USB::OnChooserServiceConnectionError, @@ -272,7 +271,7 @@ return; DCHECK(GetFrame()); - GetFrame()->Client()->GetInterfaceProvider()->GetInterface( + GetFrame()->GetInterfaceProvider().GetInterface( mojo::MakeRequest(&device_manager_)); device_manager_.set_connection_error_handler(ConvertToBaseCallback(WTF::Bind( &USB::OnDeviceManagerConnectionError, WrapWeakPersistent(this))));
diff --git a/third_party/WebKit/Source/platform/BUILD.gn b/third_party/WebKit/Source/platform/BUILD.gn index 93a78d7..74bbce27 100644 --- a/third_party/WebKit/Source/platform/BUILD.gn +++ b/third_party/WebKit/Source/platform/BUILD.gn
@@ -1283,6 +1283,8 @@ "scheduler/base/queueing_time_estimator.h", "scheduler/base/real_time_domain.cc", "scheduler/base/real_time_domain.h", + "scheduler/base/task_queue.cc", + "scheduler/base/task_queue.h", "scheduler/base/task_queue_impl.cc", "scheduler/base/task_queue_impl.h", "scheduler/base/task_queue_manager.cc", @@ -1328,8 +1330,12 @@ "scheduler/child/worker_global_scope_scheduler.h", "scheduler/child/worker_scheduler.cc", "scheduler/child/worker_scheduler.h", + "scheduler/child/worker_scheduler_helper.cc", + "scheduler/child/worker_scheduler_helper.h", "scheduler/child/worker_scheduler_impl.cc", "scheduler/child/worker_scheduler_impl.h", + "scheduler/child/worker_task_queue.cc", + "scheduler/child/worker_task_queue.h", "scheduler/renderer/auto_advancing_virtual_time_domain.cc", "scheduler/renderer/auto_advancing_virtual_time_domain.h", "scheduler/renderer/budget_pool.cc", @@ -1340,6 +1346,10 @@ "scheduler/renderer/deadline_task_runner.h", "scheduler/renderer/idle_time_estimator.cc", "scheduler/renderer/idle_time_estimator.h", + "scheduler/renderer/main_thread_scheduler_helper.cc", + "scheduler/renderer/main_thread_scheduler_helper.h", + "scheduler/renderer/main_thread_task_queue.cc", + "scheduler/renderer/main_thread_task_queue.h", "scheduler/renderer/render_widget_scheduling_state.cc", "scheduler/renderer/render_widget_signals.cc", "scheduler/renderer/render_widget_signals.h", @@ -1709,6 +1719,7 @@ "graphics/gpu/DrawingBufferTestHelpers.h", "network/mime/MockMimeRegistry.h", "scheduler/base/task_queue_manager_delegate_for_test.cc", + "scheduler/base/task_queue_manager_delegate_for_test.h", "scheduler/base/test_task_time_observer.h", "scheduler/base/test_time_source.cc", "scheduler/base/test_time_source.h", @@ -1720,6 +1731,8 @@ "scheduler/test/lazy_scheduler_message_loop_delegate_for_tests.cc", "scheduler/test/lazy_scheduler_message_loop_delegate_for_tests.h", "scheduler/test/renderer_scheduler_test_support.cc", + "scheduler/test/test_task_queue.cc", + "scheduler/test/test_task_queue.h", "scroll/ScrollbarTestSuite.h", "testing/CompositorTest.cpp", "testing/CompositorTest.h", @@ -1876,6 +1889,7 @@ "graphics/RecordingImageBufferSurfaceTest.cpp", "graphics/compositing/ContentLayerClientImplTest.cpp", "graphics/compositing/PaintArtifactCompositorTest.cpp", + "graphics/compositing/PaintChunksToCcLayerTest.cpp", "graphics/filters/ImageFilterBuilderTest.cpp", "graphics/gpu/DrawingBufferTest.cpp", "graphics/gpu/SharedGpuContextTest.cpp", @@ -2061,8 +2075,6 @@ test("blink_platform_perftests") { sources = [ - "scheduler/base/task_queue_manager_delegate_for_test.cc", - "scheduler/base/task_queue_manager_delegate_for_test.h", "scheduler/base/task_queue_manager_perftest.cc", "testing/BlinkPerfTestSuite.cpp", "testing/BlinkPerfTestSuite.h", @@ -2078,6 +2090,7 @@ deps = [ ":platform", + ":test_support", "//base", "//base/test:test_support", "//testing/gtest",
diff --git a/third_party/WebKit/Source/platform/DEPS b/third_party/WebKit/Source/platform/DEPS index 4edbeed..c243c07 100644 --- a/third_party/WebKit/Source/platform/DEPS +++ b/third_party/WebKit/Source/platform/DEPS
@@ -37,7 +37,6 @@ "+mozilla", "+platform", "+public/platform", - "+services/service_manager/public/interfaces", "+skia/ext", "+third_party/ced/src/compact_enc_det/compact_enc_det.h", "+third_party/khronos",
diff --git a/third_party/WebKit/Source/platform/RuntimeEnabledFeatures.json5 b/third_party/WebKit/Source/platform/RuntimeEnabledFeatures.json5 index f329ba1..cb12eb6 100644 --- a/third_party/WebKit/Source/platform/RuntimeEnabledFeatures.json5 +++ b/third_party/WebKit/Source/platform/RuntimeEnabledFeatures.json5
@@ -80,6 +80,10 @@ status: "stable", }, { + name: "AsyncClipboard", + status: "experimental", + }, + { name: "AudioOutputDevices", status: "stable", }, @@ -156,6 +160,9 @@ status: "stable", }, { + name: "ClientPlaceholdersForServerLoFi", + }, + { name: "CoalescedEvents", status: "stable", },
diff --git a/third_party/WebKit/Source/platform/TimerTest.cpp b/third_party/WebKit/Source/platform/TimerTest.cpp index b3cf96a9..6d50da8 100644 --- a/third_party/WebKit/Source/platform/TimerTest.cpp +++ b/third_party/WebKit/Source/platform/TimerTest.cpp
@@ -10,6 +10,7 @@ #include "platform/scheduler/base/task_queue_impl.h" #include "platform/scheduler/child/web_scheduler.h" #include "platform/scheduler/child/web_task_runner_impl.h" +#include "platform/scheduler/renderer/main_thread_task_queue.h" #include "platform/scheduler/renderer/renderer_scheduler_impl.h" #include "platform/scheduler/renderer/web_view_scheduler.h" #include "platform/testing/TestingPlatformSupport.h" @@ -538,7 +539,7 @@ TEST_F(TimerTest, UserSuppliedWebTaskRunner) { scoped_refptr<scheduler::TaskQueue> task_runner( platform_->GetRendererScheduler()->NewTimerTaskQueue( - scheduler::TaskQueue::QueueType::TEST)); + scheduler::MainThreadTaskQueue::QueueType::TEST)); RefPtr<scheduler::WebTaskRunnerImpl> web_task_runner = scheduler::WebTaskRunnerImpl::Create(task_runner); TimerForTest<TimerTest> timer(web_task_runner, this, @@ -626,7 +627,7 @@ scoped_refptr<scheduler::TaskQueue> task_runner1( platform_->GetRendererScheduler()->NewTimerTaskQueue( - scheduler::TaskQueue::QueueType::TEST)); + scheduler::MainThreadTaskQueue::QueueType::TEST)); RefPtr<scheduler::WebTaskRunnerImpl> web_task_runner1 = scheduler::WebTaskRunnerImpl::Create(task_runner1); TaskObserver task_observer1(web_task_runner1, &run_order); @@ -634,7 +635,7 @@ scoped_refptr<scheduler::TaskQueue> task_runner2( platform_->GetRendererScheduler()->NewTimerTaskQueue( - scheduler::TaskQueue::QueueType::TEST)); + scheduler::MainThreadTaskQueue::QueueType::TEST)); RefPtr<scheduler::WebTaskRunnerImpl> web_task_runner2 = scheduler::WebTaskRunnerImpl::Create(task_runner2); TaskObserver task_observer2(web_task_runner2, &run_order); @@ -666,7 +667,7 @@ scoped_refptr<scheduler::TaskQueue> task_runner1( platform_->GetRendererScheduler()->NewTimerTaskQueue( - scheduler::TaskQueue::QueueType::TEST)); + scheduler::MainThreadTaskQueue::QueueType::TEST)); RefPtr<scheduler::WebTaskRunnerImpl> web_task_runner1 = scheduler::WebTaskRunnerImpl::Create(task_runner1); TaskObserver task_observer1(web_task_runner1, &run_order); @@ -674,7 +675,7 @@ scoped_refptr<scheduler::TaskQueue> task_runner2( platform_->GetRendererScheduler()->NewTimerTaskQueue( - scheduler::TaskQueue::QueueType::TEST)); + scheduler::MainThreadTaskQueue::QueueType::TEST)); RefPtr<scheduler::WebTaskRunnerImpl> web_task_runner2 = scheduler::WebTaskRunnerImpl::Create(task_runner2); TaskObserver task_observer2(web_task_runner2, &run_order); @@ -708,13 +709,13 @@ TEST_F(TimerTest, MoveToNewTaskRunnerWithoutTasks) { scoped_refptr<scheduler::TaskQueue> task_runner1( platform_->GetRendererScheduler()->NewTimerTaskQueue( - scheduler::TaskQueue::QueueType::TEST)); + scheduler::MainThreadTaskQueue::QueueType::TEST)); RefPtr<scheduler::WebTaskRunnerImpl> web_task_runner1 = scheduler::WebTaskRunnerImpl::Create(task_runner1); scoped_refptr<scheduler::TaskQueue> task_runner2( platform_->GetRendererScheduler()->NewTimerTaskQueue( - scheduler::TaskQueue::QueueType::TEST)); + scheduler::MainThreadTaskQueue::QueueType::TEST)); RefPtr<scheduler::WebTaskRunnerImpl> web_task_runner2 = scheduler::WebTaskRunnerImpl::Create(task_runner2);
diff --git a/third_party/WebKit/Source/platform/exported/WebRuntimeFeatures.cpp b/third_party/WebKit/Source/platform/exported/WebRuntimeFeatures.cpp index 8ab62d4..bc0e908 100644 --- a/third_party/WebKit/Source/platform/exported/WebRuntimeFeatures.cpp +++ b/third_party/WebKit/Source/platform/exported/WebRuntimeFeatures.cpp
@@ -422,4 +422,8 @@ RuntimeEnabledFeatures::SetWebAuthEnabled(enable); } +void WebRuntimeFeatures::EnableClientPlaceholdersForServerLoFi(bool enable) { + RuntimeEnabledFeatures::SetClientPlaceholdersForServerLoFiEnabled(enable); +} + } // namespace blink
diff --git a/third_party/WebKit/Source/platform/graphics/DEPS b/third_party/WebKit/Source/platform/graphics/DEPS index 7dcab9c..767e09e6 100644 --- a/third_party/WebKit/Source/platform/graphics/DEPS +++ b/third_party/WebKit/Source/platform/graphics/DEPS
@@ -8,6 +8,7 @@ "+base/threading/thread_checker.h", "+cc", "-cc/blink", + "+components/viz/common/quads", "+gpu/command_buffer/client/gles2_interface.h", "+gpu/command_buffer/client/gpu_memory_buffer_manager.h", "+gpu/command_buffer/common/capabilities.h",
diff --git a/third_party/WebKit/Source/platform/graphics/Gradient.cpp b/third_party/WebKit/Source/platform/graphics/Gradient.cpp index 477657d..5d34b39 100644 --- a/third_party/WebKit/Source/platform/graphics/Gradient.cpp +++ b/third_party/WebKit/Source/platform/graphics/Gradient.cpp
@@ -129,7 +129,7 @@ } } -std::unique_ptr<PaintShader> Gradient::CreateShaderInternal( +sk_sp<PaintShader> Gradient::CreateShaderInternal( const SkMatrix& local_matrix) { SortStopsIfNecessary(); DCHECK(stops_sorted_); @@ -159,7 +159,7 @@ uint32_t flags = color_interpolation_ == ColorInterpolation::kPremultiplied ? SkGradientShader::kInterpolateColorsInPremul_Flag : 0; - std::unique_ptr<PaintShader> shader = + sk_sp<PaintShader> shader = CreateShader(colors, pos, tile, flags, local_matrix, colors.back()); DCHECK(shader); @@ -175,7 +175,7 @@ cached_shader_ = CreateShaderInternal(local_matrix); } - flags.setShader(WTF::MakeUnique<PaintShader>(*cached_shader_)); + flags.setShader(cached_shader_); // Legacy behavior: gradients are always dithered. flags.setDither(true); @@ -194,13 +194,12 @@ p1_(p1) {} protected: - std::unique_ptr<PaintShader> CreateShader( - const ColorBuffer& colors, - const OffsetBuffer& pos, - SkShader::TileMode tile_mode, - uint32_t flags, - const SkMatrix& local_matrix, - SkColor fallback_color) const override { + sk_sp<PaintShader> CreateShader(const ColorBuffer& colors, + const OffsetBuffer& pos, + SkShader::TileMode tile_mode, + uint32_t flags, + const SkMatrix& local_matrix, + SkColor fallback_color) const override { SkPoint pts[2] = {p0_.Data(), p1_.Data()}; return PaintShader::MakeLinearGradient( pts, colors.data(), pos.data(), static_cast<int>(colors.size()), @@ -229,13 +228,12 @@ aspect_ratio_(aspect_ratio) {} protected: - std::unique_ptr<PaintShader> CreateShader( - const ColorBuffer& colors, - const OffsetBuffer& pos, - SkShader::TileMode tile_mode, - uint32_t flags, - const SkMatrix& local_matrix, - SkColor fallback_color) const override { + sk_sp<PaintShader> CreateShader(const ColorBuffer& colors, + const OffsetBuffer& pos, + SkShader::TileMode tile_mode, + uint32_t flags, + const SkMatrix& local_matrix, + SkColor fallback_color) const override { SkTCopyOnFirstWrite<SkMatrix> adjusted_local_matrix(local_matrix); if (aspect_ratio_ != 1) { // CSS3 elliptical gradients: apply the elliptical scaling at the @@ -282,13 +280,12 @@ angle_(angle) {} protected: - std::unique_ptr<PaintShader> CreateShader( - const ColorBuffer& colors, - const OffsetBuffer& pos, - SkShader::TileMode tile_mode, - uint32_t flags, - const SkMatrix& local_matrix, - SkColor fallback_color) const override { + sk_sp<PaintShader> CreateShader(const ColorBuffer& colors, + const OffsetBuffer& pos, + SkShader::TileMode tile_mode, + uint32_t flags, + const SkMatrix& local_matrix, + SkColor fallback_color) const override { DCHECK_NE(tile_mode, SkShader::kMirror_TileMode); // Skia's sweep gradient angles are relative to the x-axis, not the y-axis.
diff --git a/third_party/WebKit/Source/platform/graphics/Gradient.h b/third_party/WebKit/Source/platform/graphics/Gradient.h index 19f952a..eab3f275 100644 --- a/third_party/WebKit/Source/platform/graphics/Gradient.h +++ b/third_party/WebKit/Source/platform/graphics/Gradient.h
@@ -102,16 +102,15 @@ using ColorBuffer = Vector<SkColor, 8>; using OffsetBuffer = Vector<SkScalar, 8>; - virtual std::unique_ptr<PaintShader> CreateShader(const ColorBuffer&, - const OffsetBuffer&, - SkShader::TileMode, - uint32_t flags, - const SkMatrix&, - SkColor) const = 0; + virtual sk_sp<PaintShader> CreateShader(const ColorBuffer&, + const OffsetBuffer&, + SkShader::TileMode, + uint32_t flags, + const SkMatrix&, + SkColor) const = 0; private: - std::unique_ptr<PaintShader> CreateShaderInternal( - const SkMatrix& local_matrix); + sk_sp<PaintShader> CreateShaderInternal(const SkMatrix& local_matrix); sk_sp<SkColorFilter> color_filter_; @@ -125,7 +124,7 @@ Vector<ColorStop, 2> stops_; bool stops_sorted_; - mutable std::unique_ptr<PaintShader> cached_shader_; + mutable sk_sp<PaintShader> cached_shader_; }; } // namespace blink
diff --git a/third_party/WebKit/Source/platform/graphics/Image.cpp b/third_party/WebKit/Source/platform/graphics/Image.cpp index a49261b..4e4d26c4b 100644 --- a/third_party/WebKit/Source/platform/graphics/Image.cpp +++ b/third_party/WebKit/Source/platform/graphics/Image.cpp
@@ -228,12 +228,12 @@ namespace { -std::unique_ptr<PaintShader> CreatePatternShader(const PaintImage& image, - const SkMatrix& shader_matrix, - const PaintFlags& paint, - const FloatSize& spacing, - SkShader::TileMode tmx, - SkShader::TileMode tmy) { +sk_sp<PaintShader> CreatePatternShader(const PaintImage& image, + const SkMatrix& shader_matrix, + const PaintFlags& paint, + const FloatSize& spacing, + SkShader::TileMode tmx, + SkShader::TileMode tmy) { if (spacing.IsZero()) { return PaintShader::MakeImage(image.sk_image(), tmx, tmy, &shader_matrix); }
diff --git a/third_party/WebKit/Source/platform/graphics/ImagePattern.cpp b/third_party/WebKit/Source/platform/graphics/ImagePattern.cpp index dbf9de5..25de65b1 100644 --- a/third_party/WebKit/Source/platform/graphics/ImagePattern.cpp +++ b/third_party/WebKit/Source/platform/graphics/ImagePattern.cpp
@@ -29,8 +29,7 @@ return local_matrix != previous_local_matrix_; } -std::unique_ptr<PaintShader> ImagePattern::CreateShader( - const SkMatrix& local_matrix) { +sk_sp<PaintShader> ImagePattern::CreateShader(const SkMatrix& local_matrix) { if (!tile_image_) { return PaintShader::MakeColor(SK_ColorTRANSPARENT); }
diff --git a/third_party/WebKit/Source/platform/graphics/ImagePattern.h b/third_party/WebKit/Source/platform/graphics/ImagePattern.h index ed52189..a9c0ffb 100644 --- a/third_party/WebKit/Source/platform/graphics/ImagePattern.h +++ b/third_party/WebKit/Source/platform/graphics/ImagePattern.h
@@ -20,7 +20,7 @@ bool IsTextureBacked() const override; protected: - std::unique_ptr<PaintShader> CreateShader(const SkMatrix&) override; + sk_sp<PaintShader> CreateShader(const SkMatrix&) override; bool IsLocalMatrixChanged(const SkMatrix&) const override; private:
diff --git a/third_party/WebKit/Source/platform/graphics/OffscreenCanvasFrameDispatcherImpl.cpp b/third_party/WebKit/Source/platform/graphics/OffscreenCanvasFrameDispatcherImpl.cpp index 36286e71..e6f773c 100644 --- a/third_party/WebKit/Source/platform/graphics/OffscreenCanvasFrameDispatcherImpl.cpp +++ b/third_party/WebKit/Source/platform/graphics/OffscreenCanvasFrameDispatcherImpl.cpp
@@ -6,6 +6,7 @@ #include "cc/output/compositor_frame.h" #include "cc/quads/texture_draw_quad.h" +#include "components/viz/common/quads/resource_format.h" #include "gpu/command_buffer/client/gles2_interface.h" #include "platform/CrossThreadFunctional.h" #include "platform/Histogram.h" @@ -275,7 +276,7 @@ cc::TransferableResource resource; resource.id = next_resource_id_; - resource.format = cc::ResourceFormat::RGBA_8888; + resource.format = viz::ResourceFormat::RGBA_8888; resource.size = gfx::Size(width_, height_); // This indicates the filtering on the resource inherently, not the desired // filtering effect on the quad.
diff --git a/third_party/WebKit/Source/platform/graphics/PaintRecordPattern.cpp b/third_party/WebKit/Source/platform/graphics/PaintRecordPattern.cpp index c3b59885..34c0ed6 100644 --- a/third_party/WebKit/Source/platform/graphics/PaintRecordPattern.cpp +++ b/third_party/WebKit/Source/platform/graphics/PaintRecordPattern.cpp
@@ -33,7 +33,7 @@ PaintRecordPattern::~PaintRecordPattern() {} -std::unique_ptr<PaintShader> PaintRecordPattern::CreateShader( +sk_sp<PaintShader> PaintRecordPattern::CreateShader( const SkMatrix& local_matrix) { return PaintShader::MakePaintRecord( tile_record_, tile_record_bounds_, SkShader::kRepeat_TileMode,
diff --git a/third_party/WebKit/Source/platform/graphics/PaintRecordPattern.h b/third_party/WebKit/Source/platform/graphics/PaintRecordPattern.h index 3d826a63..fe3d95d 100644 --- a/third_party/WebKit/Source/platform/graphics/PaintRecordPattern.h +++ b/third_party/WebKit/Source/platform/graphics/PaintRecordPattern.h
@@ -21,7 +21,7 @@ ~PaintRecordPattern() override; protected: - std::unique_ptr<PaintShader> CreateShader(const SkMatrix&) override; + sk_sp<PaintShader> CreateShader(const SkMatrix&) override; private: PaintRecordPattern(sk_sp<PaintRecord>,
diff --git a/third_party/WebKit/Source/platform/graphics/Pattern.cpp b/third_party/WebKit/Source/platform/graphics/Pattern.cpp index 53cf3a8..181339a 100644 --- a/third_party/WebKit/Source/platform/graphics/Pattern.cpp +++ b/third_party/WebKit/Source/platform/graphics/Pattern.cpp
@@ -59,7 +59,7 @@ if (!cached_shader_ || IsLocalMatrixChanged(local_matrix)) cached_shader_ = CreateShader(local_matrix); - flags.setShader(WTF::MakeUnique<PaintShader>(*cached_shader_)); + flags.setShader(cached_shader_); } bool Pattern::IsLocalMatrixChanged(const SkMatrix& local_matrix) const {
diff --git a/third_party/WebKit/Source/platform/graphics/Pattern.h b/third_party/WebKit/Source/platform/graphics/Pattern.h index f939b5e..1db8d22 100644 --- a/third_party/WebKit/Source/platform/graphics/Pattern.h +++ b/third_party/WebKit/Source/platform/graphics/Pattern.h
@@ -72,13 +72,13 @@ virtual bool IsTextureBacked() const { return false; } protected: - virtual std::unique_ptr<PaintShader> CreateShader(const SkMatrix&) = 0; + virtual sk_sp<PaintShader> CreateShader(const SkMatrix&) = 0; virtual bool IsLocalMatrixChanged(const SkMatrix&) const; RepeatMode repeat_mode_; Pattern(RepeatMode); - mutable std::unique_ptr<PaintShader> cached_shader_; + mutable sk_sp<PaintShader> cached_shader_; }; } // namespace blink
diff --git a/third_party/WebKit/Source/platform/graphics/compositing/PaintArtifactCompositorTest.cpp b/third_party/WebKit/Source/platform/graphics/compositing/PaintArtifactCompositorTest.cpp index d265df4..eca0d14 100644 --- a/third_party/WebKit/Source/platform/graphics/compositing/PaintArtifactCompositorTest.cpp +++ b/third_party/WebKit/Source/platform/graphics/compositing/PaintArtifactCompositorTest.cpp
@@ -1478,7 +1478,7 @@ rects_with_color.push_back( RectWithColor(FloatRect(0, 0, 100, 100), Color::kWhite)); rects_with_color.push_back( - RectWithColor(FloatRect(40, 50, 50, 60), Color(Color::kBlack))); + RectWithColor(FloatRect(40, 50, 10, 10), Color(Color::kBlack))); rects_with_color.push_back( RectWithColor(FloatRect(0, 0, 200, 300), Color::kGray)); const cc::Layer* layer = ContentLayerAt(0);
diff --git a/third_party/WebKit/Source/platform/graphics/compositing/PaintChunksToCcLayer.cpp b/third_party/WebKit/Source/platform/graphics/compositing/PaintChunksToCcLayer.cpp index 44f49632..21ee964e 100644 --- a/third_party/WebKit/Source/platform/graphics/compositing/PaintChunksToCcLayer.cpp +++ b/third_party/WebKit/Source/platform/graphics/compositing/PaintChunksToCcLayer.cpp
@@ -19,210 +19,341 @@ namespace { -// Applies the clips between |localState| and |ancestorState| into a single -// combined cc::FloatClipDisplayItem on |ccList|. -static void ApplyClipsBetweenStates(const PropertyTreeState& local_state, - const PropertyTreeState& ancestor_state, - cc::DisplayItemList& cc_list, - Vector<int>& needed_restores) { - DCHECK(local_state.Transform() == ancestor_state.Transform()); -#if DCHECK_IS_ON() - const TransformPaintPropertyNode* transform_node = - local_state.Clip()->LocalTransformSpace(); - if (transform_node != ancestor_state.Transform()) { - const TransformationMatrix& local_to_ancestor_matrix = - GeometryMapper::SourceToDestinationProjection( - transform_node, ancestor_state.Transform()); - // Clips are only in descendant spaces that are transformed by one - // or more scrolls. - DCHECK(local_to_ancestor_matrix.IsIdentityOrTranslation()); - } -#endif - - const FloatClipRect& combined_clip = - GeometryMapper::LocalToAncestorClipRect(local_state, ancestor_state); - bool antialias = false; - - { - cc::PaintOpBuffer* buffer = cc_list.StartPaint(); - buffer->push<cc::SaveOp>(); - buffer->push<cc::ClipRectOp>(combined_clip.Rect(), SkClipOp::kIntersect, - antialias); - cc_list.EndPaintOfPairedBegin(); - } - needed_restores.push_back(1); -} - -static void RecordPairedBeginDisplayItems( - const Vector<PropertyTreeState>& paired_states, - const PropertyTreeState& pending_layer_state, - cc::DisplayItemList& cc_list, - Vector<int>& needed_restores) { - PropertyTreeState mapped_clip_destination_space = pending_layer_state; - PropertyTreeState clip_space = pending_layer_state; - bool has_clip = false; - - for (Vector<PropertyTreeState>::const_reverse_iterator paired_state = - paired_states.rbegin(); - paired_state != paired_states.rend(); ++paired_state) { - switch (paired_state->GetInnermostNode()) { - case PropertyTreeState::kTransform: { - if (has_clip) { - ApplyClipsBetweenStates(clip_space, mapped_clip_destination_space, - cc_list, needed_restores); - has_clip = false; - } - mapped_clip_destination_space = *paired_state; - clip_space = *paired_state; - - TransformationMatrix matrix = paired_state->Transform()->Matrix(); - matrix.ApplyTransformOrigin(paired_state->Transform()->Origin()); - - SkMatrix skmatrix = - static_cast<SkMatrix>(TransformationMatrix::ToSkMatrix44(matrix)); - { - cc::PaintOpBuffer* buffer = cc_list.StartPaint(); - buffer->push<cc::SaveOp>(); - buffer->push<cc::ConcatOp>(skmatrix); - cc_list.EndPaintOfPairedBegin(); - } - needed_restores.push_back(1); - break; - } - case PropertyTreeState::kClip: { - // Clips are handled in |applyClips| when ending the iterator, or - // transitioning between transform spaces. Here we store off the - // PropertyTreeState of the first found clip, under the transform of - // pairedState->transform(). All subsequent clips before applying the - // transform will be applied in applyClips. - clip_space = *paired_state; - has_clip = true; -#if DCHECK_IS_ON() - if (paired_state->Clip()->LocalTransformSpace() != - paired_state->Transform()) { - const TransformationMatrix& local_transform_matrix = - paired_state->Effect()->LocalTransformSpace()->Matrix(); - // Clips are only in descendant spaces that are transformed by scroll. - DCHECK(local_transform_matrix.IsIdentityOrTranslation()); - } -#endif - break; - } - case PropertyTreeState::kEffect: { - // TODO(chrishtr): skip effect and/or compositing display items if - // not necessary. - - FloatRect clip_rect = - paired_state->Effect()->OutputClip()->ClipRect().Rect(); - // TODO(chrishtr): specify origin of the filter. - FloatPoint filter_origin; - if (paired_state->Effect()->LocalTransformSpace() != - paired_state->Transform()) { - const TransformPaintPropertyNode* transform_node = - paired_state->Effect()->LocalTransformSpace(); - const TransformationMatrix& local_to_ancestor_matrix = - GeometryMapper::SourceToDestinationProjection( - transform_node, paired_state->Transform()); - // Effects are only in descendant spaces that are transformed by one - // or more scrolls. - DCHECK(local_to_ancestor_matrix.IsIdentityOrTranslation()); - - clip_rect = local_to_ancestor_matrix.MapRect(clip_rect); - filter_origin = local_to_ancestor_matrix.MapPoint(filter_origin); - } - - { - cc::PaintFlags flags; - flags.setBlendMode(paired_state->Effect()->BlendMode()); - // TODO(ajuma): This should really be rounding instead of flooring the - // alpha value, but that breaks slimming paint reftests. - flags.setAlpha(static_cast<uint8_t>( - gfx::ToFlooredInt(255 * paired_state->Effect()->Opacity()))); - flags.setColorFilter( - GraphicsContext::WebCoreColorFilterToSkiaColorFilter( - paired_state->Effect()->GetColorFilter())); - - cc::PaintOpBuffer* buffer = cc_list.StartPaint(); - // TODO(chrishtr): compute bounds as necessary. - buffer->push<cc::SaveLayerOp>(nullptr, &flags); - cc_list.EndPaintOfPairedBegin(); - } - needed_restores.push_back(1); - - { - cc::PaintOpBuffer* buffer = cc_list.StartPaint(); - - buffer->push<cc::SaveOp>(); - buffer->push<cc::TranslateOp>(filter_origin.X(), filter_origin.Y()); - - cc::PaintFlags flags; - flags.setImageFilter(cc::RenderSurfaceFilters::BuildImageFilter( - paired_state->Effect()->Filter().AsCcFilterOperations(), - gfx::SizeF(clip_rect.Width(), clip_rect.Height()))); - - SkRect layer_bounds = clip_rect; - layer_bounds.offset(-filter_origin.X(), -filter_origin.Y()); - buffer->push<cc::SaveLayerOp>(&layer_bounds, &flags); - buffer->push<cc::TranslateOp>(-filter_origin.X(), -filter_origin.Y()); - - cc_list.EndPaintOfPairedBegin(); - } - // The SaveOp+SaveLayerOp above are grouped such that they share a - // visual rect, so group the two restores in the same way so we don't - // have a mismatch in the number of EndPaintOfPairedBegin() vs - // EndPaintOfPairedEnd(). - needed_restores.push_back(2); - break; - } - case PropertyTreeState::kNone: - break; - } - } - - if (has_clip) { - ApplyClipsBetweenStates(clip_space, mapped_clip_destination_space, cc_list, - needed_restores); - } -} - -static void RecordPairedEndDisplayItems(const Vector<int>& needed_restores, - cc::DisplayItemList& cc_list) { - // TODO(danakj): This loop could use base::Reversed once it's allowed here. - for (auto it = needed_restores.rbegin(); it != needed_restores.rend(); ++it) { - cc::PaintOpBuffer* buffer = cc_list.StartPaint(); - int num_restores = *it; - for (int i = 0; i < num_restores; ++i) - buffer->push<cc::RestoreOp>(); - cc_list.EndPaintOfPairedEnd(); - } -} - constexpr gfx::Rect g_large_rect(-200000, -200000, 400000, 400000); -static void AppendDisplayItemToCcDisplayItemList( - const DisplayItem& display_item, - cc::DisplayItemList& cc_list) { +void AppendDisplayItemToCcDisplayItemList(const DisplayItem& display_item, + cc::DisplayItemList& list) { DCHECK(DisplayItem::IsDrawingType(display_item.GetType())); - if (DisplayItem::IsDrawingType(display_item.GetType())) { - const auto& drawing_display_item = - static_cast<const DrawingDisplayItem&>(display_item); - sk_sp<const cc::PaintOpBuffer> record = - drawing_display_item.GetPaintRecord(); - if (!record) - return; - // In theory we would pass the bounds of the record, previously done as: - // gfx::Rect bounds = gfx::SkIRectToRect(record->cullRect().roundOut()); - // or use the visual rect directly. However, clip content layers attempt - // to raster in a different space than that of the visual rects. We'll be - // reworking visual rects further for SPv2, so for now we just pass a - // visual rect large enough to make sure items raster. - { - cc::PaintOpBuffer* buffer = cc_list.StartPaint(); - buffer->push<cc::DrawRecordOp>(std::move(record)); - cc_list.EndPaintOfUnpaired(g_large_rect); + + sk_sp<const PaintRecord> record = + static_cast<const DrawingDisplayItem&>(display_item).GetPaintRecord(); + if (!record) + return; + cc::PaintOpBuffer* buffer = list.StartPaint(); + buffer->push<cc::DrawRecordOp>(std::move(record)); + // TODO(trchen): Pass correct visual rect here. + // The visual rect of the item can be used by cc to skip replaying items + // that can't be seen. To workaround a space conversion bug, the optimization + // is suppressed by passing a large rect. + list.EndPaintOfUnpaired(g_large_rect); +} + +void AppendRestore(cc::DisplayItemList& list, size_t n) { + cc::PaintOpBuffer* buffer = list.StartPaint(); + while (n--) + buffer->push<cc::RestoreOp>(); + list.EndPaintOfPairedEnd(); +} + +class ConversionContext { + public: + ConversionContext(const PropertyTreeState& layer_state, + cc::DisplayItemList& cc_list) + : current_transform_(layer_state.Transform()), + current_clip_(layer_state.Clip()), + current_effect_(layer_state.Effect()), + cc_list_(cc_list) {} + ~ConversionContext(); + + // The main function of this class. It converts a list of paint chunks into + // non-pair display items, and paint properties associated with them are + // implemented by paired display items. + // This is done by closing and opening paired items to adjust the current + // property state to the chunk's state when each chunk is consumed. + // Note that the clip/effect state is "lazy" in the sense that it stays + // in whatever state the last chunk left with, and only adjusted when + // a new chunk is consumed. The class implemented a few helpers to manage + // state switching so that paired display items are nested properly. + // + // State management example (transform tree omitted). + // Corresponds to unit test PaintChunksToCcLayerTest.InterleavedClipEffect: + // Clip tree: C0 <-- C1 <-- C2 <-- C3 <-- C4 + // Effect tree: E0(clip=C0) <-- E1(clip=C2) <-- E2(clip=C4) + // Layer state: C0, E0 + // Paint chunks: P0(C3, E0), P1(C4, E2), P2(C3, E1), P3(C4, E0) + // Initialization: + // The current state is initalized with the layer state, and starts with + // an empty state stack. + // current_clip = C0 + // current_effect = E0 + // state_stack = [] + // When P0 is consumed, C1, C2 and C3 need to be applied to the state: + // Output: Begin_C1 Begin_C2 Begin_C3 Draw_P0 + // current_clip = C3 + // state_stack = [C0, C1, C2] + // When P1 is consumed, C3 needs to be closed before E1 can be entered, + // then C3 and C4 need to be entered before E2 can be entered: + // Output: End_C3 Begin_E1 Begin_C3 Begin_C4 Begin_E2 Draw_P1 + // current_clip = C4 + // current_effect = E2 + // state_stack = [C0, C1, E0, C2, C3, E1] + // When P2 is consumed, E2 then C4 need to be exited: + // Output: End_E2 End_C4 Draw_P2 + // current_clip = C3 + // current_effect = E1 + // state_stack = [C0, C1, E0, C2] + // When P3 is consumed, C3 must exit before E1 can be exited, then we can + // enter C3 and C4: + // Output: End_C3 End_E1 Enter_C3 Enter_C4 Draw_P3 + // current_clip = C4 + // current_effect = E0 + // state_stack = [C0, C1, C2, C3] + // At last, close all pushed states to balance pairs (this happens when the + // context object is destructed): + // Output: End_C4 End_C3 End_C2 End_C1 + void Convert(const Vector<const PaintChunk*>&, const DisplayItemList&); + + private: + // Switch the current clip to the target state, staying in the same effect. + // It is no-op if the context is already in the target state. + // Otherwise zero or more clips will be popped from or pushed onto the + // current state stack. + // INPUT: + // The target clip must be a descendant of the input clip of current effect. + // OUTPUT: + // The current transform may be changed. + // The current clip will change to the target clip. + // The current effect will not change. + void SwitchToClip(const ClipPaintPropertyNode*); + + // Switch the current effect to the target state. + // It is no-op if the context is already in the target state. + // Otherwise zero or more effect effects will be popped from or pushed onto + // the state stack. As effects getting popped from the stack, clips applied + // on top of them will be popped as well. Also clips will be pushed at + // appropriate steps to apply output clip to newly pushed effects. + // INPUT: + // The target effect must be a descendant of the layer's effect. + // OUTPUT: + // The current transform may be changed. + // The current clip may be changed, and is guaranteed to be a descendant of + // the output clip of the target effect. + // The current effect will change to the target effect. + void SwitchToEffect(const EffectPaintPropertyNode*); + + const TransformPaintPropertyNode* current_transform_; + const ClipPaintPropertyNode* current_clip_; + const EffectPaintPropertyNode* current_effect_; + + // State stack. + // The size of the stack is the number of nested paired items that are + // currently nested. Note that this is a "restore stack", i.e. the top + // element does not represent the current state, but the state prior to + // applying the last paired begin. + struct StateEntry { + // Remembers the type of paired begin that caused a state to be saved. + // This is useful for emitting corresponding paired end. + enum class PairedType : char { kClip, kEffect } type; + + const TransformPaintPropertyNode* transform; + const ClipPaintPropertyNode* clip; + const EffectPaintPropertyNode* effect; + }; + Vector<StateEntry> state_stack_; + + cc::DisplayItemList& cc_list_; +}; + +ConversionContext::~ConversionContext() { + for (size_t i = state_stack_.size(); i--;) { + if (state_stack_[i].type == StateEntry::PairedType::kClip) { + AppendRestore(cc_list_, 1); + } else { + DCHECK_EQ(StateEntry::PairedType::kEffect, state_stack_[i].type); + AppendRestore(cc_list_, 2); } } } +void ConversionContext::SwitchToClip(const ClipPaintPropertyNode* target_clip) { + if (target_clip == current_clip_) + return; + + // Step 1: Exit all clips until the lowest common ancestor is found. + const ClipPaintPropertyNode* lca_clip = + &LowestCommonAncestor(*target_clip, *current_clip_); + while (current_clip_ != lca_clip) { + DCHECK(state_stack_.size() && + state_stack_.back().type == StateEntry::PairedType::kClip) + << "Error: Chunk has a clip that escaped its effect's clip."; + if (!state_stack_.size() || + state_stack_.back().type != StateEntry::PairedType::kClip) + break; + StateEntry& previous_state = state_stack_.back(); + current_transform_ = previous_state.transform; + current_clip_ = previous_state.clip; + DCHECK_EQ(previous_state.effect, current_effect_); + state_stack_.pop_back(); + AppendRestore(cc_list_, 1); + } + + // Step 2: Collect all clips between the target clip and the current clip. + // At this point the current clip must be an ancestor of the target. + Vector<const ClipPaintPropertyNode*, 1u> pending_clips; + for (const ClipPaintPropertyNode* clip = target_clip; clip != current_clip_; + clip = clip->Parent()) { + // This should never happen unless the DCHECK in step 1 failed. + if (!clip) + break; + pending_clips.push_back(clip); + } + + // Step 3: Now apply the list of clips in top-down order. + for (size_t i = pending_clips.size(); i--;) { + const ClipPaintPropertyNode* sub_clip = pending_clips[i]; + DCHECK_EQ(current_clip_, sub_clip->Parent()); + + // Step 3a: Switch CTM to the clip's local space then apply clip. + cc::PaintOpBuffer* buffer = cc_list_.StartPaint(); + buffer->push<cc::SaveOp>(); + const TransformPaintPropertyNode* target_transform = + sub_clip->LocalTransformSpace(); + if (current_transform_ != target_transform) { + buffer->push<cc::ConcatOp>( + static_cast<SkMatrix>(TransformationMatrix::ToSkMatrix44( + GeometryMapper::SourceToDestinationProjection( + target_transform, current_transform_)))); + } + buffer->push<cc::ClipRectOp>( + static_cast<SkRect>(sub_clip->ClipRect().Rect()), SkClipOp::kIntersect, + false); + if (sub_clip->ClipRect().IsRounded()) { + buffer->push<cc::ClipRRectOp>(static_cast<SkRRect>(sub_clip->ClipRect()), + SkClipOp::kIntersect, true); + } + cc_list_.EndPaintOfPairedBegin(); + + // Step 3b: Adjust state and push previous state onto clip stack. + state_stack_.emplace_back(StateEntry{StateEntry::PairedType::kClip, + current_transform_, current_clip_, + current_effect_}); + current_transform_ = target_transform; + current_clip_ = sub_clip; + } +} + +void ConversionContext::SwitchToEffect( + const EffectPaintPropertyNode* target_effect) { + if (target_effect == current_effect_) + return; + + // Step 1: Exit all effects until the lowest common ancestor is found. + const EffectPaintPropertyNode* lca_effect = + &LowestCommonAncestor(*target_effect, *current_effect_); + while (current_effect_ != lca_effect) { + DCHECK(state_stack_.size()) << "Error: Chunk layerized into a layer with " + "an effect that's too deep."; + if (!state_stack_.size()) + break; + + StateEntry& previous_state = state_stack_.back(); + if (previous_state.type == StateEntry::PairedType::kClip) { + AppendRestore(cc_list_, 1); + } else { + DCHECK_EQ(StateEntry::PairedType::kEffect, previous_state.type); + AppendRestore(cc_list_, 2); + } + current_transform_ = previous_state.transform; + current_clip_ = previous_state.clip; + current_effect_ = previous_state.effect; + state_stack_.pop_back(); + } + + // Step 2: Collect all effects between the target effect and the current + // effect. At this point the current effect must be an ancestor of the target. + Vector<const EffectPaintPropertyNode*, 1u> pending_effects; + for (const EffectPaintPropertyNode* effect = target_effect; + effect != current_effect_; effect = effect->Parent()) { + // This should never happen unless the DCHECK in step 1 failed. + if (!effect) + break; + pending_effects.push_back(effect); + } + + // Step 3: Now apply the list of effects in top-down order. + for (size_t i = pending_effects.size(); i--;) { + const EffectPaintPropertyNode* sub_effect = pending_effects[i]; + DCHECK_EQ(current_effect_, sub_effect->Parent()); + + // Step 3a: Before each effect can be applied, we must enter its output + // clip first. + SwitchToClip(sub_effect->OutputClip()); + + // Step 3b: Apply non-spatial effects first, adjust CTM, then apply spatial + // effects. Strictly speaking the CTM shall be appled first, it is done + // in this particular order only to save one SaveOp. + // TODO(trchen): Omit one of the SaveLayerOp if no-op. + cc::PaintOpBuffer* buffer = cc_list_.StartPaint(); + + cc::PaintFlags flags; + flags.setBlendMode(sub_effect->BlendMode()); + // TODO(ajuma): This should really be rounding instead of flooring the + // alpha value, but that breaks slimming paint reftests. + flags.setAlpha( + static_cast<uint8_t>(gfx::ToFlooredInt(255 * sub_effect->Opacity()))); + flags.setColorFilter(GraphicsContext::WebCoreColorFilterToSkiaColorFilter( + sub_effect->GetColorFilter())); + buffer->push<cc::SaveLayerOp>(nullptr, &flags); + + const TransformPaintPropertyNode* target_transform = + sub_effect->LocalTransformSpace(); + if (current_transform_ != target_transform) { + buffer->push<cc::ConcatOp>( + static_cast<SkMatrix>(TransformationMatrix::ToSkMatrix44( + GeometryMapper::SourceToDestinationProjection( + target_transform, current_transform_)))); + } + + // TODO(chrishtr): specify origin of the filter. + FloatPoint filter_origin; + buffer->push<cc::TranslateOp>(filter_origin.X(), filter_origin.Y()); + // The size parameter is only used to computed the origin of zoom + // operation, which we never generate. + gfx::SizeF empty; + cc::PaintFlags filter_flags; + filter_flags.setImageFilter(cc::RenderSurfaceFilters::BuildImageFilter( + sub_effect->Filter().AsCcFilterOperations(), empty)); + buffer->push<cc::SaveLayerOp>(nullptr, &filter_flags); + buffer->push<cc::TranslateOp>(-filter_origin.X(), -filter_origin.Y()); + + cc_list_.EndPaintOfPairedBegin(); + + // Step 3c: Adjust state and push previous state onto effect stack. + // TODO(trchen): Change input clip to expansion hint once implemented. + const ClipPaintPropertyNode* input_clip = current_clip_; + state_stack_.emplace_back(StateEntry{StateEntry::PairedType::kEffect, + current_transform_, current_clip_, + current_effect_}); + current_transform_ = target_transform; + current_clip_ = input_clip; + current_effect_ = sub_effect; + } +} + +void ConversionContext::Convert(const Vector<const PaintChunk*>& paint_chunks, + const DisplayItemList& display_items) { + for (auto chunk_it = paint_chunks.begin(); chunk_it != paint_chunks.end(); + chunk_it++) { + const PaintChunk& chunk = **chunk_it; + const PropertyTreeState& chunk_state = chunk.properties.property_tree_state; + SwitchToEffect(chunk_state.Effect()); + SwitchToClip(chunk_state.Clip()); + bool transformed = chunk_state.Transform() != current_transform_; + if (transformed) { + cc::PaintOpBuffer* buffer = cc_list_.StartPaint(); + buffer->push<cc::SaveOp>(); + buffer->push<cc::ConcatOp>( + static_cast<SkMatrix>(TransformationMatrix::ToSkMatrix44( + GeometryMapper::SourceToDestinationProjection( + chunk_state.Transform(), current_transform_)))); + cc_list_.EndPaintOfPairedBegin(); + } + for (const auto& item : display_items.ItemsInPaintChunk(chunk)) + AppendDisplayItemToCcDisplayItemList(item, cc_list_); + if (transformed) + AppendRestore(cc_list_, 1); + } +} + } // unnamed namespace scoped_refptr<cc::DisplayItemList> PaintChunksToCcLayer::Convert( @@ -241,36 +372,10 @@ cc_list->EndPaintOfPairedBegin(); } - for (const auto* paint_chunk : paint_chunks) { - const PropertyTreeState* state = - &paint_chunk->properties.property_tree_state; - PropertyTreeStateIterator iterator(*state); - Vector<PropertyTreeState> paired_states; - for (; state && *state != layer_state; state = iterator.Next()) { - if (state->GetInnermostNode() != PropertyTreeState::kNone) - paired_states.push_back(*state); - } + ConversionContext(layer_state, *cc_list).Convert(paint_chunks, display_items); - // TODO(chrishtr): we can avoid some extra paired display items if - // multiple PaintChunks share them. We can also collapse clips between - // transforms into single clips in the same way that PaintLayerClipper does. - Vector<int> needed_restores; - - RecordPairedBeginDisplayItems(paired_states, layer_state, *cc_list, - needed_restores); - - for (const auto& display_item : - display_items.ItemsInPaintChunk(*paint_chunk)) - AppendDisplayItemToCcDisplayItemList(display_item, *cc_list); - - RecordPairedEndDisplayItems(needed_restores, *cc_list); - } - - if (need_translate) { - cc::PaintOpBuffer* buffer = cc_list->StartPaint(); - buffer->push<cc::RestoreOp>(); - cc_list->EndPaintOfPairedEnd(); - } + if (need_translate) + AppendRestore(*cc_list, 1); if (under_invalidation_checking_params) { auto& params = *under_invalidation_checking_params;
diff --git a/third_party/WebKit/Source/platform/graphics/compositing/PaintChunksToCcLayerTest.cpp b/third_party/WebKit/Source/platform/graphics/compositing/PaintChunksToCcLayerTest.cpp new file mode 100644 index 0000000..db3ba00 --- /dev/null +++ b/third_party/WebKit/Source/platform/graphics/compositing/PaintChunksToCcLayerTest.cpp
@@ -0,0 +1,375 @@ +// Copyright 2017 The Chromium Authors. All rights reserved. +// Use of this source code is governed by a BSD-style license that can be +// found in the LICENSE file. + +#include "platform/graphics/compositing/PaintChunksToCcLayer.h" + +#include <initializer_list> + +#include "cc/paint/display_item_list.h" +#include "cc/paint/paint_op_buffer.h" +#include "platform/graphics/paint/ClipPaintPropertyNode.h" +#include "platform/graphics/paint/DisplayItemList.h" +#include "platform/graphics/paint/DrawingDisplayItem.h" +#include "platform/graphics/paint/EffectPaintPropertyNode.h" +#include "platform/graphics/paint/PaintChunk.h" +#include "platform/graphics/paint/TransformPaintPropertyNode.h" +#include "platform/testing/FakeDisplayItemClient.h" +#include "platform/testing/PaintPropertyTestHelpers.h" +#include "platform/testing/RuntimeEnabledFeaturesTestHelpers.h" +#include "testing/gmock/include/gmock/gmock.h" +#include "testing/gtest/include/gtest/gtest.h" + +namespace blink { +namespace { + +using testing::CreateOpacityOnlyEffect; + +class PaintChunksToCcLayerTest : public ::testing::Test, + private ScopedSlimmingPaintV2ForTest { + protected: + PaintChunksToCcLayerTest() : ScopedSlimmingPaintV2ForTest(true) {} +}; + +const char* GetOpName(cc::PaintOpType op) { + if (op == cc::PaintOpType::ClipRect) + return "ClipRect"; + if (op == cc::PaintOpType::Concat) + return "Concat"; + if (op == cc::PaintOpType::DrawRecord) + return "DrawRecord"; + if (op == cc::PaintOpType::Save) + return "Save"; + if (op == cc::PaintOpType::SaveLayer) + return "SaveLayer"; + if (op == cc::PaintOpType::Restore) + return "Restore"; + NOTREACHED(); + return "ERROR"; +} + +// A simple matcher that only looks for a few ops, ignoring all else. +// Recognized ops: ClipRect, Concat, DrawRecord, Save, SaveLayer, Restore. +class PaintRecordMatcher + : public ::testing::MatcherInterface<const cc::PaintOpBuffer&> { + public: + static ::testing::Matcher<const cc::PaintOpBuffer&> Make( + std::initializer_list<cc::PaintOpType> args) { + return ::testing::MakeMatcher(new PaintRecordMatcher(args)); + } + PaintRecordMatcher(std::initializer_list<cc::PaintOpType> args) + : expected_ops_(args) {} + + bool MatchAndExplain( + const cc::PaintOpBuffer& buffer, + ::testing::MatchResultListener* listener) const override { + auto next = expected_ops_.begin(); + for (cc::PaintOpBuffer::Iterator it(&buffer); it; ++it) { + cc::PaintOpType op = (*it)->GetType(); + switch (op) { + case cc::PaintOpType::ClipRect: + case cc::PaintOpType::Concat: + case cc::PaintOpType::DrawRecord: + case cc::PaintOpType::Save: + case cc::PaintOpType::SaveLayer: + case cc::PaintOpType::Restore: + if (next == expected_ops_.end()) { + if (listener->IsInterested()) { + *listener << "unexpected op " << GetOpName(op) << " at index " + << it.op_idx() << ", expecting end of list."; + } + return false; + } + if (*next == op) { + next++; + continue; + } + if (listener->IsInterested()) { + *listener << "unexpected op " << GetOpName(op) << " at index " + << it.op_idx() << ", expecting " << GetOpName(*next) + << "(#" << (next - expected_ops_.begin()) << ")."; + } + return false; + default: + continue; + } + } + if (next == expected_ops_.end()) + return true; + if (listener->IsInterested()) { + *listener << "unexpected end of list, expecting " << GetOpName(*next) + << "(#" << (next - expected_ops_.begin()) << ")."; + } + return false; + } + void DescribeTo(::std::ostream* os) const override { + *os << "["; + bool first = true; + for (auto op : expected_ops_) { + if (first) + first = false; + else + *os << ", "; + *os << GetOpName(op); + } + *os << "]"; + } + + private: + Vector<cc::PaintOpType> expected_ops_; +}; + +// Convenient shorthands. +const TransformPaintPropertyNode* t0() { + return TransformPaintPropertyNode::Root(); +} +const ClipPaintPropertyNode* c0() { + return ClipPaintPropertyNode::Root(); +} +const EffectPaintPropertyNode* e0() { + return EffectPaintPropertyNode::Root(); +} + +PaintChunk::Id DefaultId() { + DEFINE_STATIC_LOCAL(FakeDisplayItemClient, fake_client, ()); + return PaintChunk::Id(fake_client, DisplayItem::kDrawingFirst); +} + +struct TestChunks { + Vector<PaintChunk> chunks; + DisplayItemList items = DisplayItemList(0); + + void AddChunk(const TransformPaintPropertyNode* t, + const ClipPaintPropertyNode* c, + const EffectPaintPropertyNode* e) { + size_t i = items.size(); + auto record = sk_make_sp<PaintRecord>(); + record->push<cc::NoopOp>(); + items.AllocateAndConstruct<DrawingDisplayItem>( + DefaultId().client, DefaultId().type, std::move(record), + FloatRect(-200000, -200000, 400000, 400000)); + chunks.emplace_back(i, i + 1, DefaultId(), PropertyTreeState(t, c, e)); + } + + Vector<const PaintChunk*> GetChunkList() const { + Vector<const PaintChunk*> result; + for (const PaintChunk& chunk : chunks) + result.push_back(&chunk); + return result; + } +}; + +TEST_F(PaintChunksToCcLayerTest, EffectGroupingSimple) { + // This test verifies effects are applied as a group. + RefPtr<EffectPaintPropertyNode> e1 = CreateOpacityOnlyEffect(e0(), 0.5f); + TestChunks chunks; + chunks.AddChunk(t0(), c0(), e1.Get()); + chunks.AddChunk(t0(), c0(), e1.Get()); + + sk_sp<PaintRecord> output = + PaintChunksToCcLayer::Convert(chunks.GetChunkList(), + PropertyTreeState(t0(), c0(), e0()), + gfx::Vector2dF(), chunks.items) + ->ReleaseAsRecord(); + EXPECT_THAT( + output, + Pointee(PaintRecordMatcher::Make( + {cc::PaintOpType::SaveLayer, cc::PaintOpType::SaveLayer, // <e1> + cc::PaintOpType::DrawRecord, // <p0/> + cc::PaintOpType::DrawRecord, // <p1/> + cc::PaintOpType::Restore, cc::PaintOpType::Restore}))); // </e1> +} + +TEST_F(PaintChunksToCcLayerTest, EffectGroupingNested) { + // This test verifies nested effects are grouped properly. + RefPtr<EffectPaintPropertyNode> e1 = CreateOpacityOnlyEffect(e0(), 0.5f); + RefPtr<EffectPaintPropertyNode> e2 = CreateOpacityOnlyEffect(e1.Get(), 0.5f); + RefPtr<EffectPaintPropertyNode> e3 = CreateOpacityOnlyEffect(e1.Get(), 0.5f); + TestChunks chunks; + chunks.AddChunk(t0(), c0(), e2.Get()); + chunks.AddChunk(t0(), c0(), e3.Get()); + + sk_sp<PaintRecord> output = + PaintChunksToCcLayer::Convert(chunks.GetChunkList(), + PropertyTreeState(t0(), c0(), e0()), + gfx::Vector2dF(), chunks.items) + ->ReleaseAsRecord(); + EXPECT_THAT( + output, + Pointee(PaintRecordMatcher::Make( + {cc::PaintOpType::SaveLayer, cc::PaintOpType::SaveLayer, // <e1> + cc::PaintOpType::SaveLayer, cc::PaintOpType::SaveLayer, // <e2> + cc::PaintOpType::DrawRecord, // <p0/> + cc::PaintOpType::Restore, cc::PaintOpType::Restore, // </e2> + cc::PaintOpType::SaveLayer, cc::PaintOpType::SaveLayer, // <e3> + cc::PaintOpType::DrawRecord, // <p1/> + cc::PaintOpType::Restore, cc::PaintOpType::Restore, // </e3> + cc::PaintOpType::Restore, cc::PaintOpType::Restore}))); // </e1> +} + +TEST_F(PaintChunksToCcLayerTest, InterleavedClipEffect) { + // This test verifies effects are enclosed by their output clips. + // It is the same as the example made in the class comments of + // ConversionContext. + // Refer to PaintChunksToCcLayer.cpp for detailed explanation. + // (Search "State management example".) + RefPtr<ClipPaintPropertyNode> c1 = ClipPaintPropertyNode::Create( + c0(), t0(), FloatRoundedRect(0.f, 0.f, 1.f, 1.f)); + RefPtr<ClipPaintPropertyNode> c2 = ClipPaintPropertyNode::Create( + c1.Get(), t0(), FloatRoundedRect(0.f, 0.f, 1.f, 1.f)); + RefPtr<ClipPaintPropertyNode> c3 = ClipPaintPropertyNode::Create( + c2.Get(), t0(), FloatRoundedRect(0.f, 0.f, 1.f, 1.f)); + RefPtr<ClipPaintPropertyNode> c4 = ClipPaintPropertyNode::Create( + c3.Get(), t0(), FloatRoundedRect(0.f, 0.f, 1.f, 1.f)); + RefPtr<EffectPaintPropertyNode> e1 = EffectPaintPropertyNode::Create( + e0(), t0(), c2.Get(), ColorFilter(), CompositorFilterOperations(), 0.5f, + SkBlendMode::kSrcOver); + RefPtr<EffectPaintPropertyNode> e2 = EffectPaintPropertyNode::Create( + e1.Get(), t0(), c4.Get(), ColorFilter(), CompositorFilterOperations(), + 0.5f, SkBlendMode::kSrcOver); + TestChunks chunks; + chunks.AddChunk(t0(), c3.Get(), e0()); + chunks.AddChunk(t0(), c4.Get(), e2.Get()); + chunks.AddChunk(t0(), c3.Get(), e1.Get()); + chunks.AddChunk(t0(), c4.Get(), e0()); + + sk_sp<PaintRecord> output = + PaintChunksToCcLayer::Convert(chunks.GetChunkList(), + PropertyTreeState(t0(), c0(), e0()), + gfx::Vector2dF(), chunks.items) + ->ReleaseAsRecord(); + EXPECT_THAT( + output, + Pointee(PaintRecordMatcher::Make( + {cc::PaintOpType::Save, cc::PaintOpType::ClipRect, // <c1> + cc::PaintOpType::Save, cc::PaintOpType::ClipRect, // <c2> + cc::PaintOpType::Save, cc::PaintOpType::ClipRect, // <c3> + cc::PaintOpType::DrawRecord, // <p0/> + cc::PaintOpType::Restore, // </c3> + cc::PaintOpType::SaveLayer, cc::PaintOpType::SaveLayer, // <e1> + cc::PaintOpType::Save, cc::PaintOpType::ClipRect, // <c3> + cc::PaintOpType::Save, cc::PaintOpType::ClipRect, // <c4> + cc::PaintOpType::SaveLayer, cc::PaintOpType::SaveLayer, // <e2> + cc::PaintOpType::DrawRecord, // <p1/> + cc::PaintOpType::Restore, cc::PaintOpType::Restore, // </e2> + cc::PaintOpType::Restore, // </c4> + cc::PaintOpType::DrawRecord, // <p2/> + cc::PaintOpType::Restore, // </c3> + cc::PaintOpType::Restore, cc::PaintOpType::Restore, // </e1> + cc::PaintOpType::Save, cc::PaintOpType::ClipRect, // <c3> + cc::PaintOpType::Save, cc::PaintOpType::ClipRect, // <c4> + cc::PaintOpType::DrawRecord, // <p3/> + cc::PaintOpType::Restore, // </c4> + cc::PaintOpType::Restore, // </c3> + cc::PaintOpType::Restore, // </c2> + cc::PaintOpType::Restore}))); // </c1> +} + +TEST_F(PaintChunksToCcLayerTest, ClipSpaceInversion) { + // This test verifies chunks that have a shallower transform state than + // its clip can still be painted. The infamous CSS corner case: + // <div style="position:absolute; clip:rect(...)"> + // <div style="position:fixed;">Clipped but not scroll along.</div> + // </div> + RefPtr<TransformPaintPropertyNode> t1 = TransformPaintPropertyNode::Create( + t0(), TransformationMatrix().Scale(2.f), FloatPoint3D()); + RefPtr<ClipPaintPropertyNode> c1 = ClipPaintPropertyNode::Create( + c0(), t1.Get(), FloatRoundedRect(0.f, 0.f, 1.f, 1.f)); + TestChunks chunks; + chunks.AddChunk(t0(), c1.Get(), e0()); + + sk_sp<PaintRecord> output = + PaintChunksToCcLayer::Convert(chunks.GetChunkList(), + PropertyTreeState(t0(), c0(), e0()), + gfx::Vector2dF(), chunks.items) + ->ReleaseAsRecord(); + EXPECT_THAT(output, + Pointee(PaintRecordMatcher::Make( + {cc::PaintOpType::Save, cc::PaintOpType::Concat, // <t1 + cc::PaintOpType::ClipRect, // c1> + cc::PaintOpType::Save, cc::PaintOpType::Concat, // <t1^-1> + cc::PaintOpType::DrawRecord, // <p0/> + cc::PaintOpType::Restore, // </t1^-1> + cc::PaintOpType::Restore}))); // </c1 t1> +} + +TEST_F(PaintChunksToCcLayerTest, EffectSpaceInversion) { + // This test verifies chunks that have a shallower transform state than + // its effect can still be painted. The infamous CSS corner case: + // <div style="overflow:scroll"> + // <div style="opacity:0.5"> + // <div style="position:absolute;">Transparent but not scroll + // along.</div> + // </div> + // </div> + RefPtr<TransformPaintPropertyNode> t1 = TransformPaintPropertyNode::Create( + t0(), TransformationMatrix().Scale(2.f), FloatPoint3D()); + RefPtr<EffectPaintPropertyNode> e1 = EffectPaintPropertyNode::Create( + e0(), t1.Get(), c0(), ColorFilter(), CompositorFilterOperations(), 0.5f, + SkBlendMode::kSrcOver); + TestChunks chunks; + chunks.AddChunk(t0(), c0(), e1.Get()); + + sk_sp<PaintRecord> output = + PaintChunksToCcLayer::Convert(chunks.GetChunkList(), + PropertyTreeState(t0(), c0(), e0()), + gfx::Vector2dF(), chunks.items) + ->ReleaseAsRecord(); + EXPECT_THAT( + output, + Pointee(PaintRecordMatcher::Make( + {cc::PaintOpType::SaveLayer, cc::PaintOpType::Concat, // <t1 + cc::PaintOpType::SaveLayer, // e1> + cc::PaintOpType::Save, cc::PaintOpType::Concat, // <t1^-1> + cc::PaintOpType::DrawRecord, // <p0/> + cc::PaintOpType::Restore, // </t1^-1> + cc::PaintOpType::Restore, cc::PaintOpType::Restore}))); // </e1 t1> +} + +TEST_F(PaintChunksToCcLayerTest, NonRootLayerSimple) { + // This test verifies a layer with composited property state does not + // apply properties again internally. + RefPtr<TransformPaintPropertyNode> t1 = TransformPaintPropertyNode::Create( + t0(), TransformationMatrix().Scale(2.f), FloatPoint3D()); + RefPtr<ClipPaintPropertyNode> c1 = ClipPaintPropertyNode::Create( + c0(), t0(), FloatRoundedRect(0.f, 0.f, 1.f, 1.f)); + RefPtr<EffectPaintPropertyNode> e1 = CreateOpacityOnlyEffect(e0(), 0.5f); + TestChunks chunks; + chunks.AddChunk(t1.Get(), c1.Get(), e1.Get()); + + sk_sp<PaintRecord> output = + PaintChunksToCcLayer::Convert( + chunks.GetChunkList(), + PropertyTreeState(t1.Get(), c1.Get(), e1.Get()), gfx::Vector2dF(), + chunks.items) + ->ReleaseAsRecord(); + EXPECT_THAT(output, + Pointee(PaintRecordMatcher::Make({cc::PaintOpType::DrawRecord}))); +} + +TEST_F(PaintChunksToCcLayerTest, NonRootLayerTransformEscape) { + // This test verifies chunks that have a shallower transform state than the + // layer can still be painted. + RefPtr<TransformPaintPropertyNode> t1 = TransformPaintPropertyNode::Create( + t0(), TransformationMatrix().Scale(2.f), FloatPoint3D()); + RefPtr<ClipPaintPropertyNode> c1 = ClipPaintPropertyNode::Create( + c0(), t0(), FloatRoundedRect(0.f, 0.f, 1.f, 1.f)); + RefPtr<EffectPaintPropertyNode> e1 = CreateOpacityOnlyEffect(e0(), 0.5f); + TestChunks chunks; + chunks.AddChunk(t0(), c1.Get(), e1.Get()); + + sk_sp<PaintRecord> output = + PaintChunksToCcLayer::Convert( + chunks.GetChunkList(), + PropertyTreeState(t1.Get(), c1.Get(), e1.Get()), gfx::Vector2dF(), + chunks.items) + ->ReleaseAsRecord(); + EXPECT_THAT(output, + Pointee(PaintRecordMatcher::Make( + {cc::PaintOpType::Save, cc::PaintOpType::Concat, // <t1^-1> + cc::PaintOpType::DrawRecord, // <p0/> + cc::PaintOpType::Restore}))); // </t1^-1> +} + +} // namespace +} // namespace blink
diff --git a/third_party/WebKit/Source/platform/instrumentation/resource_coordinator/FrameResourceCoordinator.cpp b/third_party/WebKit/Source/platform/instrumentation/resource_coordinator/FrameResourceCoordinator.cpp index 2729c5f..23627c7 100644 --- a/third_party/WebKit/Source/platform/instrumentation/resource_coordinator/FrameResourceCoordinator.cpp +++ b/third_party/WebKit/Source/platform/instrumentation/resource_coordinator/FrameResourceCoordinator.cpp
@@ -4,10 +4,9 @@ #include "platform/instrumentation/resource_coordinator/FrameResourceCoordinator.h" -#include "public/platform/InterfaceProvider.h" -#include "public/platform/Platform.h" #include "services/resource_coordinator/public/cpp/resource_coordinator_features.h" #include "services/resource_coordinator/public/interfaces/coordination_unit_provider.mojom-blink.h" +#include "services/service_manager/public/cpp/interface_provider.h" namespace blink { @@ -24,12 +23,12 @@ // static FrameResourceCoordinator* FrameResourceCoordinator::Create( - InterfaceProvider* interface_provider) { + service_manager::InterfaceProvider* interface_provider) { return new FrameResourceCoordinator(interface_provider); } FrameResourceCoordinator::FrameResourceCoordinator( - InterfaceProvider* interface_provider) { + service_manager::InterfaceProvider* interface_provider) { interface_provider->GetInterface(mojo::MakeRequest(&service_)); service_.set_connection_error_handler(
diff --git a/third_party/WebKit/Source/platform/instrumentation/resource_coordinator/FrameResourceCoordinator.h b/third_party/WebKit/Source/platform/instrumentation/resource_coordinator/FrameResourceCoordinator.h index 51e405dd..810706f09 100644 --- a/third_party/WebKit/Source/platform/instrumentation/resource_coordinator/FrameResourceCoordinator.h +++ b/third_party/WebKit/Source/platform/instrumentation/resource_coordinator/FrameResourceCoordinator.h
@@ -8,9 +8,11 @@ #include "platform/heap/Handle.h" #include "services/resource_coordinator/public/interfaces/coordination_unit.mojom-blink.h" -namespace blink { - +namespace service_manager { class InterfaceProvider; +} + +namespace blink { class PLATFORM_EXPORT FrameResourceCoordinator final : public GarbageCollectedFinalized<FrameResourceCoordinator> { @@ -18,14 +20,14 @@ public: static bool IsEnabled(); - static FrameResourceCoordinator* Create(InterfaceProvider*); + static FrameResourceCoordinator* Create(service_manager::InterfaceProvider*); virtual ~FrameResourceCoordinator(); void SendEvent(const resource_coordinator::mojom::blink::EventType&); DECLARE_TRACE(); private: - explicit FrameResourceCoordinator(InterfaceProvider*); + explicit FrameResourceCoordinator(service_manager::InterfaceProvider*); resource_coordinator::mojom::blink::CoordinationUnitPtr service_; };
diff --git a/third_party/WebKit/Source/platform/loader/fetch/ResourceFetcherTest.cpp b/third_party/WebKit/Source/platform/loader/fetch/ResourceFetcherTest.cpp index 5dd391e..adaf7bc 100644 --- a/third_party/WebKit/Source/platform/loader/fetch/ResourceFetcherTest.cpp +++ b/third_party/WebKit/Source/platform/loader/fetch/ResourceFetcherTest.cpp
@@ -614,7 +614,7 @@ EXPECT_TRUE(fetcher->ContainsAsPreload(resource1)); Platform::Current()->GetURLLoaderMockFactory()->ServeAsynchronousRequests(); - // The second preload fetch returnes the first preload. + // The second preload fetch returns the first preload. Resource* resource2 = MockResource::Fetch(fetch_params_for_preload, fetcher); EXPECT_TRUE(fetcher->ContainsAsPreload(resource1)); EXPECT_TRUE(resource1->IsPreloaded()); @@ -645,7 +645,7 @@ EXPECT_TRUE(fetcher->ContainsAsPreload(resource1)); Platform::Current()->GetURLLoaderMockFactory()->ServeAsynchronousRequests(); - // The second preload fetch returnes the first preload. + // The second preload fetch returns the first preload. Resource* resource2 = MockResource::Fetch(fetch_params_for_preload, fetcher); EXPECT_TRUE(fetcher->ContainsAsPreload(resource1)); EXPECT_TRUE(resource1->IsPreloaded()); @@ -681,7 +681,7 @@ EXPECT_TRUE(fetcher->ContainsAsPreload(resource1)); Platform::Current()->GetURLLoaderMockFactory()->ServeAsynchronousRequests(); - // The second preload fetch returnes the first preload. + // The second preload fetch returns the first preload. Resource* resource2 = MockResource::Fetch(fetch_params_for_link_preload, fetcher); EXPECT_TRUE(fetcher->ContainsAsPreload(resource1));
diff --git a/third_party/WebKit/Source/platform/scheduler/base/task_queue.cc b/third_party/WebKit/Source/platform/scheduler/base/task_queue.cc new file mode 100644 index 0000000..ad00471 --- /dev/null +++ b/third_party/WebKit/Source/platform/scheduler/base/task_queue.cc
@@ -0,0 +1,128 @@ +// Copyright 2017 The Chromium Authors. All rights reserved. +// Use of this source code is governed by a BSD-style license that can be +// found in the LICENSE file. + +#include "platform/scheduler/base/task_queue.h" + +#include "platform/scheduler/base/task_queue_impl.h" + +namespace blink { +namespace scheduler { + +TaskQueue::TaskQueue(std::unique_ptr<internal::TaskQueueImpl> impl) + : impl_(std::move(impl)) {} + +TaskQueue::~TaskQueue() {} + +void TaskQueue::UnregisterTaskQueue() { + impl_->UnregisterTaskQueue(this); +} + +bool TaskQueue::RunsTasksInCurrentSequence() const { + return impl_->RunsTasksInCurrentSequence(); +} + +bool TaskQueue::PostDelayedTask(const tracked_objects::Location& from_here, + base::OnceClosure task, + base::TimeDelta delay) { + return impl_->PostDelayedTask(from_here, std::move(task), delay); +} + +bool TaskQueue::PostNonNestableDelayedTask( + const tracked_objects::Location& from_here, + base::OnceClosure task, + base::TimeDelta delay) { + return impl_->PostNonNestableDelayedTask(from_here, std::move(task), delay); +} + +std::unique_ptr<TaskQueue::QueueEnabledVoter> +TaskQueue::CreateQueueEnabledVoter() { + return impl_->CreateQueueEnabledVoter(this); +} + +bool TaskQueue::IsQueueEnabled() const { + return impl_->IsQueueEnabled(); +} + +bool TaskQueue::IsEmpty() const { + return impl_->IsEmpty(); +} + +size_t TaskQueue::GetNumberOfPendingTasks() const { + return impl_->GetNumberOfPendingTasks(); +} + +bool TaskQueue::HasTaskToRunImmediately() const { + return impl_->HasTaskToRunImmediately(); +} + +base::Optional<base::TimeTicks> TaskQueue::GetNextScheduledWakeUp() { + return impl_->GetNextScheduledWakeUp(); +} + +void TaskQueue::SetQueuePriority(TaskQueue::QueuePriority priority) { + impl_->SetQueuePriority(priority); +} + +TaskQueue::QueuePriority TaskQueue::GetQueuePriority() const { + return impl_->GetQueuePriority(); +} + +void TaskQueue::AddTaskObserver( + base::MessageLoop::TaskObserver* task_observer) { + impl_->AddTaskObserver(task_observer); +} + +void TaskQueue::RemoveTaskObserver( + base::MessageLoop::TaskObserver* task_observer) { + impl_->RemoveTaskObserver(task_observer); +} + +void TaskQueue::SetTimeDomain(TimeDomain* time_domain) { + impl_->SetTimeDomain(time_domain); +} + +TimeDomain* TaskQueue::GetTimeDomain() const { + return impl_->GetTimeDomain(); +} + +void TaskQueue::SetBlameContext( + base::trace_event::BlameContext* blame_context) { + impl_->SetBlameContext(blame_context); +} + +void TaskQueue::InsertFence(InsertFencePosition position) { + impl_->InsertFence(position); +} + +void TaskQueue::RemoveFence() { + impl_->RemoveFence(); +} + +bool TaskQueue::HasFence() const { + return impl_->HasFence(); +} + +bool TaskQueue::BlockedByFence() const { + return impl_->BlockedByFence(); +} + +const char* TaskQueue::GetName() const { + return impl_->GetName(); +} + +void TaskQueue::SetObserver(Observer* observer) { + if (observer) { + // Observer is guaranteed to outlive TaskQueue and TaskQueueImpl lifecycle + // is controlled by |this|. + impl_->SetOnNextWakeUpChangedCallback( + base::Bind(&TaskQueue::Observer::OnQueueNextWakeUpChanged, + base::Unretained(observer), base::Unretained(this))); + } else { + impl_->SetOnNextWakeUpChangedCallback( + base::Callback<void(base::TimeTicks)>()); + } +} + +} // namespace scheduler +} // namespace blink
diff --git a/third_party/WebKit/Source/platform/scheduler/base/task_queue.h b/third_party/WebKit/Source/platform/scheduler/base/task_queue.h index 237aef3..27c0652 100644 --- a/third_party/WebKit/Source/platform/scheduler/base/task_queue.h +++ b/third_party/WebKit/Source/platform/scheduler/base/task_queue.h
@@ -9,6 +9,8 @@ #include "base/message_loop/message_loop.h" #include "base/optional.h" #include "base/single_thread_task_runner.h" +#include "base/synchronization/lock.h" +#include "base/threading/platform_thread.h" #include "base/time/time.h" #include "platform/PlatformExport.h" @@ -21,12 +23,14 @@ namespace blink { namespace scheduler { +namespace internal { +class TaskQueueImpl; +} + class TimeDomain; class PLATFORM_EXPORT TaskQueue : public base::SingleThreadTaskRunner { public: - TaskQueue() {} - class PLATFORM_EXPORT Observer { public: virtual ~Observer() {} @@ -46,7 +50,7 @@ // Unregisters the task queue after which no tasks posted to it will run and // the TaskQueueManager's reference to it will be released soon. - virtual void UnregisterTaskQueue() = 0; + virtual void UnregisterTaskQueue(); enum QueuePriority { // Queues with control priority will run before any other queue, and will @@ -74,33 +78,10 @@ // Can be called on any thread. static const char* PriorityToString(QueuePriority priority); - enum class QueueType { - // Keep TaskQueue::NameForQueueType in sync. - // This enum is used for a histogram and it should not be re-numbered. - CONTROL = 0, - DEFAULT = 1, - DEFAULT_LOADING = 2, - DEFAULT_TIMER = 3, - UNTHROTTLED = 4, - FRAME_LOADING = 5, - FRAME_TIMER = 6, - FRAME_UNTHROTTLED = 7, - COMPOSITOR = 8, - IDLE = 9, - TEST = 10, - - COUNT = 11 - }; - - // Returns name of the given queue type. Returned string has application - // lifetime. - static const char* NameForQueueType(QueueType queue_type); - - // Options for constructing a TaskQueue. Once set the |name| and - // |should_monitor_quiescence| are immutable. + // Options for constructing a TaskQueue. struct Spec { - explicit Spec(QueueType type) - : type(type), + explicit Spec(const char* name) + : name(name), should_monitor_quiescence(false), time_domain(nullptr), should_notify_observers(true), @@ -127,7 +108,7 @@ return *this; } - QueueType type; + const char* name; bool should_monitor_quiescence; TimeDomain* time_domain; bool should_notify_observers; @@ -156,59 +137,53 @@ // TaskQueue is enabled. The TaskQueue will be enabled if there are no voters // or if all agree it should be enabled. // NOTE this must be called on the thread this TaskQueue was created by. - virtual std::unique_ptr<QueueEnabledVoter> CreateQueueEnabledVoter() = 0; + std::unique_ptr<QueueEnabledVoter> CreateQueueEnabledVoter(); // NOTE this must be called on the thread this TaskQueue was created by. - virtual bool IsQueueEnabled() const = 0; + bool IsQueueEnabled() const; // Returns true if the queue is completely empty. - virtual bool IsEmpty() const = 0; + bool IsEmpty() const; // Returns the number of pending tasks in the queue. - virtual size_t GetNumberOfPendingTasks() const = 0; + size_t GetNumberOfPendingTasks() const; // Returns true if the queue has work that's ready to execute now. // NOTE: this must be called on the thread this TaskQueue was created by. - virtual bool HasTaskToRunImmediately() const = 0; + bool HasTaskToRunImmediately() const; // Returns requested run time of next scheduled wake-up for a delayed task // which is not ready to run. If there are no such tasks or the queue is // disabled (by a QueueEnabledVoter) it returns base::nullopt. // NOTE: this must be called on the thread this TaskQueue was created by. - virtual base::Optional<base::TimeTicks> GetNextScheduledWakeUp() = 0; + base::Optional<base::TimeTicks> GetNextScheduledWakeUp(); // Can be called on any thread. - virtual QueueType GetQueueType() const = 0; - - // Can be called on any thread. - virtual const char* GetName() const = 0; + virtual const char* GetName() const; // Set the priority of the queue to |priority|. NOTE this must be called on // the thread this TaskQueue was created by. - virtual void SetQueuePriority(QueuePriority priority) = 0; + void SetQueuePriority(QueuePriority priority); // Returns the current queue priority. - virtual QueuePriority GetQueuePriority() const = 0; + QueuePriority GetQueuePriority() const; // These functions can only be called on the same thread that the task queue // manager executes its tasks on. - virtual void AddTaskObserver( - base::MessageLoop::TaskObserver* task_observer) = 0; - virtual void RemoveTaskObserver( - base::MessageLoop::TaskObserver* task_observer) = 0; + void AddTaskObserver(base::MessageLoop::TaskObserver* task_observer); + void RemoveTaskObserver(base::MessageLoop::TaskObserver* task_observer); // Set the blame context which is entered and left while executing tasks from // this task queue. |blame_context| must be null or outlive this task queue. // Must be called on the thread this TaskQueue was created by. - virtual void SetBlameContext( - base::trace_event::BlameContext* blame_context) = 0; + void SetBlameContext(base::trace_event::BlameContext* blame_context); // Removes the task queue from the previous TimeDomain and adds it to // |domain|. This is a moderately expensive operation. - virtual void SetTimeDomain(TimeDomain* domain) = 0; + void SetTimeDomain(TimeDomain* domain); // Returns the queue's current TimeDomain. Can be called from any thread. - virtual TimeDomain* GetTimeDomain() const = 0; + TimeDomain* GetTimeDomain() const; enum class InsertFencePosition { NOW, // Tasks posted on the queue up till this point further may run. @@ -221,21 +196,41 @@ // removed or a subsequent fence has unblocked some tasks within the queue. // Note: delayed tasks get their enqueue order set once their delay has // expired, and non-delayed tasks get their enqueue order set when posted. - virtual void InsertFence(InsertFencePosition position) = 0; + void InsertFence(InsertFencePosition position); // Removes any previously added fence and unblocks execution of any tasks // blocked by it. - virtual void RemoveFence() = 0; + void RemoveFence(); - virtual bool HasFence() const = 0; + bool HasFence() const; // Returns true if the queue has a fence which is blocking execution of tasks. - virtual bool BlockedByFence() const = 0; + bool BlockedByFence() const; - virtual void SetObserver(Observer* observer) = 0; + void SetObserver(Observer* observer); + + // base::SingleThreadTaskRunner implementation + bool RunsTasksInCurrentSequence() const override; + bool PostDelayedTask(const tracked_objects::Location& from_here, + base::OnceClosure task, + base::TimeDelta delay) override; + bool PostNonNestableDelayedTask(const tracked_objects::Location& from_here, + base::OnceClosure task, + base::TimeDelta delay) override; protected: - ~TaskQueue() override {} + explicit TaskQueue(std::unique_ptr<internal::TaskQueueImpl> impl); + ~TaskQueue() override; + + internal::TaskQueueImpl* GetTaskQueueImpl() const { return impl_.get(); } + + private: + friend class internal::TaskQueueImpl; + friend class TaskQueueManager; + + friend class TaskQueueThrottlerTest; + + const std::unique_ptr<internal::TaskQueueImpl> impl_; DISALLOW_COPY_AND_ASSIGN(TaskQueue); };
diff --git a/third_party/WebKit/Source/platform/scheduler/base/task_queue_impl.cc b/third_party/WebKit/Source/platform/scheduler/base/task_queue_impl.cc index 8063c89c..b16bea2b 100644 --- a/third_party/WebKit/Source/platform/scheduler/base/task_queue_impl.cc +++ b/third_party/WebKit/Source/platform/scheduler/base/task_queue_impl.cc
@@ -20,40 +20,7 @@ namespace scheduler { // static -const char* TaskQueue::NameForQueueType(TaskQueue::QueueType queue_type) { - switch (queue_type) { - case TaskQueue::QueueType::CONTROL: - return "control_tq"; - case TaskQueue::QueueType::DEFAULT: - return "default_tq"; - case TaskQueue::QueueType::DEFAULT_LOADING: - return "default_loading_tq"; - case TaskQueue::QueueType::DEFAULT_TIMER: - return "default_timer_tq"; - case TaskQueue::QueueType::UNTHROTTLED: - return "unthrottled_tq"; - case TaskQueue::QueueType::FRAME_LOADING: - return "frame_loading_tq"; - case TaskQueue::QueueType::FRAME_TIMER: - return "frame_timer_tq"; - case TaskQueue::QueueType::FRAME_UNTHROTTLED: - return "frame_unthrottled_tq"; - case TaskQueue::QueueType::COMPOSITOR: - return "compositor_tq"; - case TaskQueue::QueueType::IDLE: - return "idle_tq"; - case TaskQueue::QueueType::TEST: - return "test_tq"; - case TaskQueue::QueueType::COUNT: - DCHECK(false); - return nullptr; - } - DCHECK(false); - return nullptr; -} - -// static -const char* TaskQueue::PriorityToString(QueuePriority priority) { +const char* TaskQueue::PriorityToString(TaskQueue::QueuePriority priority) { switch (priority) { case CONTROL_PRIORITY: return "control"; @@ -75,11 +42,10 @@ TaskQueueImpl::TaskQueueImpl(TaskQueueManager* task_queue_manager, TimeDomain* time_domain, - const Spec& spec) - : thread_id_(base::PlatformThread::CurrentId()), + const TaskQueue::Spec& spec) + : name_(spec.name), + thread_id_(base::PlatformThread::CurrentId()), any_thread_(task_queue_manager, time_domain), - type_(spec.type), - name_(NameForQueueType(spec.type)), main_thread_only_(task_queue_manager, this, time_domain), should_monitor_quiescence_(spec.should_monitor_quiescence), should_notify_observers_(spec.should_notify_observers), @@ -141,9 +107,7 @@ TaskQueueImpl::AnyThread::AnyThread(TaskQueueManager* task_queue_manager, TimeDomain* time_domain) - : task_queue_manager(task_queue_manager), - time_domain(time_domain), - observer(nullptr) {} + : task_queue_manager(task_queue_manager), time_domain(time_domain) {} TaskQueueImpl::AnyThread::~AnyThread() {} @@ -153,7 +117,6 @@ TimeDomain* time_domain) : task_queue_manager(task_queue_manager), time_domain(time_domain), - observer(nullptr), delayed_work_queue( new WorkQueue(task_queue, "delayed", WorkQueue::QueueType::DELAYED)), immediate_work_queue(new WorkQueue(task_queue, @@ -163,31 +126,39 @@ is_enabled_refcount(0), voter_refcount(0), blame_context(nullptr), - current_fence(0) {} + current_fence(0), + is_enabled_for_test(true) {} TaskQueueImpl::MainThreadOnly::~MainThreadOnly() {} -void TaskQueueImpl::UnregisterTaskQueue() { +void TaskQueueImpl::UnregisterTaskQueue(scoped_refptr<TaskQueue> task_queue) { base::AutoLock lock(any_thread_lock_); base::AutoLock immediate_incoming_queue_lock(immediate_incoming_queue_lock_); if (main_thread_only().time_domain) main_thread_only().time_domain->UnregisterQueue(this); if (!any_thread().task_queue_manager) return; + + main_thread_only().on_task_completed_handler = OnTaskCompletedHandler(); any_thread().time_domain = nullptr; main_thread_only().time_domain = nullptr; - any_thread().task_queue_manager->UnregisterTaskQueue(this); + any_thread().task_queue_manager->UnregisterTaskQueue(task_queue); any_thread().task_queue_manager = nullptr; main_thread_only().task_queue_manager = nullptr; - any_thread().observer = nullptr; - main_thread_only().observer = nullptr; + any_thread().on_next_wake_up_changed_callback = OnNextWakeUpChangedCallback(); + main_thread_only().on_next_wake_up_changed_callback = + OnNextWakeUpChangedCallback(); main_thread_only().delayed_incoming_queue = std::priority_queue<Task>(); immediate_incoming_queue().clear(); main_thread_only().immediate_work_queue.reset(); main_thread_only().delayed_work_queue.reset(); } +const char* TaskQueueImpl::GetName() const { + return name_; +} + bool TaskQueueImpl::RunsTasksInCurrentSequence() const { return base::PlatformThread::CurrentId() == thread_id_; } @@ -304,12 +275,10 @@ int thread_hop_task_sequence_number = any_thread().task_queue_manager->GetNextSequenceNumber(); PushOntoImmediateIncomingQueueLocked( - FROM_HERE, - base::Bind(&TaskQueueImpl::ScheduleDelayedWorkTask, this, - base::Passed(&pending_task)), - base::TimeTicks(), - thread_hop_task_sequence_number, - false); + FROM_HERE, + base::Bind(&TaskQueueImpl::ScheduleDelayedWorkTask, + base::Unretained(this), base::Passed(&pending_task)), + base::TimeTicks(), thread_hop_task_sequence_number, false); } void TaskQueueImpl::ScheduleDelayedWorkTask(Task pending_task) { @@ -361,8 +330,8 @@ (!IsQueueEnabled() || main_thread_only().current_fence); any_thread().task_queue_manager->OnQueueHasIncomingImmediateWork( this, sequence_number, queue_is_blocked); - if (any_thread().observer) - any_thread().observer->OnQueueNextWakeUpChanged(this, desired_run_time); + if (!any_thread().on_next_wake_up_changed_callback.is_null()) + any_thread().on_next_wake_up_changed_callback.Run(desired_run_time); } TraceQueueSize(); @@ -479,22 +448,14 @@ main_thread_only().delayed_incoming_queue.size()); } -const char* TaskQueueImpl::GetName() const { - return name_; -} - -TaskQueue::QueueType TaskQueueImpl::GetQueueType() const { - return type_; -} - -void TaskQueueImpl::SetQueuePriority(QueuePriority priority) { +void TaskQueueImpl::SetQueuePriority(TaskQueue::QueuePriority priority) { if (!main_thread_only().task_queue_manager || priority == GetQueuePriority()) return; main_thread_only().task_queue_manager->selector_.SetQueuePriority(this, priority); } -TaskQueueImpl::QueuePriority TaskQueueImpl::GetQueuePriority() const { +TaskQueue::QueuePriority TaskQueueImpl::GetQueuePriority() const { size_t set_index = immediate_work_queue()->work_queue_set_index(); DCHECK_EQ(set_index, delayed_work_queue()->work_queue_set_index()); return static_cast<TaskQueue::QueuePriority>(set_index); @@ -548,7 +509,7 @@ QueueAsValueInto(main_thread_only().delayed_incoming_queue, now, state); state->EndArray(); } - state->SetString("priority", PriorityToString(GetQueuePriority())); + state->SetString("priority", TaskQueue::PriorityToString(GetQueuePriority())); state->EndDictionary(); } @@ -762,18 +723,19 @@ } TaskQueueImpl::QueueEnabledVoterImpl::QueueEnabledVoterImpl( - TaskQueueImpl* task_queue) + scoped_refptr<TaskQueue> task_queue) : task_queue_(task_queue), enabled_(true) {} TaskQueueImpl::QueueEnabledVoterImpl::~QueueEnabledVoterImpl() { - task_queue_->RemoveQueueEnabledVoter(this); + if (task_queue_->GetTaskQueueImpl()) + task_queue_->GetTaskQueueImpl()->RemoveQueueEnabledVoter(this); } void TaskQueueImpl::QueueEnabledVoterImpl::SetQueueEnabled(bool enabled) { if (enabled_ == enabled) return; - task_queue_->OnQueueEnabledVoteChanged(enabled); + task_queue_->GetTaskQueueImpl()->OnQueueEnabledVoteChanged(enabled); enabled_ = enabled; } @@ -798,8 +760,10 @@ } bool TaskQueueImpl::IsQueueEnabled() const { - return main_thread_only().is_enabled_refcount == - main_thread_only().voter_refcount; + // By default is_enabled_refcount and voter_refcount both equal zero. + return (main_thread_only().is_enabled_refcount == + main_thread_only().voter_refcount) && + main_thread_only().is_enabled_for_test; } void TaskQueueImpl::OnQueueEnabledVoteChanged(bool enabled) { @@ -823,10 +787,11 @@ return; if (enable) { - if (HasPendingImmediateWork() && main_thread_only().observer) { + if (HasPendingImmediateWork() && + !main_thread_only().on_next_wake_up_changed_callback.is_null()) { // Delayed work notification will be issued via time domain. - main_thread_only().observer->OnQueueNextWakeUpChanged(this, - base::TimeTicks()); + main_thread_only().on_next_wake_up_changed_callback.Run( + base::TimeTicks()); } ScheduleDelayedWorkInTimeDomain(main_thread_only().time_domain->Now()); @@ -841,11 +806,12 @@ } } -std::unique_ptr<TaskQueueImpl::QueueEnabledVoter> -TaskQueueImpl::CreateQueueEnabledVoter() { +std::unique_ptr<TaskQueue::QueueEnabledVoter> +TaskQueueImpl::CreateQueueEnabledVoter(scoped_refptr<TaskQueue> task_queue) { + DCHECK_EQ(task_queue->GetTaskQueueImpl(), this); main_thread_only().voter_refcount++; main_thread_only().is_enabled_refcount++; - return base::MakeUnique<QueueEnabledVoterImpl>(this); + return base::MakeUnique<QueueEnabledVoterImpl>(task_queue); } void TaskQueueImpl::SweepCanceledDelayedTasks(base::TimeTicks now) { @@ -882,17 +848,18 @@ immediate_incoming_queue().push_back(std::move(task)); } -void TaskQueueImpl::SetObserver(Observer* observer) { +void TaskQueueImpl::SetOnNextWakeUpChangedCallback( + TaskQueueImpl::OnNextWakeUpChangedCallback callback) { #if DCHECK_IS_ON() - if (observer) { - DCHECK(!main_thread_only().observer) << "Can't assign two different " - "observers to " - "blink::scheduler::TaskQueue"; + if (callback) { + DCHECK(main_thread_only().on_next_wake_up_changed_callback.is_null()) + << "Can't assign two different observers to " + "blink::scheduler::TaskQueue"; } #endif base::AutoLock lock(any_thread_lock_); - any_thread().observer = observer; - main_thread_only().observer = observer; + any_thread().on_next_wake_up_changed_callback = callback; + main_thread_only().on_next_wake_up_changed_callback = callback; } void TaskQueueImpl::ScheduleDelayedWorkInTimeDomain(base::TimeTicks now) { @@ -913,12 +880,13 @@ // If queue has immediate work an appropriate notification has already // been issued. - if (!scheduled_time_domain_wake_up || !main_thread_only().observer || + if (!scheduled_time_domain_wake_up || + main_thread_only().on_next_wake_up_changed_callback.is_null() || HasPendingImmediateWork()) return; - main_thread_only().observer->OnQueueNextWakeUpChanged( - this, scheduled_time_domain_wake_up.value()); + main_thread_only().on_next_wake_up_changed_callback.Run( + scheduled_time_domain_wake_up.value()); } bool TaskQueueImpl::HasPendingImmediateWork() { @@ -933,6 +901,22 @@ return !immediate_incoming_queue().empty(); } +void TaskQueueImpl::SetOnTaskCompletedHandler( + TaskQueueImpl::OnTaskCompletedHandler handler) { + main_thread_only().on_task_completed_handler = std::move(handler); +} + +void TaskQueueImpl::OnTaskCompleted(base::TimeTicks start, + base::TimeTicks end) { + if (!main_thread_only().on_task_completed_handler.is_null()) + main_thread_only().on_task_completed_handler.Run(start, end); +} + +void TaskQueueImpl::SetQueueEnabledForTest(bool enabled) { + main_thread_only().is_enabled_for_test = enabled; + EnableOrDisableWithSelector(IsQueueEnabled()); +} + } // namespace internal } // namespace scheduler } // namespace blink
diff --git a/third_party/WebKit/Source/platform/scheduler/base/task_queue_impl.h b/third_party/WebKit/Source/platform/scheduler/base/task_queue_impl.h index 77fbf79..1ae5094 100644 --- a/third_party/WebKit/Source/platform/scheduler/base/task_queue_impl.h +++ b/third_party/WebKit/Source/platform/scheduler/base/task_queue_impl.h
@@ -12,6 +12,7 @@ #include "base/callback.h" #include "base/macros.h" +#include "base/memory/weak_ptr.h" #include "base/message_loop/message_loop.h" #include "base/pending_task.h" #include "base/threading/thread_checker.h" @@ -58,11 +59,13 @@ // queue is selected, it round-robins between the immediate_work_queue and // delayed_work_queue. The reason for this is we want to make sure delayed // tasks (normally the most common type) don't starve out immediate work. -class PLATFORM_EXPORT TaskQueueImpl final : public TaskQueue { +class PLATFORM_EXPORT TaskQueueImpl { public: TaskQueueImpl(TaskQueueManager* task_queue_manager, TimeDomain* time_domain, - const Spec& spec); + const TaskQueue::Spec& spec); + + ~TaskQueueImpl(); // Represents a time at which a task wants to run. Tasks scheduled for the // same point in time will be ordered by their sequence numbers. @@ -130,36 +133,42 @@ EnqueueOrder enqueue_order_; }; + using OnNextWakeUpChangedCallback = base::Callback<void(base::TimeTicks)>; + using OnTaskCompletedHandler = + base::Callback<void(base::TimeTicks, base::TimeTicks)>; + // TaskQueue implementation. - void UnregisterTaskQueue() override; - bool RunsTasksInCurrentSequence() const override; + const char* GetName() const; + bool RunsTasksInCurrentSequence() const; bool PostDelayedTask(const tracked_objects::Location& from_here, base::OnceClosure task, - base::TimeDelta delay) override; + base::TimeDelta delay); bool PostNonNestableDelayedTask(const tracked_objects::Location& from_here, base::OnceClosure task, - base::TimeDelta delay) override; - std::unique_ptr<QueueEnabledVoter> CreateQueueEnabledVoter() override; - bool IsQueueEnabled() const override; - bool IsEmpty() const override; - size_t GetNumberOfPendingTasks() const override; - bool HasTaskToRunImmediately() const override; - base::Optional<base::TimeTicks> GetNextScheduledWakeUp() override; - void SetQueuePriority(QueuePriority priority) override; - QueuePriority GetQueuePriority() const override; - void AddTaskObserver(base::MessageLoop::TaskObserver* task_observer) override; - void RemoveTaskObserver( - base::MessageLoop::TaskObserver* task_observer) override; - void SetTimeDomain(TimeDomain* time_domain) override; - TimeDomain* GetTimeDomain() const override; - void SetBlameContext(base::trace_event::BlameContext* blame_context) override; - void InsertFence(InsertFencePosition position) override; - void RemoveFence() override; - bool HasFence() const override; - bool BlockedByFence() const override; - const char* GetName() const override; - QueueType GetQueueType() const override; - void SetObserver(Observer* observer) override; + base::TimeDelta delay); + // Require a reference to enclosing task queue for lifetime control. + std::unique_ptr<TaskQueue::QueueEnabledVoter> CreateQueueEnabledVoter( + scoped_refptr<TaskQueue> owning_task_queue); + bool IsQueueEnabled() const; + bool IsEmpty() const; + size_t GetNumberOfPendingTasks() const; + bool HasTaskToRunImmediately() const; + base::Optional<base::TimeTicks> GetNextScheduledWakeUp(); + void SetQueuePriority(TaskQueue::QueuePriority priority); + TaskQueue::QueuePriority GetQueuePriority() const; + void AddTaskObserver(base::MessageLoop::TaskObserver* task_observer); + void RemoveTaskObserver(base::MessageLoop::TaskObserver* task_observer); + void SetTimeDomain(TimeDomain* time_domain); + TimeDomain* GetTimeDomain() const; + void SetBlameContext(base::trace_event::BlameContext* blame_context); + void InsertFence(TaskQueue::InsertFencePosition position); + void RemoveFence(); + bool HasFence() const; + bool BlockedByFence() const; + // Implementation of TaskQueue::SetObserver. + void SetOnNextWakeUpChangedCallback(OnNextWakeUpChangedCallback callback); + + void UnregisterTaskQueue(scoped_refptr<TaskQueue> task_queue); // Returns true if a (potentially hypothetical) task with the specified // |enqueue_order| could run on the queue. Must be called from the main @@ -228,26 +237,37 @@ void PushImmediateIncomingTaskForTest(TaskQueueImpl::Task&& task); EnqueueOrder GetFenceForTest() const; - class QueueEnabledVoterImpl : public QueueEnabledVoter { + class QueueEnabledVoterImpl : public TaskQueue::QueueEnabledVoter { public: - explicit QueueEnabledVoterImpl(TaskQueueImpl* task_queue); + explicit QueueEnabledVoterImpl(scoped_refptr<TaskQueue> task_queue); ~QueueEnabledVoterImpl() override; // QueueEnabledVoter implementation. void SetQueueEnabled(bool enabled) override; - TaskQueueImpl* GetTaskQueueForTest() const { return task_queue_.get(); } + TaskQueueImpl* GetTaskQueueForTest() const { + return task_queue_->GetTaskQueueImpl(); + } private: friend class TaskQueueImpl; - scoped_refptr<TaskQueueImpl> task_queue_; + scoped_refptr<TaskQueue> task_queue_; bool enabled_; }; // Iterates over |delayed_incoming_queue| removing canceled tasks. void SweepCanceledDelayedTasks(base::TimeTicks now); + // Allows wrapping TaskQueue to set a handler to subscribe for notifications + // about completed tasks. + void SetOnTaskCompletedHandler(OnTaskCompletedHandler handler); + void OnTaskCompleted(base::TimeTicks start, base::TimeTicks end); + + // Disables queue for testing purposes, when a QueueEnabledVoter can't be + // constructed due to not having TaskQueue. + void SetQueueEnabledForTest(bool enabled); + private: friend class WorkQueue; friend class WorkQueueTest; @@ -266,7 +286,8 @@ // main thread, so it should be locked before accessing from other threads. TaskQueueManager* task_queue_manager; TimeDomain* time_domain; - Observer* observer; + // Callback corresponding to TaskQueue::Observer::OnQueueNextChanged. + OnNextWakeUpChangedCallback on_next_wake_up_changed_callback; }; struct MainThreadOnly { @@ -280,7 +301,8 @@ // See description inside struct AnyThread for details. TaskQueueManager* task_queue_manager; TimeDomain* time_domain; - Observer* observer; + // Callback corresponding to TaskQueue::Observer::OnQueueNextChanged. + OnNextWakeUpChangedCallback on_next_wake_up_changed_callback; std::unique_ptr<WorkQueue> delayed_work_queue; std::unique_ptr<WorkQueue> immediate_work_queue; @@ -293,10 +315,11 @@ base::trace_event::BlameContext* blame_context; // Not owned. EnqueueOrder current_fence; base::Optional<base::TimeTicks> scheduled_time_domain_wake_up; + OnTaskCompletedHandler on_task_completed_handler; + // If false, queue will be disabled. Used only for tests. + bool is_enabled_for_test; }; - ~TaskQueueImpl() override; - bool PostImmediateTaskImpl(const tracked_objects::Location& from_here, base::OnceClosure task, TaskType task_type); @@ -354,6 +377,8 @@ // Schedules delayed work on time domain and calls the observer. void ScheduleDelayedWorkInTimeDomain(base::TimeTicks now); + const char* name_; + const base::PlatformThreadId thread_id_; mutable base::Lock any_thread_lock_; @@ -367,9 +392,6 @@ return any_thread_; } - const QueueType type_; - const char* const name_; - base::ThreadChecker main_thread_checker_; MainThreadOnly main_thread_only_; MainThreadOnly& main_thread_only() {
diff --git a/third_party/WebKit/Source/platform/scheduler/base/task_queue_manager.cc b/third_party/WebKit/Source/platform/scheduler/base/task_queue_manager.cc index d409fcf..0108188 100644 --- a/third_party/WebKit/Source/platform/scheduler/base/task_queue_manager.cc +++ b/third_party/WebKit/Source/platform/scheduler/base/task_queue_manager.cc
@@ -17,6 +17,7 @@ #include "platform/scheduler/base/task_time_observer.h" #include "platform/scheduler/base/work_queue.h" #include "platform/scheduler/base/work_queue_sets.h" +#include "platform/wtf/PtrUtil.h" namespace blink { namespace scheduler { @@ -106,19 +107,18 @@ time_domains_.erase(time_domain); } -scoped_refptr<internal::TaskQueueImpl> TaskQueueManager::NewTaskQueue( +std::unique_ptr<internal::TaskQueueImpl> TaskQueueManager::CreateTaskQueueImpl( const TaskQueue::Spec& spec) { - TRACE_EVENT1("renderer.scheduler", "TaskQueueManager::NewTaskQueue", - "queue_name", TaskQueue::NameForQueueType(spec.type)); DCHECK(main_thread_checker_.CalledOnValidThread()); TimeDomain* time_domain = spec.time_domain ? spec.time_domain : real_time_domain_.get(); DCHECK(time_domains_.find(time_domain) != time_domains_.end()); - scoped_refptr<internal::TaskQueueImpl> queue( - make_scoped_refptr(new internal::TaskQueueImpl(this, time_domain, spec))); - queues_.insert(queue); - selector_.AddQueue(queue.get()); - return queue; + return WTF::MakeUnique<internal::TaskQueueImpl>(this, time_domain, spec); +} + +void TaskQueueManager::RegisterTaskQueue(scoped_refptr<TaskQueue> task_queue) { + queues_.insert(task_queue); + selector_.AddQueue(task_queue->GetTaskQueueImpl()); } void TaskQueueManager::SetObserver(Observer* observer) { @@ -127,23 +127,22 @@ } void TaskQueueManager::UnregisterTaskQueue( - scoped_refptr<internal::TaskQueueImpl> task_queue) { + scoped_refptr<TaskQueue> task_queue) { TRACE_EVENT1("renderer.scheduler", "TaskQueueManager::UnregisterTaskQueue", "queue_name", task_queue->GetName()); DCHECK(main_thread_checker_.CalledOnValidThread()); - if (observer_) - observer_->OnUnregisterTaskQueue(task_queue); // Add |task_queue| to |queues_to_delete_| so we can prevent it from being // freed while any of our structures hold hold a raw pointer to it. queues_to_delete_.insert(task_queue); queues_.erase(task_queue); - selector_.RemoveQueue(task_queue.get()); + selector_.RemoveQueue(task_queue->GetTaskQueueImpl()); { base::AutoLock lock(any_thread_lock_); - any_thread().has_incoming_immediate_work.erase(task_queue.get()); + any_thread().has_incoming_immediate_work.erase( + task_queue->GetTaskQueueImpl()); } } @@ -516,7 +515,7 @@ if (notify_time_observers) { task_start_time = MonotonicTimeInSeconds(time_before_task.Now()); for (auto& observer : task_time_observers_) - observer.WillProcessTask(queue, task_start_time); + observer.WillProcessTask(task_start_time); } } @@ -541,8 +540,13 @@ if (task_start_time) { *time_after_task = real_time_domain()->Now(); double task_end_time = MonotonicTimeInSeconds(*time_after_task); + + queue->OnTaskCompleted( + base::TimeTicks() + base::TimeDelta::FromSecondsD(task_start_time), + base::TimeTicks() + base::TimeDelta::FromSecondsD(task_end_time)); + for (auto& observer : task_time_observers_) - observer.DidProcessTask(queue, task_start_time, task_end_time); + observer.DidProcessTask(task_start_time, task_end_time); } for (auto& observer : task_observers_) @@ -639,7 +643,7 @@ base::TimeTicks now = real_time_domain()->CreateLazyNow().Now(); state->BeginArray("queues"); for (auto& queue : queues_) - queue->AsValueInto(now, state.get()); + queue->GetTaskQueueImpl()->AsValueInto(now, state.get()); state->EndArray(); state->BeginDictionary("selector"); selector_.AsValueInto(state.get()); @@ -683,10 +687,8 @@ internal::WorkQueue* work_queue) { DCHECK(main_thread_checker_.CalledOnValidThread()); DCHECK(!work_queue->Empty()); - if (observer_) { - observer_->OnTriedToExecuteBlockedTask(*work_queue->task_queue(), - *work_queue->GetFrontTask()); - } + if (observer_) + observer_->OnTriedToExecuteBlockedTask(); } bool TaskQueueManager::HasImmediateWorkForTesting() const { @@ -701,11 +703,12 @@ void TaskQueueManager::SweepCanceledDelayedTasks() { std::map<TimeDomain*, base::TimeTicks> time_domain_now; - for (const scoped_refptr<internal::TaskQueueImpl>& queue : queues_) { + for (const auto& queue : queues_) { TimeDomain* time_domain = queue->GetTimeDomain(); if (time_domain_now.find(time_domain) == time_domain_now.end()) time_domain_now.insert(std::make_pair(time_domain, time_domain->Now())); - queue->SweepCanceledDelayedTasks(time_domain_now[time_domain]); + queue->GetTaskQueueImpl()->SweepCanceledDelayedTasks( + time_domain_now[time_domain]); } }
diff --git a/third_party/WebKit/Source/platform/scheduler/base/task_queue_manager.h b/third_party/WebKit/Source/platform/scheduler/base/task_queue_manager.h index dd8e9a18..5e86eda7 100644 --- a/third_party/WebKit/Source/platform/scheduler/base/task_queue_manager.h +++ b/third_party/WebKit/Source/platform/scheduler/base/task_queue_manager.h
@@ -36,9 +36,10 @@ class LazyNow; class RealTimeDomain; -class TimeDomain; +class TaskQueue; class TaskQueueManagerDelegate; class TaskTimeObserver; +class TimeDomain; // The task queue manager provides N task queues and a selector interface for // choosing which task queue to service next. Each task queue consists of two @@ -98,23 +99,22 @@ // last call to GetAndClearSystemIsQuiescentBit. bool GetAndClearSystemIsQuiescentBit(); - // Creates a task queue with the given |spec|. Must be called on the thread - // this class was created on. - scoped_refptr<internal::TaskQueueImpl> NewTaskQueue( - const TaskQueue::Spec& spec); + // Creates a task queue with the given type, |spec| and args. Must be called + // on the thread this class was created on. + template <typename TaskQueueType, typename... Args> + scoped_refptr<TaskQueueType> CreateTaskQueue(const TaskQueue::Spec& spec, + Args&&... args) { + scoped_refptr<TaskQueueType> task_queue(new TaskQueueType( + CreateTaskQueueImpl(spec), std::forward<Args>(args)...)); + RegisterTaskQueue(task_queue); + return task_queue; + } class PLATFORM_EXPORT Observer { public: virtual ~Observer() {} - // Called when |queue| is unregistered. - virtual void OnUnregisterTaskQueue( - const scoped_refptr<TaskQueue>& queue) = 0; - - // Called when the manager tried to execute a task from a disabled - // queue. See TaskQueue::Spec::SetShouldReportWhenExecutionBlocked. - virtual void OnTriedToExecuteBlockedTask(const TaskQueue& queue, - const base::PendingTask& task) = 0; + virtual void OnTriedToExecuteBlockedTask() = 0; }; // Called once to set the Observer. This function is called on the main @@ -135,7 +135,7 @@ // Returns the currently executing TaskQueue if any. Must be called on the // thread this class was created on. - TaskQueue* currently_executing_task_queue() const { + internal::TaskQueueImpl* currently_executing_task_queue() const { DCHECK(main_thread_checker_.CalledOnValidThread()); return currently_executing_task_queue_; } @@ -227,7 +227,7 @@ }; // Unregisters a TaskQueue previously created by |NewTaskQueue()|. - void UnregisterTaskQueue(scoped_refptr<internal::TaskQueueImpl> task_queue); + void UnregisterTaskQueue(scoped_refptr<TaskQueue> task_queue); // TaskQueueSelector::Observer implementation: void OnTaskQueueEnabled(internal::TaskQueueImpl* queue) override; @@ -312,14 +312,18 @@ void ReloadEmptyWorkQueues( const IncomingImmediateWorkMap& queues_to_reload) const; + std::unique_ptr<internal::TaskQueueImpl> CreateTaskQueueImpl( + const TaskQueue::Spec& spec); + void RegisterTaskQueue(scoped_refptr<TaskQueue> task_queue); + std::set<TimeDomain*> time_domains_; std::unique_ptr<RealTimeDomain> real_time_domain_; - std::set<scoped_refptr<internal::TaskQueueImpl>> queues_; + std::set<scoped_refptr<TaskQueue>> queues_; // We have to be careful when deleting a queue because some of the code uses // raw pointers and doesn't expect the rug to be pulled out from underneath. - std::set<scoped_refptr<internal::TaskQueueImpl>> queues_to_delete_; + std::set<scoped_refptr<TaskQueue>> queues_to_delete_; internal::EnqueueOrderGenerator enqueue_order_generator_; base::debug::TaskAnnotator task_annotator_;
diff --git a/third_party/WebKit/Source/platform/scheduler/base/task_queue_manager_perftest.cc b/third_party/WebKit/Source/platform/scheduler/base/task_queue_manager_perftest.cc index 4c33e1d2..c93d4246 100644 --- a/third_party/WebKit/Source/platform/scheduler/base/task_queue_manager_perftest.cc +++ b/third_party/WebKit/Source/platform/scheduler/base/task_queue_manager_perftest.cc
@@ -21,6 +21,7 @@ #include "platform/scheduler/base/test_task_time_observer.h" #include "platform/scheduler/base/virtual_time_domain.h" #include "platform/scheduler/base/work_queue_sets.h" +#include "platform/scheduler/test/test_task_queue.h" #include "testing/gtest/include/gtest/gtest.h" #include "testing/perf/perf_test.h" @@ -93,9 +94,8 @@ manager_->RegisterTimeDomain(virtual_time_domain_.get()); for (size_t i = 0; i < num_queues; i++) { - queues_.push_back(manager_->NewTaskQueue( - TaskQueue::Spec(TaskQueue::QueueType::TEST) - .SetTimeDomain(virtual_time_domain_.get()))); + queues_.push_back(manager_->CreateTaskQueue<TestTaskQueue>( + TaskQueue::Spec("test").SetTimeDomain(virtual_time_domain_.get()))); } }
diff --git a/third_party/WebKit/Source/platform/scheduler/base/task_queue_manager_unittest.cc b/third_party/WebKit/Source/platform/scheduler/base/task_queue_manager_unittest.cc index 5ab22a8..13115f9 100644 --- a/third_party/WebKit/Source/platform/scheduler/base/task_queue_manager_unittest.cc +++ b/third_party/WebKit/Source/platform/scheduler/base/task_queue_manager_unittest.cc
@@ -31,6 +31,7 @@ #include "platform/scheduler/base/virtual_time_domain.h" #include "platform/scheduler/base/work_queue.h" #include "platform/scheduler/base/work_queue_sets.h" +#include "platform/scheduler/test/test_task_queue.h" #include "testing/gmock/include/gmock/gmock.h" using ::testing::AnyNumber; @@ -89,6 +90,19 @@ void DeleteTaskQueueManager() { manager_.reset(); } protected: + scoped_refptr<TestTaskQueue> CreateTaskQueueWithSpec(TaskQueue::Spec spec) { + return manager_->CreateTaskQueue<TestTaskQueue>(spec); + } + + scoped_refptr<TestTaskQueue> CreateTaskQueue() { + return CreateTaskQueueWithSpec(TaskQueue::Spec("test")); + } + + scoped_refptr<TestTaskQueue> CreateTaskQueueWithMonitoredQuiescence() { + return CreateTaskQueueWithSpec( + TaskQueue::Spec("test").SetShouldMonitorQuiescence(true)); + } + void InitializeWithClock(size_t num_queues, std::unique_ptr<base::TickClock> test_time_source) { test_task_runner_ = make_scoped_refptr( @@ -100,8 +114,7 @@ manager_ = base::MakeUnique<TaskQueueManagerForTest>(main_task_runner_); for (size_t i = 0; i < num_queues; i++) - runners_.push_back( - manager_->NewTaskQueue(TaskQueue::Spec(TaskQueue::QueueType::TEST))); + runners_.push_back(CreateTaskQueue()); } void Initialize(size_t num_queues) { @@ -121,8 +134,7 @@ base::WrapUnique(new TestTimeSource(now_src_.get())))); for (size_t i = 0; i < num_queues; i++) - runners_.push_back( - manager_->NewTaskQueue(TaskQueue::Spec(TaskQueue::QueueType::TEST))); + runners_.push_back(CreateTaskQueue()); } void WakeUpReadyDelayedQueues(LazyNow lazy_now) { @@ -187,7 +199,7 @@ scoped_refptr<TaskQueueManagerDelegateForTest> main_task_runner_; scoped_refptr<cc::OrderedSimpleTaskRunner> test_task_runner_; std::unique_ptr<TaskQueueManagerForTest> manager_; - std::vector<scoped_refptr<internal::TaskQueueImpl>> runners_; + std::vector<scoped_refptr<TestTaskQueue>> runners_; TestTaskTimeObserver test_task_time_observer_; }; @@ -222,8 +234,7 @@ manager_->AddTaskTimeObserver(&test_task_time_observer_); for (size_t i = 0; i < 3; i++) - runners_.push_back( - manager_->NewTaskQueue(TaskQueue::Spec(TaskQueue::QueueType::TEST))); + runners_.push_back(CreateTaskQueue()); runners_[0]->PostTask(FROM_HERE, base::Bind(&NopTask)); runners_[0]->PostTask(FROM_HERE, base::Bind(&NopTask)); @@ -252,8 +263,7 @@ base::WrapUnique(test_count_uses_time_source))); manager_->AddTaskTimeObserver(&test_task_time_observer_); - runners_.push_back( - manager_->NewTaskQueue(TaskQueue::Spec(TaskQueue::QueueType::TEST))); + runners_.push_back(CreateTaskQueue()); std::vector<std::pair<base::Closure, bool>> tasks_to_post_from_nested_loop; for (int i = 0; i <= 6; ++i) { @@ -365,12 +375,13 @@ EXPECT_TRUE(runners_[0]->HasTaskToRunImmediately()); // Move the task into the |immediate_work_queue|. - EXPECT_TRUE(runners_[0]->immediate_work_queue()->Empty()); + EXPECT_TRUE(runners_[0]->GetTaskQueueImpl()->immediate_work_queue()->Empty()); std::unique_ptr<TaskQueue::QueueEnabledVoter> voter = runners_[0]->CreateQueueEnabledVoter(); voter->SetQueueEnabled(false); test_task_runner_->RunUntilIdle(); - EXPECT_FALSE(runners_[0]->immediate_work_queue()->Empty()); + EXPECT_FALSE( + runners_[0]->GetTaskQueueImpl()->immediate_work_queue()->Empty()); EXPECT_TRUE(runners_[0]->HasTaskToRunImmediately()); // Run the task, making the queue empty. @@ -392,7 +403,7 @@ // Move the task into the |delayed_work_queue|. WakeUpReadyDelayedQueues(LazyNow(now_src_.get())); - EXPECT_FALSE(runners_[0]->delayed_work_queue()->Empty()); + EXPECT_FALSE(runners_[0]->GetTaskQueueImpl()->delayed_work_queue()->Empty()); EXPECT_TRUE(runners_[0]->HasTaskToRunImmediately()); // Run the task, making the queue empty. @@ -1099,15 +1110,9 @@ TEST_F(TaskQueueManagerTest, GetAndClearSystemIsQuiescentBit) { Initialize(3u); - scoped_refptr<internal::TaskQueueImpl> queue0 = - manager_->NewTaskQueue(TaskQueue::Spec(TaskQueue::QueueType::TEST) - .SetShouldMonitorQuiescence(true)); - scoped_refptr<internal::TaskQueueImpl> queue1 = - manager_->NewTaskQueue(TaskQueue::Spec(TaskQueue::QueueType::TEST) - .SetShouldMonitorQuiescence(true)); - scoped_refptr<internal::TaskQueueImpl> queue2 = - manager_->NewTaskQueue(TaskQueue::Spec(TaskQueue::QueueType::TEST) - .SetShouldMonitorQuiescence(false)); + scoped_refptr<TaskQueue> queue0 = CreateTaskQueueWithMonitoredQuiescence(); + scoped_refptr<TaskQueue> queue1 = CreateTaskQueueWithMonitoredQuiescence(); + scoped_refptr<TaskQueue> queue2 = CreateTaskQueue(); EXPECT_TRUE(manager_->GetAndClearSystemIsQuiescentBit()); @@ -1329,12 +1334,9 @@ TEST_F(TaskQueueManagerTest, NewTaskQueues) { Initialize(1u); - scoped_refptr<internal::TaskQueueImpl> queue1 = - manager_->NewTaskQueue(TaskQueue::Spec(TaskQueue::QueueType::TEST)); - scoped_refptr<internal::TaskQueueImpl> queue2 = - manager_->NewTaskQueue(TaskQueue::Spec(TaskQueue::QueueType::TEST)); - scoped_refptr<internal::TaskQueueImpl> queue3 = - manager_->NewTaskQueue(TaskQueue::Spec(TaskQueue::QueueType::TEST)); + scoped_refptr<TaskQueue> queue1 = CreateTaskQueue(); + scoped_refptr<TaskQueue> queue2 = CreateTaskQueue(); + scoped_refptr<TaskQueue> queue3 = CreateTaskQueue(); ASSERT_NE(queue1, queue2); ASSERT_NE(queue1, queue3); @@ -1352,12 +1354,9 @@ TEST_F(TaskQueueManagerTest, UnregisterTaskQueue) { Initialize(1u); - scoped_refptr<internal::TaskQueueImpl> queue1 = - manager_->NewTaskQueue(TaskQueue::Spec(TaskQueue::QueueType::TEST)); - scoped_refptr<internal::TaskQueueImpl> queue2 = - manager_->NewTaskQueue(TaskQueue::Spec(TaskQueue::QueueType::TEST)); - scoped_refptr<internal::TaskQueueImpl> queue3 = - manager_->NewTaskQueue(TaskQueue::Spec(TaskQueue::QueueType::TEST)); + scoped_refptr<TaskQueue> queue1 = CreateTaskQueue(); + scoped_refptr<TaskQueue> queue2 = CreateTaskQueue(); + scoped_refptr<TaskQueue> queue3 = CreateTaskQueue(); ASSERT_NE(queue1, queue2); ASSERT_NE(queue1, queue3); @@ -1394,7 +1393,7 @@ } namespace { -void UnregisterQueue(scoped_refptr<internal::TaskQueueImpl> queue) { +void UnregisterQueue(scoped_refptr<TaskQueue> queue) { queue->UnregisterTaskQueue(); } } @@ -1417,38 +1416,19 @@ class MockObserver : public TaskQueueManager::Observer { public: - MOCK_METHOD1(OnUnregisterTaskQueue, - void(const scoped_refptr<TaskQueue>& queue)); - MOCK_METHOD2(OnTriedToExecuteBlockedTask, - void(const TaskQueue& queue, const base::PendingTask& task)); + MOCK_METHOD0(OnTriedToExecuteBlockedTask, void()); }; } // namespace -TEST_F(TaskQueueManagerTest, OnUnregisterTaskQueue) { - Initialize(0u); - - MockObserver observer; - manager_->SetObserver(&observer); - - scoped_refptr<internal::TaskQueueImpl> task_queue = - manager_->NewTaskQueue(TaskQueue::Spec(TaskQueue::QueueType::TEST)); - - EXPECT_CALL(observer, OnUnregisterTaskQueue(_)).Times(1); - task_queue->UnregisterTaskQueue(); - - manager_->SetObserver(nullptr); -} - TEST_F(TaskQueueManagerTest, OnTriedToExecuteBlockedTask) { Initialize(0u); MockObserver observer; manager_->SetObserver(&observer); - scoped_refptr<internal::TaskQueueImpl> task_queue = - manager_->NewTaskQueue(TaskQueue::Spec(TaskQueue::QueueType::TEST) - .SetShouldReportWhenExecutionBlocked(true)); + scoped_refptr<TaskQueue> task_queue = CreateTaskQueueWithSpec( + TaskQueue::Spec("test").SetShouldReportWhenExecutionBlocked(true)); std::unique_ptr<TaskQueue::QueueEnabledVoter> voter = task_queue->CreateQueueEnabledVoter(); @@ -1460,7 +1440,7 @@ voter->SetQueueEnabled(true); voter->SetQueueEnabled(false); - EXPECT_CALL(observer, OnTriedToExecuteBlockedTask(_, _)).Times(1); + EXPECT_CALL(observer, OnTriedToExecuteBlockedTask()).Times(1); test_task_runner_->RunPendingTasks(); manager_->SetObserver(nullptr); @@ -1472,28 +1452,22 @@ MockObserver observer; manager_->SetObserver(&observer); - scoped_refptr<internal::TaskQueueImpl> task_queue = - manager_->NewTaskQueue(TaskQueue::Spec(TaskQueue::QueueType::TEST) - .SetShouldReportWhenExecutionBlocked(true)); + scoped_refptr<TaskQueue> task_queue = CreateTaskQueueWithSpec( + TaskQueue::Spec("test").SetShouldReportWhenExecutionBlocked(true)); task_queue->PostTask(FROM_HERE, base::Bind(&NopTask)); - EXPECT_CALL(observer, OnTriedToExecuteBlockedTask(_, _)).Times(0); + EXPECT_CALL(observer, OnTriedToExecuteBlockedTask()).Times(0); test_task_runner_->RunPendingTasks(); manager_->SetObserver(nullptr); } -void HasOneRefTask(std::vector<bool>* log, internal::TaskQueueImpl* tq) { - log->push_back(tq->HasOneRef()); -} - TEST_F(TaskQueueManagerTest, UnregisterTaskQueueInNestedLoop) { InitializeWithRealMessageLoop(1u); // We retain a reference to the task queue even when the manager has deleted // its reference. - scoped_refptr<internal::TaskQueueImpl> task_queue = - manager_->NewTaskQueue(TaskQueue::Spec(TaskQueue::QueueType::TEST)); + scoped_refptr<TaskQueue> task_queue = CreateTaskQueue(); std::vector<bool> log; std::vector<std::pair<base::Closure, bool>> tasks_to_post_from_nested_loop; @@ -1503,31 +1477,20 @@ // reference until the nested run loop exits. // NB: This first HasOneRefTask is a sanity check. tasks_to_post_from_nested_loop.push_back( - std::make_pair(base::Bind(&HasOneRefTask, base::Unretained(&log), + std::make_pair(base::Bind(&NopTask), true)); + tasks_to_post_from_nested_loop.push_back( + std::make_pair(base::Bind(&TaskQueue::UnregisterTaskQueue, base::Unretained(task_queue.get())), true)); tasks_to_post_from_nested_loop.push_back( - std::make_pair(base::Bind(&internal::TaskQueueImpl::UnregisterTaskQueue, - base::Unretained(task_queue.get())), - true)); - tasks_to_post_from_nested_loop.push_back( - std::make_pair(base::Bind(&HasOneRefTask, base::Unretained(&log), - base::Unretained(task_queue.get())), - true)); + std::make_pair(base::Bind(&NopTask), true)); runners_[0]->PostTask( FROM_HERE, base::Bind(&PostFromNestedRunloop, message_loop_.get(), base::RetainedRef(runners_[0]), base::Unretained(&tasks_to_post_from_nested_loop))); base::RunLoop().RunUntilIdle(); - // Add a final call to HasOneRefTask. This gives the manager a chance to - // release its reference, and checks that it has. - runners_[0]->PostTask(FROM_HERE, - base::Bind(&HasOneRefTask, base::Unretained(&log), - base::Unretained(task_queue.get()))); - base::RunLoop().RunUntilIdle(); - - EXPECT_THAT(log, ElementsAre(false, false, true)); + // Just make sure that we don't crash. } TEST_F(TaskQueueManagerTest, TimeDomainsAreIndependant) { @@ -1708,7 +1671,7 @@ Mock::VerifyAndClearExpectations(&observer); // Unless the immediate work queue is emptied. - runners_[0]->ReloadImmediateWorkQueueIfEmpty(); + runners_[0]->GetTaskQueueImpl()->ReloadImmediateWorkQueueIfEmpty(); EXPECT_CALL(observer, OnQueueNextWakeUpChanged(runners_[0].get(), base::TimeTicks())); runners_[0]->PostTask(FROM_HERE, base::Bind(&NopTask)); @@ -1930,7 +1893,7 @@ class QuadraticTask { public: - QuadraticTask(scoped_refptr<internal::TaskQueueImpl> task_queue, + QuadraticTask(scoped_refptr<TaskQueue> task_queue, base::TimeDelta delay, base::SimpleTestTickClock* now_src) : count_(0), task_queue_(task_queue), delay_(delay), now_src_(now_src) {} @@ -1956,7 +1919,7 @@ private: int count_; - scoped_refptr<internal::TaskQueueImpl> task_queue_; + scoped_refptr<TaskQueue> task_queue_; base::TimeDelta delay_; base::Callback<bool()> should_exit_; base::SimpleTestTickClock* now_src_; @@ -1964,7 +1927,7 @@ class LinearTask { public: - LinearTask(scoped_refptr<internal::TaskQueueImpl> task_queue, + LinearTask(scoped_refptr<TaskQueue> task_queue, base::TimeDelta delay, base::SimpleTestTickClock* now_src) : count_(0), task_queue_(task_queue), delay_(delay), now_src_(now_src) {} @@ -1987,7 +1950,7 @@ private: int count_; - scoped_refptr<internal::TaskQueueImpl> task_queue_; + scoped_refptr<TaskQueue> task_queue_; base::TimeDelta delay_; base::Callback<bool()> should_exit_; base::SimpleTestTickClock* now_src_; @@ -2117,7 +2080,7 @@ namespace { void CurrentlyExecutingTaskQueueTestTask( TaskQueueManager* task_queue_manager, - std::vector<TaskQueue*>* task_sources) { + std::vector<internal::TaskQueueImpl*>* task_sources) { task_sources->push_back(task_queue_manager->currently_executing_task_queue()); } } @@ -2125,17 +2088,18 @@ TEST_F(TaskQueueManagerTest, CurrentlyExecutingTaskQueue_TaskRunning) { Initialize(2u); - internal::TaskQueueImpl* queue0 = runners_[0].get(); - internal::TaskQueueImpl* queue1 = runners_[1].get(); + TestTaskQueue* queue0 = runners_[0].get(); + TestTaskQueue* queue1 = runners_[1].get(); - std::vector<TaskQueue*> task_sources; + std::vector<internal::TaskQueueImpl*> task_sources; queue0->PostTask(FROM_HERE, base::Bind(&CurrentlyExecutingTaskQueueTestTask, manager_.get(), &task_sources)); queue1->PostTask(FROM_HERE, base::Bind(&CurrentlyExecutingTaskQueueTestTask, manager_.get(), &task_sources)); test_task_runner_->RunUntilIdle(); - EXPECT_THAT(task_sources, ElementsAre(queue0, queue1)); + EXPECT_THAT(task_sources, ElementsAre(queue0->GetTaskQueueImpl(), + queue1->GetTaskQueueImpl())); EXPECT_EQ(nullptr, manager_->currently_executing_task_queue()); } @@ -2143,12 +2107,12 @@ void RunloopCurrentlyExecutingTaskQueueTestTask( base::MessageLoop* message_loop, TaskQueueManager* task_queue_manager, - std::vector<TaskQueue*>* task_sources, - std::vector<std::pair<base::Closure, TaskQueue*>>* tasks) { + std::vector<internal::TaskQueueImpl*>* task_sources, + std::vector<std::pair<base::Closure, TestTaskQueue*>>* tasks) { base::MessageLoop::ScopedNestableTaskAllower allow(message_loop); task_sources->push_back(task_queue_manager->currently_executing_task_queue()); - for (std::pair<base::Closure, TaskQueue*>& pair : *tasks) { + for (std::pair<base::Closure, TestTaskQueue*>& pair : *tasks) { pair.second->PostTask(FROM_HERE, pair.first); } @@ -2160,12 +2124,12 @@ TEST_F(TaskQueueManagerTest, CurrentlyExecutingTaskQueue_NestedLoop) { InitializeWithRealMessageLoop(3u); - TaskQueue* queue0 = runners_[0].get(); - TaskQueue* queue1 = runners_[1].get(); - TaskQueue* queue2 = runners_[2].get(); + TestTaskQueue* queue0 = runners_[0].get(); + TestTaskQueue* queue1 = runners_[1].get(); + TestTaskQueue* queue2 = runners_[2].get(); - std::vector<TaskQueue*> task_sources; - std::vector<std::pair<base::Closure, TaskQueue*>> + std::vector<internal::TaskQueueImpl*> task_sources; + std::vector<std::pair<base::Closure, TestTaskQueue*>> tasks_to_post_from_nested_loop; tasks_to_post_from_nested_loop.push_back( std::make_pair(base::Bind(&CurrentlyExecutingTaskQueueTestTask, @@ -2182,7 +2146,10 @@ &tasks_to_post_from_nested_loop)); base::RunLoop().RunUntilIdle(); - EXPECT_THAT(task_sources, ElementsAre(queue0, queue1, queue2, queue0)); + EXPECT_THAT( + task_sources, + ElementsAre(queue0->GetTaskQueueImpl(), queue1->GetTaskQueueImpl(), + queue2->GetTaskQueueImpl(), queue0->GetTaskQueueImpl())); EXPECT_EQ(nullptr, manager_->currently_executing_task_queue()); } @@ -2233,7 +2200,7 @@ using trace_analyzer::Query; InitializeWithRealMessageLoop(1u); - TaskQueue* queue = runners_[0].get(); + TestTaskQueue* queue = runners_[0].get(); StartTracing(); { @@ -2459,8 +2426,7 @@ TEST_F(TaskQueueManagerTest, UnregisterQueueBeforeEnabledVoterDeleted) { Initialize(1u); - scoped_refptr<internal::TaskQueueImpl> queue = - manager_->NewTaskQueue(TaskQueue::Spec(TaskQueue::QueueType::TEST)); + scoped_refptr<TaskQueue> queue = CreateTaskQueue(); std::unique_ptr<TaskQueue::QueueEnabledVoter> voter = queue->CreateQueueEnabledVoter(); @@ -2475,8 +2441,7 @@ TEST_F(TaskQueueManagerTest, UnregisterQueueBeforeDisabledVoterDeleted) { Initialize(1u); - scoped_refptr<internal::TaskQueueImpl> queue = - manager_->NewTaskQueue(TaskQueue::Spec(TaskQueue::QueueType::TEST)); + scoped_refptr<TaskQueue> queue = CreateTaskQueue(); std::unique_ptr<TaskQueue::QueueEnabledVoter> voter = queue->CreateQueueEnabledVoter(); @@ -2736,10 +2701,9 @@ } namespace { -void MessageLoopTaskWithDelayedQuit( - base::MessageLoop* message_loop, - base::SimpleTestTickClock* now_src, - scoped_refptr<internal::TaskQueueImpl> task_queue) { +void MessageLoopTaskWithDelayedQuit(base::MessageLoop* message_loop, + base::SimpleTestTickClock* now_src, + scoped_refptr<TaskQueue> task_queue) { base::MessageLoop::ScopedNestableTaskAllower allow(message_loop); base::RunLoop run_loop; task_queue->PostDelayedTask(FROM_HERE, run_loop.QuitClosure(), @@ -2760,10 +2724,9 @@ } namespace { -void MessageLoopTaskWithImmediateQuit( - base::MessageLoop* message_loop, - base::Closure non_nested_quit_closure, - scoped_refptr<internal::TaskQueueImpl> task_queue) { +void MessageLoopTaskWithImmediateQuit(base::MessageLoop* message_loop, + base::Closure non_nested_quit_closure, + scoped_refptr<TaskQueue> task_queue) { base::MessageLoop::ScopedNestableTaskAllower allow(message_loop); base::RunLoop run_loop; @@ -2794,31 +2757,31 @@ Initialize(1u); EnqueueOrder enqueue_order = GetNextSequenceNumber(); - EXPECT_TRUE(runners_[0]->CouldTaskRun(enqueue_order)); + EXPECT_TRUE(runners_[0]->GetTaskQueueImpl()->CouldTaskRun(enqueue_order)); std::unique_ptr<TaskQueue::QueueEnabledVoter> voter = runners_[0]->CreateQueueEnabledVoter(); voter->SetQueueEnabled(false); - EXPECT_FALSE(runners_[0]->CouldTaskRun(enqueue_order)); + EXPECT_FALSE(runners_[0]->GetTaskQueueImpl()->CouldTaskRun(enqueue_order)); voter->SetQueueEnabled(true); - EXPECT_TRUE(runners_[0]->CouldTaskRun(enqueue_order)); + EXPECT_TRUE(runners_[0]->GetTaskQueueImpl()->CouldTaskRun(enqueue_order)); } TEST_F(TaskQueueManagerTest, CouldTaskRun_Fence) { Initialize(1u); EnqueueOrder enqueue_order = GetNextSequenceNumber(); - EXPECT_TRUE(runners_[0]->CouldTaskRun(enqueue_order)); + EXPECT_TRUE(runners_[0]->GetTaskQueueImpl()->CouldTaskRun(enqueue_order)); runners_[0]->InsertFence(TaskQueue::InsertFencePosition::NOW); - EXPECT_TRUE(runners_[0]->CouldTaskRun(enqueue_order)); + EXPECT_TRUE(runners_[0]->GetTaskQueueImpl()->CouldTaskRun(enqueue_order)); runners_[0]->InsertFence(TaskQueue::InsertFencePosition::BEGINNING_OF_TIME); - EXPECT_FALSE(runners_[0]->CouldTaskRun(enqueue_order)); + EXPECT_FALSE(runners_[0]->GetTaskQueueImpl()->CouldTaskRun(enqueue_order)); runners_[0]->RemoveFence(); - EXPECT_TRUE(runners_[0]->CouldTaskRun(enqueue_order)); + EXPECT_TRUE(runners_[0]->GetTaskQueueImpl()->CouldTaskRun(enqueue_order)); } TEST_F(TaskQueueManagerTest, CouldTaskRun_FenceBeforeThenAfter) { @@ -2827,10 +2790,10 @@ runners_[0]->InsertFence(TaskQueue::InsertFencePosition::NOW); EnqueueOrder enqueue_order = GetNextSequenceNumber(); - EXPECT_FALSE(runners_[0]->CouldTaskRun(enqueue_order)); + EXPECT_FALSE(runners_[0]->GetTaskQueueImpl()->CouldTaskRun(enqueue_order)); runners_[0]->InsertFence(TaskQueue::InsertFencePosition::NOW); - EXPECT_TRUE(runners_[0]->CouldTaskRun(enqueue_order)); + EXPECT_TRUE(runners_[0]->GetTaskQueueImpl()->CouldTaskRun(enqueue_order)); } TEST_F(TaskQueueManagerTest, DelayedDoWorkNotPostedForDisabledQueue) {
diff --git a/third_party/WebKit/Source/platform/scheduler/base/task_queue_selector_unittest.cc b/third_party/WebKit/Source/platform/scheduler/base/task_queue_selector_unittest.cc index 96f1c6c..9bf2ad2 100644 --- a/third_party/WebKit/Source/platform/scheduler/base/task_queue_selector_unittest.cc +++ b/third_party/WebKit/Source/platform/scheduler/base/task_queue_selector_unittest.cc
@@ -98,35 +98,16 @@ static void TestFunction() {} - void EnableQueue(TaskQueue::QueueEnabledVoter* voter) { - TaskQueueImpl::QueueEnabledVoterImpl* voter_impl = - static_cast<TaskQueueImpl::QueueEnabledVoterImpl*>(voter); - - voter_impl->SetQueueEnabled(true); - - ASSERT_TRUE(voter_impl->GetTaskQueueForTest()->IsQueueEnabled()); - selector_.EnableQueue(voter_impl->GetTaskQueueForTest()); - } - - void DisableQueue(TaskQueue::QueueEnabledVoter* voter) { - TaskQueueImpl::QueueEnabledVoterImpl* voter_impl = - static_cast<TaskQueueImpl::QueueEnabledVoterImpl*>(voter); - - voter_impl->SetQueueEnabled(false); - ASSERT_FALSE(voter_impl->GetTaskQueueForTest()->IsQueueEnabled()); - selector_.DisableQueue(voter_impl->GetTaskQueueForTest()); - } - protected: void SetUp() final { virtual_time_domain_ = base::WrapUnique<VirtualTimeDomain>( new VirtualTimeDomain(base::TimeTicks())); for (size_t i = 0; i < kTaskQueueCount; i++) { - scoped_refptr<TaskQueueImpl> task_queue = make_scoped_refptr( - new TaskQueueImpl(nullptr, virtual_time_domain_.get(), - TaskQueue::Spec(TaskQueue::QueueType::TEST))); + std::unique_ptr<TaskQueueImpl> task_queue = + base::MakeUnique<TaskQueueImpl>(nullptr, virtual_time_domain_.get(), + TaskQueue::Spec("test")); selector_.AddQueue(task_queue.get()); - task_queues_.push_back(task_queue); + task_queues_.push_back(std::move(task_queue)); } for (size_t i = 0; i < kTaskQueueCount; i++) { EXPECT_EQ(TaskQueue::NORMAL_PRIORITY, task_queues_[i]->GetQueuePriority()) @@ -136,27 +117,26 @@ } void TearDown() final { - for (scoped_refptr<TaskQueueImpl>& task_queue : task_queues_) { - task_queue->UnregisterTaskQueue(); + for (std::unique_ptr<TaskQueueImpl>& task_queue : task_queues_) { // Note since this test doesn't have a TaskQueueManager we need to // manually remove |task_queue| from the |selector_|. Normally // UnregisterTaskQueue would do that. selector_.RemoveQueue(task_queue.get()); + task_queue->UnregisterTaskQueue(nullptr); } } - scoped_refptr<TaskQueueImpl> NewTaskQueueWithBlockReporting() { - return make_scoped_refptr( - new TaskQueueImpl(nullptr, virtual_time_domain_.get(), - TaskQueue::Spec(TaskQueue::QueueType::TEST) - .SetShouldReportWhenExecutionBlocked(true))); + std::unique_ptr<TaskQueueImpl> NewTaskQueueWithBlockReporting() { + return base::MakeUnique<TaskQueueImpl>( + nullptr, virtual_time_domain_.get(), + TaskQueue::Spec("test").SetShouldReportWhenExecutionBlocked(true)); } const size_t kTaskQueueCount = 5; base::Closure test_closure_; TaskQueueSelectorForTest selector_; std::unique_ptr<VirtualTimeDomain> virtual_time_domain_; - std::vector<scoped_refptr<TaskQueueImpl>> task_queues_; + std::vector<std::unique_ptr<TaskQueueImpl>> task_queues_; std::map<TaskQueueImpl*, size_t> queue_to_index_map_; }; @@ -202,13 +182,13 @@ } TEST_F(TaskQueueSelectorTest, TestObserverWithEnabledQueue) { - std::unique_ptr<TaskQueue::QueueEnabledVoter> voter1 = - task_queues_[1]->CreateQueueEnabledVoter(); - DisableQueue(voter1.get()); + task_queues_[1]->SetQueueEnabledForTest(false); + selector_.DisableQueue(task_queues_[1].get()); MockObserver mock_observer; selector_.SetTaskQueueSelectorObserver(&mock_observer); EXPECT_CALL(mock_observer, OnTaskQueueEnabled(_)).Times(1); - EnableQueue(voter1.get()); + task_queues_[1]->SetQueueEnabledForTest(true); + selector_.EnableQueue(task_queues_[1].get()); } TEST_F(TaskQueueSelectorTest, @@ -226,33 +206,31 @@ size_t queue_order[] = {0, 1, 2, 3, 4}; PushTasks(queue_order, 5); - std::unique_ptr<TaskQueue::QueueEnabledVoter> voter2 = - task_queues_[2]->CreateQueueEnabledVoter(); - std::unique_ptr<TaskQueue::QueueEnabledVoter> voter4 = - task_queues_[4]->CreateQueueEnabledVoter(); - DisableQueue(voter2.get()); - DisableQueue(voter4.get()); + task_queues_[2]->SetQueueEnabledForTest(false); + selector_.DisableQueue(task_queues_[2].get()); + task_queues_[4]->SetQueueEnabledForTest(false); + selector_.DisableQueue(task_queues_[4].get()); // Disabling a queue should not affect its priority. EXPECT_EQ(TaskQueue::NORMAL_PRIORITY, task_queues_[2]->GetQueuePriority()); EXPECT_EQ(TaskQueue::NORMAL_PRIORITY, task_queues_[4]->GetQueuePriority()); EXPECT_THAT(PopTasks(), ::testing::ElementsAre(0, 1, 3)); EXPECT_CALL(mock_observer, OnTaskQueueEnabled(_)).Times(2); - EnableQueue(voter2.get()); + task_queues_[2]->SetQueueEnabledForTest(true); + selector_.EnableQueue(task_queues_[2].get()); selector_.SetQueuePriority(task_queues_[2].get(), TaskQueue::BEST_EFFORT_PRIORITY); - EXPECT_THAT(PopTasks(), ::testing::ElementsAre(2)); - EnableQueue(voter4.get()); - EXPECT_THAT(PopTasks(), ::testing::ElementsAre(4)); + EXPECT_THAT(PopTasks(), testing::ElementsAre(2)); + task_queues_[4]->SetQueueEnabledForTest(true); + selector_.EnableQueue(task_queues_[4].get()); + EXPECT_THAT(PopTasks(), testing::ElementsAre(4)); } TEST_F(TaskQueueSelectorTest, TestDisableChangePriorityThenEnable) { EXPECT_TRUE(task_queues_[2]->delayed_work_queue()->Empty()); EXPECT_TRUE(task_queues_[2]->immediate_work_queue()->Empty()); - std::unique_ptr<TaskQueue::QueueEnabledVoter> voter2 = - task_queues_[2]->CreateQueueEnabledVoter(); - DisableQueue(voter2.get()); + task_queues_[2]->SetQueueEnabledForTest(false); selector_.SetQueuePriority(task_queues_[2].get(), TaskQueue::HIGH_PRIORITY); size_t queue_order[] = {0, 1, 2, 3, 4}; @@ -260,7 +238,7 @@ EXPECT_TRUE(task_queues_[2]->delayed_work_queue()->Empty()); EXPECT_FALSE(task_queues_[2]->immediate_work_queue()->Empty()); - EnableQueue(voter2.get()); + task_queues_[2]->SetQueueEnabledForTest(true); EXPECT_EQ(TaskQueue::HIGH_PRIORITY, task_queues_[2]->GetQueuePriority()); EXPECT_THAT(PopTasks(), ::testing::ElementsAre(2, 0, 1, 3, 4)); @@ -273,15 +251,15 @@ // Test only disabled queues. size_t queue_order[] = {0}; PushTasks(queue_order, 1); - std::unique_ptr<TaskQueue::QueueEnabledVoter> voter0 = - task_queues_[0]->CreateQueueEnabledVoter(); - DisableQueue(voter0.get()); + task_queues_[0]->SetQueueEnabledForTest(false); + selector_.DisableQueue(task_queues_[0].get()); EXPECT_FALSE(selector_.SelectWorkQueueToService(&chosen_work_queue)); // These tests are unusual since there's no TQM. To avoid a later DCHECK when // deleting the task queue, we re-enable the queue here so the selector // doesn't get out of sync. - EnableQueue(voter0.get()); + task_queues_[0]->SetQueueEnabledForTest(true); + selector_.EnableQueue(task_queues_[0].get()); } TEST_F(TaskQueueSelectorTest, TestAge) { @@ -456,12 +434,10 @@ EXPECT_CALL(mock_observer, OnTaskQueueEnabled(_)).Times(1); - scoped_refptr<TaskQueueImpl> task_queue(NewTaskQueueWithBlockReporting()); + std::unique_ptr<TaskQueueImpl> task_queue(NewTaskQueueWithBlockReporting()); selector.AddQueue(task_queue.get()); - std::unique_ptr<TaskQueue::QueueEnabledVoter> voter = - task_queue->CreateQueueEnabledVoter(); - voter->SetQueueEnabled(false); + task_queue->SetQueueEnabledForTest(false); selector.DisableQueue(task_queue.get()); TaskQueueImpl::Task task(FROM_HERE, test_closure_, base::TimeTicks(), 0, @@ -473,10 +449,10 @@ EXPECT_CALL(mock_observer, OnTriedToSelectBlockedWorkQueue(_)).Times(1); EXPECT_FALSE(selector.SelectWorkQueueToService(&chosen_work_queue)); - voter.reset(); + task_queue->SetQueueEnabledForTest(true); selector.EnableQueue(task_queue.get()); - task_queue->UnregisterTaskQueue(); selector.RemoveQueue(task_queue.get()); + task_queue->UnregisterTaskQueue(nullptr); } TEST_F(TaskQueueSelectorTest, TestObserverWithTwoBlockedQueues) { @@ -484,17 +460,13 @@ MockObserver mock_observer; selector.SetTaskQueueSelectorObserver(&mock_observer); - scoped_refptr<TaskQueueImpl> task_queue(NewTaskQueueWithBlockReporting()); - scoped_refptr<TaskQueueImpl> task_queue2(NewTaskQueueWithBlockReporting()); + std::unique_ptr<TaskQueueImpl> task_queue(NewTaskQueueWithBlockReporting()); + std::unique_ptr<TaskQueueImpl> task_queue2(NewTaskQueueWithBlockReporting()); selector.AddQueue(task_queue.get()); selector.AddQueue(task_queue2.get()); - std::unique_ptr<TaskQueue::QueueEnabledVoter> voter = - task_queue->CreateQueueEnabledVoter(); - std::unique_ptr<TaskQueue::QueueEnabledVoter> voter2 = - task_queue2->CreateQueueEnabledVoter(); - voter->SetQueueEnabled(false); - voter2->SetQueueEnabled(false); + task_queue->SetQueueEnabledForTest(false); + task_queue2->SetQueueEnabledForTest(false); selector.DisableQueue(task_queue.get()); selector.DisableQueue(task_queue2.get()); @@ -517,20 +489,20 @@ EXPECT_CALL(mock_observer, OnTaskQueueEnabled(_)).Times(2); - voter.reset(); + task_queue->SetQueueEnabledForTest(true); selector.EnableQueue(task_queue.get()); // Removing the second queue and selecting again should result in another // notification. - task_queue->UnregisterTaskQueue(); selector.RemoveQueue(task_queue.get()); + task_queue->UnregisterTaskQueue(nullptr); EXPECT_CALL(mock_observer, OnTriedToSelectBlockedWorkQueue(_)).Times(1); EXPECT_FALSE(selector.SelectWorkQueueToService(&chosen_work_queue)); - voter2.reset(); + task_queue2->SetQueueEnabledForTest(true); selector.EnableQueue(task_queue2.get()); - task_queue2->UnregisterTaskQueue(); selector.RemoveQueue(task_queue2.get()); + task_queue2->UnregisterTaskQueue(nullptr); } struct ChooseOldestWithPriorityTestParam {
diff --git a/third_party/WebKit/Source/platform/scheduler/base/task_time_observer.h b/third_party/WebKit/Source/platform/scheduler/base/task_time_observer.h index 50db881..85b0ad9 100644 --- a/third_party/WebKit/Source/platform/scheduler/base/task_time_observer.h +++ b/third_party/WebKit/Source/platform/scheduler/base/task_time_observer.h
@@ -11,8 +11,6 @@ namespace blink { namespace scheduler { -class TaskQueue; - // TaskTimeObserver provides an API for observing completion of renderer tasks. class PLATFORM_EXPORT TaskTimeObserver { public: @@ -20,17 +18,13 @@ virtual ~TaskTimeObserver() {} // Callback to be called when task is about to start. - // |task_queue| - TaskQueue on which this task will run, // |start_time| - time in seconds when task started to run, - virtual void WillProcessTask(TaskQueue* task_queue, double start_time) = 0; + virtual void WillProcessTask(double start_time) = 0; // Callback to be called when task is completed. - // |task_queue| - TaskQueue on which this task was run, // |start_time| - time in seconds when task started to run, // |end_time| - time in seconds when task was completed. - virtual void DidProcessTask(TaskQueue* task_queue, - double start_time, - double end_time) = 0; + virtual void DidProcessTask(double start_time, double end_time) = 0; // Callback to be called when we enter a nested run loop. virtual void OnBeginNestedRunLoop() = 0;
diff --git a/third_party/WebKit/Source/platform/scheduler/base/test_task_time_observer.h b/third_party/WebKit/Source/platform/scheduler/base/test_task_time_observer.h index 53538b9..794a6617 100644 --- a/third_party/WebKit/Source/platform/scheduler/base/test_task_time_observer.h +++ b/third_party/WebKit/Source/platform/scheduler/base/test_task_time_observer.h
@@ -13,10 +13,8 @@ class TestTaskTimeObserver : public TaskTimeObserver { public: - void WillProcessTask(TaskQueue* task_queue, double start_time) override {} - void DidProcessTask(TaskQueue* task_queue, - double start_time, - double end_time) override {} + void WillProcessTask(double start_time) override {} + void DidProcessTask(double start_time, double end_time) override {} void OnBeginNestedRunLoop() override {} };
diff --git a/third_party/WebKit/Source/platform/scheduler/base/time_domain.cc b/third_party/WebKit/Source/platform/scheduler/base/time_domain.cc index 66b7bae..1194263 100644 --- a/third_party/WebKit/Source/platform/scheduler/base/time_domain.cc +++ b/third_party/WebKit/Source/platform/scheduler/base/time_domain.cc
@@ -113,7 +113,8 @@ return true; } -bool TimeDomain::NextScheduledTaskQueue(TaskQueue** out_task_queue) const { +bool TimeDomain::NextScheduledTaskQueue( + internal::TaskQueueImpl** out_task_queue) const { DCHECK(main_thread_checker_.CalledOnValidThread()); if (delayed_wake_up_queue_.empty()) return false;
diff --git a/third_party/WebKit/Source/platform/scheduler/base/time_domain.h b/third_party/WebKit/Source/platform/scheduler/base/time_domain.h index 19cec2d..cb2dd61a 100644 --- a/third_party/WebKit/Source/platform/scheduler/base/time_domain.h +++ b/third_party/WebKit/Source/platform/scheduler/base/time_domain.h
@@ -69,7 +69,7 @@ // If there is a scheduled delayed task, |out_task_queue| is set to the queue // the next task was posted to and it returns true. Returns false otherwise. - bool NextScheduledTaskQueue(TaskQueue** out_task_queue) const; + bool NextScheduledTaskQueue(internal::TaskQueueImpl** out_task_queue) const; // Schedules a call to TaskQueueImpl::WakeUpForDelayedWork when this // TimeDomain reaches |delayed_run_time|. This supersedes any previously
diff --git a/third_party/WebKit/Source/platform/scheduler/base/time_domain_unittest.cc b/third_party/WebKit/Source/platform/scheduler/base/time_domain_unittest.cc index d77dee24..196185d 100644 --- a/third_party/WebKit/Source/platform/scheduler/base/time_domain_unittest.cc +++ b/third_party/WebKit/Source/platform/scheduler/base/time_domain_unittest.cc
@@ -68,14 +68,13 @@ public: void SetUp() final { time_domain_ = base::WrapUnique(CreateMockTimeDomain()); - task_queue_ = make_scoped_refptr(new internal::TaskQueueImpl( - nullptr, time_domain_.get(), - TaskQueue::Spec(TaskQueue::QueueType::TEST))); + task_queue_ = base::MakeUnique<internal::TaskQueueImpl>( + nullptr, time_domain_.get(), TaskQueue::Spec("test")); } void TearDown() final { if (task_queue_) - task_queue_->UnregisterTaskQueue(); + task_queue_->UnregisterTaskQueue(nullptr); } virtual MockTimeDomain* CreateMockTimeDomain() { @@ -83,7 +82,7 @@ } std::unique_ptr<MockTimeDomain> time_domain_; - scoped_refptr<internal::TaskQueueImpl> task_queue_; + std::unique_ptr<internal::TaskQueueImpl> task_queue_; }; TEST_F(TimeDomainTest, ScheduleDelayedWork) { @@ -97,7 +96,7 @@ EXPECT_TRUE(time_domain_->NextScheduledRunTime(&next_scheduled_runtime)); EXPECT_EQ(delayed_runtime, next_scheduled_runtime); - TaskQueue* next_task_queue; + internal::TaskQueueImpl* next_task_queue; EXPECT_TRUE(time_domain_->NextScheduledTaskQueue(&next_task_queue)); EXPECT_EQ(task_queue_.get(), next_task_queue); Mock::VerifyAndClearExpectations(time_domain_.get()); @@ -135,17 +134,17 @@ } TEST_F(TimeDomainTest, RequestWakeUpAt_OnlyCalledForEarlierTasks) { - scoped_refptr<internal::TaskQueueImpl> task_queue2 = make_scoped_refptr( - new internal::TaskQueueImpl(nullptr, time_domain_.get(), - TaskQueue::Spec(TaskQueue::QueueType::TEST))); + std::unique_ptr<internal::TaskQueueImpl> task_queue2 = + base::MakeUnique<internal::TaskQueueImpl>(nullptr, time_domain_.get(), + TaskQueue::Spec("test")); - scoped_refptr<internal::TaskQueueImpl> task_queue3 = make_scoped_refptr( - new internal::TaskQueueImpl(nullptr, time_domain_.get(), - TaskQueue::Spec(TaskQueue::QueueType::TEST))); + std::unique_ptr<internal::TaskQueueImpl> task_queue3 = + base::MakeUnique<internal::TaskQueueImpl>(nullptr, time_domain_.get(), + TaskQueue::Spec("test")); - scoped_refptr<internal::TaskQueueImpl> task_queue4 = make_scoped_refptr( - new internal::TaskQueueImpl(nullptr, time_domain_.get(), - TaskQueue::Spec(TaskQueue::QueueType::TEST))); + std::unique_ptr<internal::TaskQueueImpl> task_queue4 = + base::MakeUnique<internal::TaskQueueImpl>(nullptr, time_domain_.get(), + TaskQueue::Spec("test")); base::TimeDelta delay1 = base::TimeDelta::FromMilliseconds(10); base::TimeDelta delay2 = base::TimeDelta::FromMilliseconds(20); @@ -173,15 +172,15 @@ EXPECT_CALL(*time_domain_.get(), RequestWakeUpAt(_, _)); EXPECT_CALL(*time_domain_.get(), CancelWakeUpAt(_)).Times(2); - task_queue2->UnregisterTaskQueue(); - task_queue3->UnregisterTaskQueue(); - task_queue4->UnregisterTaskQueue(); + task_queue2->UnregisterTaskQueue(nullptr); + task_queue3->UnregisterTaskQueue(nullptr); + task_queue4->UnregisterTaskQueue(nullptr); } TEST_F(TimeDomainTest, UnregisterQueue) { - scoped_refptr<internal::TaskQueueImpl> task_queue2_ = make_scoped_refptr( - new internal::TaskQueueImpl(nullptr, time_domain_.get(), - TaskQueue::Spec(TaskQueue::QueueType::TEST))); + std::unique_ptr<internal::TaskQueueImpl> task_queue2_ = + base::MakeUnique<internal::TaskQueueImpl>(nullptr, time_domain_.get(), + TaskQueue::Spec("test")); base::TimeTicks now = time_domain_->Now(); base::TimeTicks wake_up1 = now + base::TimeDelta::FromMilliseconds(10); @@ -190,7 +189,7 @@ base::TimeTicks wake_up2 = now + base::TimeDelta::FromMilliseconds(100); time_domain_->ScheduleDelayedWork(task_queue2_.get(), {wake_up2, 0}, now); - TaskQueue* next_task_queue; + internal::TaskQueueImpl* next_task_queue; EXPECT_TRUE(time_domain_->NextScheduledTaskQueue(&next_task_queue)); EXPECT_EQ(task_queue_.get(), next_task_queue); @@ -200,7 +199,7 @@ EXPECT_CALL(*time_domain_.get(), RequestWakeUpAt(_, wake_up2)).Times(1); time_domain_->UnregisterQueue(task_queue_.get()); - task_queue_ = scoped_refptr<internal::TaskQueueImpl>(); + task_queue_ = std::unique_ptr<internal::TaskQueueImpl>(); EXPECT_TRUE(time_domain_->NextScheduledTaskQueue(&next_task_queue)); EXPECT_EQ(task_queue2_.get(), next_task_queue); @@ -243,9 +242,9 @@ EXPECT_CALL(*time_domain_.get(), RequestWakeUpAt(_, delayed_runtime)); EXPECT_CALL(*time_domain_.get(), CancelWakeUpAt(delayed_runtime)); - scoped_refptr<internal::TaskQueueImpl> task_queue2 = make_scoped_refptr( - new internal::TaskQueueImpl(nullptr, time_domain_.get(), - TaskQueue::Spec(TaskQueue::QueueType::TEST))); + std::unique_ptr<internal::TaskQueueImpl> task_queue2 = + base::MakeUnique<internal::TaskQueueImpl>(nullptr, time_domain_.get(), + TaskQueue::Spec("test")); time_domain_->ScheduleDelayedWork(task_queue2.get(), {delayed_runtime, ++sequence_num}, now); @@ -257,11 +256,11 @@ // The second task queue should wake up first since it has a lower sequence // number. - TaskQueue* next_task_queue; + internal::TaskQueueImpl* next_task_queue; EXPECT_TRUE(time_domain_->NextScheduledTaskQueue(&next_task_queue)); EXPECT_EQ(task_queue2.get(), next_task_queue); - task_queue2->UnregisterTaskQueue(); + task_queue2->UnregisterTaskQueue(nullptr); } TEST_F(TimeDomainTest, CancelDelayedWork) { @@ -271,7 +270,7 @@ EXPECT_CALL(*time_domain_.get(), RequestWakeUpAt(_, run_time)); time_domain_->ScheduleDelayedWork(task_queue_.get(), {run_time, 0}, now); - TaskQueue* next_task_queue; + internal::TaskQueueImpl* next_task_queue; EXPECT_TRUE(time_domain_->NextScheduledTaskQueue(&next_task_queue)); EXPECT_EQ(task_queue_.get(), next_task_queue); @@ -281,9 +280,9 @@ } TEST_F(TimeDomainTest, CancelDelayedWork_TwoQueues) { - scoped_refptr<internal::TaskQueueImpl> task_queue2 = make_scoped_refptr( - new internal::TaskQueueImpl(nullptr, time_domain_.get(), - TaskQueue::Spec(TaskQueue::QueueType::TEST))); + std::unique_ptr<internal::TaskQueueImpl> task_queue2 = + base::MakeUnique<internal::TaskQueueImpl>(nullptr, time_domain_.get(), + TaskQueue::Spec("test")); base::TimeTicks now = time_domain_->Now(); base::TimeTicks run_time1 = now + base::TimeDelta::FromMilliseconds(20); @@ -296,7 +295,7 @@ time_domain_->ScheduleDelayedWork(task_queue2.get(), {run_time2, 0}, now); Mock::VerifyAndClearExpectations(time_domain_.get()); - TaskQueue* next_task_queue; + internal::TaskQueueImpl* next_task_queue; EXPECT_TRUE(time_domain_->NextScheduledTaskQueue(&next_task_queue)); EXPECT_EQ(task_queue_.get(), next_task_queue); @@ -318,7 +317,7 @@ EXPECT_CALL(*time_domain_.get(), CancelWakeUpAt(_)).Times(AnyNumber()); // Tidy up. - task_queue2->UnregisterTaskQueue(); + task_queue2->UnregisterTaskQueue(nullptr); } } // namespace scheduler
diff --git a/third_party/WebKit/Source/platform/scheduler/base/work_queue_unittest.cc b/third_party/WebKit/Source/platform/scheduler/base/work_queue_unittest.cc index 4941dbe..1835001 100644 --- a/third_party/WebKit/Source/platform/scheduler/base/work_queue_unittest.cc +++ b/third_party/WebKit/Source/platform/scheduler/base/work_queue_unittest.cc
@@ -24,9 +24,8 @@ public: void SetUp() override { time_domain_.reset(new RealTimeDomain()); - task_queue_ = make_scoped_refptr( - new TaskQueueImpl(nullptr, time_domain_.get(), - TaskQueue::Spec(TaskQueue::QueueType::TEST))); + task_queue_ = base::MakeUnique<TaskQueueImpl>(nullptr, time_domain_.get(), + TaskQueue::Spec("test")); work_queue_.reset(new WorkQueue(task_queue_.get(), "test", WorkQueue::QueueType::IMMEDIATE)); @@ -45,7 +44,7 @@ } std::unique_ptr<RealTimeDomain> time_domain_; - scoped_refptr<TaskQueueImpl> task_queue_; + std::unique_ptr<TaskQueueImpl> task_queue_; std::unique_ptr<WorkQueue> work_queue_; std::unique_ptr<WorkQueueSets> work_queue_sets_; std::unique_ptr<TaskQueueImpl::TaskDeque> incoming_queue_;
diff --git a/third_party/WebKit/Source/platform/scheduler/child/compositor_worker_scheduler.cc b/third_party/WebKit/Source/platform/scheduler/child/compositor_worker_scheduler.cc index 10522bcb..5d293ea 100644 --- a/third_party/WebKit/Source/platform/scheduler/child/compositor_worker_scheduler.cc +++ b/third_party/WebKit/Source/platform/scheduler/child/compositor_worker_scheduler.cc
@@ -20,15 +20,15 @@ CompositorWorkerScheduler::CompositorWorkerScheduler( base::Thread* thread, scoped_refptr<SchedulerTqmDelegate> main_task_runner) - : WorkerScheduler(WTF::MakeUnique<SchedulerHelper>(main_task_runner)), + : WorkerScheduler(WTF::MakeUnique<WorkerSchedulerHelper>(main_task_runner)), thread_(thread) {} CompositorWorkerScheduler::~CompositorWorkerScheduler() {} void CompositorWorkerScheduler::Init() {} -scoped_refptr<TaskQueue> CompositorWorkerScheduler::DefaultTaskQueue() { - return helper_->DefaultTaskQueue(); +scoped_refptr<WorkerTaskQueue> CompositorWorkerScheduler::DefaultTaskQueue() { + return helper_->DefaultWorkerTaskQueue(); } scoped_refptr<base::SingleThreadTaskRunner>
diff --git a/third_party/WebKit/Source/platform/scheduler/child/compositor_worker_scheduler.h b/third_party/WebKit/Source/platform/scheduler/child/compositor_worker_scheduler.h index e42cdec1..ba2393a 100644 --- a/third_party/WebKit/Source/platform/scheduler/child/compositor_worker_scheduler.h +++ b/third_party/WebKit/Source/platform/scheduler/child/compositor_worker_scheduler.h
@@ -32,7 +32,7 @@ // WorkerScheduler: void Init() override; - scoped_refptr<TaskQueue> DefaultTaskQueue() override; + scoped_refptr<WorkerTaskQueue> DefaultTaskQueue() override; // ChildScheduler: scoped_refptr<base::SingleThreadTaskRunner> DefaultTaskRunner() override;
diff --git a/third_party/WebKit/Source/platform/scheduler/child/idle_canceled_delayed_task_sweeper_unittest.cc b/third_party/WebKit/Source/platform/scheduler/child/idle_canceled_delayed_task_sweeper_unittest.cc index d106333..c2a20ad 100644 --- a/third_party/WebKit/Source/platform/scheduler/child/idle_canceled_delayed_task_sweeper_unittest.cc +++ b/third_party/WebKit/Source/platform/scheduler/child/idle_canceled_delayed_task_sweeper_unittest.cc
@@ -13,6 +13,7 @@ #include "platform/scheduler/child/idle_helper.h" #include "platform/scheduler/child/scheduler_helper.h" #include "platform/scheduler/child/scheduler_tqm_delegate_for_test.h" +#include "platform/scheduler/renderer/main_thread_scheduler_helper.h" #include "testing/gtest/include/gtest/gtest.h" namespace blink { @@ -36,15 +37,18 @@ delegate_(SchedulerTqmDelegateForTest::Create( mock_task_runner_, base::WrapUnique(new TestTimeSource(clock_.get())))), - scheduler_helper_(new SchedulerHelper(delegate_)), + scheduler_helper_(new MainThreadSchedulerHelper(delegate_, nullptr)), idle_helper_(new IdleHelper(scheduler_helper_.get(), this, "test", - base::TimeDelta::FromSeconds(30))), + base::TimeDelta::FromSeconds(30), + scheduler_helper_->NewTaskQueue( + MainThreadTaskQueue::QueueType::TEST, + TaskQueue::Spec("test_idle_tq")))), idle_canceled_delayed_taks_sweeper_( new IdleCanceledDelayedTaskSweeper(scheduler_helper_.get(), idle_helper_->IdleTaskRunner())), - default_task_queue_(scheduler_helper_->DefaultTaskQueue()) { + default_task_queue_(scheduler_helper_->DefaultMainThreadTaskQueue()) { clock_->Advance(base::TimeDelta::FromMicroseconds(5000)); } @@ -73,7 +77,7 @@ scoped_refptr<cc::OrderedSimpleTaskRunner> mock_task_runner_; scoped_refptr<SchedulerTqmDelegateForTest> delegate_; - std::unique_ptr<SchedulerHelper> scheduler_helper_; + std::unique_ptr<MainThreadSchedulerHelper> scheduler_helper_; std::unique_ptr<IdleHelper> idle_helper_; std::unique_ptr<IdleCanceledDelayedTaskSweeper> idle_canceled_delayed_taks_sweeper_;
diff --git a/third_party/WebKit/Source/platform/scheduler/child/idle_helper.cc b/third_party/WebKit/Source/platform/scheduler/child/idle_helper.cc index f16a09a..1132e8a 100644 --- a/third_party/WebKit/Source/platform/scheduler/child/idle_helper.cc +++ b/third_party/WebKit/Source/platform/scheduler/child/idle_helper.cc
@@ -20,14 +20,12 @@ SchedulerHelper* helper, Delegate* delegate, const char* idle_period_tracing_name, - base::TimeDelta required_quiescence_duration_before_long_idle_period) + base::TimeDelta required_quiescence_duration_before_long_idle_period, + scoped_refptr<TaskQueue> idle_queue) : helper_(helper), delegate_(delegate), - idle_queue_( - helper_->NewTaskQueue(TaskQueue::Spec(TaskQueue::QueueType::IDLE))), - state_(helper, - delegate, - idle_period_tracing_name), + idle_queue_(std::move(idle_queue)), + state_(helper, delegate, idle_period_tracing_name), required_quiescence_duration_before_long_idle_period_( required_quiescence_duration_before_long_idle_period), is_shutdown_(false),
diff --git a/third_party/WebKit/Source/platform/scheduler/child/idle_helper.h b/third_party/WebKit/Source/platform/scheduler/child/idle_helper.h index a1335c5c..aec0d27 100644 --- a/third_party/WebKit/Source/platform/scheduler/child/idle_helper.h +++ b/third_party/WebKit/Source/platform/scheduler/child/idle_helper.h
@@ -91,7 +91,8 @@ SchedulerHelper* helper, Delegate* delegate, const char* idle_period_tracing_name, - base::TimeDelta required_quiescence_duration_before_long_idle_period); + base::TimeDelta required_quiescence_duration_before_long_idle_period, + scoped_refptr<TaskQueue> idle_queue); ~IdleHelper() override; // Prevents any further idle tasks from running.
diff --git a/third_party/WebKit/Source/platform/scheduler/child/idle_helper_unittest.cc b/third_party/WebKit/Source/platform/scheduler/child/idle_helper_unittest.cc index 8901a29..d5e9161 100644 --- a/third_party/WebKit/Source/platform/scheduler/child/idle_helper_unittest.cc +++ b/third_party/WebKit/Source/platform/scheduler/child/idle_helper_unittest.cc
@@ -21,6 +21,7 @@ #include "platform/scheduler/child/scheduler_helper.h" #include "platform/scheduler/child/scheduler_tqm_delegate_for_test.h" #include "platform/scheduler/child/scheduler_tqm_delegate_impl.h" +#include "platform/scheduler/child/worker_scheduler_helper.h" #include "testing/gmock/include/gmock/gmock.h" #include "testing/gtest/include/gtest/gtest.h" @@ -158,11 +159,13 @@ public: explicit IdleHelperForTest( SchedulerHelper* scheduler_helper, - base::TimeDelta required_quiescence_duration_before_long_idle_period) + base::TimeDelta required_quiescence_duration_before_long_idle_period, + scoped_refptr<TaskQueue> idle_task_runner) : IdleHelper(scheduler_helper, this, "TestSchedulerIdlePeriod", - required_quiescence_duration_before_long_idle_period) {} + required_quiescence_duration_before_long_idle_period, + idle_task_runner) {} ~IdleHelperForTest() override {} @@ -192,11 +195,12 @@ message_loop, mock_task_runner_, base::WrapUnique(new TestTimeSource(clock_.get())))), - scheduler_helper_(new SchedulerHelper(main_task_runner_)), + scheduler_helper_(new WorkerSchedulerHelper(main_task_runner_)), idle_helper_(new IdleHelperForTest( scheduler_helper_.get(), - required_quiescence_duration_before_long_idle_period)), - default_task_runner_(scheduler_helper_->DefaultTaskQueue()), + required_quiescence_duration_before_long_idle_period, + scheduler_helper_->NewTaskQueue(TaskQueue::Spec("idle_test")))), + default_task_runner_(scheduler_helper_->DefaultWorkerTaskQueue()), idle_task_runner_(idle_helper_->IdleTaskRunner()) { clock_->Advance(base::TimeDelta::FromMicroseconds(5000)); } @@ -292,7 +296,7 @@ std::unique_ptr<base::MessageLoop> message_loop_; scoped_refptr<SchedulerTqmDelegate> main_task_runner_; - std::unique_ptr<SchedulerHelper> scheduler_helper_; + std::unique_ptr<WorkerSchedulerHelper> scheduler_helper_; std::unique_ptr<IdleHelperForTest> idle_helper_; scoped_refptr<base::SingleThreadTaskRunner> default_task_runner_; scoped_refptr<SingleThreadIdleTaskRunner> idle_task_runner_;
diff --git a/third_party/WebKit/Source/platform/scheduler/child/scheduler_helper.cc b/third_party/WebKit/Source/platform/scheduler/child/scheduler_helper.cc index b0a71c95..2fa8cd8d 100644 --- a/third_party/WebKit/Source/platform/scheduler/child/scheduler_helper.cc +++ b/third_party/WebKit/Source/platform/scheduler/child/scheduler_helper.cc
@@ -15,26 +15,19 @@ SchedulerHelper::SchedulerHelper( scoped_refptr<SchedulerTqmDelegate> task_queue_manager_delegate) - : SchedulerHelper(task_queue_manager_delegate, - TaskQueue::Spec(TaskQueue::QueueType::DEFAULT) - .SetShouldMonitorQuiescence(true)) {} - -SchedulerHelper::SchedulerHelper( - scoped_refptr<SchedulerTqmDelegate> task_queue_manager_delegate, - TaskQueue::Spec default_task_queue_spec) : task_queue_manager_delegate_(task_queue_manager_delegate), task_queue_manager_(new TaskQueueManager(task_queue_manager_delegate)), - control_task_queue_( - NewTaskQueue(TaskQueue::Spec(TaskQueue::QueueType::CONTROL) - .SetShouldNotifyObservers(false))), - default_task_queue_(NewTaskQueue(default_task_queue_spec)), observer_(nullptr) { - control_task_queue_->SetQueuePriority(TaskQueue::CONTROL_PRIORITY); - task_queue_manager_->SetWorkBatchSize(4); +} + +void SchedulerHelper::InitDefaultQueues( + scoped_refptr<TaskQueue> default_task_queue, + scoped_refptr<TaskQueue> control_task_queue) { + control_task_queue->SetQueuePriority(TaskQueue::CONTROL_PRIORITY); DCHECK(task_queue_manager_delegate_); - task_queue_manager_delegate_->SetDefaultTaskRunner(default_task_queue_.get()); + task_queue_manager_delegate_->SetDefaultTaskRunner(default_task_queue); } SchedulerHelper::~SchedulerHelper() { @@ -58,21 +51,6 @@ record_task_delay_histograms); } -scoped_refptr<TaskQueue> SchedulerHelper::NewTaskQueue( - const TaskQueue::Spec& spec) { - DCHECK(task_queue_manager_.get()); - return task_queue_manager_->NewTaskQueue(spec); -} - -scoped_refptr<TaskQueue> SchedulerHelper::DefaultTaskQueue() { - CheckOnValidThread(); - return default_task_queue_; -} - -scoped_refptr<TaskQueue> SchedulerHelper::ControlTaskQueue() { - return control_task_queue_; -} - size_t SchedulerHelper::GetNumberOfPendingTasks() const { return task_queue_manager_->GetNumberOfPendingTasks(); } @@ -156,23 +134,9 @@ task_queue_manager_->UnregisterTimeDomain(time_domain); } -void SchedulerHelper::OnUnregisterTaskQueue( - const scoped_refptr<TaskQueue>& queue) { +void SchedulerHelper::OnTriedToExecuteBlockedTask() { if (observer_) - observer_->OnUnregisterTaskQueue(queue); -} - -void SchedulerHelper::OnTriedToExecuteBlockedTask( - const TaskQueue& queue, - const base::PendingTask& task) { - if (observer_) - observer_->OnTriedToExecuteBlockedTask(queue, task); -} - -TaskQueue* SchedulerHelper::CurrentlyExecutingTaskQueue() const { - if (!task_queue_manager_) - return nullptr; - return task_queue_manager_->currently_executing_task_queue(); + observer_->OnTriedToExecuteBlockedTask(); } } // namespace scheduler
diff --git a/third_party/WebKit/Source/platform/scheduler/child/scheduler_helper.h b/third_party/WebKit/Source/platform/scheduler/child/scheduler_helper.h index f4329de..ce645c81 100644 --- a/third_party/WebKit/Source/platform/scheduler/child/scheduler_helper.h +++ b/third_party/WebKit/Source/platform/scheduler/child/scheduler_helper.h
@@ -23,9 +23,6 @@ public: explicit SchedulerHelper( scoped_refptr<SchedulerTqmDelegate> task_queue_manager_delegate); - explicit SchedulerHelper( - scoped_refptr<SchedulerTqmDelegate> task_queue_manager_delegate, - TaskQueue::Spec default_task_queue_spec); ~SchedulerHelper() override; // There is a small overhead to recording task delay histograms, we may not @@ -33,17 +30,15 @@ void SetRecordTaskDelayHistograms(bool record_task_delay_histograms); // TaskQueueManager::Observer implementation: - void OnUnregisterTaskQueue(const scoped_refptr<TaskQueue>& queue) override; - void OnTriedToExecuteBlockedTask(const TaskQueue& queue, - const base::PendingTask& task) override; + void OnTriedToExecuteBlockedTask() override; // Returns the default task queue. - scoped_refptr<TaskQueue> DefaultTaskQueue(); + virtual scoped_refptr<TaskQueue> DefaultTaskQueue() = 0; // Returns the control task queue. Tasks posted to this queue are executed // with the highest priority. Care must be taken to avoid starvation of other // task queues. - scoped_refptr<TaskQueue> ControlTaskQueue(); + virtual scoped_refptr<TaskQueue> ControlTaskQueue() = 0; // Adds or removes a task observer from the scheduler. The observer will be // notified before and after every executed task. These functions can only be @@ -66,21 +61,13 @@ DCHECK(thread_checker_.CalledOnValidThread()); } - // Creates a new TaskQueue with the given |spec|. - scoped_refptr<TaskQueue> NewTaskQueue(const TaskQueue::Spec& spec); - class PLATFORM_EXPORT Observer { public: virtual ~Observer() {} - // Called when |queue| is unregistered. - virtual void OnUnregisterTaskQueue( - const scoped_refptr<TaskQueue>& queue) = 0; - // Called when the scheduler tried to execute a task from a disabled // queue. See TaskQueue::Spec::SetShouldReportWhenExecutionBlocked. - virtual void OnTriedToExecuteBlockedTask(const TaskQueue& queue, - const base::PendingTask& task) = 0; + virtual void OnTriedToExecuteBlockedTask() = 0; }; // Called once to set the Observer. This function is called on the main @@ -97,7 +84,6 @@ void UnregisterTimeDomain(TimeDomain* time_domain); const scoped_refptr<SchedulerTqmDelegate>& scheduler_tqm_delegate() const; bool GetAndClearSystemIsQuiescentBit(); - TaskQueue* CurrentlyExecutingTaskQueue() const; size_t GetNumberOfPendingTasks() const; @@ -105,14 +91,16 @@ void SetWorkBatchSizeForTesting(size_t work_batch_size); TaskQueueManager* GetTaskQueueManagerForTesting(); - private: - friend class SchedulerHelperTest; + protected: + void InitDefaultQueues(scoped_refptr<TaskQueue> default_task_queue, + scoped_refptr<TaskQueue> control_task_queue); base::ThreadChecker thread_checker_; scoped_refptr<SchedulerTqmDelegate> task_queue_manager_delegate_; std::unique_ptr<TaskQueueManager> task_queue_manager_; - scoped_refptr<TaskQueue> control_task_queue_; - scoped_refptr<TaskQueue> default_task_queue_; + + private: + friend class SchedulerHelperTest; Observer* observer_; // NOT OWNED
diff --git a/third_party/WebKit/Source/platform/scheduler/child/scheduler_helper_unittest.cc b/third_party/WebKit/Source/platform/scheduler/child/scheduler_helper_unittest.cc index f3dae923..2b5537e 100644 --- a/third_party/WebKit/Source/platform/scheduler/child/scheduler_helper_unittest.cc +++ b/third_party/WebKit/Source/platform/scheduler/child/scheduler_helper_unittest.cc
@@ -15,6 +15,7 @@ #include "platform/scheduler/base/task_queue.h" #include "platform/scheduler/base/test_time_source.h" #include "platform/scheduler/child/scheduler_tqm_delegate_for_test.h" +#include "platform/scheduler/child/worker_scheduler_helper.h" #include "testing/gmock/include/gmock/gmock.h" #include "testing/gtest/include/gtest/gtest.h" @@ -55,8 +56,8 @@ main_task_runner_(SchedulerTqmDelegateForTest::Create( mock_task_runner_, base::WrapUnique(new TestTimeSource(clock_.get())))), - scheduler_helper_(new SchedulerHelper(main_task_runner_)), - default_task_runner_(scheduler_helper_->DefaultTaskQueue()) { + scheduler_helper_(new WorkerSchedulerHelper(main_task_runner_)), + default_task_runner_(scheduler_helper_->DefaultWorkerTaskQueue()) { clock_->Advance(base::TimeDelta::FromMicroseconds(5000)); } @@ -86,7 +87,7 @@ scoped_refptr<cc::OrderedSimpleTaskRunner> mock_task_runner_; scoped_refptr<SchedulerTqmDelegateForTest> main_task_runner_; - std::unique_ptr<SchedulerHelper> scheduler_helper_; + std::unique_ptr<WorkerSchedulerHelper> scheduler_helper_; scoped_refptr<base::SingleThreadTaskRunner> default_task_runner_; DISALLOW_COPY_AND_ASSIGN(SchedulerHelperTest); @@ -130,18 +131,18 @@ TEST_F(SchedulerHelperTest, DefaultTaskRunnerRegistration) { EXPECT_EQ(main_task_runner_->default_task_runner(), - scheduler_helper_->DefaultTaskQueue()); + scheduler_helper_->DefaultWorkerTaskQueue()); scheduler_helper_->Shutdown(); EXPECT_EQ(nullptr, main_task_runner_->default_task_runner()); } TEST_F(SchedulerHelperTest, GetNumberOfPendingTasks) { std::vector<std::string> run_order; - scheduler_helper_->DefaultTaskQueue()->PostTask( + scheduler_helper_->DefaultWorkerTaskQueue()->PostTask( FROM_HERE, base::Bind(&AppendToVectorTestTask, &run_order, "D1")); - scheduler_helper_->DefaultTaskQueue()->PostTask( + scheduler_helper_->DefaultWorkerTaskQueue()->PostTask( FROM_HERE, base::Bind(&AppendToVectorTestTask, &run_order, "D2")); - scheduler_helper_->ControlTaskQueue()->PostTask( + scheduler_helper_->ControlWorkerTaskQueue()->PostTask( FROM_HERE, base::Bind(&AppendToVectorTestTask, &run_order, "C1")); EXPECT_EQ(3U, scheduler_helper_->GetNumberOfPendingTasks()); RunUntilIdle(); @@ -162,8 +163,8 @@ MockTaskObserver observer; scheduler_helper_->AddTaskObserver(&observer); - scheduler_helper_->DefaultTaskQueue()->PostTask(FROM_HERE, - base::Bind(&NopTask)); + scheduler_helper_->DefaultWorkerTaskQueue()->PostTask(FROM_HERE, + base::Bind(&NopTask)); EXPECT_CALL(observer, WillProcessTask(_)).Times(1); EXPECT_CALL(observer, DidProcessTask(_)).Times(1); @@ -174,8 +175,8 @@ MockTaskObserver observer; scheduler_helper_->AddTaskObserver(&observer); - scheduler_helper_->ControlTaskQueue()->PostTask(FROM_HERE, - base::Bind(&NopTask)); + scheduler_helper_->ControlWorkerTaskQueue()->PostTask(FROM_HERE, + base::Bind(&NopTask)); EXPECT_CALL(observer, WillProcessTask(_)).Times(0); EXPECT_CALL(observer, DidProcessTask(_)).Times(0); @@ -186,34 +187,17 @@ class MockObserver : public SchedulerHelper::Observer { public: - MOCK_METHOD1(OnUnregisterTaskQueue, - void(const scoped_refptr<TaskQueue>& queue)); - MOCK_METHOD2(OnTriedToExecuteBlockedTask, - void(const TaskQueue& queue, const base::PendingTask& task)); + MOCK_METHOD0(OnTriedToExecuteBlockedTask, void()); }; } // namespace -TEST_F(SchedulerHelperTest, OnUnregisterTaskQueue) { - MockObserver observer; - scheduler_helper_->SetObserver(&observer); - - scoped_refptr<TaskQueue> task_queue = scheduler_helper_->NewTaskQueue( - TaskQueue::Spec(TaskQueue::QueueType::TEST)); - - EXPECT_CALL(observer, OnUnregisterTaskQueue(_)).Times(1); - task_queue->UnregisterTaskQueue(); - - scheduler_helper_->SetObserver(nullptr); -} - TEST_F(SchedulerHelperTest, OnTriedToExecuteBlockedTask) { MockObserver observer; scheduler_helper_->SetObserver(&observer); scoped_refptr<TaskQueue> task_queue = scheduler_helper_->NewTaskQueue( - TaskQueue::Spec(TaskQueue::QueueType::TEST) - .SetShouldReportWhenExecutionBlocked(true)); + TaskQueue::Spec("test").SetShouldReportWhenExecutionBlocked(true)); std::unique_ptr<TaskQueue::QueueEnabledVoter> voter = task_queue->CreateQueueEnabledVoter(); voter->SetQueueEnabled(false); @@ -224,7 +208,7 @@ voter->SetQueueEnabled(true); voter->SetQueueEnabled(false); - EXPECT_CALL(observer, OnTriedToExecuteBlockedTask(_, _)).Times(1); + EXPECT_CALL(observer, OnTriedToExecuteBlockedTask()).Times(1); RunUntilIdle(); scheduler_helper_->SetObserver(nullptr);
diff --git a/third_party/WebKit/Source/platform/scheduler/child/worker_global_scope_scheduler.cc b/third_party/WebKit/Source/platform/scheduler/child/worker_global_scope_scheduler.cc index 7178a0b..af790692 100644 --- a/third_party/WebKit/Source/platform/scheduler/child/worker_global_scope_scheduler.cc +++ b/third_party/WebKit/Source/platform/scheduler/child/worker_global_scope_scheduler.cc
@@ -11,9 +11,7 @@ WorkerGlobalScopeScheduler::WorkerGlobalScopeScheduler( WorkerScheduler* worker_scheduler) { - scoped_refptr<TaskQueue> task_queue = - worker_scheduler->CreateUnthrottledTaskRunner( - TaskQueue::QueueType::UNTHROTTLED); + scoped_refptr<TaskQueue> task_queue = worker_scheduler->CreateTaskRunner(); unthrottled_task_runner_ = WebTaskRunnerImpl::Create(std::move(task_queue)); }
diff --git a/third_party/WebKit/Source/platform/scheduler/child/worker_scheduler.cc b/third_party/WebKit/Source/platform/scheduler/child/worker_scheduler.cc index d3ca3a9..d0fa1a6 100644 --- a/third_party/WebKit/Source/platform/scheduler/child/worker_scheduler.cc +++ b/third_party/WebKit/Source/platform/scheduler/child/worker_scheduler.cc
@@ -14,7 +14,7 @@ namespace blink { namespace scheduler { -WorkerScheduler::WorkerScheduler(std::unique_ptr<SchedulerHelper> helper) +WorkerScheduler::WorkerScheduler(std::unique_ptr<WorkerSchedulerHelper> helper) : helper_(std::move(helper)) {} WorkerScheduler::~WorkerScheduler() {} @@ -25,14 +25,11 @@ return base::WrapUnique(new WorkerSchedulerImpl(std::move(main_task_runner))); } -scoped_refptr<TaskQueue> WorkerScheduler::CreateUnthrottledTaskRunner( - TaskQueue::QueueType queue_type) { +scoped_refptr<WorkerTaskQueue> WorkerScheduler::CreateTaskRunner() { helper_->CheckOnValidThread(); - scoped_refptr<TaskQueue> unthrottled_task_queue( - helper_->NewTaskQueue(TaskQueue::Spec(queue_type) - .SetShouldMonitorQuiescence(true) - .SetTimeDomain(nullptr))); - return unthrottled_task_queue; + return helper_->NewTaskQueue(TaskQueue::Spec("worker_tq") + .SetShouldMonitorQuiescence(true) + .SetTimeDomain(nullptr)); } } // namespace scheduler
diff --git a/third_party/WebKit/Source/platform/scheduler/child/worker_scheduler.h b/third_party/WebKit/Source/platform/scheduler/child/worker_scheduler.h index 1e55375..0b434e2 100644 --- a/third_party/WebKit/Source/platform/scheduler/child/worker_scheduler.h +++ b/third_party/WebKit/Source/platform/scheduler/child/worker_scheduler.h
@@ -11,7 +11,8 @@ #include "base/message_loop/message_loop.h" #include "platform/PlatformExport.h" #include "platform/scheduler/base/task_queue.h" -#include "platform/scheduler/child/scheduler_helper.h" +#include "platform/scheduler/child/worker_scheduler_helper.h" +#include "platform/scheduler/child/worker_task_queue.h" #include "public/platform/scheduler/child/child_scheduler.h" #include "public/platform/scheduler/child/single_thread_idle_task_runner.h" @@ -27,19 +28,18 @@ // Blink should use WorkerScheduler::DefaultTaskQueue instead of // ChildScheduler::DefaultTaskRunner. - virtual scoped_refptr<TaskQueue> DefaultTaskQueue() = 0; + virtual scoped_refptr<WorkerTaskQueue> DefaultTaskQueue() = 0; // Must be called before the scheduler can be used. Does any post construction // initialization needed such as initializing idle period detection. virtual void Init() = 0; - scoped_refptr<TaskQueue> CreateUnthrottledTaskRunner( - TaskQueue::QueueType queue_type); + scoped_refptr<WorkerTaskQueue> CreateTaskRunner(); protected: - explicit WorkerScheduler(std::unique_ptr<SchedulerHelper> helper); + explicit WorkerScheduler(std::unique_ptr<WorkerSchedulerHelper> helper); - std::unique_ptr<SchedulerHelper> helper_; + std::unique_ptr<WorkerSchedulerHelper> helper_; DISALLOW_COPY_AND_ASSIGN(WorkerScheduler); };
diff --git a/third_party/WebKit/Source/platform/scheduler/child/worker_scheduler_helper.cc b/third_party/WebKit/Source/platform/scheduler/child/worker_scheduler_helper.cc new file mode 100644 index 0000000..1b43c03 --- /dev/null +++ b/third_party/WebKit/Source/platform/scheduler/child/worker_scheduler_helper.cc
@@ -0,0 +1,47 @@ +// Copyright 2017 The Chromium Authors. All rights reserved. +// Use of this source code is governed by a BSD-style license that can be +// found in the LICENSE file. + +#include "platform/scheduler/child/worker_scheduler_helper.h" + +#include "platform/scheduler/child/scheduler_tqm_delegate.h" +#include "platform/scheduler/child/worker_task_queue.h" + +namespace blink { +namespace scheduler { + +WorkerSchedulerHelper::WorkerSchedulerHelper( + scoped_refptr<SchedulerTqmDelegate> task_queue_manager_delegate) + : SchedulerHelper(task_queue_manager_delegate), + default_task_queue_(NewTaskQueue(TaskQueue::Spec("worker_default_tq") + .SetShouldMonitorQuiescence(true))), + control_task_queue_(NewTaskQueue(TaskQueue::Spec("worker_control_tq") + .SetShouldNotifyObservers(false))) { + InitDefaultQueues(default_task_queue_, control_task_queue_); +} + +WorkerSchedulerHelper::~WorkerSchedulerHelper() {} + +scoped_refptr<WorkerTaskQueue> WorkerSchedulerHelper::DefaultWorkerTaskQueue() { + return default_task_queue_; +} + +scoped_refptr<TaskQueue> WorkerSchedulerHelper::DefaultTaskQueue() { + return default_task_queue_; +} + +scoped_refptr<WorkerTaskQueue> WorkerSchedulerHelper::ControlWorkerTaskQueue() { + return control_task_queue_; +} + +scoped_refptr<TaskQueue> WorkerSchedulerHelper::ControlTaskQueue() { + return control_task_queue_; +} + +scoped_refptr<WorkerTaskQueue> WorkerSchedulerHelper::NewTaskQueue( + const TaskQueue::Spec& spec) { + return task_queue_manager_->CreateTaskQueue<WorkerTaskQueue>(spec); +} + +} // namespace scheduler +} // namespace blink
diff --git a/third_party/WebKit/Source/platform/scheduler/child/worker_scheduler_helper.h b/third_party/WebKit/Source/platform/scheduler/child/worker_scheduler_helper.h new file mode 100644 index 0000000..7598407b --- /dev/null +++ b/third_party/WebKit/Source/platform/scheduler/child/worker_scheduler_helper.h
@@ -0,0 +1,40 @@ +// Copyright 2017 The Chromium Authors. All rights reserved. +// Use of this source code is governed by a BSD-style license that can be +// found in the LICENSE file. + +#ifndef THIRD_PARTY_WEBKIT_SOURCE_PLATFORM_SCHEDULER_CHILD_WORKER_SCHEDULER_HELPER_H_ +#define THIRD_PARTY_WEBKIT_SOURCE_PLATFORM_SCHEDULER_CHILD_WORKER_SCHEDULER_HELPER_H_ + +#include "platform/scheduler/child/scheduler_helper.h" + +#include "platform/scheduler/child/worker_task_queue.h" + +namespace blink { +namespace scheduler { + +class PLATFORM_EXPORT WorkerSchedulerHelper : public SchedulerHelper { + public: + explicit WorkerSchedulerHelper( + scoped_refptr<SchedulerTqmDelegate> task_queue_manager_delegate); + ~WorkerSchedulerHelper() override; + + scoped_refptr<WorkerTaskQueue> NewTaskQueue(const TaskQueue::Spec& spec); + + scoped_refptr<WorkerTaskQueue> DefaultWorkerTaskQueue(); + scoped_refptr<WorkerTaskQueue> ControlWorkerTaskQueue(); + + protected: + scoped_refptr<TaskQueue> DefaultTaskQueue() override; + scoped_refptr<TaskQueue> ControlTaskQueue() override; + + protected: + const scoped_refptr<WorkerTaskQueue> default_task_queue_; + const scoped_refptr<WorkerTaskQueue> control_task_queue_; + + DISALLOW_COPY_AND_ASSIGN(WorkerSchedulerHelper); +}; + +} // namespace scheduler +} // namespace blink + +#endif // THIRD_PARTY_WEBKIT_SOURCE_PLATFORM_SCHEDULER_CHILD_WORKER_SCHEDULER_HELPER_H_
diff --git a/third_party/WebKit/Source/platform/scheduler/child/worker_scheduler_impl.cc b/third_party/WebKit/Source/platform/scheduler/child/worker_scheduler_impl.cc index 196009b4..3d66f3c 100644 --- a/third_party/WebKit/Source/platform/scheduler/child/worker_scheduler_impl.cc +++ b/third_party/WebKit/Source/platform/scheduler/child/worker_scheduler_impl.cc
@@ -12,6 +12,7 @@ #include "platform/scheduler/base/task_queue.h" #include "platform/scheduler/base/time_converter.h" #include "platform/scheduler/child/scheduler_tqm_delegate.h" +#include "platform/scheduler/child/worker_scheduler_helper.h" #include "platform/wtf/PtrUtil.h" namespace blink { @@ -38,11 +39,12 @@ WorkerSchedulerImpl::WorkerSchedulerImpl( scoped_refptr<SchedulerTqmDelegate> main_task_runner) - : WorkerScheduler(WTF::MakeUnique<SchedulerHelper>(main_task_runner)), + : WorkerScheduler(WTF::MakeUnique<WorkerSchedulerHelper>(main_task_runner)), idle_helper_(helper_.get(), this, "WorkerSchedulerIdlePeriod", - base::TimeDelta::FromMilliseconds(300)), + base::TimeDelta::FromMilliseconds(300), + helper_->NewTaskQueue(TaskQueue::Spec("worker_idle_tq"))), idle_canceled_delayed_task_sweeper_(helper_.get(), idle_helper_.IdleTaskRunner()), load_tracker_(helper_->scheduler_tqm_delegate()->NowTicks(), @@ -71,12 +73,12 @@ scoped_refptr<base::SingleThreadTaskRunner> WorkerSchedulerImpl::DefaultTaskRunner() { DCHECK(initialized_); - return helper_->DefaultTaskQueue(); + return helper_->DefaultWorkerTaskQueue(); } -scoped_refptr<TaskQueue> WorkerSchedulerImpl::DefaultTaskQueue() { +scoped_refptr<WorkerTaskQueue> WorkerSchedulerImpl::DefaultTaskQueue() { DCHECK(initialized_); - return helper_->DefaultTaskQueue(); + return helper_->DefaultWorkerTaskQueue(); } scoped_refptr<SingleThreadIdleTaskRunner> @@ -135,12 +137,9 @@ return idle_helper_.CurrentIdleTaskDeadline(); } -void WorkerSchedulerImpl::WillProcessTask(TaskQueue* task_queue, - double start_time) {} +void WorkerSchedulerImpl::WillProcessTask(double start_time) {} -void WorkerSchedulerImpl::DidProcessTask(TaskQueue* task_queue, - double start_time, - double end_time) { +void WorkerSchedulerImpl::DidProcessTask(double start_time, double end_time) { DEFINE_THREAD_SAFE_STATIC_LOCAL(CustomCountHistogram, task_time_counter, ("WorkerThread.Task.Time", 0, 10000000, 50)); task_time_counter.Count((end_time - start_time) *
diff --git a/third_party/WebKit/Source/platform/scheduler/child/worker_scheduler_impl.h b/third_party/WebKit/Source/platform/scheduler/child/worker_scheduler_impl.h index a14e776..0fdc4f2 100644 --- a/third_party/WebKit/Source/platform/scheduler/child/worker_scheduler_impl.h +++ b/third_party/WebKit/Source/platform/scheduler/child/worker_scheduler_impl.h
@@ -29,7 +29,7 @@ // WorkerScheduler implementation: scoped_refptr<base::SingleThreadTaskRunner> DefaultTaskRunner() override; - scoped_refptr<TaskQueue> DefaultTaskQueue() override; + scoped_refptr<WorkerTaskQueue> DefaultTaskQueue() override; scoped_refptr<SingleThreadIdleTaskRunner> IdleTaskRunner() override; bool CanExceedIdleDeadlineIfRequired() const override; bool ShouldYieldForHighPriorityWork() override; @@ -40,10 +40,8 @@ void Shutdown() override; // TaskTimeObserver implementation: - void WillProcessTask(TaskQueue* task_queue, double start_time) override; - void DidProcessTask(TaskQueue* task_queue, - double start_time, - double end_time) override; + void WillProcessTask(double start_time) override; + void DidProcessTask(double start_time, double end_time) override; void OnBeginNestedRunLoop() override; SchedulerHelper* GetSchedulerHelperForTesting();
diff --git a/third_party/WebKit/Source/platform/scheduler/child/worker_task_queue.cc b/third_party/WebKit/Source/platform/scheduler/child/worker_task_queue.cc new file mode 100644 index 0000000..423dd6e --- /dev/null +++ b/third_party/WebKit/Source/platform/scheduler/child/worker_task_queue.cc
@@ -0,0 +1,18 @@ +// Copyright 2015 The Chromium Authors. All rights reserved. +// Use of this source code is governed by a BSD-style license that can be +// found in the LICENSE file. + +#include "platform/scheduler/child/worker_task_queue.h" + +#include "platform/scheduler/base/task_queue_impl.h" + +namespace blink { +namespace scheduler { + +WorkerTaskQueue::WorkerTaskQueue(std::unique_ptr<internal::TaskQueueImpl> impl) + : TaskQueue(std::move(impl)) {} + +WorkerTaskQueue::~WorkerTaskQueue() {} + +} // namespace scheduler +} // namespace blink
diff --git a/third_party/WebKit/Source/platform/scheduler/child/worker_task_queue.h b/third_party/WebKit/Source/platform/scheduler/child/worker_task_queue.h new file mode 100644 index 0000000..c6945512 --- /dev/null +++ b/third_party/WebKit/Source/platform/scheduler/child/worker_task_queue.h
@@ -0,0 +1,22 @@ +// Copyright 2017 The Chromium Authors. All rights reserved. +// Use of this source code is governed by a BSD-style license that can be +// found in the LICENSE file. + +#ifndef THIRD_PARTY_WEBKIT_SOURCE_PLATFORM_SCHEDULER_CHILD_WORKER_TASK_QUEUE_H_ +#define THIRD_PARTY_WEBKIT_SOURCE_PLATFORM_SCHEDULER_CHILD_WORKER_TASK_QUEUE_H_ + +#include "platform/scheduler/base/task_queue.h" + +namespace blink { +namespace scheduler { + +class PLATFORM_EXPORT WorkerTaskQueue : public TaskQueue { + public: + explicit WorkerTaskQueue(std::unique_ptr<internal::TaskQueueImpl> impl); + ~WorkerTaskQueue() override; +}; + +} // namespace scheduler +} // namespace blink + +#endif // THIRD_PARTY_WEBKIT_SOURCE_PLATFORM_SCHEDULER_CHILD_WORKER_TASK_QUEUE_H_
diff --git a/third_party/WebKit/Source/platform/scheduler/renderer/auto_advancing_virtual_time_domain_unittest.cc b/third_party/WebKit/Source/platform/scheduler/renderer/auto_advancing_virtual_time_domain_unittest.cc index b6b847e7..bd25f1df 100644 --- a/third_party/WebKit/Source/platform/scheduler/renderer/auto_advancing_virtual_time_domain_unittest.cc +++ b/third_party/WebKit/Source/platform/scheduler/renderer/auto_advancing_virtual_time_domain_unittest.cc
@@ -11,6 +11,7 @@ #include "platform/scheduler/base/test_task_time_observer.h" #include "platform/scheduler/base/test_time_source.h" #include "platform/scheduler/child/scheduler_tqm_delegate_for_test.h" +#include "platform/scheduler/test/test_task_queue.h" #include "testing/gmock/include/gmock/gmock.h" #include "testing/gtest/include/gtest/gtest.h" @@ -35,7 +36,7 @@ manager_ = base::MakeUnique<TaskQueueManager>(main_task_runner_); manager_->AddTaskTimeObserver(&test_task_time_observer_); task_queue_ = - manager_->NewTaskQueue(TaskQueue::Spec(TaskQueue::QueueType::TEST)); + manager_->CreateTaskQueue<TestTaskQueue>(TaskQueue::Spec("test")); initial_time_ = clock_->NowTicks(); auto_advancing_time_domain_.reset( new AutoAdvancingVirtualTimeDomain(initial_time_));
diff --git a/third_party/WebKit/Source/platform/scheduler/renderer/budget_pool_unittest.cc b/third_party/WebKit/Source/platform/scheduler/renderer/budget_pool_unittest.cc index 5e2c42b..2f1e7252 100644 --- a/third_party/WebKit/Source/platform/scheduler/renderer/budget_pool_unittest.cc +++ b/third_party/WebKit/Source/platform/scheduler/renderer/budget_pool_unittest.cc
@@ -134,7 +134,7 @@ task_queue_throttler_->CreateWakeUpBudgetPool("test"); scoped_refptr<TaskQueue> queue = - scheduler_->NewTimerTaskQueue(TaskQueue::QueueType::TEST); + scheduler_->NewTimerTaskQueue(MainThreadTaskQueue::QueueType::TEST); pool->SetWakeUpRate(0.1); pool->SetWakeUpDuration(base::TimeDelta::FromMilliseconds(10));
diff --git a/third_party/WebKit/Source/platform/scheduler/renderer/idle_time_estimator_unittest.cc b/third_party/WebKit/Source/platform/scheduler/renderer/idle_time_estimator_unittest.cc index e770040..7c087a4f 100644 --- a/third_party/WebKit/Source/platform/scheduler/renderer/idle_time_estimator_unittest.cc +++ b/third_party/WebKit/Source/platform/scheduler/renderer/idle_time_estimator_unittest.cc
@@ -5,12 +5,15 @@ #include "platform/scheduler/renderer/idle_time_estimator.h" #include "base/memory/ptr_util.h" +#include "base/memory/ref_counted.h" #include "base/test/simple_test_tick_clock.h" #include "cc/test/ordered_simple_task_runner.h" +#include "platform/scheduler/base/task_queue.h" #include "platform/scheduler/base/task_queue_manager.h" #include "platform/scheduler/base/test_task_time_observer.h" #include "platform/scheduler/base/test_time_source.h" #include "platform/scheduler/child/scheduler_tqm_delegate_for_test.h" +#include "platform/scheduler/test/test_task_queue.h" #include "testing/gmock/include/gmock/gmock.h" #include "testing/gtest/include/gtest/gtest.h" @@ -46,8 +49,8 @@ main_task_runner_ = SchedulerTqmDelegateForTest::Create( mock_task_runner_, base::MakeUnique<TestTimeSource>(clock_.get())); manager_ = base::MakeUnique<TaskQueueManager>(main_task_runner_); - compositor_task_queue_ = manager_->NewTaskQueue( - TaskQueue::Spec(TaskQueue::QueueType::COMPOSITOR)); + compositor_task_queue_ = + manager_->CreateTaskQueue<TestTaskQueue>(TaskQueue::Spec("test_tq")); estimator_.reset(new IdleTimeEstimatorForTest( compositor_task_queue_, test_time_source_.get(), 10, 50)); }
diff --git a/third_party/WebKit/Source/platform/scheduler/renderer/main_thread_scheduler_helper.cc b/third_party/WebKit/Source/platform/scheduler/renderer/main_thread_scheduler_helper.cc new file mode 100644 index 0000000..c8e59e0 --- /dev/null +++ b/third_party/WebKit/Source/platform/scheduler/renderer/main_thread_scheduler_helper.cc
@@ -0,0 +1,59 @@ +// Copyright 2017 The Chromium Authors. All rights reserved. +// Use of this source code is governed by a BSD-style license that can be +// found in the LICENSE file. + +#include "platform/scheduler/renderer/main_thread_scheduler_helper.h" + +#include "platform/scheduler/child/scheduler_tqm_delegate.h" +#include "platform/scheduler/renderer/main_thread_task_queue.h" + +namespace blink { +namespace scheduler { + +MainThreadSchedulerHelper::MainThreadSchedulerHelper( + scoped_refptr<SchedulerTqmDelegate> task_queue_manager_delegate, + RendererSchedulerImpl* renderer_scheduler) + : SchedulerHelper(task_queue_manager_delegate), + renderer_scheduler_(renderer_scheduler), + default_task_queue_( + NewTaskQueue(MainThreadTaskQueue::QueueType::DEFAULT, + MainThreadTaskQueue::CreateSpecForType( + MainThreadTaskQueue::QueueType::DEFAULT) + .SetShouldMonitorQuiescence(true))), + control_task_queue_( + NewTaskQueue(MainThreadTaskQueue::QueueType::CONTROL, + MainThreadTaskQueue::CreateSpecForType( + MainThreadTaskQueue::QueueType::CONTROL) + .SetShouldNotifyObservers(false))) { + InitDefaultQueues(default_task_queue_, control_task_queue_); +} + +MainThreadSchedulerHelper::~MainThreadSchedulerHelper() {} + +scoped_refptr<MainThreadTaskQueue> +MainThreadSchedulerHelper::DefaultMainThreadTaskQueue() { + return default_task_queue_; +} + +scoped_refptr<TaskQueue> MainThreadSchedulerHelper::DefaultTaskQueue() { + return default_task_queue_; +} + +scoped_refptr<MainThreadTaskQueue> +MainThreadSchedulerHelper::ControlMainThreadTaskQueue() { + return control_task_queue_; +} + +scoped_refptr<TaskQueue> MainThreadSchedulerHelper::ControlTaskQueue() { + return control_task_queue_; +} + +scoped_refptr<MainThreadTaskQueue> MainThreadSchedulerHelper::NewTaskQueue( + MainThreadTaskQueue::QueueType type, + const TaskQueue::Spec& spec) { + return task_queue_manager_->CreateTaskQueue<MainThreadTaskQueue>( + spec, type, renderer_scheduler_); +} + +} // namespace scheduler +} // namespace blink
diff --git a/third_party/WebKit/Source/platform/scheduler/renderer/main_thread_scheduler_helper.h b/third_party/WebKit/Source/platform/scheduler/renderer/main_thread_scheduler_helper.h new file mode 100644 index 0000000..bf70cf1 --- /dev/null +++ b/third_party/WebKit/Source/platform/scheduler/renderer/main_thread_scheduler_helper.h
@@ -0,0 +1,47 @@ +// Copyright 2017 The Chromium Authors. All rights reserved. +// Use of this source code is governed by a BSD-style license that can be +// found in the LICENSE file. + +#ifndef THIRD_PARTY_WEBKIT_SOURCE_PLATFORM_SCHEDULER_RENDERER_MAIN_THREAD_SCHEDULER_HELPER_H_ +#define THIRD_PARTY_WEBKIT_SOURCE_PLATFORM_SCHEDULER_RENDERER_MAIN_THREAD_SCHEDULER_HELPER_H_ + +#include "platform/scheduler/child/scheduler_helper.h" + +#include "platform/scheduler/renderer/main_thread_task_queue.h" + +namespace blink { +namespace scheduler { + +class RendererSchedulerImpl; + +class PLATFORM_EXPORT MainThreadSchedulerHelper : public SchedulerHelper { + public: + MainThreadSchedulerHelper( + scoped_refptr<SchedulerTqmDelegate> task_queue_manager_delegate, + RendererSchedulerImpl* renderer_scheduler); + ~MainThreadSchedulerHelper() override; + + scoped_refptr<MainThreadTaskQueue> NewTaskQueue( + MainThreadTaskQueue::QueueType type, + const TaskQueue::Spec& spec); + + scoped_refptr<MainThreadTaskQueue> DefaultMainThreadTaskQueue(); + scoped_refptr<MainThreadTaskQueue> ControlMainThreadTaskQueue(); + + protected: + scoped_refptr<TaskQueue> DefaultTaskQueue() override; + scoped_refptr<TaskQueue> ControlTaskQueue() override; + + private: + RendererSchedulerImpl* renderer_scheduler_; // NOT OWNED + + const scoped_refptr<MainThreadTaskQueue> default_task_queue_; + const scoped_refptr<MainThreadTaskQueue> control_task_queue_; + + DISALLOW_COPY_AND_ASSIGN(MainThreadSchedulerHelper); +}; + +} // namespace scheduler +} // namespace blink + +#endif // THIRD_PARTY_WEBKIT_SOURCE_PLATFORM_SCHEDULER_RENDERER_MAIN_THREAD_SCHEDULER_HELPER_H_
diff --git a/third_party/WebKit/Source/platform/scheduler/renderer/main_thread_task_queue.cc b/third_party/WebKit/Source/platform/scheduler/renderer/main_thread_task_queue.cc new file mode 100644 index 0000000..15fb1a0 --- /dev/null +++ b/third_party/WebKit/Source/platform/scheduler/renderer/main_thread_task_queue.cc
@@ -0,0 +1,80 @@ +// Copyright 2015 The Chromium Authors. All rights reserved. +// Use of this source code is governed by a BSD-style license that can be +// found in the LICENSE file. + +#include "platform/scheduler/renderer/main_thread_task_queue.h" + +#include "platform/scheduler/base/task_queue_impl.h" +#include "platform/scheduler/renderer/renderer_scheduler_impl.h" + +namespace blink { +namespace scheduler { + +// static +const char* MainThreadTaskQueue::NameForQueueType( + MainThreadTaskQueue::QueueType queue_type) { + switch (queue_type) { + case MainThreadTaskQueue::QueueType::CONTROL: + return "control_tq"; + case MainThreadTaskQueue::QueueType::DEFAULT: + return "default_tq"; + case MainThreadTaskQueue::QueueType::DEFAULT_LOADING: + return "default_loading_tq"; + case MainThreadTaskQueue::QueueType::DEFAULT_TIMER: + return "default_timer_tq"; + case MainThreadTaskQueue::QueueType::UNTHROTTLED: + return "unthrottled_tq"; + case MainThreadTaskQueue::QueueType::FRAME_LOADING: + return "frame_loading_tq"; + case MainThreadTaskQueue::QueueType::FRAME_TIMER: + return "frame_timer_tq"; + case MainThreadTaskQueue::QueueType::FRAME_UNTHROTTLED: + return "frame_unthrottled_tq"; + case MainThreadTaskQueue::QueueType::COMPOSITOR: + return "compositor_tq"; + case MainThreadTaskQueue::QueueType::IDLE: + return "idle_tq"; + case MainThreadTaskQueue::QueueType::TEST: + return "test_tq"; + case MainThreadTaskQueue::QueueType::COUNT: + NOTREACHED(); + return nullptr; + } + NOTREACHED(); + return nullptr; +} + +// static +TaskQueue::Spec MainThreadTaskQueue::CreateSpecForType( + MainThreadTaskQueue::QueueType queue_type) { + return TaskQueue::Spec(NameForQueueType(queue_type)); +} + +MainThreadTaskQueue::MainThreadTaskQueue( + std::unique_ptr<internal::TaskQueueImpl> impl, + MainThreadTaskQueue::QueueType queue_type, + RendererSchedulerImpl* renderer_scheduler) + : TaskQueue(std::move(impl)), + queue_type_(queue_type), + renderer_scheduler_(renderer_scheduler) { + GetTaskQueueImpl()->SetOnTaskCompletedHandler(base::Bind( + &MainThreadTaskQueue::OnTaskCompleted, base::Unretained(this))); +} + +MainThreadTaskQueue::~MainThreadTaskQueue() {} + +void MainThreadTaskQueue::OnTaskCompleted(base::TimeTicks start, + base::TimeTicks end) { + renderer_scheduler_->OnTaskCompleted(this, start, end); +} + +void MainThreadTaskQueue::UnregisterTaskQueue() { + if (renderer_scheduler_) { + // RendererScheduler can be null in tests. + renderer_scheduler_->OnUnregisterTaskQueue(this); + } + TaskQueue::UnregisterTaskQueue(); +} + +} // namespace scheduler +} // namespace blink
diff --git a/third_party/WebKit/Source/platform/scheduler/renderer/main_thread_task_queue.h b/third_party/WebKit/Source/platform/scheduler/renderer/main_thread_task_queue.h new file mode 100644 index 0000000..09bbe24 --- /dev/null +++ b/third_party/WebKit/Source/platform/scheduler/renderer/main_thread_task_queue.h
@@ -0,0 +1,69 @@ +// Copyright 2015 The Chromium Authors. All rights reserved. +// Use of this source code is governed by a BSD-style license that can be +// found in the LICENSE file. + +#ifndef THIRD_PARTY_WEBKIT_SOURCE_PLATFORM_SCHEDULER_RENDERER_MAIN_THREAD_TASK_QUEUE_H_ +#define THIRD_PARTY_WEBKIT_SOURCE_PLATFORM_SCHEDULER_RENDERER_MAIN_THREAD_TASK_QUEUE_H_ + +#include "platform/scheduler/base/task_queue.h" + +namespace blink { +namespace scheduler { + +class RendererSchedulerImpl; + +class PLATFORM_EXPORT MainThreadTaskQueue : public TaskQueue { + public: + enum class QueueType { + // Keep MainThreadTaskQueue::NameForQueueType in sync. + // This enum is used for a histogram and it should not be re-numbered. + CONTROL = 0, + DEFAULT = 1, + DEFAULT_LOADING = 2, + DEFAULT_TIMER = 3, + UNTHROTTLED = 4, + FRAME_LOADING = 5, + FRAME_TIMER = 6, + FRAME_UNTHROTTLED = 7, + COMPOSITOR = 8, + IDLE = 9, + TEST = 10, + + COUNT = 11 + }; + + // Returns name of the given queue type. Returned string has application + // lifetime. + static const char* NameForQueueType(QueueType queue_type); + + // Create spec with correct name for given type. + static TaskQueue::Spec CreateSpecForType(QueueType queue_type); + + ~MainThreadTaskQueue() override; + + QueueType queue_type() const { return queue_type_; } + + void OnTaskCompleted(base::TimeTicks start, base::TimeTicks end); + + // Override base method to notify RendererScheduler about unregistered queue. + void UnregisterTaskQueue() override; + + private: + MainThreadTaskQueue(std::unique_ptr<internal::TaskQueueImpl> impl, + QueueType queue_type, + RendererSchedulerImpl* renderer_scheduler); + + friend class TaskQueueManager; + + QueueType queue_type_; + + // Needed to notify renderer scheduler about completed tasks. + RendererSchedulerImpl* renderer_scheduler_; // NOT OWNED + + DISALLOW_COPY_AND_ASSIGN(MainThreadTaskQueue); +}; + +} // namespace scheduler +} // namespace blink + +#endif // THIRD_PARTY_WEBKIT_SOURCE_PLATFORM_SCHEDULER_RENDERER_MAIN_THREAD_TASK_QUEUE_H_
diff --git a/third_party/WebKit/Source/platform/scheduler/renderer/renderer_scheduler_impl.cc b/third_party/WebKit/Source/platform/scheduler/renderer/renderer_scheduler_impl.cc index c0dcae2..e5e244f 100644 --- a/third_party/WebKit/Source/platform/scheduler/renderer/renderer_scheduler_impl.cc +++ b/third_party/WebKit/Source/platform/scheduler/renderer/renderer_scheduler_impl.cc
@@ -89,24 +89,30 @@ RendererSchedulerImpl::RendererSchedulerImpl( scoped_refptr<SchedulerTqmDelegate> main_task_runner) - : helper_(main_task_runner), - idle_helper_(&helper_, - this, - "RendererSchedulerIdlePeriod", - base::TimeDelta()), + : helper_(main_task_runner, this), + idle_helper_( + &helper_, + this, + "RendererSchedulerIdlePeriod", + base::TimeDelta(), + helper_.NewTaskQueue(MainThreadTaskQueue::QueueType::IDLE, + MainThreadTaskQueue::CreateSpecForType( + MainThreadTaskQueue::QueueType::IDLE))), idle_canceled_delayed_task_sweeper_(&helper_, idle_helper_.IdleTaskRunner()), render_widget_scheduler_signals_(this), - control_task_queue_(helper_.ControlTaskQueue()), + control_task_queue_(helper_.ControlMainThreadTaskQueue()), compositor_task_queue_( - helper_.NewTaskQueue(TaskQueue::Spec(TaskQueue::QueueType::COMPOSITOR) + helper_.NewTaskQueue(MainThreadTaskQueue::QueueType::COMPOSITOR, + MainThreadTaskQueue::CreateSpecForType( + MainThreadTaskQueue::QueueType::COMPOSITOR) .SetShouldMonitorQuiescence(true))), compositor_task_queue_enabled_voter_( compositor_task_queue_->CreateQueueEnabledVoter()), delayed_update_policy_runner_( base::Bind(&RendererSchedulerImpl::UpdatePolicy, base::Unretained(this)), - helper_.ControlTaskQueue()), + helper_.ControlMainThreadTaskQueue()), seqlock_queueing_time_estimator_( QueueingTimeEstimator(this, kQueueingTimeWindowDuration, 20)), main_thread_only_(this, @@ -122,9 +128,9 @@ &RendererSchedulerImpl::EndIdlePeriod, weak_factory_.GetWeakPtr())); default_loading_task_queue_ = - NewLoadingTaskQueue(TaskQueue::QueueType::DEFAULT_LOADING); + NewLoadingTaskQueue(MainThreadTaskQueue::QueueType::DEFAULT_LOADING); default_timer_task_queue_ = - NewTimerTaskQueue(TaskQueue::QueueType::DEFAULT_TIMER); + NewTimerTaskQueue(MainThreadTaskQueue::QueueType::DEFAULT_TIMER); TRACE_EVENT_OBJECT_CREATED_WITH_ID( TRACE_DISABLED_BY_DEFAULT("renderer.scheduler"), "RendererScheduler", @@ -173,7 +179,7 @@ RendererSchedulerImpl::MainThreadOnly::MainThreadOnly( RendererSchedulerImpl* renderer_scheduler_impl, - const scoped_refptr<TaskQueue>& compositor_task_runner, + const scoped_refptr<MainThreadTaskQueue>& compositor_task_runner, base::TickClock* time_source, base::TimeTicks now) : loading_task_cost_estimator(time_source, @@ -293,7 +299,7 @@ scoped_refptr<base::SingleThreadTaskRunner> RendererSchedulerImpl::DefaultTaskRunner() { - return helper_.DefaultTaskQueue(); + return helper_.DefaultMainThreadTaskQueue(); } scoped_refptr<base::SingleThreadTaskRunner> @@ -319,44 +325,46 @@ return default_timer_task_queue_; } -scoped_refptr<TaskQueue> RendererSchedulerImpl::DefaultTaskQueue() { - return helper_.DefaultTaskQueue(); +scoped_refptr<MainThreadTaskQueue> RendererSchedulerImpl::DefaultTaskQueue() { + return helper_.DefaultMainThreadTaskQueue(); } -scoped_refptr<TaskQueue> RendererSchedulerImpl::CompositorTaskQueue() { +scoped_refptr<MainThreadTaskQueue> +RendererSchedulerImpl::CompositorTaskQueue() { helper_.CheckOnValidThread(); return compositor_task_queue_; } -scoped_refptr<TaskQueue> RendererSchedulerImpl::LoadingTaskQueue() { +scoped_refptr<MainThreadTaskQueue> RendererSchedulerImpl::LoadingTaskQueue() { helper_.CheckOnValidThread(); return default_loading_task_queue_; } -scoped_refptr<TaskQueue> RendererSchedulerImpl::TimerTaskQueue() { +scoped_refptr<MainThreadTaskQueue> RendererSchedulerImpl::TimerTaskQueue() { helper_.CheckOnValidThread(); return default_timer_task_queue_; } -scoped_refptr<TaskQueue> RendererSchedulerImpl::ControlTaskQueue() { +scoped_refptr<MainThreadTaskQueue> RendererSchedulerImpl::ControlTaskQueue() { helper_.CheckOnValidThread(); - return helper_.ControlTaskQueue(); + return helper_.ControlMainThreadTaskQueue(); } -scoped_refptr<TaskQueue> RendererSchedulerImpl::VirtualTimeControlTaskQueue() { +scoped_refptr<MainThreadTaskQueue> +RendererSchedulerImpl::VirtualTimeControlTaskQueue() { helper_.CheckOnValidThread(); return virtual_time_control_task_queue_; } -scoped_refptr<TaskQueue> RendererSchedulerImpl::NewLoadingTaskQueue( - TaskQueue::QueueType queue_type) { +scoped_refptr<MainThreadTaskQueue> RendererSchedulerImpl::NewLoadingTaskQueue( + MainThreadTaskQueue::QueueType queue_type) { helper_.CheckOnValidThread(); - scoped_refptr<TaskQueue> loading_task_queue(helper_.NewTaskQueue( - TaskQueue::Spec(queue_type) - .SetShouldMonitorQuiescence(true) - .SetTimeDomain(GetMainThreadOnly().use_virtual_time - ? GetVirtualTimeDomain() - : nullptr))); + scoped_refptr<MainThreadTaskQueue> loading_task_queue(helper_.NewTaskQueue( + queue_type, MainThreadTaskQueue::CreateSpecForType(queue_type) + .SetShouldMonitorQuiescence(true) + .SetTimeDomain(GetMainThreadOnly().use_virtual_time + ? GetVirtualTimeDomain() + : nullptr))); auto insert_result = loading_task_runners_.insert(std::make_pair( loading_task_queue, loading_task_queue->CreateQueueEnabledVoter())); insert_result.first->second->SetQueueEnabled( @@ -374,17 +382,17 @@ return loading_task_queue; } -scoped_refptr<TaskQueue> RendererSchedulerImpl::NewTimerTaskQueue( - TaskQueue::QueueType queue_type) { +scoped_refptr<MainThreadTaskQueue> RendererSchedulerImpl::NewTimerTaskQueue( + MainThreadTaskQueue::QueueType queue_type) { helper_.CheckOnValidThread(); // TODO(alexclarke): Consider using ApplyTaskQueuePolicy() for brevity. - scoped_refptr<TaskQueue> timer_task_queue(helper_.NewTaskQueue( - TaskQueue::Spec(queue_type) - .SetShouldMonitorQuiescence(true) - .SetShouldReportWhenExecutionBlocked(true) - .SetTimeDomain(GetMainThreadOnly().use_virtual_time - ? GetVirtualTimeDomain() - : nullptr))); + scoped_refptr<MainThreadTaskQueue> timer_task_queue(helper_.NewTaskQueue( + queue_type, MainThreadTaskQueue::CreateSpecForType(queue_type) + .SetShouldMonitorQuiescence(true) + .SetShouldReportWhenExecutionBlocked(true) + .SetTimeDomain(GetMainThreadOnly().use_virtual_time + ? GetVirtualTimeDomain() + : nullptr))); auto insert_result = timer_task_runners_.insert(std::make_pair( timer_task_queue, timer_task_queue->CreateQueueEnabledVoter())); insert_result.first->second->SetQueueEnabled( @@ -403,15 +411,17 @@ return timer_task_queue; } -scoped_refptr<TaskQueue> RendererSchedulerImpl::NewUnthrottledTaskQueue( - TaskQueue::QueueType queue_type) { +scoped_refptr<MainThreadTaskQueue> +RendererSchedulerImpl::NewUnthrottledTaskQueue( + MainThreadTaskQueue::QueueType queue_type) { helper_.CheckOnValidThread(); - scoped_refptr<TaskQueue> unthrottled_task_queue(helper_.NewTaskQueue( - TaskQueue::Spec(queue_type) - .SetShouldMonitorQuiescence(true) - .SetTimeDomain(GetMainThreadOnly().use_virtual_time - ? GetVirtualTimeDomain() - : nullptr))); + scoped_refptr<MainThreadTaskQueue> unthrottled_task_queue( + helper_.NewTaskQueue( + queue_type, MainThreadTaskQueue::CreateSpecForType(queue_type) + .SetShouldMonitorQuiescence(true) + .SetTimeDomain(GetMainThreadOnly().use_virtual_time + ? GetVirtualTimeDomain() + : nullptr))); unthrottled_task_runners_.insert(unthrottled_task_queue); return unthrottled_task_queue; } @@ -422,7 +432,7 @@ } void RendererSchedulerImpl::OnUnregisterTaskQueue( - const scoped_refptr<TaskQueue>& task_queue) { + const scoped_refptr<MainThreadTaskQueue>& task_queue) { if (task_queue_throttler_) task_queue_throttler_->UnregisterTaskQueue(task_queue.get()); @@ -1272,7 +1282,7 @@ // TODO(alexclarke): We shouldn't have to prioritize the default queue, but it // appears to be necessary since the order of loading tasks and IPCs (which // are mostly dispatched on the default queue) need to be preserved. - ApplyTaskQueuePolicy(helper_.DefaultTaskQueue().get(), nullptr, + ApplyTaskQueuePolicy(helper_.DefaultMainThreadTaskQueue().get(), nullptr, GetMainThreadOnly().current_policy.default_queue_policy, new_policy.default_queue_policy); if (GetMainThreadOnly().rail_mode_observer && @@ -1298,7 +1308,7 @@ } void RendererSchedulerImpl::ApplyTaskQueuePolicy( - TaskQueue* task_queue, + MainThreadTaskQueue* task_queue, TaskQueue::QueueEnabledVoter* task_queue_enabled_voter, const TaskQueuePolicy& old_task_queue_policy, const TaskQueuePolicy& new_task_queue_policy) const { @@ -1426,7 +1436,8 @@ return true; } -SchedulerHelper* RendererSchedulerImpl::GetSchedulerHelperForTesting() { +MainThreadSchedulerHelper* +RendererSchedulerImpl::GetSchedulerHelperForTesting() { return &helper_; } @@ -1886,9 +1897,7 @@ web_view_scheduler->ReportIntervention(message); } -void RendererSchedulerImpl::OnTriedToExecuteBlockedTask( - const TaskQueue& queue, - const base::PendingTask& task) { +void RendererSchedulerImpl::OnTriedToExecuteBlockedTask() { if (GetMainThreadOnly().current_use_case == UseCase::TOUCHSTART || GetMainThreadOnly().longest_jank_free_task_duration < base::TimeDelta::FromMilliseconds(kRailsResponseTimeMillis) || @@ -1928,8 +1937,7 @@ } } -void RendererSchedulerImpl::WillProcessTask(TaskQueue* task_queue, - double start_time) { +void RendererSchedulerImpl::WillProcessTask(double start_time) { base::TimeTicks start_time_ticks = MonotonicTimeInSecondsToTimeTicks(start_time); GetMainThreadOnly().current_task_start_time = start_time_ticks; @@ -1938,26 +1946,24 @@ seqlock_queueing_time_estimator_.seqlock.WriteEnd(); } -void RendererSchedulerImpl::DidProcessTask(TaskQueue* task_queue, - double start_time, - double end_time) { +void RendererSchedulerImpl::DidProcessTask(double start_time, double end_time) { DCHECK_LE(start_time, end_time); // TODO(scheduler-dev): Remove conversions when Blink starts using // base::TimeTicks instead of doubles for time. - base::TimeTicks start_time_ticks = - MonotonicTimeInSecondsToTimeTicks(start_time); base::TimeTicks end_time_ticks = MonotonicTimeInSecondsToTimeTicks(end_time); seqlock_queueing_time_estimator_.seqlock.WriteBegin(); seqlock_queueing_time_estimator_.data.OnTopLevelTaskCompleted(end_time_ticks); seqlock_queueing_time_estimator_.seqlock.WriteEnd(); +} - task_queue_throttler()->OnTaskRunTimeReported(task_queue, start_time_ticks, - end_time_ticks); +void RendererSchedulerImpl::OnTaskCompleted(MainThreadTaskQueue* queue, + base::TimeTicks start, + base::TimeTicks end) { + task_queue_throttler()->OnTaskRunTimeReported(queue, start, end); // TODO(altimin): Per-page metrics should also be considered. - RecordTaskMetrics(task_queue->GetQueueType(), start_time_ticks, - end_time_ticks); + RecordTaskMetrics(queue->queue_type(), start, end); } namespace { @@ -1975,9 +1981,10 @@ } // namespace -void RendererSchedulerImpl::RecordTaskMetrics(TaskQueue::QueueType queue_type, - base::TimeTicks start_time, - base::TimeTicks end_time) { +void RendererSchedulerImpl::RecordTaskMetrics( + MainThreadTaskQueue::QueueType queue_type, + base::TimeTicks start_time, + base::TimeTicks end_time) { base::TimeDelta duration = end_time - start_time; if (duration > kLongTaskDiscardingThreshold) return; @@ -1994,9 +2001,10 @@ // TODO(altimin): See whether this metric is still useful after // adding RendererScheduler.TaskDurationPerQueueType. - UMA_HISTOGRAM_ENUMERATION("RendererScheduler.NumberOfTasksPerQueueType2", - static_cast<int>(queue_type), - static_cast<int>(TaskQueue::QueueType::COUNT)); + UMA_HISTOGRAM_ENUMERATION( + "RendererScheduler.NumberOfTasksPerQueueType2", + static_cast<int>(queue_type), + static_cast<int>(MainThreadTaskQueue::QueueType::COUNT)); GetMainThreadOnly().task_duration_reporter.RecordTask(queue_type, duration); @@ -2171,12 +2179,15 @@ // The |unthrottled_task_runners_| are not actively managed by UpdatePolicy(). AutoAdvancingVirtualTimeDomain* time_domain = GetVirtualTimeDomain(); - for (const scoped_refptr<TaskQueue>& task_queue : unthrottled_task_runners_) + for (const scoped_refptr<MainThreadTaskQueue>& task_queue : + unthrottled_task_runners_) task_queue->SetTimeDomain(time_domain); DCHECK(!virtual_time_control_task_queue_); virtual_time_control_task_queue_ = - helper_.NewTaskQueue(TaskQueue::Spec(TaskQueue::QueueType::CONTROL)); + helper_.NewTaskQueue(MainThreadTaskQueue::QueueType::CONTROL, + MainThreadTaskQueue::CreateSpecForType( + MainThreadTaskQueue::QueueType::CONTROL)); virtual_time_control_task_queue_->SetQueuePriority( TaskQueue::CONTROL_PRIORITY); virtual_time_control_task_queue_->SetTimeDomain(time_domain); @@ -2189,7 +2200,8 @@ RealTimeDomain* time_domain = real_time_domain(); // The |unthrottled_task_runners_| are not actively managed by UpdatePolicy(). - for (const scoped_refptr<TaskQueue>& task_queue : unthrottled_task_runners_) + for (const scoped_refptr<MainThreadTaskQueue>& task_queue : + unthrottled_task_runners_) task_queue->SetTimeDomain(time_domain); virtual_time_control_task_queue_->UnregisterTaskQueue(); virtual_time_control_task_queue_ = nullptr; @@ -2210,7 +2222,8 @@ now; } -void RendererSchedulerImpl::AddQueueToWakeUpBudgetPool(TaskQueue* queue) { +void RendererSchedulerImpl::AddQueueToWakeUpBudgetPool( + MainThreadTaskQueue* queue) { if (!GetMainThreadOnly().wake_up_budget_pool) { GetMainThreadOnly().wake_up_budget_pool = task_queue_throttler()->CreateWakeUpBudgetPool("renderer_wake_up_pool");
diff --git a/third_party/WebKit/Source/platform/scheduler/renderer/renderer_scheduler_impl.h b/third_party/WebKit/Source/platform/scheduler/renderer/renderer_scheduler_impl.h index c9929be..e14c904 100644 --- a/third_party/WebKit/Source/platform/scheduler/renderer/renderer_scheduler_impl.h +++ b/third_party/WebKit/Source/platform/scheduler/renderer/renderer_scheduler_impl.h
@@ -20,9 +20,10 @@ #include "platform/scheduler/base/thread_load_tracker.h" #include "platform/scheduler/child/idle_canceled_delayed_task_sweeper.h" #include "platform/scheduler/child/idle_helper.h" -#include "platform/scheduler/child/scheduler_helper.h" #include "platform/scheduler/renderer/deadline_task_runner.h" #include "platform/scheduler/renderer/idle_time_estimator.h" +#include "platform/scheduler/renderer/main_thread_scheduler_helper.h" +#include "platform/scheduler/renderer/main_thread_task_queue.h" #include "platform/scheduler/renderer/render_widget_signals.h" #include "platform/scheduler/renderer/task_cost_estimator.h" #include "platform/scheduler/renderer/task_duration_metric_reporter.h" @@ -46,7 +47,7 @@ class PLATFORM_EXPORT RendererSchedulerImpl : public RendererScheduler, public IdleHelper::Delegate, - public SchedulerHelper::Observer, + public MainThreadSchedulerHelper::Observer, public RenderWidgetSignals::Observer, public TaskTimeObserver, public QueueingTimeEstimator::Client, @@ -134,15 +135,11 @@ bool has_visible_render_widget_with_touch_handler) override; // SchedulerHelper::Observer implementation: - void OnUnregisterTaskQueue(const scoped_refptr<TaskQueue>& queue) override; - void OnTriedToExecuteBlockedTask(const TaskQueue& queue, - const base::PendingTask& task) override; + void OnTriedToExecuteBlockedTask() override; // TaskTimeObserver implementation: - void WillProcessTask(TaskQueue* task_queue, double start_time) override; - void DidProcessTask(TaskQueue* task_queue, - double start_time, - double end_time) override; + void WillProcessTask(double start_time) override; + void DidProcessTask(double start_time, double end_time) override; void OnBeginNestedRunLoop() override; // QueueingTimeEstimator::Client implementation: @@ -150,28 +147,30 @@ base::TimeDelta queueing_time, base::TimeTicks window_start_time) override; - scoped_refptr<TaskQueue> DefaultTaskQueue(); - scoped_refptr<TaskQueue> CompositorTaskQueue(); - scoped_refptr<TaskQueue> LoadingTaskQueue(); - scoped_refptr<TaskQueue> TimerTaskQueue(); + scoped_refptr<MainThreadTaskQueue> DefaultTaskQueue(); + scoped_refptr<MainThreadTaskQueue> CompositorTaskQueue(); + scoped_refptr<MainThreadTaskQueue> LoadingTaskQueue(); + scoped_refptr<MainThreadTaskQueue> TimerTaskQueue(); // Returns a new loading task queue. This queue is intended for tasks related // to resource dispatch, foreground HTML parsing, etc... - scoped_refptr<TaskQueue> NewLoadingTaskQueue(TaskQueue::QueueType queue_type); + scoped_refptr<MainThreadTaskQueue> NewLoadingTaskQueue( + MainThreadTaskQueue::QueueType queue_type); // Returns a new timer task queue. This queue is intended for DOM Timers. - scoped_refptr<TaskQueue> NewTimerTaskQueue(TaskQueue::QueueType queue_type); + scoped_refptr<MainThreadTaskQueue> NewTimerTaskQueue( + MainThreadTaskQueue::QueueType queue_type); // Returns a task queue for tasks which should never get throttled. - scoped_refptr<TaskQueue> NewUnthrottledTaskQueue( - TaskQueue::QueueType queue_type); + scoped_refptr<MainThreadTaskQueue> NewUnthrottledTaskQueue( + MainThreadTaskQueue::QueueType queue_type); // Returns a task queue where tasks run at the highest possible priority. - scoped_refptr<TaskQueue> ControlTaskQueue(); + scoped_refptr<MainThreadTaskQueue> ControlTaskQueue(); // A control task queue which also respects virtual time. Only available if // virtual time has been enabled. - scoped_refptr<TaskQueue> VirtualTimeControlTaskQueue(); + scoped_refptr<MainThreadTaskQueue> VirtualTimeControlTaskQueue(); void RegisterTimeDomain(TimeDomain* time_domain); void UnregisterTimeDomain(TimeDomain* time_domain); @@ -207,7 +206,7 @@ bool is_main_frame); // Test helpers. - SchedulerHelper* GetSchedulerHelperForTesting(); + MainThreadSchedulerHelper* GetSchedulerHelperForTesting(); TaskCostEstimator* GetLoadingTaskCostEstimatorForTesting(); TaskCostEstimator* GetTimerTaskCostEstimatorForTesting(); IdleTimeEstimator* GetIdleTimeEstimatorForTesting(); @@ -234,6 +233,12 @@ void OnFirstMeaningfulPaint(); + void OnUnregisterTaskQueue(const scoped_refptr<MainThreadTaskQueue>& queue); + + void OnTaskCompleted(MainThreadTaskQueue* queue, + base::TimeTicks start, + base::TimeTicks end); + // base::trace_event::TraceLog::EnabledStateObserver implementation: void OnTraceLogEnabled() override; void OnTraceLogDisabled() override; @@ -416,7 +421,7 @@ void BroadcastIntervention(const std::string& message); void ApplyTaskQueuePolicy( - TaskQueue* task_queue, + MainThreadTaskQueue* task_queue, TaskQueue::QueueEnabledVoter* task_queue_enabled_voter, const TaskQueuePolicy& old_task_queue_policy, const TaskQueuePolicy& new_task_queue_policy) const; @@ -426,33 +431,33 @@ bool ShouldDisableThrottlingBecauseOfAudio(base::TimeTicks now); - void AddQueueToWakeUpBudgetPool(TaskQueue* queue); + void AddQueueToWakeUpBudgetPool(MainThreadTaskQueue* queue); - void RecordTaskMetrics(TaskQueue::QueueType queue_type, + void RecordTaskMetrics(MainThreadTaskQueue::QueueType queue_type, base::TimeTicks start_time, base::TimeTicks end_time); - SchedulerHelper helper_; + MainThreadSchedulerHelper helper_; IdleHelper idle_helper_; IdleCanceledDelayedTaskSweeper idle_canceled_delayed_task_sweeper_; std::unique_ptr<TaskQueueThrottler> task_queue_throttler_; RenderWidgetSignals render_widget_scheduler_signals_; - const scoped_refptr<TaskQueue> control_task_queue_; - const scoped_refptr<TaskQueue> compositor_task_queue_; - scoped_refptr<TaskQueue> virtual_time_control_task_queue_; + const scoped_refptr<MainThreadTaskQueue> control_task_queue_; + const scoped_refptr<MainThreadTaskQueue> compositor_task_queue_; + scoped_refptr<MainThreadTaskQueue> virtual_time_control_task_queue_; std::unique_ptr<TaskQueue::QueueEnabledVoter> compositor_task_queue_enabled_voter_; using TaskQueueVoterMap = - std::map<scoped_refptr<TaskQueue>, + std::map<scoped_refptr<MainThreadTaskQueue>, std::unique_ptr<TaskQueue::QueueEnabledVoter>>; TaskQueueVoterMap loading_task_runners_; TaskQueueVoterMap timer_task_runners_; - std::set<scoped_refptr<TaskQueue>> unthrottled_task_runners_; - scoped_refptr<TaskQueue> default_loading_task_queue_; - scoped_refptr<TaskQueue> default_timer_task_queue_; + std::set<scoped_refptr<MainThreadTaskQueue>> unthrottled_task_runners_; + scoped_refptr<MainThreadTaskQueue> default_loading_task_queue_; + scoped_refptr<MainThreadTaskQueue> default_timer_task_queue_; // Note |virtual_time_domain_| is lazily created. std::unique_ptr<AutoAdvancingVirtualTimeDomain> virtual_time_domain_; @@ -471,10 +476,11 @@ // (the accessors) for the following data members. struct MainThreadOnly { - MainThreadOnly(RendererSchedulerImpl* renderer_scheduler_impl, - const scoped_refptr<TaskQueue>& compositor_task_runner, - base::TickClock* time_source, - base::TimeTicks now); + MainThreadOnly( + RendererSchedulerImpl* renderer_scheduler_impl, + const scoped_refptr<MainThreadTaskQueue>& compositor_task_runner, + base::TickClock* time_source, + base::TimeTicks now); ~MainThreadOnly(); TaskCostEstimator loading_task_cost_estimator;
diff --git a/third_party/WebKit/Source/platform/scheduler/renderer/renderer_scheduler_impl_unittest.cc b/third_party/WebKit/Source/platform/scheduler/renderer/renderer_scheduler_impl_unittest.cc index 556ffba..9d0c2094 100644 --- a/third_party/WebKit/Source/platform/scheduler/renderer/renderer_scheduler_impl_unittest.cc +++ b/third_party/WebKit/Source/platform/scheduler/renderer/renderer_scheduler_impl_unittest.cc
@@ -563,8 +563,8 @@ double start = (clock_->NowTicks() - base::TimeTicks()).InSecondsF(); clock_->Advance(base::TimeDelta::FromSecondsD(duration)); double end = (clock_->NowTicks() - base::TimeTicks()).InSecondsF(); - scheduler_->WillProcessTask(scheduler_->TimerTaskQueue().get(), start); - scheduler_->DidProcessTask(scheduler_->TimerTaskQueue().get(), start, end); + scheduler_->WillProcessTask(start); + scheduler_->DidProcessTask(start, end); } void GetQueueingTimeEstimatorLock() { @@ -3702,7 +3702,8 @@ // task runner. SimulateCompositorGestureStart(TouchEventPolicy::SEND_TOUCH_START); scoped_refptr<TaskQueue> unthrottled_task_runner = - scheduler_->NewUnthrottledTaskQueue(TaskQueue::QueueType::UNTHROTTLED); + scheduler_->NewUnthrottledTaskQueue( + MainThreadTaskQueue::QueueType::UNTHROTTLED); size_t timer_count = 0; size_t unthrottled_count = 0; @@ -3746,11 +3747,11 @@ scheduler_->EnableVirtualTime(); scoped_refptr<TaskQueue> loading_tq = - scheduler_->NewLoadingTaskQueue(TaskQueue::QueueType::TEST); + scheduler_->NewLoadingTaskQueue(MainThreadTaskQueue::QueueType::TEST); scoped_refptr<TaskQueue> timer_tq = - scheduler_->NewTimerTaskQueue(TaskQueue::QueueType::TEST); + scheduler_->NewTimerTaskQueue(MainThreadTaskQueue::QueueType::TEST); scoped_refptr<TaskQueue> unthrottled_tq = - scheduler_->NewUnthrottledTaskQueue(TaskQueue::QueueType::TEST); + scheduler_->NewUnthrottledTaskQueue(MainThreadTaskQueue::QueueType::TEST); EXPECT_EQ(scheduler_->DefaultTaskQueue()->GetTimeDomain(), scheduler_->GetVirtualTimeDomain()); @@ -3772,24 +3773,26 @@ EXPECT_EQ(unthrottled_tq->GetTimeDomain(), scheduler_->GetVirtualTimeDomain()); - EXPECT_EQ(scheduler_->NewLoadingTaskQueue(TaskQueue::QueueType::TEST) + EXPECT_EQ( + scheduler_->NewLoadingTaskQueue(MainThreadTaskQueue::QueueType::TEST) + ->GetTimeDomain(), + scheduler_->GetVirtualTimeDomain()); + EXPECT_EQ(scheduler_->NewTimerTaskQueue(MainThreadTaskQueue::QueueType::TEST) ->GetTimeDomain(), scheduler_->GetVirtualTimeDomain()); - EXPECT_EQ(scheduler_->NewTimerTaskQueue(TaskQueue::QueueType::TEST) - ->GetTimeDomain(), - scheduler_->GetVirtualTimeDomain()); - EXPECT_EQ(scheduler_->NewUnthrottledTaskQueue(TaskQueue::QueueType::TEST) - ->GetTimeDomain(), - scheduler_->GetVirtualTimeDomain()); + EXPECT_EQ( + scheduler_->NewUnthrottledTaskQueue(MainThreadTaskQueue::QueueType::TEST) + ->GetTimeDomain(), + scheduler_->GetVirtualTimeDomain()); } TEST_F(RendererSchedulerImplTest, DisableVirtualTimeForTesting) { scheduler_->EnableVirtualTime(); scoped_refptr<TaskQueue> timer_tq = - scheduler_->NewTimerTaskQueue(TaskQueue::QueueType::TEST); + scheduler_->NewTimerTaskQueue(MainThreadTaskQueue::QueueType::TEST); scoped_refptr<TaskQueue> unthrottled_tq = - scheduler_->NewUnthrottledTaskQueue(TaskQueue::QueueType::TEST); + scheduler_->NewUnthrottledTaskQueue(MainThreadTaskQueue::QueueType::TEST); scheduler_->DisableVirtualTimeForTesting(); EXPECT_EQ(scheduler_->DefaultTaskQueue()->GetTimeDomain(), @@ -3931,7 +3934,6 @@ scheduler_->MainThreadSeemsUnresponsive(responsiveness_threshold())); clock_->Advance(base::TimeDelta::FromSecondsD(2)); scheduler_->WillProcessTask( - scheduler_->TimerTaskQueue().get(), (clock_->NowTicks() - base::TimeTicks()).InSecondsF()); EXPECT_FALSE( scheduler_->MainThreadSeemsUnresponsive(responsiveness_threshold()));
diff --git a/third_party/WebKit/Source/platform/scheduler/renderer/task_duration_metric_reporter.cc b/third_party/WebKit/Source/platform/scheduler/renderer/task_duration_metric_reporter.cc index d0f1f45..49f004a 100644 --- a/third_party/WebKit/Source/platform/scheduler/renderer/task_duration_metric_reporter.cc +++ b/third_party/WebKit/Source/platform/scheduler/renderer/task_duration_metric_reporter.cc
@@ -13,8 +13,8 @@ : TaskDurationMetricReporter(base::Histogram::FactoryGet( metric_name, 1, - static_cast<int>(TaskQueue::QueueType::COUNT), - static_cast<int>(TaskQueue::QueueType::COUNT) + 1, + static_cast<int>(MainThreadTaskQueue::QueueType::COUNT), + static_cast<int>(MainThreadTaskQueue::QueueType::COUNT) + 1, base::HistogramBase::kUmaTargetedHistogramFlag)) {} TaskDurationMetricReporter::TaskDurationMetricReporter( @@ -23,8 +23,9 @@ TaskDurationMetricReporter::~TaskDurationMetricReporter() {} -void TaskDurationMetricReporter::RecordTask(TaskQueue::QueueType queue_type, - base::TimeDelta duration) { +void TaskDurationMetricReporter::RecordTask( + MainThreadTaskQueue::QueueType queue_type, + base::TimeDelta duration) { // Report only whole milliseconds to avoid overflow. base::TimeDelta& unreported_duration = unreported_task_duration_[static_cast<int>(queue_type)];
diff --git a/third_party/WebKit/Source/platform/scheduler/renderer/task_duration_metric_reporter.h b/third_party/WebKit/Source/platform/scheduler/renderer/task_duration_metric_reporter.h index f305e7f..c5790c38 100644 --- a/third_party/WebKit/Source/platform/scheduler/renderer/task_duration_metric_reporter.h +++ b/third_party/WebKit/Source/platform/scheduler/renderer/task_duration_metric_reporter.h
@@ -11,7 +11,7 @@ #include "base/macros.h" #include "base/time/time.h" #include "platform/PlatformExport.h" -#include "platform/scheduler/base/task_queue.h" +#include "platform/scheduler/renderer/main_thread_task_queue.h" namespace base { class HistogramBase; @@ -27,7 +27,7 @@ explicit TaskDurationMetricReporter(const char* metric_name); ~TaskDurationMetricReporter(); - void RecordTask(TaskQueue::QueueType queue_type, + void RecordTask(MainThreadTaskQueue::QueueType queue_type, base::TimeDelta time_duration); private: @@ -35,7 +35,8 @@ TaskDurationMetricReporter(base::HistogramBase* histogram); - std::array<base::TimeDelta, static_cast<size_t>(TaskQueue::QueueType::COUNT)> + std::array<base::TimeDelta, + static_cast<size_t>(MainThreadTaskQueue::QueueType::COUNT)> unreported_task_duration_; base::HistogramBase* task_duration_per_queue_type_histogram_;
diff --git a/third_party/WebKit/Source/platform/scheduler/renderer/task_duration_metric_reporter_unittest.cc b/third_party/WebKit/Source/platform/scheduler/renderer/task_duration_metric_reporter_unittest.cc index 4e7a63f..be6a216d 100644 --- a/third_party/WebKit/Source/platform/scheduler/renderer/task_duration_metric_reporter_unittest.cc +++ b/third_party/WebKit/Source/platform/scheduler/renderer/task_duration_metric_reporter_unittest.cc
@@ -57,22 +57,22 @@ TaskDurationMetricReporter metric_reporter(&histogram); EXPECT_CALL(histogram, AddCount(2, 3)); - metric_reporter.RecordTask(static_cast<TaskQueue::QueueType>(2), + metric_reporter.RecordTask(static_cast<MainThreadTaskQueue::QueueType>(2), base::TimeDelta::FromMicroseconds(3400)); Mock::VerifyAndClearExpectations(&histogram); EXPECT_CALL(histogram, AddCount(_, _)).Times(0); - metric_reporter.RecordTask(static_cast<TaskQueue::QueueType>(2), + metric_reporter.RecordTask(static_cast<MainThreadTaskQueue::QueueType>(2), base::TimeDelta::FromMicroseconds(300)); Mock::VerifyAndClearExpectations(&histogram); EXPECT_CALL(histogram, AddCount(2, 1)); - metric_reporter.RecordTask(static_cast<TaskQueue::QueueType>(2), + metric_reporter.RecordTask(static_cast<MainThreadTaskQueue::QueueType>(2), base::TimeDelta::FromMicroseconds(800)); Mock::VerifyAndClearExpectations(&histogram); EXPECT_CALL(histogram, AddCount(2, 16)); - metric_reporter.RecordTask(static_cast<TaskQueue::QueueType>(2), + metric_reporter.RecordTask(static_cast<MainThreadTaskQueue::QueueType>(2), base::TimeDelta::FromMicroseconds(15600)); Mock::VerifyAndClearExpectations(&histogram); }
diff --git a/third_party/WebKit/Source/platform/scheduler/renderer/task_queue_throttler_unittest.cc b/third_party/WebKit/Source/platform/scheduler/renderer/task_queue_throttler_unittest.cc index cd39aa3..80f44e3 100644 --- a/third_party/WebKit/Source/platform/scheduler/renderer/task_queue_throttler_unittest.cc +++ b/third_party/WebKit/Source/platform/scheduler/renderer/task_queue_throttler_unittest.cc
@@ -52,16 +52,6 @@ } } -bool IsQueueBlocked(TaskQueue* task_queue) { - internal::TaskQueueImpl* task_queue_impl = - reinterpret_cast<internal::TaskQueueImpl*>(task_queue); - if (!task_queue_impl->IsQueueEnabled()) - return true; - return task_queue_impl->GetFenceForTest() == - static_cast<internal::EnqueueOrder>( - internal::EnqueueOrderValues::BLOCKING_FENCE); -} - // Test clock which simulates passage of time by automatically // advancing time with each call to Now(). class AutoAdvancingTestClock : public base::SimpleTestTickClock { @@ -99,7 +89,8 @@ mock_task_runner_, base::MakeUnique<TestTimeSource>(clock_.get())); scheduler_.reset(new RendererSchedulerImpl(delegate_)); task_queue_throttler_ = scheduler_->task_queue_throttler(); - timer_queue_ = scheduler_->NewTimerTaskQueue(TaskQueue::QueueType::TEST); + timer_queue_ = + scheduler_->NewTimerTaskQueue(MainThreadTaskQueue::QueueType::TEST); } void TearDown() override { @@ -130,6 +121,15 @@ mock_task_runner_->RunUntilIdle(); } + bool IsQueueBlocked(TaskQueue* task_queue) { + internal::TaskQueueImpl* task_queue_impl = task_queue->GetTaskQueueImpl(); + if (!task_queue_impl->IsQueueEnabled()) + return true; + return task_queue_impl->GetFenceForTest() == + static_cast<internal::EnqueueOrder>( + internal::EnqueueOrderValues::BLOCKING_FENCE); + } + protected: virtual std::unique_ptr<AutoAdvancingTestClock> CreateClock() { return base::MakeUnique<AutoAdvancingTestClock>(base::TimeDelta()); @@ -745,7 +745,7 @@ std::vector<base::TimeTicks> run_times; scoped_refptr<TaskQueue> second_queue = - scheduler_->NewTimerTaskQueue(TaskQueue::QueueType::TEST); + scheduler_->NewTimerTaskQueue(MainThreadTaskQueue::QueueType::TEST); CPUTimeBudgetPool* pool = task_queue_throttler_->CreateCPUTimeBudgetPool("test"); @@ -1070,7 +1070,7 @@ std::vector<base::TimeTicks> run_times; scoped_refptr<TaskQueue> second_queue = - scheduler_->NewTimerTaskQueue(TaskQueue::QueueType::TEST); + scheduler_->NewTimerTaskQueue(MainThreadTaskQueue::QueueType::TEST); task_queue_throttler_->IncreaseThrottleRefCount(timer_queue_.get()); task_queue_throttler_->IncreaseThrottleRefCount(second_queue.get()); @@ -1106,7 +1106,7 @@ std::vector<base::TimeTicks> run_times; scoped_refptr<TaskQueue> second_queue = - scheduler_->NewTimerTaskQueue(TaskQueue::QueueType::TEST); + scheduler_->NewTimerTaskQueue(MainThreadTaskQueue::QueueType::TEST); CPUTimeBudgetPool* pool1 = task_queue_throttler_->CreateCPUTimeBudgetPool("test");
diff --git a/third_party/WebKit/Source/platform/scheduler/renderer/web_frame_scheduler_impl.cc b/third_party/WebKit/Source/platform/scheduler/renderer/web_frame_scheduler_impl.cc index 15094cd..35341de 100644 --- a/third_party/WebKit/Source/platform/scheduler/renderer/web_frame_scheduler_impl.cc +++ b/third_party/WebKit/Source/platform/scheduler/renderer/web_frame_scheduler_impl.cc
@@ -147,7 +147,7 @@ DCHECK(parent_web_view_scheduler_); if (!loading_web_task_runner_) { loading_task_queue_ = renderer_scheduler_->NewLoadingTaskQueue( - TaskQueue::QueueType::FRAME_LOADING); + MainThreadTaskQueue::QueueType::FRAME_LOADING); loading_task_queue_->SetBlameContext(blame_context_); loading_queue_enabled_voter_ = loading_task_queue_->CreateQueueEnabledVoter(); @@ -161,7 +161,7 @@ DCHECK(parent_web_view_scheduler_); if (!timer_web_task_runner_) { timer_task_queue_ = renderer_scheduler_->NewTimerTaskQueue( - TaskQueue::QueueType::FRAME_TIMER); + MainThreadTaskQueue::QueueType::FRAME_TIMER); timer_task_queue_->SetBlameContext(blame_context_); timer_queue_enabled_voter_ = timer_task_queue_->CreateQueueEnabledVoter(); timer_queue_enabled_voter_->SetQueueEnabled(!frame_suspended_); @@ -188,7 +188,7 @@ // TODO(altimin): Split FRAME_UNTHROTTLED into FRAME_UNTHROTTLED and // FRAME_UNSUSPENDED. suspendable_task_queue_ = renderer_scheduler_->NewTimerTaskQueue( - TaskQueue::QueueType::FRAME_UNTHROTTLED); + MainThreadTaskQueue::QueueType::FRAME_UNTHROTTLED); suspendable_task_queue_->SetBlameContext(blame_context_); suspendable_web_task_runner_ = WebTaskRunnerImpl::Create(suspendable_task_queue_); @@ -203,7 +203,7 @@ DCHECK(parent_web_view_scheduler_); if (!unthrottled_web_task_runner_) { unthrottled_task_queue_ = renderer_scheduler_->NewUnthrottledTaskQueue( - TaskQueue::QueueType::FRAME_UNTHROTTLED); + MainThreadTaskQueue::QueueType::FRAME_UNTHROTTLED); unthrottled_task_queue_->SetBlameContext(blame_context_); unthrottled_web_task_runner_ = WebTaskRunnerImpl::Create(unthrottled_task_queue_); @@ -217,7 +217,7 @@ if (!unthrottled_but_blockable_web_task_runner_) { unthrottled_but_blockable_task_queue_ = renderer_scheduler_->NewTimerTaskQueue( - TaskQueue::QueueType::FRAME_UNTHROTTLED); + MainThreadTaskQueue::QueueType::FRAME_UNTHROTTLED); unthrottled_but_blockable_task_queue_->SetBlameContext(blame_context_); unthrottled_but_blockable_web_task_runner_ = WebTaskRunnerImpl::Create(unthrottled_but_blockable_task_queue_);
diff --git a/third_party/WebKit/Source/platform/scheduler/test/test_task_queue.cc b/third_party/WebKit/Source/platform/scheduler/test/test_task_queue.cc new file mode 100644 index 0000000..53338a6 --- /dev/null +++ b/third_party/WebKit/Source/platform/scheduler/test/test_task_queue.cc
@@ -0,0 +1,18 @@ +// Copyright 2017 The Chromium Authors. All rights reserved. +// Use of this source code is governed by a BSD-style license that can be +// found in the LICENSE file. + +#include "platform/scheduler/test/test_task_queue.h" + +#include "platform/scheduler/base/task_queue_impl.h" + +namespace blink { +namespace scheduler { + +TestTaskQueue::TestTaskQueue(std::unique_ptr<internal::TaskQueueImpl> impl) + : TaskQueue(std::move(impl)) {} + +TestTaskQueue::~TestTaskQueue() {} + +} // namespace scheduler +} // namespace blink
diff --git a/third_party/WebKit/Source/platform/scheduler/test/test_task_queue.h b/third_party/WebKit/Source/platform/scheduler/test/test_task_queue.h new file mode 100644 index 0000000..260979f --- /dev/null +++ b/third_party/WebKit/Source/platform/scheduler/test/test_task_queue.h
@@ -0,0 +1,24 @@ +// Copyright 2017 The Chromium Authors. All rights reserved. +// Use of this source code is governed by a BSD-style license that can be +// found in the LICENSE file. + +#ifndef THIRD_PARTY_WEBKIT_SOURCE_PLATFORM_SCHEDULER_TEST_TEST_TASK_QUEUE_H_ +#define THIRD_PARTY_WEBKIT_SOURCE_PLATFORM_SCHEDULER_TEST_TEST_TASK_QUEUE_H_ + +#include "platform/scheduler/base/task_queue.h" + +namespace blink { +namespace scheduler { + +class TestTaskQueue : public TaskQueue { + public: + explicit TestTaskQueue(std::unique_ptr<internal::TaskQueueImpl> impl); + ~TestTaskQueue() override; + + using TaskQueue::GetTaskQueueImpl; +}; + +} // namespace scheduler +} // namespace blink + +#endif // THIRD_PARTY_WEBKIT_SOURCE_PLATFORM_SCHEDULER_TEST_TEST_TASK_QUEUE_H_
diff --git a/third_party/WebKit/Source/platform/testing/PictureMatchers.cpp b/third_party/WebKit/Source/platform/testing/PictureMatchers.cpp index f39a0bf..07567bd 100644 --- a/third_party/WebKit/Source/platform/testing/PictureMatchers.cpp +++ b/third_party/WebKit/Source/platform/testing/PictureMatchers.cpp
@@ -17,11 +17,6 @@ namespace { -struct QuadWithColor { - FloatQuad quad; - Color color; -}; - class DrawsRectangleCanvas : public SkCanvas { public: DrawsRectangleCanvas() @@ -29,26 +24,27 @@ save_count_(0), alpha_(255), alpha_save_layer_count_(-1) {} - const Vector<QuadWithColor>& QuadsWithColor() const { return quads_; } + const Vector<RectWithColor>& RectsWithColor() const { return rects_; } void onDrawRect(const SkRect& rect, const SkPaint& paint) override { - SkRect clipped_rect(rect); - for (Vector<ClipAndIndex>::const_reverse_iterator clip = clips_.rbegin(); - clip != clips_.rend(); clip++) { - if (SkRect::Intersects(rect, clip->rect)) - CHECK(clipped_rect.intersect(clip->rect)); - } SkPoint quad[4]; - getTotalMatrix().mapRectToQuad(quad, clipped_rect); - QuadWithColor quad_with_color; - quad_with_color.quad = FloatQuad(quad); + getTotalMatrix().mapRectToQuad(quad, rect); + + SkRect device_rect; + device_rect.set(quad, 4); + SkIRect device_clip_bounds; + FloatRect clipped_rect; + if (getDeviceClipBounds(&device_clip_bounds) && + device_rect.intersect(SkRect::Make(device_clip_bounds))) + clipped_rect = device_rect; unsigned paint_alpha = static_cast<unsigned>(paint.getAlpha()); SkPaint paint_with_alpha(paint); paint_with_alpha.setAlpha(static_cast<U8CPU>(alpha_ * paint_alpha / 255)); - quad_with_color.color = Color(paint_with_alpha.getColor()); - quads_.push_back(quad_with_color); - SkCanvas::onDrawRect(clipped_rect, paint); + Color color = Color(paint_with_alpha.getColor()); + + rects_.emplace_back(clipped_rect, color); + SkCanvas::onDrawRect(rect, paint); } SkCanvas::SaveLayerStrategy getSaveLayerStrategy( @@ -70,8 +66,6 @@ void willRestore() override { DCHECK_GT(save_count_, 0); - if (clips_.size() && save_count_ == clips_.back().save_count) - clips_.pop_back(); if (alpha_save_layer_count_ == save_count_) { alpha_ = 255; alpha_save_layer_count_ = -1; @@ -80,24 +74,8 @@ SkCanvas::willRestore(); } - void onClipRect(const SkRect& rect, - SkClipOp op, - ClipEdgeStyle style) override { - ClipAndIndex clip_struct; - clip_struct.rect = rect; - clip_struct.save_count = save_count_; - clips_.push_back(clip_struct); - SkCanvas::onClipRect(rect, op, style); - } - - struct ClipAndIndex { - SkRect rect; - int save_count; - }; - private: - Vector<QuadWithColor> quads_; - Vector<ClipAndIndex> clips_; + Vector<RectWithColor> rects_; int save_count_; unsigned alpha_; int alpha_save_layer_count_; @@ -114,24 +92,24 @@ ::testing::MatchResultListener* listener) const override { DrawsRectangleCanvas canvas; picture.playback(&canvas); - const auto& quads = canvas.QuadsWithColor(); - if (quads.size() != rects_with_color_.size()) { - *listener << "which draws " << quads.size() << " quads"; + const auto& actual_rects = canvas.RectsWithColor(); + if (actual_rects.size() != rects_with_color_.size()) { + *listener << "which draws " << actual_rects.size() << " rects"; return false; } - for (unsigned index = 0; index < quads.size(); index++) { - const auto& quad_with_color = quads[index]; - const auto& rect_with_color = rects_with_color_[index]; + for (unsigned index = 0; index < actual_rects.size(); index++) { + const auto& actual_rect_with_color = actual_rects[index]; + const auto& expect_rect_with_color = rects_with_color_[index]; - const FloatRect& rect = quad_with_color.quad.BoundingBox(); - if (EnclosingIntRect(rect) != EnclosingIntRect(rect_with_color.rect) || - quad_with_color.color != rect_with_color.color) { + if (EnclosingIntRect(actual_rect_with_color.rect) != + EnclosingIntRect(expect_rect_with_color.rect) || + actual_rect_with_color.color != expect_rect_with_color.color) { if (listener->IsInterested()) { *listener << "at index " << index << " which draws "; - PrintTo(rect, listener->stream()); + PrintTo(actual_rect_with_color.rect, listener->stream()); *listener << " with color " - << quad_with_color.color.Serialized().Ascii().data() + << actual_rect_with_color.color.Serialized().Ascii().data() << "\n"; } return false;
diff --git a/third_party/WebKit/Source/platform/wtf/HashMap.h b/third_party/WebKit/Source/platform/wtf/HashMap.h index 2eb7921..cdc1d92 100644 --- a/third_party/WebKit/Source/platform/wtf/HashMap.h +++ b/third_party/WebKit/Source/platform/wtf/HashMap.h
@@ -39,8 +39,9 @@ }; // Note: empty or deleted key values are not allowed, using them may lead to -// undefined behavior. For pointer keys this means that null pointers are not -// allowed unless you supply custom key traits. +// undefined behavior. For pointer keys this means that null pointers are not +// allowed; for integer keys 0 or -1 can't be used as a key. This restriction +// can be lifted if you supply custom key traits. template <typename KeyArg, typename MappedArg, typename HashArg = typename DefaultHash<KeyArg>::Hash,
diff --git a/third_party/WebKit/Source/platform/wtf/HashSet.h b/third_party/WebKit/Source/platform/wtf/HashSet.h index 1729e0d8..b4c11c8 100644 --- a/third_party/WebKit/Source/platform/wtf/HashSet.h +++ b/third_party/WebKit/Source/platform/wtf/HashSet.h
@@ -30,8 +30,9 @@ struct IdentityExtractor; // Note: empty or deleted values are not allowed, using them may lead to -// undefined behavior. For pointer valuess this means that null pointers are -// not allowed unless you supply custom traits. +// undefined behavior. For pointer keys this means that null pointers are not +// allowed; for integer keys 0 or -1 can't be used as a key. This restriction +// can be lifted if you supply custom key traits. template <typename ValueArg, typename HashArg = typename DefaultHash<ValueArg>::Hash, typename TraitsArg = HashTraits<ValueArg>,
diff --git a/third_party/WebKit/Source/web/WebFactoryImpl.cpp b/third_party/WebKit/Source/web/WebFactoryImpl.cpp index 0a76029..45d9449 100644 --- a/third_party/WebKit/Source/web/WebFactoryImpl.cpp +++ b/third_party/WebKit/Source/web/WebFactoryImpl.cpp
@@ -26,19 +26,18 @@ WebLocalFrameBase* WebFactoryImpl::CreateMainWebLocalFrameBase( WebView* web_view, WebFrameClient* client, - InterfaceProvider* provider, InterfaceRegistry* registry) const { - return WebLocalFrameImpl::CreateMainFrame(web_view, client, provider, - registry, nullptr, g_empty_atom, + return WebLocalFrameImpl::CreateMainFrame(web_view, client, registry, nullptr, + g_empty_atom, WebSandboxFlags::kNone); } WebLocalFrameBase* WebFactoryImpl::CreateWebLocalFrameBase( WebTreeScopeType type, WebFrameClient* client, - InterfaceProvider* provider, InterfaceRegistry* registry, WebFrame* opener) const { - return WebLocalFrameImpl::Create(type, client, provider, registry, opener); + return WebLocalFrameImpl::Create(type, client, registry, opener); } -} + +} // namespace blink
diff --git a/third_party/WebKit/Source/web/WebFactoryImpl.h b/third_party/WebKit/Source/web/WebFactoryImpl.h index 674a7a5d..9219769 100644 --- a/third_party/WebKit/Source/web/WebFactoryImpl.h +++ b/third_party/WebKit/Source/web/WebFactoryImpl.h
@@ -24,11 +24,9 @@ WebLocalFrameBase* CreateMainWebLocalFrameBase( WebView*, WebFrameClient*, - InterfaceProvider*, InterfaceRegistry*) const override; WebLocalFrameBase* CreateWebLocalFrameBase(WebTreeScopeType, WebFrameClient*, - InterfaceProvider*, InterfaceRegistry*, WebFrame* opener) const override; };
diff --git a/third_party/WebKit/Source/web/WebLocalFrameImpl.cpp b/third_party/WebKit/Source/web/WebLocalFrameImpl.cpp index f6317cf7..13dec4e 100644 --- a/third_party/WebKit/Source/web/WebLocalFrameImpl.cpp +++ b/third_party/WebKit/Source/web/WebLocalFrameImpl.cpp
@@ -1496,36 +1496,31 @@ WebLocalFrame* WebLocalFrame::CreateMainFrame( WebView* web_view, WebFrameClient* client, - InterfaceProvider* interface_provider, InterfaceRegistry* interface_registry, WebFrame* opener, const WebString& name, WebSandboxFlags sandbox_flags) { return WebLocalFrameImpl::CreateMainFrame( - web_view, client, interface_provider, interface_registry, opener, name, - sandbox_flags); + web_view, client, interface_registry, opener, name, sandbox_flags); } WebLocalFrame* WebLocalFrame::CreateProvisional( WebFrameClient* client, - InterfaceProvider* interface_provider, InterfaceRegistry* interface_registry, WebRemoteFrame* old_web_frame, WebSandboxFlags flags, WebParsedFeaturePolicy container_policy) { - return WebLocalFrameImpl::CreateProvisional(client, interface_provider, - interface_registry, old_web_frame, - flags, container_policy); + return WebLocalFrameImpl::CreateProvisional( + client, interface_registry, old_web_frame, flags, container_policy); } WebLocalFrameImpl* WebLocalFrameImpl::Create( WebTreeScopeType scope, WebFrameClient* client, - blink::InterfaceProvider* interface_provider, blink::InterfaceRegistry* interface_registry, WebFrame* opener) { - WebLocalFrameImpl* frame = new WebLocalFrameImpl( - scope, client, interface_provider, interface_registry); + WebLocalFrameImpl* frame = + new WebLocalFrameImpl(scope, client, interface_registry); frame->SetOpener(opener); return frame; } @@ -1533,14 +1528,12 @@ WebLocalFrameImpl* WebLocalFrameImpl::CreateMainFrame( WebView* web_view, WebFrameClient* client, - InterfaceProvider* interface_provider, InterfaceRegistry* interface_registry, WebFrame* opener, const WebString& name, WebSandboxFlags sandbox_flags) { - WebLocalFrameImpl* frame = - new WebLocalFrameImpl(WebTreeScopeType::kDocument, client, - interface_provider, interface_registry); + WebLocalFrameImpl* frame = new WebLocalFrameImpl(WebTreeScopeType::kDocument, + client, interface_registry); frame->SetOpener(opener); Page& page = *static_cast<WebViewBase*>(web_view)->GetPage(); DCHECK(!page.MainFrame()); @@ -1553,14 +1546,13 @@ WebLocalFrameImpl* WebLocalFrameImpl::CreateProvisional( WebFrameClient* client, - blink::InterfaceProvider* interface_provider, blink::InterfaceRegistry* interface_registry, WebRemoteFrame* old_web_frame, WebSandboxFlags flags, WebParsedFeaturePolicy container_policy) { DCHECK(client); - WebLocalFrameImpl* web_frame = new WebLocalFrameImpl( - old_web_frame, client, interface_provider, interface_registry); + WebLocalFrameImpl* web_frame = + new WebLocalFrameImpl(old_web_frame, client, interface_registry); Frame* old_frame = ToWebRemoteFrameImpl(old_web_frame)->GetFrame(); web_frame->SetParent(old_web_frame->Parent()); web_frame->SetOpener(old_web_frame->Opener()); @@ -1593,10 +1585,9 @@ WebLocalFrameImpl* WebLocalFrameImpl::CreateLocalChild( WebTreeScopeType scope, WebFrameClient* client, - blink::InterfaceProvider* interface_provider, blink::InterfaceRegistry* interface_registry) { - WebLocalFrameImpl* frame = new WebLocalFrameImpl( - scope, client, interface_provider, interface_registry); + WebLocalFrameImpl* frame = + new WebLocalFrameImpl(scope, client, interface_registry); AppendChild(frame); return frame; } @@ -1604,14 +1595,12 @@ WebLocalFrameImpl::WebLocalFrameImpl( WebTreeScopeType scope, WebFrameClient* client, - blink::InterfaceProvider* interface_provider, blink::InterfaceRegistry* interface_registry) : WebLocalFrameBase(scope), local_frame_client_impl_(LocalFrameClientImpl::Create(this)), client_(client), autofill_client_(0), input_events_scale_factor_for_emulation_(1), - interface_provider_(interface_provider), interface_registry_(interface_registry), web_dev_tools_frontend_(0), input_method_controller_(*this), @@ -1626,13 +1615,11 @@ WebLocalFrameImpl::WebLocalFrameImpl( WebRemoteFrame* old_web_frame, WebFrameClient* client, - blink::InterfaceProvider* interface_provider, blink::InterfaceRegistry* interface_registry) : WebLocalFrameImpl(old_web_frame->InShadowTree() ? WebTreeScopeType::kShadow : WebTreeScopeType::kDocument, client, - interface_provider, interface_registry) {} WebLocalFrameImpl::~WebLocalFrameImpl() { @@ -1664,7 +1651,7 @@ FrameOwner* owner, const AtomicString& name) { SetCoreFrame(LocalFrame::Create(local_frame_client_impl_.Get(), page, owner, - interface_provider_, interface_registry_)); + interface_registry_)); frame_->Tree().SetName(name); // We must call init() after frame_ is assigned because it is referenced // during init().
diff --git a/third_party/WebKit/Source/web/WebLocalFrameImpl.h b/third_party/WebKit/Source/web/WebLocalFrameImpl.h index b1e67a0..4695423 100644 --- a/third_party/WebKit/Source/web/WebLocalFrameImpl.h +++ b/third_party/WebKit/Source/web/WebLocalFrameImpl.h
@@ -241,7 +241,6 @@ // WebLocalFrame methods: WebLocalFrameImpl* CreateLocalChild(WebTreeScopeType, WebFrameClient*, - blink::InterfaceProvider*, blink::InterfaceRegistry*) override; void SetAutofillClient(WebAutofillClient*) override; WebAutofillClient* AutofillClient() override; @@ -335,18 +334,15 @@ static WebLocalFrameImpl* Create(WebTreeScopeType, WebFrameClient*, - InterfaceProvider*, InterfaceRegistry*, WebFrame* opener); static WebLocalFrameImpl* CreateMainFrame(WebView*, WebFrameClient*, - InterfaceProvider*, InterfaceRegistry*, WebFrame* opener, const WebString& name, WebSandboxFlags); static WebLocalFrameImpl* CreateProvisional(WebFrameClient*, - InterfaceProvider*, InterfaceRegistry*, WebRemoteFrame*, WebSandboxFlags, @@ -458,11 +454,9 @@ WebLocalFrameImpl(WebTreeScopeType, WebFrameClient*, - blink::InterfaceProvider*, blink::InterfaceRegistry*); WebLocalFrameImpl(WebRemoteFrame*, WebFrameClient*, - blink::InterfaceProvider*, blink::InterfaceRegistry*); // Inherited from WebFrame, but intentionally hidden: it never makes sense @@ -518,7 +512,6 @@ float input_events_scale_factor_for_emulation_; // Borrowed pointers to Mojo objects. - blink::InterfaceProvider* interface_provider_; blink::InterfaceRegistry* interface_registry_; WebDevToolsFrontendImpl* web_dev_tools_frontend_;
diff --git a/third_party/WebKit/Tools/Scripts/webkitpy/w3c/common_unittest.py b/third_party/WebKit/Tools/Scripts/webkitpy/w3c/common_unittest.py index 56c3d1d..0bd1c15e5 100644 --- a/third_party/WebKit/Tools/Scripts/webkitpy/w3c/common_unittest.py +++ b/third_party/WebKit/Tools/Scripts/webkitpy/w3c/common_unittest.py
@@ -83,16 +83,16 @@ def test_commit_that_has_open_pr_is_exportable(self): commit = MockChromiumCommit(MockHost(), change_id='Change-Id: I00decade') github = MockWPTGitHub(pull_requests=[ - PullRequest('PR1', 1, 'body\nChange-Id: I00c0ffee', 'closed'), - PullRequest('PR2', 2, 'body\nChange-Id: I00decade', 'open'), + PullRequest('PR1', 1, 'body\nChange-Id: I00c0ffee', 'closed', []), + PullRequest('PR2', 2, 'body\nChange-Id: I00decade', 'open', []), ]) self.assertTrue(is_exportable(commit, MockLocalWPT(), github)) def test_commit_that_has_closed_pr_is_not_exportable(self): commit = MockChromiumCommit(MockHost(), change_id='Change-Id: I00decade') github = MockWPTGitHub(pull_requests=[ - PullRequest('PR1', 1, 'body\nChange-Id: I00c0ffee', 'closed'), - PullRequest('PR2', 2, 'body\nChange-Id: I00decade', 'closed'), + PullRequest('PR1', 1, 'body\nChange-Id: I00c0ffee', 'closed', []), + PullRequest('PR2', 2, 'body\nChange-Id: I00decade', 'closed', []), ]) self.assertFalse(is_exportable(commit, MockLocalWPT(), github))
diff --git a/third_party/WebKit/Tools/Scripts/webkitpy/w3c/test_exporter.py b/third_party/WebKit/Tools/Scripts/webkitpy/w3c/test_exporter.py index 6c894c8..25bb5a7 100644 --- a/third_party/WebKit/Tools/Scripts/webkitpy/w3c/test_exporter.py +++ b/third_party/WebKit/Tools/Scripts/webkitpy/w3c/test_exporter.py
@@ -89,8 +89,9 @@ _log.info('[dry_run] Would have attempted to merge PR') return - _log.info('Removing provisional label...') - self.wpt_github.remove_label(pull_request.number, PROVISIONAL_PR_LABEL) + if PROVISIONAL_PR_LABEL in pull_request.labels: + _log.info('Removing provisional label "%s"...', PROVISIONAL_PR_LABEL) + self.wpt_github.remove_label(pull_request.number, PROVISIONAL_PR_LABEL) _log.info('Attempting to merge...')
diff --git a/third_party/WebKit/Tools/Scripts/webkitpy/w3c/test_exporter_unittest.py b/third_party/WebKit/Tools/Scripts/webkitpy/w3c/test_exporter_unittest.py index 3ca537b..0355827 100644 --- a/third_party/WebKit/Tools/Scripts/webkitpy/w3c/test_exporter_unittest.py +++ b/third_party/WebKit/Tools/Scripts/webkitpy/w3c/test_exporter_unittest.py
@@ -28,7 +28,7 @@ test_exporter = TestExporter(host, 'gh-username', 'gh-token', gerrit_user=None, gerrit_token=None, dry_run=True) test_exporter.wpt_github = MockWPTGitHub(pull_requests=[ - PullRequest(title='title1', number=1234, body='', state='open'), + PullRequest(title='title1', number=1234, body='', state='open', labels=[]), ]) test_exporter.gerrit = MockGerritAPI(host, 'gerrit-username', 'gerrit-token') test_exporter.get_exportable_commits = lambda: [ @@ -115,19 +115,22 @@ title='Open PR', number=1234, body='rutabaga\nCr-Commit-Position: refs/heads/master@{#458475}', - state='open' + state='open', + labels=['do not merge yet'] ), PullRequest( title='Merged PR', number=2345, body='rutabaga\nCr-Commit-Position: refs/heads/master@{#458477}', - state='closed' + state='closed', + labels=[] ), PullRequest( title='Open PR', number=3456, body='rutabaga\nCr-Commit-Position: refs/heads/master@{#458478}', - state='open' + state='open', + labels=[] # It's important that this is empty. ), ], unsuccessful_merge_index=0) test_exporter.gerrit = MockGerritAPI(host, 'gerrit-username', 'gerrit-token') @@ -148,7 +151,9 @@ 'add_label "chromium-export"', 'pr_with_position', 'pr_with_position', - 'remove_label "do not merge yet"', + # Testing the lack of remove_label here. The exporter should not + # try to remove the provisional label from PRs it has already + # removed it from. 'get_pr_branch', 'merge_pull_request', 'delete_remote_branch', @@ -199,7 +204,8 @@ gerrit_token=None, dry_run=False) test_exporter.wpt_github = MockWPTGitHub(pull_requests=[ PullRequest(title='title1', number=1234, - body='description\nWPT-Export-Revision: 1', state='open'), + body='description\nWPT-Export-Revision: 1', + state='open', labels=[]), ]) test_exporter.get_exportable_commits = lambda: [] test_exporter.gerrit = MockGerritAPI(host, 'gerrit-username', 'gerrit-token') @@ -228,7 +234,8 @@ gerrit_token=None, dry_run=False) test_exporter.wpt_github = MockWPTGitHub(pull_requests=[ PullRequest(title='title1', number=1234, - body='description\nWPT-Export-Revision: 1', state='open'), + body='description\nWPT-Export-Revision: 1', + state='open', labels=[]), ]) test_exporter.get_exportable_commits = lambda: [] test_exporter.gerrit = MockGerritAPI(host, 'gerrit-username', 'gerrit-token') @@ -277,7 +284,7 @@ test_exporter.wpt_github = MockWPTGitHub(pull_requests=[ PullRequest(title='title1', number=1234, body='description\nWPT-Export-Revision: 9\nChange-Id: decafbad', - state='open'), + state='open', labels=['do not merge yet']), ]) test_exporter.get_exportable_commits = lambda: [ ChromiumCommit(host, sha='c881563d734a86f7d9cd57ac509653a61c45c240'),
diff --git a/third_party/WebKit/Tools/Scripts/webkitpy/w3c/test_importer_unittest.py b/third_party/WebKit/Tools/Scripts/webkitpy/w3c/test_importer_unittest.py index 6641d7a..38727022 100644 --- a/third_party/WebKit/Tools/Scripts/webkitpy/w3c/test_importer_unittest.py +++ b/third_party/WebKit/Tools/Scripts/webkitpy/w3c/test_importer_unittest.py
@@ -20,7 +20,7 @@ def test_main_abort_on_exportable_commit_if_open_pr_found(self): host = MockHost() wpt_github = MockWPTGitHub(pull_requests=[ - PullRequest('Title', 5, 'Commit body\nChange-Id: Iba5eba11', 'open'), + PullRequest('Title', 5, 'Commit body\nChange-Id: Iba5eba11', 'open', []), ]) importer = TestImporter(host, wpt_github=wpt_github) importer.exportable_but_not_exported_commits = lambda _: [
diff --git a/third_party/WebKit/Tools/Scripts/webkitpy/w3c/wpt_github.py b/third_party/WebKit/Tools/Scripts/webkitpy/w3c/wpt_github.py index ff5e090..b2f099f 100644 --- a/third_party/WebKit/Tools/Scripts/webkitpy/w3c/wpt_github.py +++ b/third_party/WebKit/Tools/Scripts/webkitpy/w3c/wpt_github.py
@@ -123,11 +123,15 @@ WPT_GH_ORG, WPT_GH_REPO_NAME, number, - label, + urllib2.quote(label), ) + _, status_code = self.request(path, method='DELETE') - if status_code != 204: - raise GitHubError('Received non-204 status code attempting to delete remote branch: {}'.format(status_code)) + # The GitHub API documentation claims that this endpoint returns a 204 + # on success. However in reality it returns a 200. + # https://developer.github.com/v3/issues/labels/#remove-a-label-from-an-issue + if status_code not in (200, 204): + raise GitHubError('Received non-200 status code attempting to delete label: {}'.format(status_code)) def in_flight_pull_requests(self): path = '/search/issues?q=repo:{}/{}%20is:open%20type:pr%20label:{}'.format( @@ -142,11 +146,13 @@ raise Exception('Non-200 status code (%s): %s' % (status_code, data)) def make_pr_from_item(self, item): + labels = [label['name'] for label in item['labels']] return PullRequest( title=item['title'], number=item['number'], body=item['body'], - state=item['state']) + state=item['state'], + labels=labels) @memoized def all_pull_requests(self): @@ -267,4 +273,4 @@ pass -PullRequest = namedtuple('PullRequest', ['title', 'number', 'body', 'state']) +PullRequest = namedtuple('PullRequest', ['title', 'number', 'body', 'state', 'labels'])
diff --git a/third_party/WebKit/Tools/Scripts/webkitpy/w3c/wpt_github_unittest.py b/third_party/WebKit/Tools/Scripts/webkitpy/w3c/wpt_github_unittest.py index 5d32b44c..d30d7bdf 100644 --- a/third_party/WebKit/Tools/Scripts/webkitpy/w3c/wpt_github_unittest.py +++ b/third_party/WebKit/Tools/Scripts/webkitpy/w3c/wpt_github_unittest.py
@@ -34,9 +34,9 @@ with self.assertRaises(MergeError): self.wpt_github.merge_pull_request(5678) - def test_remove_label_throws_github_error_on_non_204(self): + def test_remove_label_throws_github_error_on_non_200_or_204(self): self.wpt_github.host.web.responses = [ - {'status_code': 200}, + {'status_code': 201}, ] with self.assertRaises(GitHubError):
diff --git a/third_party/WebKit/public/platform/WebDocumentSubresourceFilter.h b/third_party/WebKit/public/platform/WebDocumentSubresourceFilter.h index 25f6e8c..9ec6052 100644 --- a/third_party/WebKit/public/platform/WebDocumentSubresourceFilter.h +++ b/third_party/WebKit/public/platform/WebDocumentSubresourceFilter.h
@@ -13,6 +13,14 @@ class WebDocumentSubresourceFilter { public: + // This builder class is created on the main thread and passed to a worker + // thread to create the subresource filter for the worker thread. + class Builder { + public: + virtual ~Builder() {} + virtual std::unique_ptr<WebDocumentSubresourceFilter> Build() = 0; + }; + enum LoadPolicy { kAllow, kDisallow, kWouldDisallow }; virtual ~WebDocumentSubresourceFilter() {}
diff --git a/third_party/WebKit/public/platform/WebRuntimeFeatures.h b/third_party/WebKit/public/platform/WebRuntimeFeatures.h index 89c42a6..1ce4008 100644 --- a/third_party/WebKit/public/platform/WebRuntimeFeatures.h +++ b/third_party/WebKit/public/platform/WebRuntimeFeatures.h
@@ -162,6 +162,7 @@ BLINK_PLATFORM_EXPORT static void EnableMediaControlsOverlayPlayButton(bool); BLINK_PLATFORM_EXPORT static void EnableRemotePlaybackBackend(bool); BLINK_PLATFORM_EXPORT static void EnableMediaCastOverlayButton(bool); + BLINK_PLATFORM_EXPORT static void EnableClientPlaceholdersForServerLoFi(bool); private: WebRuntimeFeatures();
diff --git a/third_party/WebKit/public/platform/WebWorkerFetchContext.h b/third_party/WebKit/public/platform/WebWorkerFetchContext.h index d325f0d..ee5cb9f 100644 --- a/third_party/WebKit/public/platform/WebWorkerFetchContext.h +++ b/third_party/WebKit/public/platform/WebWorkerFetchContext.h
@@ -5,7 +5,10 @@ #ifndef WebWorkerFetchContext_h #define WebWorkerFetchContext_h +#include <memory> + #include "public/platform/WebApplicationCacheHost.h" +#include "public/platform/WebDocumentSubresourceFilter.h" #include "public/platform/WebURL.h" namespace base { @@ -16,6 +19,7 @@ class WebURLLoader; class WebURLRequest; +class WebDocumentSubresourceFilter; // WebWorkerFetchContext is a per-worker object created on the main thread, // passed to a worker (dedicated, shared and service worker) and initialized on @@ -60,6 +64,20 @@ virtual int ApplicationCacheHostID() const { return WebApplicationCacheHost::kAppCacheNoHostId; } + + // Sets the builder object of WebDocumentSubresourceFilter on the main thread + // which will be used in TakeSubresourceFilter() to create a + // WebDocumentSubresourceFilter on the worker thread. + virtual void SetSubresourceFilterBuilder( + std::unique_ptr<WebDocumentSubresourceFilter::Builder>) {} + + // Creates a WebDocumentSubresourceFilter on the worker thread using the + // WebDocumentSubresourceFilter::Builder which is set on the main thread. + // This method should only be called once. + virtual std::unique_ptr<WebDocumentSubresourceFilter> + TakeSubresourceFilter() { + return nullptr; + } }; } // namespace blink
diff --git a/third_party/WebKit/public/web/WebFrameClient.h b/third_party/WebKit/public/web/WebFrameClient.h index c16217eb..92a7365 100644 --- a/third_party/WebKit/public/web/WebFrameClient.h +++ b/third_party/WebKit/public/web/WebFrameClient.h
@@ -193,8 +193,9 @@ virtual BlameContext* GetFrameBlameContext() { return nullptr; } // Returns an InterfaceProvider the frame can use to request interfaces from - // the browser. + // the browser. This method may not return nullptr. virtual service_manager::InterfaceProvider* GetInterfaceProvider() { + NOTREACHED(); return nullptr; }
diff --git a/third_party/WebKit/public/web/WebLocalFrame.h b/third_party/WebKit/public/web/WebLocalFrame.h index 8e4c158..7b9db02e 100644 --- a/third_party/WebKit/public/web/WebLocalFrame.h +++ b/third_party/WebKit/public/web/WebLocalFrame.h
@@ -27,7 +27,6 @@ namespace blink { -class InterfaceProvider; class InterfaceRegistry; class WebAssociatedURLLoader; class WebAutofillClient; @@ -77,7 +76,6 @@ BLINK_EXPORT static WebLocalFrame* CreateMainFrame( WebView*, WebFrameClient*, - blink::InterfaceProvider*, blink::InterfaceRegistry*, WebFrame* opener = nullptr, const WebString& name = WebString(), @@ -102,7 +100,6 @@ // frame. BLINK_EXPORT static WebLocalFrame* CreateProvisional( WebFrameClient*, - blink::InterfaceProvider*, blink::InterfaceRegistry*, WebRemoteFrame*, WebSandboxFlags, @@ -113,7 +110,6 @@ // it's no longer needed. virtual WebLocalFrame* CreateLocalChild(WebTreeScopeType, WebFrameClient*, - blink::InterfaceProvider*, blink::InterfaceRegistry*) = 0; // Returns the WebFrame associated with the current V8 context. This
diff --git a/third_party/WebKit/public/web/WebRemoteFrame.h b/third_party/WebKit/public/web/WebRemoteFrame.h index 13482bc..7c78c3e 100644 --- a/third_party/WebKit/public/web/WebRemoteFrame.h +++ b/third_party/WebKit/public/web/WebRemoteFrame.h
@@ -15,7 +15,6 @@ namespace blink { enum class WebTreeScopeType; -class InterfaceProvider; class InterfaceRegistry; class WebFrameClient; class WebLayer; @@ -44,7 +43,6 @@ const WebString& name, WebSandboxFlags, WebFrameClient*, - blink::InterfaceProvider*, blink::InterfaceRegistry*, WebFrame* previous_sibling, const WebParsedFeaturePolicy&,
diff --git a/third_party/WebKit/public/web/modules/serviceworker/WebServiceWorkerContextClient.h b/third_party/WebKit/public/web/modules/serviceworker/WebServiceWorkerContextClient.h index 689ba8f..2251c02f 100644 --- a/third_party/WebKit/public/web/modules/serviceworker/WebServiceWorkerContextClient.h +++ b/third_party/WebKit/public/web/modules/serviceworker/WebServiceWorkerContextClient.h
@@ -188,6 +188,9 @@ const WebServiceWorkerResponse& response, WebServiceWorkerStreamHandle* body_as_stream, double event_dispatch_time) {} + virtual void RespondToCanMakePaymentEvent(int event_id, + bool can_make_payment, + double event_dispatch_time) {} virtual void RespondToPaymentRequestEvent( int event_id, const WebPaymentAppResponse& response,
diff --git a/third_party/axe-core/LICENSE b/third_party/axe-core/LICENSE new file mode 100644 index 0000000..be2cc4df --- /dev/null +++ b/third_party/axe-core/LICENSE
@@ -0,0 +1,362 @@ +Mozilla Public License, version 2.0 + +1. Definitions + +1.1. "Contributor" + + means each individual or legal entity that creates, contributes to the + creation of, or owns Covered Software. + +1.2. "Contributor Version" + + means the combination of the Contributions of others (if any) used by a + Contributor and that particular Contributor's Contribution. + +1.3. "Contribution" + + means Covered Software of a particular Contributor. + +1.4. "Covered Software" + + means Source Code Form to which the initial Contributor has attached the + notice in Exhibit A, the Executable Form of such Source Code Form, and + Modifications of such Source Code Form, in each case including portions + thereof. + +1.5. "Incompatible With Secondary Licenses" + means + + a. that the initial Contributor has attached the notice described in + Exhibit B to the Covered Software; or + + b. that the Covered Software was made available under the terms of + version 1.1 or earlier of the License, but not also under the terms of + a Secondary License. + +1.6. "Executable Form" + + means any form of the work other than Source Code Form. + +1.7. "Larger Work" + + means a work that combines Covered Software with other material, in a + separate file or files, that is not Covered Software. + +1.8. "License" + + means this document. + +1.9. "Licensable" + + means having the right to grant, to the maximum extent possible, whether + at the time of the initial grant or subsequently, any and all of the + rights conveyed by this License. + +1.10. "Modifications" + + means any of the following: + + a. any file in Source Code Form that results from an addition to, + deletion from, or modification of the contents of Covered Software; or + + b. any new file in Source Code Form that contains any Covered Software. + +1.11. "Patent Claims" of a Contributor + + means any patent claim(s), including without limitation, method, + process, and apparatus claims, in any patent Licensable by such + Contributor that would be infringed, but for the grant of the License, + by the making, using, selling, offering for sale, having made, import, + or transfer of either its Contributions or its Contributor Version. + +1.12. "Secondary License" + + means either the GNU General Public License, Version 2.0, the GNU Lesser + General Public License, Version 2.1, the GNU Affero General Public + License, Version 3.0, or any later versions of those licenses. + +1.13. "Source Code Form" + + means the form of the work preferred for making modifications. + +1.14. "You" (or "Your") + + means an individual or a legal entity exercising rights under this + License. For legal entities, "You" includes any entity that controls, is + controlled by, or is under common control with You. For purposes of this + definition, "control" means (a) the power, direct or indirect, to cause + the direction or management of such entity, whether by contract or + otherwise, or (b) ownership of more than fifty percent (50%) of the + outstanding shares or beneficial ownership of such entity. + + +2. License Grants and Conditions + +2.1. Grants + + Each Contributor hereby grants You a world-wide, royalty-free, + non-exclusive license: + + a. under intellectual property rights (other than patent or trademark) + Licensable by such Contributor to use, reproduce, make available, + modify, display, perform, distribute, and otherwise exploit its + Contributions, either on an unmodified basis, with Modifications, or + as part of a Larger Work; and + + b. under Patent Claims of such Contributor to make, use, sell, offer for + sale, have made, import, and otherwise transfer either its + Contributions or its Contributor Version. + +2.2. Effective Date + + The licenses granted in Section 2.1 with respect to any Contribution + become effective for each Contribution on the date the Contributor first + distributes such Contribution. + +2.3. Limitations on Grant Scope + + The licenses granted in this Section 2 are the only rights granted under + this License. No additional rights or licenses will be implied from the + distribution or licensing of Covered Software under this License. + Notwithstanding Section 2.1(b) above, no patent license is granted by a + Contributor: + + a. for any code that a Contributor has removed from Covered Software; or + + b. for infringements caused by: (i) Your and any other third party's + modifications of Covered Software, or (ii) the combination of its + Contributions with other software (except as part of its Contributor + Version); or + + c. under Patent Claims infringed by Covered Software in the absence of + its Contributions. + + This License does not grant any rights in the trademarks, service marks, + or logos of any Contributor (except as may be necessary to comply with + the notice requirements in Section 3.4). + +2.4. Subsequent Licenses + + No Contributor makes additional grants as a result of Your choice to + distribute the Covered Software under a subsequent version of this + License (see Section 10.2) or under the terms of a Secondary License (if + permitted under the terms of Section 3.3). + +2.5. Representation + + Each Contributor represents that the Contributor believes its + Contributions are its original creation(s) or it has sufficient rights to + grant the rights to its Contributions conveyed by this License. + +2.6. Fair Use + + This License is not intended to limit any rights You have under + applicable copyright doctrines of fair use, fair dealing, or other + equivalents. + +2.7. Conditions + + Sections 3.1, 3.2, 3.3, and 3.4 are conditions of the licenses granted in + Section 2.1. + + +3. Responsibilities + +3.1. Distribution of Source Form + + All distribution of Covered Software in Source Code Form, including any + Modifications that You create or to which You contribute, must be under + the terms of this License. You must inform recipients that the Source + Code Form of the Covered Software is governed by the terms of this + License, and how they can obtain a copy of this License. You may not + attempt to alter or restrict the recipients' rights in the Source Code + Form. + +3.2. Distribution of Executable Form + + If You distribute Covered Software in Executable Form then: + + a. such Covered Software must also be made available in Source Code Form, + as described in Section 3.1, and You must inform recipients of the + Executable Form how they can obtain a copy of such Source Code Form by + reasonable means in a timely manner, at a charge no more than the cost + of distribution to the recipient; and + + b. You may distribute such Executable Form under the terms of this + License, or sublicense it under different terms, provided that the + license for the Executable Form does not attempt to limit or alter the + recipients' rights in the Source Code Form under this License. + +3.3. Distribution of a Larger Work + + You may create and distribute a Larger Work under terms of Your choice, + provided that You also comply with the requirements of this License for + the Covered Software. If the Larger Work is a combination of Covered + Software with a work governed by one or more Secondary Licenses, and the + Covered Software is not Incompatible With Secondary Licenses, this + License permits You to additionally distribute such Covered Software + under the terms of such Secondary License(s), so that the recipient of + the Larger Work may, at their option, further distribute the Covered + Software under the terms of either this License or such Secondary + License(s). + +3.4. Notices + + You may not remove or alter the substance of any license notices + (including copyright notices, patent notices, disclaimers of warranty, or + limitations of liability) contained within the Source Code Form of the + Covered Software, except that You may alter any license notices to the + extent required to remedy known factual inaccuracies. + +3.5. Application of Additional Terms + + You may choose to offer, and to charge a fee for, warranty, support, + indemnity or liability obligations to one or more recipients of Covered + Software. However, You may do so only on Your own behalf, and not on + behalf of any Contributor. You must make it absolutely clear that any + such warranty, support, indemnity, or liability obligation is offered by + You alone, and You hereby agree to indemnify every Contributor for any + liability incurred by such Contributor as a result of warranty, support, + indemnity or liability terms You offer. You may include additional + disclaimers of warranty and limitations of liability specific to any + jurisdiction. + +4. Inability to Comply Due to Statute or Regulation + + If it is impossible for You to comply with any of the terms of this License + with respect to some or all of the Covered Software due to statute, + judicial order, or regulation then You must: (a) comply with the terms of + this License to the maximum extent possible; and (b) describe the + limitations and the code they affect. Such description must be placed in a + text file included with all distributions of the Covered Software under + this License. Except to the extent prohibited by statute or regulation, + such description must be sufficiently detailed for a recipient of ordinary + skill to be able to understand it. + +5. Termination + +5.1. The rights granted under this License will terminate automatically if You + fail to comply with any of its terms. However, if You become compliant, + then the rights granted under this License from a particular Contributor + are reinstated (a) provisionally, unless and until such Contributor + explicitly and finally terminates Your grants, and (b) on an ongoing + basis, if such Contributor fails to notify You of the non-compliance by + some reasonable means prior to 60 days after You have come back into + compliance. Moreover, Your grants from a particular Contributor are + reinstated on an ongoing basis if such Contributor notifies You of the + non-compliance by some reasonable means, this is the first time You have + received notice of non-compliance with this License from such + Contributor, and You become compliant prior to 30 days after Your receipt + of the notice. + +5.2. If You initiate litigation against any entity by asserting a patent + infringement claim (excluding declaratory judgment actions, + counter-claims, and cross-claims) alleging that a Contributor Version + directly or indirectly infringes any patent, then the rights granted to + You by any and all Contributors for the Covered Software under Section + 2.1 of this License shall terminate. + +5.3. In the event of termination under Sections 5.1 or 5.2 above, all end user + license agreements (excluding distributors and resellers) which have been + validly granted by You or Your distributors under this License prior to + termination shall survive termination. + +6. Disclaimer of Warranty + + Covered Software is provided under this License on an "as is" basis, + without warranty of any kind, either expressed, implied, or statutory, + including, without limitation, warranties that the Covered Software is free + of defects, merchantable, fit for a particular purpose or non-infringing. + The entire risk as to the quality and performance of the Covered Software + is with You. Should any Covered Software prove defective in any respect, + You (not any Contributor) assume the cost of any necessary servicing, + repair, or correction. This disclaimer of warranty constitutes an essential + part of this License. No use of any Covered Software is authorized under + this License except under this disclaimer. + +7. Limitation of Liability + + Under no circumstances and under no legal theory, whether tort (including + negligence), contract, or otherwise, shall any Contributor, or anyone who + distributes Covered Software as permitted above, be liable to You for any + direct, indirect, special, incidental, or consequential damages of any + character including, without limitation, damages for lost profits, loss of + goodwill, work stoppage, computer failure or malfunction, or any and all + other commercial damages or losses, even if such party shall have been + informed of the possibility of such damages. This limitation of liability + shall not apply to liability for death or personal injury resulting from + such party's negligence to the extent applicable law prohibits such + limitation. Some jurisdictions do not allow the exclusion or limitation of + incidental or consequential damages, so this exclusion and limitation may + not apply to You. + +8. Litigation + + Any litigation relating to this License may be brought only in the courts + of a jurisdiction where the defendant maintains its principal place of + business and such litigation shall be governed by laws of that + jurisdiction, without reference to its conflict-of-law provisions. Nothing + in this Section shall prevent a party's ability to bring cross-claims or + counter-claims. + +9. Miscellaneous + + This License represents the complete agreement concerning the subject + matter hereof. If any provision of this License is held to be + unenforceable, such provision shall be reformed only to the extent + necessary to make it enforceable. Any law or regulation which provides that + the language of a contract shall be construed against the drafter shall not + be used to construe this License against a Contributor. + + +10. Versions of the License + +10.1. New Versions + + Mozilla Foundation is the license steward. Except as provided in Section + 10.3, no one other than the license steward has the right to modify or + publish new versions of this License. Each version will be given a + distinguishing version number. + +10.2. Effect of New Versions + + You may distribute the Covered Software under the terms of the version + of the License under which You originally received the Covered Software, + or under the terms of any subsequent version published by the license + steward. + +10.3. Modified Versions + + If you create software not governed by this License, and you want to + create a new license for such software, you may create and use a + modified version of this License if you rename the license and remove + any references to the name of the license steward (except to note that + such modified license differs from this License). + +10.4. Distributing Source Code Form that is Incompatible With Secondary + Licenses If You choose to distribute Source Code Form that is + Incompatible With Secondary Licenses under the terms of this version of + the License, the notice described in Exhibit B of this License must be + attached. + +Exhibit A - Source Code Form License Notice + + This Source Code Form is subject to the + terms of the Mozilla Public License, v. + 2.0. If a copy of the MPL was not + distributed with this file, You can + obtain one at + http://mozilla.org/MPL/2.0/. + +If it is not possible or desirable to put the notice in a particular file, +then You may include the notice in a location (such as a LICENSE file in a +relevant directory) where a recipient would be likely to look for such a +notice. + +You may add additional accurate notices of copyright ownership. + +Exhibit B - "Incompatible With Secondary Licenses" Notice + + This Source Code Form is "Incompatible + With Secondary Licenses", as defined by + the Mozilla Public License, v. 2.0.
diff --git a/third_party/axe-core/OWNERS b/third_party/axe-core/OWNERS new file mode 100644 index 0000000..1877266f --- /dev/null +++ b/third_party/axe-core/OWNERS
@@ -0,0 +1,2 @@ +aboxhall@chromium.org +hcarmona@chromium.org
diff --git a/third_party/axe-core/README.chromium b/third_party/axe-core/README.chromium new file mode 100644 index 0000000..6bd3e1bb --- /dev/null +++ b/third_party/axe-core/README.chromium
@@ -0,0 +1,20 @@ +Name: AXE-CORE Accessibility Audit +Short Name: axe-core +URL: https://github.com/dequelabs/axe-core/ +Version: 0 +Date: Sun Jun 18 19:21:36 2017 -0400 +Revision: 1986520cdca8ed0f208d2cbd918829b27266a374 +License: MPL 2.0 +License File: LICENSE +Security Critical: no + +Description: +Accessibility engine for automated Web UI testing. This will be used to run +automated accessibility tests in web-ui. + +Local Modifications: + 1 Checked out the origin/shadowDOM branch + 2 Created build + 3 New files: + README.chromium + OWNERS
diff --git a/third_party/axe-core/axe.js b/third_party/axe-core/axe.js new file mode 100644 index 0000000..19c2cbf --- /dev/null +++ b/third_party/axe-core/axe.js
@@ -0,0 +1,9454 @@ +/*! aXe v2.3.1 + * Copyright (c) 2017 Deque Systems, Inc. + * + * Your use of this Source Code Form is subject to the terms of the Mozilla Public + * License, v. 2.0. If a copy of the MPL was not distributed with this + * file, You can obtain one at http://mozilla.org/MPL/2.0/. + * + * This entire copyright notice must appear in every copy of this file you + * distribute or in any file that contains substantial portions of this source + * code. + */ +(function axeFunction(window) { + var global = window; + var document = window.document; + 'use strict'; + var _typeof = typeof Symbol === 'function' && typeof Symbol.iterator === 'symbol' ? function(obj) { + return typeof obj; + } : function(obj) { + return obj && typeof Symbol === 'function' && obj.constructor === Symbol && obj !== Symbol.prototype ? 'symbol' : typeof obj; + }; + var axe = axe || {}; + axe.version = '2.3.1'; + if (typeof define === 'function' && define.amd) { + define([], function() { + 'use strict'; + return axe; + }); + } + if ((typeof module === 'undefined' ? 'undefined' : _typeof(module)) === 'object' && module.exports && typeof axeFunction.toString === 'function') { + axe.source = '(' + axeFunction.toString() + ')(typeof window === "object" ? window : this);'; + module.exports = axe; + } + if (typeof window.getComputedStyle === 'function') { + window.axe = axe; + } + var commons; + function SupportError(error) { + this.name = 'SupportError'; + this.cause = error.cause; + this.message = '`' + error.cause + '` - feature unsupported in your environment.'; + if (error.ruleId) { + this.ruleId = error.ruleId; + this.message += ' Skipping ' + this.ruleId + ' rule.'; + } + this.stack = new Error().stack; + } + SupportError.prototype = Object.create(Error.prototype); + SupportError.prototype.constructor = SupportError; + 'use strict'; + var utils = axe.utils = {}; + 'use strict'; + var helpers = {}; + 'use strict'; + var _typeof = typeof Symbol === 'function' && typeof Symbol.iterator === 'symbol' ? function(obj) { + return typeof obj; + } : function(obj) { + return obj && typeof Symbol === 'function' && obj.constructor === Symbol && obj !== Symbol.prototype ? 'symbol' : typeof obj; + }; + function getDefaultConfiguration(audit) { + 'use strict'; + var config; + if (audit) { + config = axe.utils.clone(audit); + config.commons = audit.commons; + } else { + config = {}; + } + config.reporter = config.reporter || null; + config.rules = config.rules || []; + config.checks = config.checks || []; + config.data = Object.assign({ + checks: {}, + rules: {} + }, config.data); + return config; + } + function unpackToObject(collection, audit, method) { + 'use strict'; + var i, l; + for (i = 0, l = collection.length; i < l; i++) { + audit[method](collection[i]); + } + } + function Audit(audit) { + this.brand = 'axe'; + this.application = 'axeAPI'; + this.tagExclude = [ 'experimental' ]; + this.defaultConfig = audit; + this._init(); + } + Audit.prototype._init = function() { + var audit = getDefaultConfiguration(this.defaultConfig); + axe.commons = commons = audit.commons; + this.reporter = audit.reporter; + this.commands = {}; + this.rules = []; + this.checks = {}; + unpackToObject(audit.rules, this, 'addRule'); + unpackToObject(audit.checks, this, 'addCheck'); + this.data = {}; + this.data.checks = audit.data && audit.data.checks || {}; + this.data.rules = audit.data && audit.data.rules || {}; + this.data.failureSummaries = audit.data && audit.data.failureSummaries || {}; + this.data.incompleteFallbackMessage = audit.data && audit.data.incompleteFallbackMessage || ''; + this._constructHelpUrls(); + }; + Audit.prototype.registerCommand = function(command) { + 'use strict'; + this.commands[command.id] = command.callback; + }; + Audit.prototype.addRule = function(spec) { + 'use strict'; + if (spec.metadata) { + this.data.rules[spec.id] = spec.metadata; + } + var rule = this.getRule(spec.id); + if (rule) { + rule.configure(spec); + } else { + this.rules.push(new Rule(spec, this)); + } + }; + Audit.prototype.addCheck = function(spec) { + 'use strict'; + var metadata = spec.metadata; + if ((typeof metadata === 'undefined' ? 'undefined' : _typeof(metadata)) === 'object') { + this.data.checks[spec.id] = metadata; + if (_typeof(metadata.messages) === 'object') { + Object.keys(metadata.messages).filter(function(prop) { + return metadata.messages.hasOwnProperty(prop) && typeof metadata.messages[prop] === 'string'; + }).forEach(function(prop) { + if (metadata.messages[prop].indexOf('function') === 0) { + metadata.messages[prop] = new Function('return ' + metadata.messages[prop] + ';')(); + } + }); + } + } + if (this.checks[spec.id]) { + this.checks[spec.id].configure(spec); + } else { + this.checks[spec.id] = new Check(spec); + } + }; + Audit.prototype.run = function(context, options, resolve, reject) { + 'use strict'; + this.validateOptions(options); + axe._tree = axe.utils.getFlattenedTree(document.body); + var q = axe.utils.queue(); + this.rules.forEach(function(rule) { + if (axe.utils.ruleShouldRun(rule, context, options)) { + if (options.performanceTimer) { + var markEnd = 'mark_rule_end_' + rule.id; + var markStart = 'mark_rule_start_' + rule.id; + axe.utils.performanceTimer.mark(markStart); + } + q.defer(function(res, rej) { + rule.run(context, options, function(out) { + if (options.performanceTimer) { + axe.utils.performanceTimer.mark(markEnd); + axe.utils.performanceTimer.measure('rule_' + rule.id, markStart, markEnd); + } + res(out); + }, function(err) { + if (!options.debug) { + var errResult = Object.assign(new RuleResult(rule), { + result: axe.constants.CANTTELL, + description: 'An error occured while running this rule', + message: err.message, + help: err.stack || err.message, + error: err + }); + res(errResult); + } else { + rej(err); + } + }); + }); + } + }); + q.then(function(results) { + axe._tree = undefined; + resolve(results.filter(function(result) { + return !!result; + })); + }).catch(reject); + }; + Audit.prototype.after = function(results, options) { + 'use strict'; + var rules = this.rules; + return results.map(function(ruleResult) { + var rule = axe.utils.findBy(rules, 'id', ruleResult.id); + return rule.after(ruleResult, options); + }); + }; + Audit.prototype.getRule = function(ruleId) { + return this.rules.find(function(rule) { + return rule.id === ruleId; + }); + }; + Audit.prototype.validateOptions = function(options) { + 'use strict'; + var audit = this; + if (_typeof(options.runOnly) === 'object') { + var only = options.runOnly; + if (only.type === 'rule' && Array.isArray(only.value)) { + only.value.forEach(function(ruleId) { + if (!audit.getRule(ruleId)) { + throw new Error('unknown rule `' + ruleId + '` in options.runOnly'); + } + }); + } else if (Array.isArray(only.value) && only.value.length > 0) { + var tags = [].concat(only.value); + audit.rules.forEach(function(rule) { + var tagPos, i, l; + if (!tags) { + return; + } + for (i = 0, l = rule.tags.length; i < l; i++) { + tagPos = tags.indexOf(rule.tags[i]); + if (tagPos !== -1) { + tags.splice(tagPos, 1); + } + } + }); + if (tags.length !== 0) { + throw new Error('could not find tags `' + tags.join('`, `') + '`'); + } + } + } + if (_typeof(options.rules) === 'object') { + Object.keys(options.rules).forEach(function(ruleId) { + if (!audit.getRule(ruleId)) { + throw new Error('unknown rule `' + ruleId + '` in options.rules'); + } + }); + } + return options; + }; + Audit.prototype.setBranding = function(branding) { + 'use strict'; + var previous = { + brand: this.brand, + application: this.application + }; + if (branding && branding.hasOwnProperty('brand') && branding.brand && typeof branding.brand === 'string') { + this.brand = branding.brand; + } + if (branding && branding.hasOwnProperty('application') && branding.application && typeof branding.application === 'string') { + this.application = branding.application; + } + this._constructHelpUrls(previous); + }; + function getHelpUrl(_ref, ruleId, version) { + var brand = _ref.brand, application = _ref.application; + return axe.constants.helpUrlBase + brand + '/' + (version || axe.version.substring(0, axe.version.lastIndexOf('.'))) + '/' + ruleId + '?application=' + application; + } + Audit.prototype._constructHelpUrls = function() { + var _this = this; + var previous = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : null; + var version = axe.version.substring(0, axe.version.lastIndexOf('.')); + this.rules.forEach(function(rule) { + if (!_this.data.rules[rule.id]) { + _this.data.rules[rule.id] = {}; + } + var metaData = _this.data.rules[rule.id]; + if (typeof metaData.helpUrl !== 'string' || previous && metaData.helpUrl === getHelpUrl(previous, rule.id, version)) { + metaData.helpUrl = getHelpUrl(_this, rule.id, version); + } + }); + }; + Audit.prototype.resetRulesAndChecks = function() { + 'use strict'; + this._init(); + }; + 'use strict'; + function CheckResult(check) { + 'use strict'; + this.id = check.id; + this.data = null; + this.relatedNodes = []; + this.result = null; + } + 'use strict'; + function createExecutionContext(spec) { + 'use strict'; + if (typeof spec === 'string') { + return new Function('return ' + spec + ';')(); + } + return spec; + } + function Check(spec) { + if (spec) { + this.id = spec.id; + this.configure(spec); + } + } + Check.prototype.enabled = true; + Check.prototype.run = function(node, options, resolve, reject) { + 'use strict'; + options = options || {}; + var enabled = options.hasOwnProperty('enabled') ? options.enabled : this.enabled, checkOptions = options.options || this.options; + if (enabled) { + var checkResult = new CheckResult(this); + var checkHelper = axe.utils.checkHelper(checkResult, options, resolve, reject); + var result; + try { + result = this.evaluate.call(checkHelper, node.actualNode, checkOptions, node); + } catch (e) { + reject(e); + return; + } + if (!checkHelper.isAsync) { + checkResult.result = result; + setTimeout(function() { + resolve(checkResult); + }, 0); + } + } else { + resolve(null); + } + }; + Check.prototype.configure = function(spec) { + var _this = this; + [ 'options', 'enabled' ].filter(function(prop) { + return spec.hasOwnProperty(prop); + }).forEach(function(prop) { + return _this[prop] = spec[prop]; + }); + [ 'evaluate', 'after' ].filter(function(prop) { + return spec.hasOwnProperty(prop); + }).forEach(function(prop) { + return _this[prop] = createExecutionContext(spec[prop]); + }); + }; + 'use strict'; + var _typeof = typeof Symbol === 'function' && typeof Symbol.iterator === 'symbol' ? function(obj) { + return typeof obj; + } : function(obj) { + return obj && typeof Symbol === 'function' && obj.constructor === Symbol && obj !== Symbol.prototype ? 'symbol' : typeof obj; + }; + function pushUniqueFrame(collection, frame) { + 'use strict'; + if (axe.utils.isHidden(frame)) { + return; + } + var fr = axe.utils.findBy(collection, 'node', frame); + if (!fr) { + collection.push({ + node: frame, + include: [], + exclude: [] + }); + } + } + function pushUniqueFrameSelector(context, type, selectorArray) { + 'use strict'; + context.frames = context.frames || []; + var result, frame; + var frames = document.querySelectorAll(selectorArray.shift()); + frameloop: for (var i = 0, l = frames.length; i < l; i++) { + frame = frames[i]; + for (var j = 0, l2 = context.frames.length; j < l2; j++) { + if (context.frames[j].node === frame) { + context.frames[j][type].push(selectorArray); + break frameloop; + } + } + result = { + node: frame, + include: [], + exclude: [] + }; + if (selectorArray) { + result[type].push(selectorArray); + } + context.frames.push(result); + } + } + function normalizeContext(context) { + 'use strict'; + if (context && (typeof context === 'undefined' ? 'undefined' : _typeof(context)) === 'object' || context instanceof NodeList) { + if (context instanceof Node) { + return { + include: [ context ], + exclude: [] + }; + } + if (context.hasOwnProperty('include') || context.hasOwnProperty('exclude')) { + return { + include: context.include && +context.include.length ? context.include : [ document ], + exclude: context.exclude || [] + }; + } + if (context.length === +context.length) { + return { + include: context, + exclude: [] + }; + } + } + if (typeof context === 'string') { + return { + include: [ context ], + exclude: [] + }; + } + return { + include: [ document ], + exclude: [] + }; + } + function parseSelectorArray(context, type) { + 'use strict'; + var item, result = [], nodeList; + for (var i = 0, l = context[type].length; i < l; i++) { + item = context[type][i]; + if (typeof item === 'string') { + nodeList = Array.from(document.querySelectorAll(item)); + result = result.concat(nodeList.map(function(node) { + return axe.utils.getFlattenedTree(node)[0]; + })); + break; + } else if (item && item.length && !(item instanceof Node)) { + if (item.length > 1) { + pushUniqueFrameSelector(context, type, item); + } else { + nodeList = Array.from(document.querySelectorAll(item[0])); + result = result.concat(nodeList.map(function(node) { + return axe.utils.getFlattenedTree(node)[0]; + })); + } + } else if (item instanceof Node) { + result.push(axe.utils.getFlattenedTree(item)[0]); + } + } + return result.filter(function(r) { + return r; + }); + } + function validateContext(context) { + 'use strict'; + if (context.include.length === 0) { + if (context.frames.length === 0) { + var env = axe.utils.respondable.isInFrame() ? 'frame' : 'page'; + return new Error('No elements found for include in ' + env + ' Context'); + } + context.frames.forEach(function(frame, i) { + if (frame.include.length === 0) { + return new Error('No elements found for include in Context of frame ' + i); + } + }); + } + } + function Context(spec) { + 'use strict'; + var self = this; + this.frames = []; + this.initiator = spec && typeof spec.initiator === 'boolean' ? spec.initiator : true; + this.page = false; + spec = normalizeContext(spec); + this.exclude = spec.exclude; + this.include = spec.include; + this.include = parseSelectorArray(this, 'include'); + this.exclude = parseSelectorArray(this, 'exclude'); + axe.utils.select('frame, iframe', this).forEach(function(frame) { + if (isNodeInContext(frame, self)) { + pushUniqueFrame(self.frames, frame.actualNode); + } + }); + if (this.include.length === 1 && this.include[0].actualNode === document.documentElement) { + this.page = true; + } + var err = validateContext(this); + if (err instanceof Error) { + throw err; + } + } + 'use strict'; + function RuleResult(rule) { + 'use strict'; + this.id = rule.id; + this.result = axe.constants.NA; + this.pageLevel = rule.pageLevel; + this.impact = null; + this.nodes = []; + } + 'use strict'; + function Rule(spec, parentAudit) { + 'use strict'; + this._audit = parentAudit; + this.id = spec.id; + this.selector = spec.selector || '*'; + this.excludeHidden = typeof spec.excludeHidden === 'boolean' ? spec.excludeHidden : true; + this.enabled = typeof spec.enabled === 'boolean' ? spec.enabled : true; + this.pageLevel = typeof spec.pageLevel === 'boolean' ? spec.pageLevel : false; + this.any = spec.any || []; + this.all = spec.all || []; + this.none = spec.none || []; + this.tags = spec.tags || []; + if (spec.matches) { + this.matches = createExecutionContext(spec.matches); + } + } + Rule.prototype.matches = function() { + 'use strict'; + return true; + }; + Rule.prototype.gather = function(context) { + 'use strict'; + var elements = axe.utils.select(this.selector, context); + if (this.excludeHidden) { + return elements.filter(function(element) { + return !axe.utils.isHidden(element.actualNode); + }); + } + return elements; + }; + Rule.prototype.runChecks = function(type, node, options, resolve, reject) { + 'use strict'; + var self = this; + var checkQueue = axe.utils.queue(); + this[type].forEach(function(c) { + var check = self._audit.checks[c.id || c]; + var option = axe.utils.getCheckOption(check, self.id, options); + checkQueue.defer(function(res, rej) { + check.run(node, option, res, rej); + }); + }); + checkQueue.then(function(results) { + results = results.filter(function(check) { + return check; + }); + resolve({ + type: type, + results: results + }); + }).catch(reject); + }; + Rule.prototype.run = function(context, options, resolve, reject) { + var _this = this; + var q = axe.utils.queue(); + var ruleResult = new RuleResult(this); + var nodes = void 0; + try { + nodes = this.gather(context).filter(function(node) { + return _this.matches(node.actualNode); + }); + } catch (error) { + reject(new SupportError({ + cause: error, + ruleId: this.id + })); + return; + } + if (options.performanceTimer) { + axe.log('gather (', nodes.length, '):', axe.utils.performanceTimer.timeElapsed() + 'ms'); + } + nodes.forEach(function(node) { + q.defer(function(resolveNode, rejectNode) { + var checkQueue = axe.utils.queue(); + checkQueue.defer(function(res, rej) { + _this.runChecks('any', node, options, res, rej); + }); + checkQueue.defer(function(res, rej) { + _this.runChecks('all', node, options, res, rej); + }); + checkQueue.defer(function(res, rej) { + _this.runChecks('none', node, options, res, rej); + }); + checkQueue.then(function(results) { + if (results.length) { + var hasResults = false, result = {}; + results.forEach(function(r) { + var res = r.results.filter(function(result) { + return result; + }); + result[r.type] = res; + if (res.length) { + hasResults = true; + } + }); + if (hasResults) { + result.node = new axe.utils.DqElement(node.actualNode, options); + ruleResult.nodes.push(result); + } + } + resolveNode(); + }).catch(function(err) { + return rejectNode(err); + }); + }); + }); + q.then(function() { + return resolve(ruleResult); + }).catch(function(error) { + return reject(error); + }); + }; + function findAfterChecks(rule) { + 'use strict'; + return axe.utils.getAllChecks(rule).map(function(c) { + var check = rule._audit.checks[c.id || c]; + return check && typeof check.after === 'function' ? check : null; + }).filter(Boolean); + } + function findCheckResults(nodes, checkID) { + 'use strict'; + var checkResults = []; + nodes.forEach(function(nodeResult) { + var checks = axe.utils.getAllChecks(nodeResult); + checks.forEach(function(checkResult) { + if (checkResult.id === checkID) { + checkResults.push(checkResult); + } + }); + }); + return checkResults; + } + function filterChecks(checks) { + 'use strict'; + return checks.filter(function(check) { + return check.filtered !== true; + }); + } + function sanitizeNodes(result) { + 'use strict'; + var checkTypes = [ 'any', 'all', 'none' ]; + var nodes = result.nodes.filter(function(detail) { + var length = 0; + checkTypes.forEach(function(type) { + detail[type] = filterChecks(detail[type]); + length += detail[type].length; + }); + return length > 0; + }); + if (result.pageLevel && nodes.length) { + nodes = [ nodes.reduce(function(a, b) { + if (a) { + checkTypes.forEach(function(type) { + a[type].push.apply(a[type], b[type]); + }); + return a; + } + }) ]; + } + return nodes; + } + Rule.prototype.after = function(result, options) { + 'use strict'; + var afterChecks = findAfterChecks(this); + var ruleID = this.id; + afterChecks.forEach(function(check) { + var beforeResults = findCheckResults(result.nodes, check.id); + var option = axe.utils.getCheckOption(check, ruleID, options); + var afterResults = check.after(beforeResults, option); + beforeResults.forEach(function(item) { + if (afterResults.indexOf(item) === -1) { + item.filtered = true; + } + }); + }); + result.nodes = sanitizeNodes(result); + return result; + }; + Rule.prototype.configure = function(spec) { + 'use strict'; + if (spec.hasOwnProperty('selector')) { + this.selector = spec.selector; + } + if (spec.hasOwnProperty('excludeHidden')) { + this.excludeHidden = typeof spec.excludeHidden === 'boolean' ? spec.excludeHidden : true; + } + if (spec.hasOwnProperty('enabled')) { + this.enabled = typeof spec.enabled === 'boolean' ? spec.enabled : true; + } + if (spec.hasOwnProperty('pageLevel')) { + this.pageLevel = typeof spec.pageLevel === 'boolean' ? spec.pageLevel : false; + } + if (spec.hasOwnProperty('any')) { + this.any = spec.any; + } + if (spec.hasOwnProperty('all')) { + this.all = spec.all; + } + if (spec.hasOwnProperty('none')) { + this.none = spec.none; + } + if (spec.hasOwnProperty('tags')) { + this.tags = spec.tags; + } + if (spec.hasOwnProperty('matches')) { + if (typeof spec.matches === 'string') { + this.matches = new Function('return ' + spec.matches + ';')(); + } else { + this.matches = spec.matches; + } + } + }; + 'use strict'; + (function(axe) { + var definitions = [ { + name: 'NA', + value: 'inapplicable', + priority: 0, + group: 'inapplicable' + }, { + name: 'PASS', + value: 'passed', + priority: 1, + group: 'passes' + }, { + name: 'CANTTELL', + value: 'cantTell', + priority: 2, + group: 'incomplete' + }, { + name: 'FAIL', + value: 'failed', + priority: 3, + group: 'violations' + } ]; + var constants = { + helpUrlBase: 'https://dequeuniversity.com/rules/', + results: [], + resultGroups: [], + resultGroupMap: {}, + impact: Object.freeze([ 'minor', 'moderate', 'serious', 'critical' ]) + }; + definitions.forEach(function(definition) { + var name = definition.name; + var value = definition.value; + var priority = definition.priority; + var group = definition.group; + constants[name] = value; + constants[name + '_PRIO'] = priority; + constants[name + '_GROUP'] = group; + constants.results[priority] = value; + constants.resultGroups[priority] = group; + constants.resultGroupMap[value] = group; + }); + Object.freeze(constants.results); + Object.freeze(constants.resultGroups); + Object.freeze(constants.resultGroupMap); + Object.freeze(constants); + Object.defineProperty(axe, 'constants', { + value: constants, + enumerable: true, + configurable: false, + writable: false + }); + })(axe); + 'use strict'; + var _typeof = typeof Symbol === 'function' && typeof Symbol.iterator === 'symbol' ? function(obj) { + return typeof obj; + } : function(obj) { + return obj && typeof Symbol === 'function' && obj.constructor === Symbol && obj !== Symbol.prototype ? 'symbol' : typeof obj; + }; + axe.log = function() { + 'use strict'; + if ((typeof console === 'undefined' ? 'undefined' : _typeof(console)) === 'object' && console.log) { + Function.prototype.apply.call(console.log, console, arguments); + } + }; + 'use strict'; + var _typeof = typeof Symbol === 'function' && typeof Symbol.iterator === 'symbol' ? function(obj) { + return typeof obj; + } : function(obj) { + return obj && typeof Symbol === 'function' && obj.constructor === Symbol && obj !== Symbol.prototype ? 'symbol' : typeof obj; + }; + axe.a11yCheck = function(context, options, callback) { + 'use strict'; + if (typeof options === 'function') { + callback = options; + options = {}; + } + if (!options || (typeof options === 'undefined' ? 'undefined' : _typeof(options)) !== 'object') { + options = {}; + } + var audit = axe._audit; + if (!audit) { + throw new Error('No audit configured'); + } + options.reporter = options.reporter || audit.reporter || 'v2'; + if (options.performanceTimer) { + axe.utils.performanceTimer.start(); + } + var reporter = axe.getReporter(options.reporter); + axe._runRules(context, options, function(results) { + var res = reporter(results, options, callback); + if (res !== undefined) { + if (options.performanceTimer) { + axe.utils.performanceTimer.end(); + } + callback(res); + } + }, axe.log); + }; + 'use strict'; + function cleanupPlugins(resolve, reject) { + 'use strict'; + if (!axe._audit) { + throw new Error('No audit configured'); + } + var q = axe.utils.queue(); + var cleanupErrors = []; + Object.keys(axe.plugins).forEach(function(key) { + q.defer(function(res) { + var rej = function rej(err) { + cleanupErrors.push(err); + res(); + }; + try { + axe.plugins[key].cleanup(res, rej); + } catch (err) { + rej(err); + } + }); + }); + axe.utils.toArray(document.querySelectorAll('frame, iframe')).forEach(function(frame) { + q.defer(function(res, rej) { + return axe.utils.sendCommandToFrame(frame, { + command: 'cleanup-plugin' + }, res, rej); + }); + }); + q.then(function(results) { + if (cleanupErrors.length === 0) { + resolve(results); + } else { + reject(cleanupErrors); + } + }).catch(reject); + } + axe.cleanup = cleanupPlugins; + 'use strict'; + function configureChecksRulesAndBranding(spec) { + 'use strict'; + var audit; + audit = axe._audit; + if (!audit) { + throw new Error('No audit configured'); + } + if (spec.reporter && (typeof spec.reporter === 'function' || reporters[spec.reporter])) { + audit.reporter = spec.reporter; + } + if (spec.checks) { + spec.checks.forEach(function(check) { + audit.addCheck(check); + }); + } + if (spec.rules) { + spec.rules.forEach(function(rule) { + audit.addRule(rule); + }); + } + if (typeof spec.branding !== 'undefined') { + audit.setBranding(spec.branding); + } else { + audit._constructHelpUrls(); + } + if (spec.tagExclude) { + audit.tagExclude = spec.tagExclude; + } + } + axe.configure = configureChecksRulesAndBranding; + 'use strict'; + axe.getRules = function(tags) { + 'use strict'; + tags = tags || []; + var matchingRules = !tags.length ? axe._audit.rules : axe._audit.rules.filter(function(item) { + return !!tags.filter(function(tag) { + return item.tags.indexOf(tag) !== -1; + }).length; + }); + var ruleData = axe._audit.data.rules || {}; + return matchingRules.map(function(matchingRule) { + var rd = ruleData[matchingRule.id] || {}; + return { + ruleId: matchingRule.id, + description: rd.description, + help: rd.help, + helpUrl: rd.helpUrl, + tags: matchingRule.tags + }; + }); + }; + 'use strict'; + function runCommand(data, keepalive, callback) { + 'use strict'; + var resolve = callback; + var reject = function reject(err) { + if (err instanceof Error === false) { + err = new Error(err); + } + callback(err); + }; + var context = data && data.context || {}; + if (context.include && !context.include.length) { + context.include = [ document ]; + } + var options = data && data.options || {}; + switch (data.command) { + case 'rules': + return runRules(context, options, resolve, reject); + + case 'cleanup-plugin': + return cleanupPlugins(resolve, reject); + + default: + if (axe._audit && axe._audit.commands && axe._audit.commands[data.command]) { + return axe._audit.commands[data.command](data, callback); + } + } + } + axe._load = function(audit) { + 'use strict'; + axe.utils.respondable.subscribe('axe.ping', function(data, keepalive, respond) { + respond({ + axe: true + }); + }); + axe.utils.respondable.subscribe('axe.start', runCommand); + axe._audit = new Audit(audit); + }; + 'use strict'; + var axe = axe || {}; + axe.plugins = {}; + function Plugin(spec) { + 'use strict'; + this._run = spec.run; + this._collect = spec.collect; + this._registry = {}; + spec.commands.forEach(function(command) { + axe._audit.registerCommand(command); + }); + } + Plugin.prototype.run = function() { + 'use strict'; + return this._run.apply(this, arguments); + }; + Plugin.prototype.collect = function() { + 'use strict'; + return this._collect.apply(this, arguments); + }; + Plugin.prototype.cleanup = function(done) { + 'use strict'; + var q = axe.utils.queue(); + var that = this; + Object.keys(this._registry).forEach(function(key) { + q.defer(function(done) { + that._registry[key].cleanup(done); + }); + }); + q.then(function() { + done(); + }); + }; + Plugin.prototype.add = function(impl) { + 'use strict'; + this._registry[impl.id] = impl; + }; + axe.registerPlugin = function(plugin) { + 'use strict'; + axe.plugins[plugin.id] = new Plugin(plugin); + }; + 'use strict'; + var reporters = {}; + var defaultReporter; + axe.getReporter = function(reporter) { + 'use strict'; + if (typeof reporter === 'string' && reporters[reporter]) { + return reporters[reporter]; + } + if (typeof reporter === 'function') { + return reporter; + } + return defaultReporter; + }; + axe.addReporter = function registerReporter(name, cb, isDefault) { + 'use strict'; + reporters[name] = cb; + if (isDefault) { + defaultReporter = cb; + } + }; + 'use strict'; + function resetConfiguration() { + 'use strict'; + var audit = axe._audit; + if (!audit) { + throw new Error('No audit configured'); + } + audit.resetRulesAndChecks(); + } + axe.reset = resetConfiguration; + 'use strict'; + function runRules(context, options, resolve, reject) { + 'use strict'; + try { + context = new Context(context); + } catch (e) { + return reject(e); + } + var q = axe.utils.queue(); + var audit = axe._audit; + if (options.performanceTimer) { + axe.utils.performanceTimer.auditStart(); + } + if (context.frames.length && options.iframes !== false) { + q.defer(function(res, rej) { + axe.utils.collectResultsFromFrames(context, options, 'rules', null, res, rej); + }); + } + q.defer(function(res, rej) { + audit.run(context, options, res, rej); + }); + q.then(function(data) { + try { + if (options.performanceTimer) { + axe.utils.performanceTimer.auditEnd(); + } + var results = axe.utils.mergeResults(data.map(function(d) { + return { + results: d + }; + })); + if (context.initiator) { + results = audit.after(results, options); + results.forEach(axe.utils.publishMetaData); + results = results.map(axe.utils.finalizeRuleResult); + } + try { + resolve(results); + } catch (e) { + axe.log(e); + } + } catch (e) { + reject(e); + } + }).catch(reject); + } + axe._runRules = runRules; + 'use strict'; + var _typeof = typeof Symbol === 'function' && typeof Symbol.iterator === 'symbol' ? function(obj) { + return typeof obj; + } : function(obj) { + return obj && typeof Symbol === 'function' && obj.constructor === Symbol && obj !== Symbol.prototype ? 'symbol' : typeof obj; + }; + function isContext(potential) { + 'use strict'; + switch (true) { + case typeof potential === 'string': + case Array.isArray(potential): + case Node && potential instanceof Node: + case NodeList && potential instanceof NodeList: + return true; + + case (typeof potential === 'undefined' ? 'undefined' : _typeof(potential)) !== 'object': + return false; + + case potential.include !== undefined: + case potential.exclude !== undefined: + case typeof potential.length === 'number': + return true; + + default: + return false; + } + } + var noop = function noop() {}; + function normalizeRunParams(context, options, callback) { + 'use strict'; + var typeErr = new TypeError('axe.run arguments are invalid'); + if (!isContext(context)) { + if (callback !== undefined) { + throw typeErr; + } + callback = options; + options = context; + context = document; + } + if ((typeof options === 'undefined' ? 'undefined' : _typeof(options)) !== 'object') { + if (callback !== undefined) { + throw typeErr; + } + callback = options; + options = {}; + } + if (typeof callback !== 'function' && callback !== undefined) { + throw typeErr; + } + return { + context: context, + options: options, + callback: callback || noop + }; + } + axe.run = function(context, options, callback) { + 'use strict'; + if (!axe._audit) { + throw new Error('No audit configured'); + } + var args = normalizeRunParams(context, options, callback); + context = args.context; + options = args.options; + callback = args.callback; + options.reporter = options.reporter || axe._audit.reporter || 'v1'; + if (options.performanceTimer) { + axe.utils.performanceTimer.start(); + } + var p = void 0; + var reject = noop; + var resolve = noop; + if (window.Promise && callback === noop) { + p = new Promise(function(_resolve, _reject) { + reject = _reject; + resolve = _resolve; + }); + } + axe._runRules(context, options, function(rawResults) { + var respond = function respond(results) { + try { + callback(null, results); + } catch (e) { + axe.log(e); + } + resolve(results); + }; + if (options.performanceTimer) { + axe.utils.performanceTimer.end(); + } + try { + var reporter = axe.getReporter(options.reporter); + var results = reporter(rawResults, options, respond); + if (results !== undefined) { + respond(results); + } + } catch (err) { + callback(err); + reject(err); + } + }, function(err) { + callback(err); + reject(err); + }); + return p; + }; + 'use strict'; + helpers.failureSummary = function failureSummary(nodeData) { + 'use strict'; + var failingChecks = {}; + failingChecks.none = nodeData.none.concat(nodeData.all); + failingChecks.any = nodeData.any; + return Object.keys(failingChecks).map(function(key) { + if (!failingChecks[key].length) { + return; + } + var sum = axe._audit.data.failureSummaries[key]; + if (sum && typeof sum.failureMessage === 'function') { + return sum.failureMessage(failingChecks[key].map(function(check) { + return check.message || ''; + })); + } + }).filter(function(i) { + return i !== undefined; + }).join('\n\n'); + }; + 'use strict'; + helpers.incompleteFallbackMessage = function incompleteFallbackMessage() { + 'use strict'; + return axe._audit.data.incompleteFallbackMessage(); + }; + 'use strict'; + var _typeof = typeof Symbol === 'function' && typeof Symbol.iterator === 'symbol' ? function(obj) { + return typeof obj; + } : function(obj) { + return obj && typeof Symbol === 'function' && obj.constructor === Symbol && obj !== Symbol.prototype ? 'symbol' : typeof obj; + }; + function normalizeRelatedNodes(node, options) { + 'use strict'; + [ 'any', 'all', 'none' ].forEach(function(type) { + if (!Array.isArray(node[type])) { + return; + } + node[type].filter(function(checkRes) { + return Array.isArray(checkRes.relatedNodes); + }).forEach(function(checkRes) { + checkRes.relatedNodes = checkRes.relatedNodes.map(function(relatedNode) { + var res = { + html: relatedNode.source + }; + if (options.elementRef && !relatedNode.fromFrame) { + res.element = relatedNode.element; + } + if (options.selectors !== false || relatedNode.fromFrame) { + res.target = relatedNode.selector; + } + if (options.xpath) { + res.xpath = relatedNode.xpath; + } + return res; + }); + }); + }); + } + var resultKeys = axe.constants.resultGroups; + helpers.processAggregate = function(results, options) { + var resultObject = axe.utils.aggregateResult(results); + resultObject.timestamp = new Date().toISOString(); + resultObject.url = window.location.href; + resultKeys.forEach(function(key) { + resultObject[key] = (resultObject[key] || []).map(function(ruleResult) { + ruleResult = Object.assign({}, ruleResult); + if (Array.isArray(ruleResult.nodes) && ruleResult.nodes.length > 0) { + ruleResult.nodes = ruleResult.nodes.map(function(subResult) { + if (_typeof(subResult.node) === 'object') { + subResult.html = subResult.node.source; + if (options.elementRef && !subResult.node.fromFrame) { + subResult.element = subResult.node.element; + } + if (options.selectors !== false || subResult.node.fromFrame) { + subResult.target = subResult.node.selector; + } + if (options.xpath) { + subResult.xpath = subResult.node.xpath; + } + } + delete subResult.result; + delete subResult.node; + normalizeRelatedNodes(subResult, options); + return subResult; + }); + } + resultKeys.forEach(function(key) { + return delete ruleResult[key]; + }); + delete ruleResult.pageLevel; + delete ruleResult.result; + return ruleResult; + }); + }); + return resultObject; + }; + 'use strict'; + axe.addReporter('na', function(results, options, callback) { + 'use strict'; + if (typeof options === 'function') { + callback = options; + options = {}; + } + var out = helpers.processAggregate(results, options); + callback({ + violations: out.violations, + passes: out.passes, + incomplete: out.incomplete, + inapplicable: out.inapplicable, + timestamp: out.timestamp, + url: out.url + }); + }); + 'use strict'; + axe.addReporter('no-passes', function(results, options, callback) { + 'use strict'; + if (typeof options === 'function') { + callback = options; + options = {}; + } + var out = helpers.processAggregate(results, options); + callback({ + violations: out.violations, + timestamp: out.timestamp, + url: out.url + }); + }); + 'use strict'; + axe.addReporter('raw', function(results, options, callback) { + 'use strict'; + if (typeof options === 'function') { + callback = options; + options = {}; + } + callback(results); + }); + 'use strict'; + axe.addReporter('v1', function(results, options, callback) { + 'use strict'; + if (typeof options === 'function') { + callback = options; + options = {}; + } + var out = helpers.processAggregate(results, options); + out.violations.forEach(function(result) { + return result.nodes.forEach(function(nodeResult) { + nodeResult.failureSummary = helpers.failureSummary(nodeResult); + }); + }); + callback({ + violations: out.violations, + passes: out.passes, + incomplete: out.incomplete, + inapplicable: out.inapplicable, + timestamp: out.timestamp, + url: out.url + }); + }); + 'use strict'; + axe.addReporter('v2', function(results, options, callback) { + 'use strict'; + if (typeof options === 'function') { + callback = options; + options = {}; + } + var out = helpers.processAggregate(results, options); + callback({ + violations: out.violations, + passes: out.passes, + incomplete: out.incomplete, + inapplicable: out.inapplicable, + timestamp: out.timestamp, + url: out.url + }); + }, true); + 'use strict'; + axe.utils.aggregate = function(map, values, initial) { + values = values.slice(); + if (initial) { + values.push(initial); + } + var sorting = values.map(function(val) { + return map.indexOf(val); + }).sort(); + return map[sorting.pop()]; + }; + 'use strict'; + var checkMap = []; + checkMap[axe.constants.PASS_PRIO] = true; + checkMap[axe.constants.CANTTELL_PRIO] = null; + checkMap[axe.constants.FAIL_PRIO] = false; + var checkTypes = [ 'any', 'all', 'none' ]; + function anyAllNone(obj, functor) { + return checkTypes.reduce(function(out, type) { + out[type] = (obj[type] || []).map(function(val) { + return functor(val, type); + }); + return out; + }, {}); + } + axe.utils.aggregateChecks = function(nodeResOriginal) { + var nodeResult = Object.assign({}, nodeResOriginal); + anyAllNone(nodeResult, function(check, type) { + var i = checkMap.indexOf(check.result); + check.priority = i !== -1 ? i : axe.constants.CANTTELL_PRIO; + if (type === 'none') { + check.priority = 4 - check.priority; + } + }); + var priorities = anyAllNone(nodeResult, function(c) { + return c.priority; + }); + nodeResult.priority = Math.max(priorities.all.reduce(function(a, b) { + return Math.max(a, b); + }, 0), priorities.none.reduce(function(a, b) { + return Math.max(a, b); + }, 0), priorities.any.reduce(function(a, b) { + return Math.min(a, b); + }, 4) % 4); + var impacts = []; + checkTypes.forEach(function(type) { + nodeResult[type] = nodeResult[type].filter(function(check) { + return check.priority === nodeResult.priority; + }); + nodeResult[type].forEach(function(check) { + return impacts.push(check.impact); + }); + }); + if (nodeResult.priority === axe.constants.FAIL_PRIO) { + nodeResult.impact = axe.utils.aggregate(axe.constants.impact, impacts); + } else { + nodeResult.impact = null; + } + anyAllNone(nodeResult, function(c) { + delete c.result; + delete c.priority; + }); + nodeResult.result = axe.constants.results[nodeResult.priority]; + delete nodeResult.priority; + return nodeResult; + }; + 'use strict'; + function copyToGroup(resultObject, subResult, group) { + var resultCopy = Object.assign({}, subResult); + resultCopy.nodes = (resultCopy[group] || []).concat(); + axe.constants.resultGroups.forEach(function(group) { + delete resultCopy[group]; + }); + resultObject[group].push(resultCopy); + } + axe.utils.aggregateResult = function(results) { + var resultObject = {}; + axe.constants.resultGroups.forEach(function(groupName) { + return resultObject[groupName] = []; + }); + results.forEach(function(subResult) { + if (subResult.error) { + copyToGroup(resultObject, subResult, axe.constants.CANTTELL_GROUP); + } else if (subResult.result === axe.constants.NA) { + copyToGroup(resultObject, subResult, axe.constants.NA_GROUP); + } else { + axe.constants.resultGroups.forEach(function(group) { + if (Array.isArray(subResult[group]) && subResult[group].length > 0) { + copyToGroup(resultObject, subResult, group); + } + }); + } + }); + return resultObject; + }; + 'use strict'; + (function() { + axe.utils.aggregateRule = function(subResults) { + var ruleResult = {}; + subResults = subResults.map(function(subResult) { + if (subResult.any && subResult.all && subResult.none) { + return axe.utils.aggregateChecks(subResult); + } else if (Array.isArray(subResult.node)) { + return axe.utils.finalizeRuleResult(subResult); + } else { + throw new TypeError('Invalid Result type'); + } + }); + var resultList = subResults.map(function(node) { + return node.result; + }); + ruleResult.result = axe.utils.aggregate(axe.constants.results, resultList, ruleResult.result); + axe.constants.resultGroups.forEach(function(group) { + return ruleResult[group] = []; + }); + subResults.forEach(function(subResult) { + var groupName = axe.constants.resultGroupMap[subResult.result]; + ruleResult[groupName].push(subResult); + }); + var failGroup = axe.constants.FAIL_GROUP; + if (ruleResult[failGroup].length > 0) { + var impactList = ruleResult[failGroup].map(function(failure) { + return failure.impact; + }); + ruleResult.impact = axe.utils.aggregate(axe.constants.impact, impactList) || null; + } else { + ruleResult.impact = null; + } + return ruleResult; + }; + })(); + 'use strict'; + function areStylesSet(el, styles, stopAt) { + 'use strict'; + var styl = window.getComputedStyle(el, null); + var set = false; + if (!styl) { + return false; + } + styles.forEach(function(att) { + if (styl.getPropertyValue(att.property) === att.value) { + set = true; + } + }); + if (set) { + return true; + } + if (el.nodeName.toUpperCase() === stopAt.toUpperCase() || !el.parentNode) { + return false; + } + return areStylesSet(el.parentNode, styles, stopAt); + } + axe.utils.areStylesSet = areStylesSet; + 'use strict'; + axe.utils.checkHelper = function checkHelper(checkResult, options, resolve, reject) { + 'use strict'; + return { + isAsync: false, + async: function async() { + this.isAsync = true; + return function(result) { + if (result instanceof Error === false) { + checkResult.value = result; + resolve(checkResult); + } else { + reject(result); + } + }; + }, + data: function data(_data) { + checkResult.data = _data; + }, + relatedNodes: function relatedNodes(nodes) { + nodes = nodes instanceof Node ? [ nodes ] : axe.utils.toArray(nodes); + checkResult.relatedNodes = nodes.map(function(element) { + return new axe.utils.DqElement(element, options); + }); + } + }; + }; + 'use strict'; + var _typeof = typeof Symbol === 'function' && typeof Symbol.iterator === 'symbol' ? function(obj) { + return typeof obj; + } : function(obj) { + return obj && typeof Symbol === 'function' && obj.constructor === Symbol && obj !== Symbol.prototype ? 'symbol' : typeof obj; + }; + axe.utils.clone = function(obj) { + 'use strict'; + var index, length, out = obj; + if (obj !== null && (typeof obj === 'undefined' ? 'undefined' : _typeof(obj)) === 'object') { + if (Array.isArray(obj)) { + out = []; + for (index = 0, length = obj.length; index < length; index++) { + out[index] = axe.utils.clone(obj[index]); + } + } else { + out = {}; + for (index in obj) { + out[index] = axe.utils.clone(obj[index]); + } + } + } + return out; + }; + 'use strict'; + function err(message, node) { + 'use strict'; + return new Error(message + ': ' + axe.utils.getSelector(node)); + } + axe.utils.sendCommandToFrame = function(node, parameters, resolve, reject) { + 'use strict'; + var win = node.contentWindow; + if (!win) { + axe.log('Frame does not have a content window', node); + resolve(null); + return; + } + var timeout = setTimeout(function() { + timeout = setTimeout(function() { + var errMsg = err('No response from frame', node); + if (!parameters.debug) { + axe.log(errMsg); + resolve(null); + } else { + reject(errMsg); + } + }, 0); + }, 500); + axe.utils.respondable(win, 'axe.ping', null, undefined, function() { + clearTimeout(timeout); + timeout = setTimeout(function() { + reject(err('Axe in frame timed out', node)); + }, 3e4); + axe.utils.respondable(win, 'axe.start', parameters, undefined, function(data) { + clearTimeout(timeout); + if (data instanceof Error === false) { + resolve(data); + } else { + reject(data); + } + }); + }); + }; + function collectResultsFromFrames(context, options, command, parameter, resolve, reject) { + 'use strict'; + var q = axe.utils.queue(); + var frames = context.frames; + frames.forEach(function(frame) { + var params = { + options: options, + command: command, + parameter: parameter, + context: { + initiator: false, + page: context.page, + include: frame.include || [], + exclude: frame.exclude || [] + } + }; + q.defer(function(res, rej) { + var node = frame.node; + axe.utils.sendCommandToFrame(node, params, function(data) { + if (data) { + return res({ + results: data, + frameElement: node, + frame: axe.utils.getSelector(node) + }); + } + res(null); + }, rej); + }); + }); + q.then(function(data) { + resolve(axe.utils.mergeResults(data, options)); + }).catch(reject); + } + axe.utils.collectResultsFromFrames = collectResultsFromFrames; + 'use strict'; + axe.utils.contains = function(node, otherNode) { + 'use strict'; + function containsShadowChild(node, otherNode) { + if (node.shadowId === otherNode.shadowId) { + return true; + } + return !!node.children.find(function(child) { + return containsShadowChild(child, otherNode); + }); + } + if (node.shadowId || otherNode.shadowId) { + return containsShadowChild(node, otherNode); + } + if (typeof node.actualNode.contains === 'function') { + return node.actualNode.contains(otherNode.actualNode); + } + return !!(node.actualNode.compareDocumentPosition(otherNode.actualNode) & 16); + }; + 'use strict'; + (function(axe) { + /*! + * The copyright below covers the code within this function block only + * + * Copyright (c) 2013 Dulin Marat + * + * Permission is hereby granted, free of charge, to any person obtaining a copy + * of this software and associated documentation files (the "Software"), to deal + * in the Software without restriction, including without limitation the rights + * to use, copy, modify, merge, publish, distribute, sublicense, and/or sell + * copies of the Software, and to permit persons to whom the Software is + * furnished to do so, subject to the following conditions: + * + * The above copyright notice and this permission notice shall be included in + * all copies or substantial portions of the Software. + * + * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR + * IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, + * FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE + * AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER + * LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, + * OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN + * THE SOFTWARE. + */ + function CssSelectorParser() { + this.pseudos = {}; + this.attrEqualityMods = {}; + this.ruleNestingOperators = {}; + this.substitutesEnabled = false; + } + CssSelectorParser.prototype.registerSelectorPseudos = function(name) { + for (var j = 0, len = arguments.length; j < len; j++) { + name = arguments[j]; + this.pseudos[name] = 'selector'; + } + return this; + }; + CssSelectorParser.prototype.unregisterSelectorPseudos = function(name) { + for (var j = 0, len = arguments.length; j < len; j++) { + name = arguments[j]; + delete this.pseudos[name]; + } + return this; + }; + CssSelectorParser.prototype.registerNumericPseudos = function(name) { + for (var j = 0, len = arguments.length; j < len; j++) { + name = arguments[j]; + this.pseudos[name] = 'numeric'; + } + return this; + }; + CssSelectorParser.prototype.unregisterNumericPseudos = function(name) { + for (var j = 0, len = arguments.length; j < len; j++) { + name = arguments[j]; + delete this.pseudos[name]; + } + return this; + }; + CssSelectorParser.prototype.registerNestingOperators = function(operator) { + for (var j = 0, len = arguments.length; j < len; j++) { + operator = arguments[j]; + this.ruleNestingOperators[operator] = true; + } + return this; + }; + CssSelectorParser.prototype.unregisterNestingOperators = function(operator) { + for (var j = 0, len = arguments.length; j < len; j++) { + operator = arguments[j]; + delete this.ruleNestingOperators[operator]; + } + return this; + }; + CssSelectorParser.prototype.registerAttrEqualityMods = function(mod) { + for (var j = 0, len = arguments.length; j < len; j++) { + mod = arguments[j]; + this.attrEqualityMods[mod] = true; + } + return this; + }; + CssSelectorParser.prototype.unregisterAttrEqualityMods = function(mod) { + for (var j = 0, len = arguments.length; j < len; j++) { + mod = arguments[j]; + delete this.attrEqualityMods[mod]; + } + return this; + }; + CssSelectorParser.prototype.enableSubstitutes = function() { + this.substitutesEnabled = true; + return this; + }; + CssSelectorParser.prototype.disableSubstitutes = function() { + this.substitutesEnabled = false; + return this; + }; + function isIdentStart(c) { + return c >= 'a' && c <= 'z' || c >= 'A' && c <= 'Z' || c === '-' || c === '_'; + } + function isIdent(c) { + return c >= 'a' && c <= 'z' || c >= 'A' && c <= 'Z' || c >= '0' && c <= '9' || c === '-' || c === '_'; + } + function isHex(c) { + return c >= 'a' && c <= 'f' || c >= 'A' && c <= 'F' || c >= '0' && c <= '9'; + } + function isDecimal(c) { + return c >= '0' && c <= '9'; + } + function isAttrMatchOperator(chr) { + return chr === '=' || chr === '^' || chr === '$' || chr === '*' || chr === '~'; + } + var identSpecialChars = { + '!': true, + '"': true, + '#': true, + $: true, + '%': true, + '&': true, + '\'': true, + '(': true, + ')': true, + '*': true, + '+': true, + ',': true, + '.': true, + '/': true, + ';': true, + '<': true, + '=': true, + '>': true, + '?': true, + '@': true, + '[': true, + '\\': true, + ']': true, + '^': true, + '`': true, + '{': true, + '|': true, + '}': true, + '~': true + }; + var strReplacementsRev = { + '\n': '\\n', + '\r': '\\r', + '\t': '\\t', + '\f': '\\f', + '\v': '\\v' + }; + var singleQuoteEscapeChars = { + n: '\n', + r: '\r', + t: '\t', + f: '\f', + '\\': '\\', + '\'': '\'' + }; + var doubleQuotesEscapeChars = { + n: '\n', + r: '\r', + t: '\t', + f: '\f', + '\\': '\\', + '"': '"' + }; + function ParseContext(str, pos, pseudos, attrEqualityMods, ruleNestingOperators, substitutesEnabled) { + var chr, getIdent, getStr, l, skipWhitespace; + l = str.length; + chr = null; + getStr = function getStr(quote, escapeTable) { + var esc, hex, result; + result = ''; + pos++; + chr = str.charAt(pos); + while (pos < l) { + if (chr === quote) { + pos++; + return result; + } else if (chr === '\\') { + pos++; + chr = str.charAt(pos); + if (chr === quote) { + result += quote; + } else if (esc = escapeTable[chr]) { + result += esc; + } else if (isHex(chr)) { + hex = chr; + pos++; + chr = str.charAt(pos); + while (isHex(chr)) { + hex += chr; + pos++; + chr = str.charAt(pos); + } + if (chr === ' ') { + pos++; + chr = str.charAt(pos); + } + result += String.fromCharCode(parseInt(hex, 16)); + continue; + } else { + result += chr; + } + } else { + result += chr; + } + pos++; + chr = str.charAt(pos); + } + return result; + }; + getIdent = function getIdent() { + var result = ''; + chr = str.charAt(pos); + while (pos < l) { + if (isIdent(chr)) { + result += chr; + } else if (chr === '\\') { + pos++; + if (pos >= l) { + throw Error('Expected symbol but end of file reached.'); + } + chr = str.charAt(pos); + if (identSpecialChars[chr]) { + result += chr; + } else if (isHex(chr)) { + var hex = chr; + pos++; + chr = str.charAt(pos); + while (isHex(chr)) { + hex += chr; + pos++; + chr = str.charAt(pos); + } + if (chr === ' ') { + pos++; + chr = str.charAt(pos); + } + result += String.fromCharCode(parseInt(hex, 16)); + continue; + } else { + result += chr; + } + } else { + return result; + } + pos++; + chr = str.charAt(pos); + } + return result; + }; + skipWhitespace = function skipWhitespace() { + chr = str.charAt(pos); + var result = false; + while (chr === ' ' || chr === '\t' || chr === '\n' || chr === '\r' || chr === '\f') { + result = true; + pos++; + chr = str.charAt(pos); + } + return result; + }; + this.parse = function() { + var res = this.parseSelector(); + if (pos < l) { + throw Error('Rule expected but "' + str.charAt(pos) + '" found.'); + } + return res; + }; + this.parseSelector = function() { + var res; + var selector = res = this.parseSingleSelector(); + chr = str.charAt(pos); + while (chr === ',') { + pos++; + skipWhitespace(); + if (res.type !== 'selectors') { + res = { + type: 'selectors', + selectors: [ selector ] + }; + } + selector = this.parseSingleSelector(); + if (!selector) { + throw Error('Rule expected after ",".'); + } + res.selectors.push(selector); + } + return res; + }; + this.parseSingleSelector = function() { + skipWhitespace(); + var selector = { + type: 'ruleSet' + }; + var rule = this.parseRule(); + if (!rule) { + return null; + } + var currentRule = selector; + while (rule) { + rule.type = 'rule'; + currentRule.rule = rule; + currentRule = rule; + skipWhitespace(); + chr = str.charAt(pos); + if (pos >= l || chr === ',' || chr === ')') { + break; + } + if (ruleNestingOperators[chr]) { + var op = chr; + pos++; + skipWhitespace(); + rule = this.parseRule(); + if (!rule) { + throw Error('Rule expected after "' + op + '".'); + } + rule.nestingOperator = op; + } else { + rule = this.parseRule(); + if (rule) { + rule.nestingOperator = null; + } + } + } + return selector; + }; + this.parseRule = function() { + var rule = null; + while (pos < l) { + chr = str.charAt(pos); + if (chr === '*') { + pos++; + (rule = rule || {}).tagName = '*'; + } else if (isIdentStart(chr) || chr === '\\') { + (rule = rule || {}).tagName = getIdent(); + } else if (chr === '.') { + pos++; + rule = rule || {}; + (rule.classNames = rule.classNames || []).push(getIdent()); + } else if (chr === '#') { + pos++; + (rule = rule || {}).id = getIdent(); + } else if (chr === '[') { + pos++; + skipWhitespace(); + var attr = { + name: getIdent() + }; + skipWhitespace(); + if (chr === ']') { + pos++; + } else { + var operator = ''; + if (attrEqualityMods[chr]) { + operator = chr; + pos++; + chr = str.charAt(pos); + } + if (pos >= l) { + throw Error('Expected "=" but end of file reached.'); + } + if (chr !== '=') { + throw Error('Expected "=" but "' + chr + '" found.'); + } + attr.operator = operator + '='; + pos++; + skipWhitespace(); + var attrValue = ''; + attr.valueType = 'string'; + if (chr === '"') { + attrValue = getStr('"', doubleQuotesEscapeChars); + } else if (chr === '\'') { + attrValue = getStr('\'', singleQuoteEscapeChars); + } else if (substitutesEnabled && chr === '$') { + pos++; + attrValue = getIdent(); + attr.valueType = 'substitute'; + } else { + while (pos < l) { + if (chr === ']') { + break; + } + attrValue += chr; + pos++; + chr = str.charAt(pos); + } + attrValue = attrValue.trim(); + } + skipWhitespace(); + if (pos >= l) { + throw Error('Expected "]" but end of file reached.'); + } + if (chr !== ']') { + throw Error('Expected "]" but "' + chr + '" found.'); + } + pos++; + attr.value = attrValue; + } + rule = rule || {}; + (rule.attrs = rule.attrs || []).push(attr); + } else if (chr === ':') { + pos++; + var pseudoName = getIdent(); + var pseudo = { + name: pseudoName + }; + if (chr === '(') { + pos++; + var value = ''; + skipWhitespace(); + if (pseudos[pseudoName] === 'selector') { + pseudo.valueType = 'selector'; + value = this.parseSelector(); + } else { + pseudo.valueType = pseudos[pseudoName] || 'string'; + if (chr === '"') { + value = getStr('"', doubleQuotesEscapeChars); + } else if (chr === '\'') { + value = getStr('\'', singleQuoteEscapeChars); + } else if (substitutesEnabled && chr === '$') { + pos++; + value = getIdent(); + pseudo.valueType = 'substitute'; + } else { + while (pos < l) { + if (chr === ')') { + break; + } + value += chr; + pos++; + chr = str.charAt(pos); + } + value = value.trim(); + } + skipWhitespace(); + } + if (pos >= l) { + throw Error('Expected ")" but end of file reached.'); + } + if (chr !== ')') { + throw Error('Expected ")" but "' + chr + '" found.'); + } + pos++; + pseudo.value = value; + } + rule = rule || {}; + (rule.pseudos = rule.pseudos || []).push(pseudo); + } else { + break; + } + } + return rule; + }; + return this; + } + CssSelectorParser.prototype.parse = function(str) { + var context = new ParseContext(str, 0, this.pseudos, this.attrEqualityMods, this.ruleNestingOperators, this.substitutesEnabled); + return context.parse(); + }; + CssSelectorParser.prototype.escapeIdentifier = function(s) { + var result = ''; + var i = 0; + var len = s.length; + while (i < len) { + var chr = s.charAt(i); + if (identSpecialChars[chr]) { + result += '\\' + chr; + } else { + if (!(chr === '_' || chr === '-' || chr >= 'A' && chr <= 'Z' || chr >= 'a' && chr <= 'z' || i !== 0 && chr >= '0' && chr <= '9')) { + var charCode = chr.charCodeAt(0); + if ((charCode & 63488) === 55296) { + var extraCharCode = s.charCodeAt(i++); + if ((charCode & 64512) !== 55296 || (extraCharCode & 64512) !== 56320) { + throw Error('UCS-2(decode): illegal sequence'); + } + charCode = ((charCode & 1023) << 10) + (extraCharCode & 1023) + 65536; + } + result += '\\' + charCode.toString(16) + ' '; + } else { + result += chr; + } + } + i++; + } + return result; + }; + CssSelectorParser.prototype.escapeStr = function(s) { + var result = ''; + var i = 0; + var len = s.length; + var chr, replacement; + while (i < len) { + chr = s.charAt(i); + if (chr === '"') { + chr = '\\"'; + } else if (chr === '\\') { + chr = '\\\\'; + } else if (replacement = strReplacementsRev[chr]) { + chr = replacement; + } + result += chr; + i++; + } + return '"' + result + '"'; + }; + CssSelectorParser.prototype.render = function(path) { + return this._renderEntity(path).trim(); + }; + CssSelectorParser.prototype._renderEntity = function(entity) { + var currentEntity, parts, res; + res = ''; + switch (entity.type) { + case 'ruleSet': + currentEntity = entity.rule; + parts = []; + while (currentEntity) { + if (currentEntity.nestingOperator) { + parts.push(currentEntity.nestingOperator); + } + parts.push(this._renderEntity(currentEntity)); + currentEntity = currentEntity.rule; + } + res = parts.join(' '); + break; + + case 'selectors': + res = entity.selectors.map(this._renderEntity, this).join(', '); + break; + + case 'rule': + if (entity.tagName) { + if (entity.tagName === '*') { + res = '*'; + } else { + res = this.escapeIdentifier(entity.tagName); + } + } + if (entity.id) { + res += '#' + this.escapeIdentifier(entity.id); + } + if (entity.classNames) { + res += entity.classNames.map(function(cn) { + return '.' + this.escapeIdentifier(cn); + }, this).join(''); + } + if (entity.attrs) { + res += entity.attrs.map(function(attr) { + if (attr.operator) { + if (attr.valueType === 'substitute') { + return '[' + this.escapeIdentifier(attr.name) + attr.operator + '$' + attr.value + ']'; + } else { + return '[' + this.escapeIdentifier(attr.name) + attr.operator + this.escapeStr(attr.value) + ']'; + } + } else { + return '[' + this.escapeIdentifier(attr.name) + ']'; + } + }, this).join(''); + } + if (entity.pseudos) { + res += entity.pseudos.map(function(pseudo) { + if (pseudo.valueType) { + if (pseudo.valueType === 'selector') { + return ':' + this.escapeIdentifier(pseudo.name) + '(' + this._renderEntity(pseudo.value) + ')'; + } else if (pseudo.valueType === 'substitute') { + return ':' + this.escapeIdentifier(pseudo.name) + '($' + pseudo.value + ')'; + } else if (pseudo.valueType === 'numeric') { + return ':' + this.escapeIdentifier(pseudo.name) + '(' + pseudo.value + ')'; + } else { + return ':' + this.escapeIdentifier(pseudo.name) + '(' + this.escapeIdentifier(pseudo.value) + ')'; + } + } else { + return ':' + this.escapeIdentifier(pseudo.name); + } + }, this).join(''); + } + break; + + default: + throw Error('Unknown entity type: "' + entity.type(+'".')); + } + return res; + }; + var parser = new CssSelectorParser(); + parser.registerNestingOperators('>'); + axe.utils.cssParser = parser; + })(axe); + 'use strict'; + function truncate(str, maxLength) { + maxLength = maxLength || 300; + if (str.length > maxLength) { + var index = str.indexOf('>'); + str = str.substring(0, index + 1); + } + return str; + } + function getSource(element) { + var source = element.outerHTML; + if (!source && typeof XMLSerializer === 'function') { + source = new XMLSerializer().serializeToString(element); + } + return truncate(source || ''); + } + function DqElement(element, options, spec) { + this._fromFrame = !!spec; + this.spec = spec || {}; + if (options && options.absolutePaths) { + this._options = { + toRoot: true + }; + } + this.source = this.spec.source !== undefined ? this.spec.source : getSource(element); + this._element = element; + } + DqElement.prototype = { + get selector() { + return this.spec.selector || [ axe.utils.getSelector(this.element, this._options) ]; + }, + get xpath() { + return this.spec.xpath || [ axe.utils.getXpath(this.element) ]; + }, + get element() { + return this._element; + }, + get fromFrame() { + return this._fromFrame; + }, + toJSON: function toJSON() { + 'use strict'; + return { + selector: this.selector, + source: this.source, + xpath: this.xpath + }; + } + }; + DqElement.fromFrame = function(node, options, frame) { + node.selector.unshift(frame.selector); + node.xpath.unshift(frame.xpath); + return new axe.utils.DqElement(frame.element, options, node); + }; + axe.utils.DqElement = DqElement; + 'use strict'; + axe.utils.matchesSelector = function() { + 'use strict'; + var method; + function getMethod(win) { + var index, candidate, elProto = win.Element.prototype, candidates = [ 'matches', 'matchesSelector', 'mozMatchesSelector', 'webkitMatchesSelector', 'msMatchesSelector' ], length = candidates.length; + for (index = 0; index < length; index++) { + candidate = candidates[index]; + if (elProto[candidate]) { + return candidate; + } + } + } + return function(node, selector) { + if (!method || !node[method]) { + method = getMethod(node.ownerDocument.defaultView); + } + return node[method](selector); + }; + }(); + 'use strict'; + axe.utils.escapeSelector = function(value) { + 'use strict'; + var string = String(value); + var length = string.length; + var index = -1; + var codeUnit; + var result = ''; + var firstCodeUnit = string.charCodeAt(0); + while (++index < length) { + codeUnit = string.charCodeAt(index); + if (codeUnit == 0) { + throw new Error('INVALID_CHARACTER_ERR'); + } + if (codeUnit >= 1 && codeUnit <= 31 || codeUnit >= 127 && codeUnit <= 159 || index == 0 && codeUnit >= 48 && codeUnit <= 57 || index == 1 && codeUnit >= 48 && codeUnit <= 57 && firstCodeUnit == 45) { + result += '\\' + codeUnit.toString(16) + ' '; + continue; + } + if (index == 1 && codeUnit == 45 && firstCodeUnit == 45) { + result += '\\' + string.charAt(index); + continue; + } + if (codeUnit >= 128 || codeUnit == 45 || codeUnit == 95 || codeUnit >= 48 && codeUnit <= 57 || codeUnit >= 65 && codeUnit <= 90 || codeUnit >= 97 && codeUnit <= 122) { + result += string.charAt(index); + continue; + } + result += '\\' + string.charAt(index); + } + return result; + }; + 'use strict'; + axe.utils.extendMetaData = function(to, from) { + Object.assign(to, from); + Object.keys(from).filter(function(prop) { + return typeof from[prop] === 'function'; + }).forEach(function(prop) { + to[prop] = null; + try { + to[prop] = from[prop](to); + } catch (e) {} + }); + }; + 'use strict'; + axe.utils.finalizeRuleResult = function(ruleResult) { + Object.assign(ruleResult, axe.utils.aggregateRule(ruleResult.nodes)); + delete ruleResult.nodes; + return ruleResult; + }; + 'use strict'; + var _typeof = typeof Symbol === 'function' && typeof Symbol.iterator === 'symbol' ? function(obj) { + return typeof obj; + } : function(obj) { + return obj && typeof Symbol === 'function' && obj.constructor === Symbol && obj !== Symbol.prototype ? 'symbol' : typeof obj; + }; + axe.utils.findBy = function(array, key, value) { + if (Array.isArray(array)) { + return array.find(function(obj) { + return (typeof obj === 'undefined' ? 'undefined' : _typeof(obj)) === 'object' && obj[key] === value; + }); + } + }; + 'use strict'; + var axe = axe || { + utils: {} + }; + function virtualDOMfromNode(node, shadowId) { + return { + shadowId: shadowId, + children: [], + actualNode: node + }; + } + function getSlotChildren(node) { + var retVal = []; + node = node.firstChild; + while (node) { + retVal.push(node); + node = node.nextSibling; + } + return retVal; + } + axe.utils.getFlattenedTree = function(node, shadowId) { + var retVal, realArray, nodeName; + function reduceShadowDOM(res, child) { + var replacements = axe.utils.getFlattenedTree(child, shadowId); + if (replacements) { + res = res.concat(replacements); + } + return res; + } + if (node.documentElement) { + node = node.documentElement; + } + nodeName = node.nodeName.toLowerCase(); + if (node.shadowRoot && nodeName !== 'marquee') { + shadowId = 'a' + Math.random().toString().substring(2); + realArray = Array.from(node.shadowRoot.childNodes); + return realArray.reduce(reduceShadowDOM, []); + } else { + if (nodeName === 'content') { + realArray = Array.from(node.getDistributedNodes()); + return realArray.reduce(reduceShadowDOM, []); + } else if (nodeName === 'slot') { + realArray = Array.from(node.assignedNodes()); + if (!realArray.length) { + realArray = getSlotChildren(node); + } + var styl = window.getComputedStyle(node); + if (false && styl.display !== 'contents') { + retVal = virtualDOMfromNode(node, shadowId); + retVal.children = realArray.reduce(reduceShadowDOM, []); + return [ retVal ]; + } else { + return realArray.reduce(reduceShadowDOM, []); + } + } else { + if (node.nodeType === 1) { + retVal = virtualDOMfromNode(node, shadowId); + realArray = Array.from(node.childNodes); + retVal.children = realArray.reduce(reduceShadowDOM, []); + return [ retVal ]; + } else if (node.nodeType === 3) { + return [ virtualDOMfromNode(node) ]; + } + return undefined; + } + } + }; + axe.utils.getNodeFromTree = function(vNode, node) { + var found; + vNode.children.forEach(function(candidate) { + var retVal; + if (candidate.actualNode === node) { + found = candidate; + } else { + retVal = axe.utils.getNodeFromTree(candidate, node); + if (retVal) { + found = retVal; + } + } + }); + return found; + }; + 'use strict'; + axe.utils.getAllChecks = function getAllChecks(object) { + 'use strict'; + var result = []; + return result.concat(object.any || []).concat(object.all || []).concat(object.none || []); + }; + 'use strict'; + axe.utils.getCheckOption = function(check, ruleID, options) { + var ruleCheckOption = ((options.rules && options.rules[ruleID] || {}).checks || {})[check.id]; + var checkOption = (options.checks || {})[check.id]; + var enabled = check.enabled; + var opts = check.options; + if (checkOption) { + if (checkOption.hasOwnProperty('enabled')) { + enabled = checkOption.enabled; + } + if (checkOption.hasOwnProperty('options')) { + opts = checkOption.options; + } + } + if (ruleCheckOption) { + if (ruleCheckOption.hasOwnProperty('enabled')) { + enabled = ruleCheckOption.enabled; + } + if (ruleCheckOption.hasOwnProperty('options')) { + opts = ruleCheckOption.options; + } + } + return { + enabled: enabled, + options: opts, + absolutePaths: options.absolutePaths + }; + }; + 'use strict'; + var _slicedToArray = function() { + function sliceIterator(arr, i) { + var _arr = []; + var _n = true; + var _d = false; + var _e = undefined; + try { + for (var _i = arr[Symbol.iterator](), _s; !(_n = (_s = _i.next()).done); _n = true) { + _arr.push(_s.value); + if (i && _arr.length === i) { + break; + } + } + } catch (err) { + _d = true; + _e = err; + } finally { + try { + if (!_n && _i['return']) { + _i['return'](); + } + } finally { + if (_d) { + throw _e; + } + } + } + return _arr; + } + return function(arr, i) { + if (Array.isArray(arr)) { + return arr; + } else if (Symbol.iterator in Object(arr)) { + return sliceIterator(arr, i); + } else { + throw new TypeError('Invalid attempt to destructure non-iterable instance'); + } + }; + }(); + function isMostlyNumbers() { + var str = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : ''; + return str.length !== 0 && (str.match(/[0-9]/g) || '').length >= str.length / 2; + } + function splitString(str, splitIndex) { + return [ str.substring(0, splitIndex), str.substring(splitIndex) ]; + } + function uriParser(url) { + var original = url; + var protocol = '', domain = '', port = '', path = '', query = '', hash = ''; + if (url.includes('#')) { + var _splitString = splitString(url, url.indexOf('#')); + var _splitString2 = _slicedToArray(_splitString, 2); + url = _splitString2[0]; + hash = _splitString2[1]; + } + if (url.includes('?')) { + var _splitString3 = splitString(url, url.indexOf('?')); + var _splitString4 = _slicedToArray(_splitString3, 2); + url = _splitString4[0]; + query = _splitString4[1]; + } + if (url.includes('://')) { + var _url$split = url.split('://'); + var _url$split2 = _slicedToArray(_url$split, 2); + protocol = _url$split2[0]; + url = _url$split2[1]; + var _splitString5 = splitString(url, url.indexOf('/')); + var _splitString6 = _slicedToArray(_splitString5, 2); + domain = _splitString6[0]; + url = _splitString6[1]; + } else if (url.substr(0, 2) === '//') { + url = url.substr(2); + var _splitString7 = splitString(url, url.indexOf('/')); + var _splitString8 = _slicedToArray(_splitString7, 2); + domain = _splitString8[0]; + url = _splitString8[1]; + } + if (domain.substr(0, 4) === 'www.') { + domain = domain.substr(4); + } + if (domain && domain.includes(':')) { + var _splitString9 = splitString(domain, domain.indexOf(':')); + var _splitString10 = _slicedToArray(_splitString9, 2); + domain = _splitString10[0]; + port = _splitString10[1]; + } + path = url; + return { + original: original, + protocol: protocol, + domain: domain, + port: port, + path: path, + query: query, + hash: hash + }; + } + axe.utils.getFriendlyUriEnd = function getFriendlyUriEnd() { + var uri = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : ''; + var options = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : {}; + if (uri.length <= 1 || uri.substr(0, 5) === 'data:' || uri.substr(0, 11) === 'javascript:' || uri.includes('?')) { + return; + } + var currentDomain = options.currentDomain, _options$maxLength = options.maxLength, maxLength = _options$maxLength === undefined ? 25 : _options$maxLength; + var _uriParser = uriParser(uri), path = _uriParser.path, domain = _uriParser.domain, hash = _uriParser.hash; + var pathEnd = path.substr(path.substr(0, path.length - 2).lastIndexOf('/') + 1); + if (hash) { + if (pathEnd && (pathEnd + hash).length <= maxLength) { + return pathEnd + hash; + } else if (pathEnd.length < 2 && hash.length > 2 && hash.length <= maxLength) { + return hash; + } else { + return; + } + } else if (domain && domain.length < maxLength && path.length <= 1) { + return domain + path; + } + if (path === '/' + pathEnd && domain && currentDomain && domain !== currentDomain && (domain + path).length <= maxLength) { + return domain + path; + } + var lastDotIndex = pathEnd.lastIndexOf('.'); + if ((lastDotIndex === -1 || lastDotIndex > 1) && (lastDotIndex !== -1 || pathEnd.length > 2) && pathEnd.length <= maxLength && !pathEnd.match(/index(\.[a-zA-Z]{2-4})?/) && !isMostlyNumbers(pathEnd)) { + return pathEnd; + } + }; + 'use strict'; + function _toConsumableArray(arr) { + if (Array.isArray(arr)) { + for (var i = 0, arr2 = Array(arr.length); i < arr.length; i++) { + arr2[i] = arr[i]; + } + return arr2; + } else { + return Array.from(arr); + } + } + var escapeSelector = axe.utils.escapeSelector; + function isUncommonClassName(className) { + return ![ 'focus', 'hover', 'hidden', 'visible', 'dirty', 'touched', 'valid', 'disable', 'enable', 'active', 'col-' ].find(function(str) { + return className.includes(str); + }); + } + function getDistinctClassList(elm) { + if (!elm.classList || elm.classList.length === 0) { + return []; + } + var siblings = elm.parentNode && Array.from(elm.parentNode.children || '') || []; + return siblings.reduce(function(classList, childElm) { + if (elm === childElm) { + return classList; + } else { + return classList.filter(function(classItem) { + return !childElm.classList.contains(classItem); + }); + } + }, Array.from(elm.classList).filter(isUncommonClassName)); + } + var commonNodes = [ 'div', 'span', 'p', 'b', 'i', 'u', 'strong', 'em', 'h2', 'h3' ]; + function getNthChildString(elm, selector) { + var siblings = elm.parentNode && Array.from(elm.parentNode.children || '') || []; + var hasMatchingSiblings = siblings.find(function(sibling) { + return sibling !== elm && axe.utils.matchesSelector(sibling, selector); + }); + if (hasMatchingSiblings) { + var nthChild = 1 + siblings.indexOf(elm); + return ':nth-child(' + nthChild + ')'; + } else { + return ''; + } + } + var createSelector = { + getElmId: function getElmId(elm) { + if (!elm.id) { + return; + } + var doc = elm.getRootNode && elm.getRootNode() || document; + var id = '#' + escapeSelector(elm.id || ''); + if (!id.match(/player_uid_/) && doc.querySelectorAll(id).length === 1) { + return id; + } + }, + getCustomElm: function getCustomElm(elm, _ref) { + var isCustomElm = _ref.isCustomElm, nodeName = _ref.nodeName; + if (isCustomElm) { + return nodeName; + } + }, + getElmRoleProp: function getElmRoleProp(elm) { + if (elm.hasAttribute('role')) { + return '[role="' + escapeSelector(elm.getAttribute('role')) + '"]'; + } + }, + getUncommonElm: function getUncommonElm(elm, _ref2) { + var isCommonElm = _ref2.isCommonElm, isCustomElm = _ref2.isCustomElm, nodeName = _ref2.nodeName; + if (!isCommonElm && !isCustomElm) { + nodeName = escapeSelector(nodeName); + if (nodeName === 'input' && elm.hasAttribute('type')) { + nodeName += '[type="' + elm.type + '"]'; + } + return nodeName; + } + }, + getElmNameProp: function getElmNameProp(elm) { + if (!elm.id && elm.name) { + return '[name="' + escapeSelector(elm.name) + '"]'; + } + }, + getDistinctClass: function getDistinctClass(elm, _ref3) { + var distinctClassList = _ref3.distinctClassList; + if (distinctClassList.length > 0 && distinctClassList.length < 3) { + return '.' + distinctClassList.map(escapeSelector).join('.'); + } + }, + getFileRefProp: function getFileRefProp(elm) { + var attr = void 0; + if (elm.hasAttribute('href')) { + attr = 'href'; + } else if (elm.hasAttribute('src')) { + attr = 'src'; + } else { + return; + } + var friendlyUriEnd = axe.utils.getFriendlyUriEnd(elm.getAttribute(attr)); + if (friendlyUriEnd) { + return '[' + attr + '$="' + encodeURI(friendlyUriEnd) + '"]'; + } + }, + getCommonName: function getCommonName(elm, _ref4) { + var nodeName = _ref4.nodeName, isCommonElm = _ref4.isCommonElm; + if (isCommonElm) { + return nodeName; + } + } + }; + function getElmFeatures(elm, featureCount) { + var nodeName = elm.nodeName.toLowerCase(); + var classList = Array.from(elm.classList) || []; + var props = { + nodeName: nodeName, + classList: classList, + isCustomElm: nodeName.includes('-'), + isCommonElm: commonNodes.includes(nodeName), + distinctClassList: getDistinctClassList(elm) + }; + return [ createSelector.getCustomElm, createSelector.getElmRoleProp, createSelector.getUncommonElm, createSelector.getElmNameProp, createSelector.getDistinctClass, createSelector.getFileRefProp, createSelector.getCommonName ].reduce(function(features, func) { + if (features.length === featureCount) { + return features; + } + var feature = func(elm, props); + if (feature) { + if (!feature[0].match(/[a-z]/)) { + features.push(feature); + } else { + features.unshift(feature); + } + } + return features; + }, []); + } + function generateSelector(elm, options, doc) { + var selector = void 0, addParent = void 0; + var _options$isUnique = options.isUnique, isUnique = _options$isUnique === undefined ? false : _options$isUnique; + var idSelector = createSelector.getElmId(elm); + var _options$featureCount = options.featureCount, featureCount = _options$featureCount === undefined ? 2 : _options$featureCount, _options$minDepth = options.minDepth, minDepth = _options$minDepth === undefined ? 1 : _options$minDepth, _options$toRoot = options.toRoot, toRoot = _options$toRoot === undefined ? false : _options$toRoot, _options$childSelecto = options.childSelectors, childSelectors = _options$childSelecto === undefined ? [] : _options$childSelecto; + if (idSelector) { + selector = idSelector; + isUnique = true; + } else { + selector = getElmFeatures(elm, featureCount).join(''); + selector += getNthChildString(elm, selector); + isUnique = options.isUnique || doc.querySelectorAll(selector).length === 1; + if (!isUnique && elm === document.documentElement) { + selector += ':root'; + } + addParent = minDepth !== 0 || !isUnique; + } + var selectorParts = [ selector ].concat(_toConsumableArray(childSelectors)); + if (elm.parentElement && elm.parentElement.nodeType !== 11 && (toRoot || addParent)) { + return generateSelector(elm.parentNode, { + toRoot: toRoot, + isUnique: isUnique, + childSelectors: selectorParts, + featureCount: 1, + minDepth: minDepth - 1 + }, doc); + } else { + return selectorParts.join(' > '); + } + } + axe.utils.getSelector = function createUniqueSelector(elm) { + var options = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : {}; + if (!elm) { + return ''; + } + var doc = elm.getRootNode && elm.getRootNode() || document; + if (doc.nodeType === 11) { + var stack = []; + while (doc.nodeType === 11) { + stack.push({ + elm: elm, + doc: doc + }); + elm = doc.host; + doc = elm.getRootNode(); + } + stack.push({ + elm: elm, + doc: doc + }); + return stack.reverse().map(function(comp) { + return generateSelector(comp.elm, options, comp.doc); + }); + } else { + return generateSelector(elm, options, doc); + } + }; + 'use strict'; + function getXPathArray(node, path) { + var sibling, count; + if (!node) { + return []; + } + if (!path && node.nodeType === 9) { + path = [ { + str: 'html' + } ]; + return path; + } + path = path || []; + if (node.parentNode && node.parentNode !== node) { + path = getXPathArray(node.parentNode, path); + } + if (node.previousSibling) { + count = 1; + sibling = node.previousSibling; + do { + if (sibling.nodeType === 1 && sibling.nodeName === node.nodeName) { + count++; + } + sibling = sibling.previousSibling; + } while (sibling); + if (count === 1) { + count = null; + } + } else if (node.nextSibling) { + sibling = node.nextSibling; + do { + if (sibling.nodeType === 1 && sibling.nodeName === node.nodeName) { + count = 1; + sibling = null; + } else { + count = null; + sibling = sibling.previousSibling; + } + } while (sibling); + } + if (node.nodeType === 1) { + var element = {}; + element.str = node.nodeName.toLowerCase(); + if (node.getAttribute && node.getAttribute('id') && node.ownerDocument.querySelectorAll('#' + axe.utils.escapeSelector(node.id)).length === 1) { + element.id = node.getAttribute('id'); + } + if (count > 1) { + element.count = count; + } + path.push(element); + } + return path; + } + function xpathToString(xpathArray) { + return xpathArray.reduce(function(str, elm) { + if (elm.id) { + return '/' + elm.str + '[@id=\'' + elm.id + '\']'; + } else { + return str + ('/' + elm.str) + (elm.count > 0 ? '[' + elm.count + ']' : ''); + } + }, ''); + } + axe.utils.getXpath = function getXpath(node) { + var xpathArray = getXPathArray(node); + return xpathToString(xpathArray); + }; + 'use strict'; + var styleSheet; + function injectStyle(style) { + 'use strict'; + if (styleSheet && styleSheet.parentNode) { + if (styleSheet.styleSheet === undefined) { + styleSheet.appendChild(document.createTextNode(style)); + } else { + styleSheet.styleSheet.cssText += style; + } + return styleSheet; + } + if (!style) { + return; + } + var head = document.head || document.getElementsByTagName('head')[0]; + styleSheet = document.createElement('style'); + styleSheet.type = 'text/css'; + if (styleSheet.styleSheet === undefined) { + styleSheet.appendChild(document.createTextNode(style)); + } else { + styleSheet.styleSheet.cssText = style; + } + head.appendChild(styleSheet); + return styleSheet; + } + axe.utils.injectStyle = injectStyle; + 'use strict'; + axe.utils.isHidden = function isHidden(el, recursed) { + 'use strict'; + var parent; + if (el.nodeType === 9) { + return false; + } + if (el.nodeType === 11) { + el = el.host; + } + var style = window.getComputedStyle(el, null); + if (!style || !el.parentNode || style.getPropertyValue('display') === 'none' || !recursed && style.getPropertyValue('visibility') === 'hidden' || el.getAttribute('aria-hidden') === 'true') { + return true; + } + parent = el.assignedSlot ? el.assignedSlot : el.parentNode; + return axe.utils.isHidden(parent, true); + }; + 'use strict'; + function pushFrame(resultSet, options, frameElement, frameSelector) { + 'use strict'; + var frameXpath = axe.utils.getXpath(frameElement); + var frameSpec = { + element: frameElement, + selector: frameSelector, + xpath: frameXpath + }; + resultSet.forEach(function(res) { + res.node = axe.utils.DqElement.fromFrame(res.node, options, frameSpec); + var checks = axe.utils.getAllChecks(res); + if (checks.length) { + checks.forEach(function(check) { + check.relatedNodes = check.relatedNodes.map(function(node) { + return axe.utils.DqElement.fromFrame(node, options, frameSpec); + }); + }); + } + }); + } + function spliceNodes(target, to) { + 'use strict'; + var firstFromFrame = to[0].node, sorterResult, t; + for (var i = 0, l = target.length; i < l; i++) { + t = target[i].node; + sorterResult = axe.utils.nodeSorter({ + actualNode: t.element + }, { + actualNode: firstFromFrame.element + }); + if (sorterResult > 0 || sorterResult === 0 && firstFromFrame.selector.length < t.selector.length) { + target.splice.apply(target, [ i, 0 ].concat(to)); + return; + } + } + target.push.apply(target, to); + } + function normalizeResult(result) { + 'use strict'; + if (!result || !result.results) { + return null; + } + if (!Array.isArray(result.results)) { + return [ result.results ]; + } + if (!result.results.length) { + return null; + } + return result.results; + } + axe.utils.mergeResults = function mergeResults(frameResults, options) { + 'use strict'; + var result = []; + frameResults.forEach(function(frameResult) { + var results = normalizeResult(frameResult); + if (!results || !results.length) { + return; + } + results.forEach(function(ruleResult) { + if (ruleResult.nodes && frameResult.frame) { + pushFrame(ruleResult.nodes, options, frameResult.frameElement, frameResult.frame); + } + var res = axe.utils.findBy(result, 'id', ruleResult.id); + if (!res) { + result.push(ruleResult); + } else { + if (ruleResult.nodes.length) { + spliceNodes(res.nodes, ruleResult.nodes); + } + } + }); + }); + return result; + }; + 'use strict'; + axe.utils.nodeSorter = function nodeSorter(a, b) { + 'use strict'; + if (a.actualNode === b.actualNode) { + return 0; + } + if (a.actualNode.compareDocumentPosition(b.actualNode) & 4) { + return -1; + } + return 1; + }; + 'use strict'; + utils.performanceTimer = function() { + 'use strict'; + function now() { + if (window.performance && window.performance) { + return window.performance.now(); + } + } + var originalTime = null; + var lastRecordedTime = now(); + return { + start: function start() { + this.mark('mark_axe_start'); + }, + end: function end() { + this.mark('mark_axe_end'); + this.measure('axe', 'mark_axe_start', 'mark_axe_end'); + this.logMeasures('axe'); + }, + auditStart: function auditStart() { + this.mark('mark_audit_start'); + }, + auditEnd: function auditEnd() { + this.mark('mark_audit_end'); + this.measure('audit_start_to_end', 'mark_audit_start', 'mark_audit_end'); + this.logMeasures(); + }, + mark: function mark(markName) { + if (window.performance && window.performance.mark !== undefined) { + window.performance.mark(markName); + } + }, + measure: function measure(measureName, startMark, endMark) { + if (window.performance && window.performance.measure !== undefined) { + window.performance.measure(measureName, startMark, endMark); + } + }, + logMeasures: function logMeasures(measureName) { + function log(req) { + axe.log('Measure ' + req.name + ' took ' + req.duration + 'ms'); + } + if (window.performance && window.performance.getEntriesByType !== undefined) { + var measures = window.performance.getEntriesByType('measure'); + for (var i = 0; i < measures.length; ++i) { + var req = measures[i]; + if (req.name === measureName) { + log(req); + return; + } + log(req); + } + } + }, + timeElapsed: function timeElapsed() { + return now() - lastRecordedTime; + }, + reset: function reset() { + if (!originalTime) { + originalTime = now(); + } + lastRecordedTime = now(); + } + }; + }(); + 'use strict'; + if (typeof Object.assign !== 'function') { + (function() { + Object.assign = function(target) { + 'use strict'; + if (target === undefined || target === null) { + throw new TypeError('Cannot convert undefined or null to object'); + } + var output = Object(target); + for (var index = 1; index < arguments.length; index++) { + var source = arguments[index]; + if (source !== undefined && source !== null) { + for (var nextKey in source) { + if (source.hasOwnProperty(nextKey)) { + output[nextKey] = source[nextKey]; + } + } + } + } + return output; + }; + })(); + } + if (!Array.prototype.find) { + Array.prototype.find = function(predicate) { + if (this === null) { + throw new TypeError('Array.prototype.find called on null or undefined'); + } + if (typeof predicate !== 'function') { + throw new TypeError('predicate must be a function'); + } + var list = Object(this); + var length = list.length >>> 0; + var thisArg = arguments[1]; + var value; + for (var i = 0; i < length; i++) { + value = list[i]; + if (predicate.call(thisArg, value, i, list)) { + return value; + } + } + return undefined; + }; + } + axe.utils.pollyfillElementsFromPoint = function() { + if (document.elementsFromPoint) { + return document.elementsFromPoint; + } + if (document.msElementsFromPoint) { + return document.msElementsFromPoint; + } + var usePointer = function() { + var element = document.createElement('x'); + element.style.cssText = 'pointer-events:auto'; + return element.style.pointerEvents === 'auto'; + }(); + var cssProp = usePointer ? 'pointer-events' : 'visibility'; + var cssDisableVal = usePointer ? 'none' : 'hidden'; + var style = document.createElement('style'); + style.innerHTML = usePointer ? '* { pointer-events: all }' : '* { visibility: visible }'; + return function(x, y) { + var current, i, d; + var elements = []; + var previousPointerEvents = []; + document.head.appendChild(style); + while ((current = document.elementFromPoint(x, y)) && elements.indexOf(current) === -1) { + elements.push(current); + previousPointerEvents.push({ + value: current.style.getPropertyValue(cssProp), + priority: current.style.getPropertyPriority(cssProp) + }); + current.style.setProperty(cssProp, cssDisableVal, 'important'); + } + for (i = previousPointerEvents.length; !!(d = previousPointerEvents[--i]); ) { + elements[i].style.setProperty(cssProp, d.value ? d.value : '', d.priority); + } + document.head.removeChild(style); + return elements; + }; + }; + if (typeof window.addEventListener === 'function') { + document.elementsFromPoint = axe.utils.pollyfillElementsFromPoint(); + } + if (!Array.prototype.includes) { + Array.prototype.includes = function(searchElement) { + 'use strict'; + var O = Object(this); + var len = parseInt(O.length, 10) || 0; + if (len === 0) { + return false; + } + var n = parseInt(arguments[1], 10) || 0; + var k; + if (n >= 0) { + k = n; + } else { + k = len + n; + if (k < 0) { + k = 0; + } + } + var currentElement; + while (k < len) { + currentElement = O[k]; + if (searchElement === currentElement || searchElement !== searchElement && currentElement !== currentElement) { + return true; + } + k++; + } + return false; + }; + } + if (!Array.prototype.some) { + Array.prototype.some = function(fun) { + 'use strict'; + if (this == null) { + throw new TypeError('Array.prototype.some called on null or undefined'); + } + if (typeof fun !== 'function') { + throw new TypeError(); + } + var t = Object(this); + var len = t.length >>> 0; + var thisArg = arguments.length >= 2 ? arguments[1] : void 0; + for (var i = 0; i < len; i++) { + if (i in t && fun.call(thisArg, t[i], i, t)) { + return true; + } + } + return false; + }; + } + if (!Array.from) { + Array.from = function() { + var toStr = Object.prototype.toString; + var isCallable = function isCallable(fn) { + return typeof fn === 'function' || toStr.call(fn) === '[object Function]'; + }; + var toInteger = function toInteger(value) { + var number = Number(value); + if (isNaN(number)) { + return 0; + } + if (number === 0 || !isFinite(number)) { + return number; + } + return (number > 0 ? 1 : -1) * Math.floor(Math.abs(number)); + }; + var maxSafeInteger = Math.pow(2, 53) - 1; + var toLength = function toLength(value) { + var len = toInteger(value); + return Math.min(Math.max(len, 0), maxSafeInteger); + }; + return function from(arrayLike) { + var C = this; + var items = Object(arrayLike); + if (arrayLike == null) { + throw new TypeError('Array.from requires an array-like object - not null or undefined'); + } + var mapFn = arguments.length > 1 ? arguments[1] : void undefined; + var T; + if (typeof mapFn !== 'undefined') { + if (!isCallable(mapFn)) { + throw new TypeError('Array.from: when provided, the second argument must be a function'); + } + if (arguments.length > 2) { + T = arguments[2]; + } + } + var len = toLength(items.length); + var A = isCallable(C) ? Object(new C(len)) : new Array(len); + var k = 0; + var kValue; + while (k < len) { + kValue = items[k]; + if (mapFn) { + A[k] = typeof T === 'undefined' ? mapFn(kValue, k) : mapFn.call(T, kValue, k); + } else { + A[k] = kValue; + } + k += 1; + } + A.length = len; + return A; + }; + }(); + } + if (!String.prototype.includes) { + String.prototype.includes = function(search, start) { + if (typeof start !== 'number') { + start = 0; + } + if (start + search.length > this.length) { + return false; + } else { + return this.indexOf(search, start) !== -1; + } + }; + } + 'use strict'; + var _typeof = typeof Symbol === 'function' && typeof Symbol.iterator === 'symbol' ? function(obj) { + return typeof obj; + } : function(obj) { + return obj && typeof Symbol === 'function' && obj.constructor === Symbol && obj !== Symbol.prototype ? 'symbol' : typeof obj; + }; + function getIncompleteReason(checkData, messages) { + function getDefaultMsg(messages) { + if (messages.incomplete && messages.incomplete.default) { + return messages.incomplete.default; + } else { + return helpers.incompleteFallbackMessage(); + } + } + if (checkData && checkData.missingData) { + try { + var msg = messages.incomplete[checkData.missingData[0].reason]; + if (!msg) { + throw new Error(); + } + return msg; + } catch (e) { + if (typeof checkData.missingData === 'string') { + return messages.incomplete[checkData.missingData]; + } else { + return getDefaultMsg(messages); + } + } + } else { + return getDefaultMsg(messages); + } + } + function extender(checksData, shouldBeTrue) { + 'use strict'; + return function(check) { + var sourceData = checksData[check.id] || {}; + var messages = sourceData.messages || {}; + var data = Object.assign({}, sourceData); + delete data.messages; + if (check.result === undefined) { + if (_typeof(messages.incomplete) === 'object') { + data.message = function() { + return getIncompleteReason(check.data, messages); + }; + } else { + data.message = messages.incomplete; + } + } else { + data.message = check.result === shouldBeTrue ? messages.pass : messages.fail; + } + axe.utils.extendMetaData(check, data); + }; + } + axe.utils.publishMetaData = function(ruleResult) { + 'use strict'; + var checksData = axe._audit.data.checks || {}; + var rulesData = axe._audit.data.rules || {}; + var rule = axe.utils.findBy(axe._audit.rules, 'id', ruleResult.id) || {}; + ruleResult.tags = axe.utils.clone(rule.tags || []); + var shouldBeTrue = extender(checksData, true); + var shouldBeFalse = extender(checksData, false); + ruleResult.nodes.forEach(function(detail) { + detail.any.forEach(shouldBeTrue); + detail.all.forEach(shouldBeTrue); + detail.none.forEach(shouldBeFalse); + }); + axe.utils.extendMetaData(ruleResult, axe.utils.clone(rulesData[ruleResult.id] || {})); + }; + 'use strict'; + var convertExpressions = function convertExpressions() {}; + var matchExpressions = function matchExpressions() {}; + function matchesTag(node, exp) { + return node.nodeType === 1 && (exp.tag === '*' || node.nodeName.toLowerCase() === exp.tag); + } + function matchesClasses(node, exp) { + return !exp.classes || exp.classes.reduce(function(result, cl) { + return result && node.className && node.className.match(cl.regexp); + }, true); + } + function matchesAttributes(node, exp) { + return !exp.attributes || exp.attributes.reduce(function(result, att) { + var nodeAtt = node.getAttribute(att.key); + return result && nodeAtt !== null && (!att.value || att.test(nodeAtt)); + }, true); + } + function matchesId(node, exp) { + return !exp.id || node.id === exp.id; + } + function matchesPseudos(target, exp) { + if (!exp.pseudos || exp.pseudos.reduce(function(result, pseudo) { + if (pseudo.name === 'not') { + return result && !matchExpressions([ target ], pseudo.expressions, false).length; + } + throw new Error('the pseudo selector ' + pseudo.name + ' has not yet been implemented'); + }, true)) { + return true; + } + return false; + } + function matchSelector(targets, exp, recurse) { + var result = []; + targets = Array.isArray(targets) ? targets : [ targets ]; + targets.forEach(function(target) { + if (matchesTag(target.actualNode, exp) && matchesClasses(target.actualNode, exp) && matchesAttributes(target.actualNode, exp) && matchesId(target.actualNode, exp) && matchesPseudos(target, exp)) { + result.push(target); + } + if (recurse) { + result = result.concat(matchSelector(target.children.filter(function(child) { + return !exp.id || child.shadowId === target.shadowId; + }), exp, recurse)); + } + }); + return result; + } + var escapeRegExp = function() { + /*! Credit: XRegExp 0.6.1 (c) 2007-2008 Steven Levithan <http://stevenlevithan.com/regex/xregexp/> MIT License */ + var from = /(?=[\-\[\]{}()*+?.\\\^$|,#\s])/g; + var to = '\\'; + return function(string) { + return string.replace(from, to); + }; + }(); + var reUnescape = /\\/g; + function convertAttributes(atts) { + /*! Credit Mootools Copyright Mootools, MIT License */ + if (!atts) { + return; + } + return atts.map(function(att) { + var attributeKey = att.name.replace(reUnescape, ''); + var attributeValue = (att.value || '').replace(reUnescape, ''); + var test, regexp; + switch (att.operator) { + case '^=': + regexp = new RegExp('^' + escapeRegExp(attributeValue)); + break; + + case '$=': + regexp = new RegExp(escapeRegExp(attributeValue) + '$'); + break; + + case '~=': + regexp = new RegExp('(^|\\s)' + escapeRegExp(attributeValue) + '(\\s|$)'); + break; + + case '|=': + regexp = new RegExp('^' + escapeRegExp(attributeValue) + '(-|$)'); + break; + + case '=': + test = function test(value) { + return attributeValue === value; + }; + break; + + case '*=': + test = function test(value) { + return value && value.indexOf(attributeValue) > -1; + }; + break; + + case '!=': + test = function test(value) { + return attributeValue !== value; + }; + break; + + default: + test = function test(value) { + return !!value; + }; + } + if (attributeValue === '' && /^[*$^]=$/.test(att.operator)) { + test = function test() { + return false; + }; + } + if (!test) { + test = function test(value) { + return value && regexp.test(value); + }; + } + return { + key: attributeKey, + value: attributeValue, + test: test + }; + }); + } + function convertClasses(classes) { + if (!classes) { + return; + } + return classes.map(function(className) { + className = className.replace(reUnescape, ''); + return { + value: className, + regexp: new RegExp('(^|\\s)' + escapeRegExp(className) + '(\\s|$)') + }; + }); + } + function convertPseudos(pseudos) { + if (!pseudos) { + return; + } + return pseudos.map(function(p) { + var expressions; + if (p.name === 'not') { + expressions = axe.utils.cssParser.parse(p.value); + expressions = expressions.selectors ? expressions.selectors : [ expressions ]; + expressions = convertExpressions(expressions); + } + return { + name: p.name, + expressions: expressions, + value: p.value + }; + }); + } + convertExpressions = function convertExpressions(expressions) { + return expressions.map(function(exp) { + var newExp = []; + var rule = exp.rule; + while (rule) { + newExp.push({ + tag: rule.tagName ? rule.tagName.toLowerCase() : '*', + combinator: rule.nestingOperator ? rule.nestingOperator : ' ', + id: rule.id, + attributes: convertAttributes(rule.attrs), + classes: convertClasses(rule.classNames), + pseudos: convertPseudos(rule.pseudos) + }); + rule = rule.rule; + } + return newExp; + }); + }; + matchExpressions = function matchExpressions(domTree, expressions, recurse) { + return expressions.reduce(function(collected, exprArr) { + var candidates = domTree; + exprArr.forEach(function(exp, index) { + recurse = exp.combinator === '>' ? false : recurse; + if ([ ' ', '>' ].indexOf(exp.combinator) === -1) { + throw new Error('axe.utils.querySelectorAll does not support the combinator: ' + exp.combinator); + } + candidates = candidates.reduce(function(result, node) { + return result.concat(matchSelector(index ? node.children : node, exp, recurse)); + }, []); + }); + return collected.concat(candidates); + }, []); + }; + axe.utils.querySelectorAll = function(domTree, selector) { + domTree = Array.isArray(domTree) ? domTree : [ domTree ]; + var expressions = axe.utils.cssParser.parse(selector); + expressions = expressions.selectors ? expressions.selectors : [ expressions ]; + expressions = convertExpressions(expressions); + return matchExpressions(domTree, expressions, true); + }; + 'use strict'; + var _typeof = typeof Symbol === 'function' && typeof Symbol.iterator === 'symbol' ? function(obj) { + return typeof obj; + } : function(obj) { + return obj && typeof Symbol === 'function' && obj.constructor === Symbol && obj !== Symbol.prototype ? 'symbol' : typeof obj; + }; + (function() { + 'use strict'; + function noop() {} + function funcGuard(f) { + if (typeof f !== 'function') { + throw new TypeError('Queue methods require functions as arguments'); + } + } + function queue() { + var tasks = []; + var started = 0; + var remaining = 0; + var completeQueue = noop; + var complete = false; + var err; + var defaultFail = function defaultFail(e) { + err = e; + setTimeout(function() { + if (err !== undefined && err !== null) { + axe.log('Uncaught error (of queue)', err); + } + }, 1); + }; + var failed = defaultFail; + function createResolve(i) { + return function(r) { + tasks[i] = r; + remaining -= 1; + if (!remaining && completeQueue !== noop) { + complete = true; + completeQueue(tasks); + } + }; + } + function abort(msg) { + completeQueue = noop; + failed(msg); + return tasks; + } + function pop() { + var length = tasks.length; + for (;started < length; started++) { + var task = tasks[started]; + try { + task.call(null, createResolve(started), abort); + } catch (e) { + abort(e); + } + } + } + var q = { + defer: function defer(fn) { + if ((typeof fn === 'undefined' ? 'undefined' : _typeof(fn)) === 'object' && fn.then && fn.catch) { + var defer = fn; + fn = function fn(resolve, reject) { + defer.then(resolve).catch(reject); + }; + } + funcGuard(fn); + if (err !== undefined) { + return; + } else if (complete) { + throw new Error('Queue already completed'); + } + tasks.push(fn); + ++remaining; + pop(); + return q; + }, + then: function then(fn) { + funcGuard(fn); + if (completeQueue !== noop) { + throw new Error('queue `then` already set'); + } + if (!err) { + completeQueue = fn; + if (!remaining) { + complete = true; + completeQueue(tasks); + } + } + return q; + }, + catch: function _catch(fn) { + funcGuard(fn); + if (failed !== defaultFail) { + throw new Error('queue `catch` already set'); + } + if (!err) { + failed = fn; + } else { + fn(err); + err = null; + } + return q; + }, + abort: abort + }; + return q; + } + axe.utils.queue = queue; + })(); + 'use strict'; + var _typeof = typeof Symbol === 'function' && typeof Symbol.iterator === 'symbol' ? function(obj) { + return typeof obj; + } : function(obj) { + return obj && typeof Symbol === 'function' && obj.constructor === Symbol && obj !== Symbol.prototype ? 'symbol' : typeof obj; + }; + (function(exports) { + 'use strict'; + var messages = {}, subscribers = {}; + function _getSource() { + var application = 'axe', version = '', src; + if (typeof axe !== 'undefined' && axe._audit && !axe._audit.application) { + application = axe._audit.application; + } + if (typeof axe !== 'undefined') { + version = axe.version; + } + src = application + '.' + version; + return src; + } + function verify(postedMessage) { + if ((typeof postedMessage === 'undefined' ? 'undefined' : _typeof(postedMessage)) === 'object' && typeof postedMessage.uuid === 'string' && postedMessage._respondable === true) { + var messageSource = _getSource(); + return postedMessage._source === messageSource || postedMessage._source === 'axe.x.y.z' || messageSource === 'axe.x.y.z'; + } + return false; + } + function post(win, topic, message, uuid, keepalive, callback) { + var error; + if (message instanceof Error) { + error = { + name: message.name, + message: message.message, + stack: message.stack + }; + message = undefined; + } + var data = { + uuid: uuid, + topic: topic, + message: message, + error: error, + _respondable: true, + _source: _getSource(), + _keepalive: keepalive + }; + if (typeof callback === 'function') { + messages[uuid] = callback; + } + win.postMessage(JSON.stringify(data), '*'); + } + function respondable(win, topic, message, keepalive, callback) { + var id = uuid.v1(); + post(win, topic, message, id, keepalive, callback); + } + respondable.subscribe = function(topic, callback) { + subscribers[topic] = callback; + }; + respondable.isInFrame = function(win) { + win = win || window; + return !!win.frameElement; + }; + function createResponder(source, topic, uuid) { + return function(message, keepalive, callback) { + post(source, topic, message, uuid, keepalive, callback); + }; + } + function publish(target, data, keepalive) { + var topic = data.topic; + var subscriber = subscribers[topic]; + if (subscriber) { + var responder = createResponder(target, null, data.uuid); + subscriber(data.message, keepalive, responder); + } + } + function buildErrorObject(error) { + var msg = error.message || 'Unknown error occurred'; + var ErrConstructor = window[error.name] || Error; + if (error.stack) { + msg += '\n' + error.stack.replace(error.message, ''); + } + return new ErrConstructor(msg); + } + function parseMessage(dataString) { + var data; + if (typeof dataString !== 'string') { + return; + } + try { + data = JSON.parse(dataString); + } catch (ex) {} + if (!verify(data)) { + return; + } + if (_typeof(data.error) === 'object') { + data.error = buildErrorObject(data.error); + } else { + data.error = undefined; + } + return data; + } + if (typeof window.addEventListener === 'function') { + window.addEventListener('message', function(e) { + var data = parseMessage(e.data); + if (!data) { + return; + } + var uuid = data.uuid; + var keepalive = data._keepalive; + var callback = messages[uuid]; + if (callback) { + var result = data.error || data.message; + var responder = createResponder(e.source, data.topic, uuid); + callback(result, keepalive, responder); + if (!keepalive) { + delete messages[uuid]; + } + } + if (!data.error) { + try { + publish(e.source, data, keepalive); + } catch (err) { + post(e.source, data.topic, err, uuid, false); + } + } + }, false); + } + exports.respondable = respondable; + })(utils); + 'use strict'; + function matchTags(rule, runOnly) { + 'use strict'; + var include, exclude, matching; + var defaultExclude = axe._audit && axe._audit.tagExclude ? axe._audit.tagExclude : []; + if (runOnly.include || runOnly.exclude) { + include = runOnly.include || []; + include = Array.isArray(include) ? include : [ include ]; + exclude = runOnly.exclude || []; + exclude = Array.isArray(exclude) ? exclude : [ exclude ]; + exclude = exclude.concat(defaultExclude.filter(function(tag) { + return include.indexOf(tag) === -1; + })); + } else { + include = Array.isArray(runOnly) ? runOnly : [ runOnly ]; + exclude = defaultExclude.filter(function(tag) { + return include.indexOf(tag) === -1; + }); + } + matching = include.some(function(tag) { + return rule.tags.indexOf(tag) !== -1; + }); + if (matching || include.length === 0 && rule.enabled !== false) { + return exclude.every(function(tag) { + return rule.tags.indexOf(tag) === -1; + }); + } else { + return false; + } + } + axe.utils.ruleShouldRun = function(rule, context, options) { + 'use strict'; + var runOnly = options.runOnly || {}; + var ruleOptions = (options.rules || {})[rule.id]; + if (rule.pageLevel && !context.page) { + return false; + } else if (runOnly.type === 'rule') { + return runOnly.values.indexOf(rule.id) !== -1; + } else if (ruleOptions && typeof ruleOptions.enabled === 'boolean') { + return ruleOptions.enabled; + } else if (runOnly.type === 'tag' && runOnly.values) { + return matchTags(rule, runOnly.values); + } else { + return matchTags(rule, []); + } + }; + 'use strict'; + function getDeepest(collection) { + 'use strict'; + return collection.sort(function(a, b) { + if (axe.utils.contains(a, b)) { + return 1; + } + return -1; + })[0]; + } + function isNodeInContext(node, context) { + 'use strict'; + var include = context.include && getDeepest(context.include.filter(function(candidate) { + return axe.utils.contains(candidate, node); + })); + var exclude = context.exclude && getDeepest(context.exclude.filter(function(candidate) { + return axe.utils.contains(candidate, node); + })); + if (!exclude && include || exclude && axe.utils.contains(exclude, include)) { + return true; + } + return false; + } + function pushNode(result, nodes, context) { + 'use strict'; + for (var i = 0, l = nodes.length; i < l; i++) { + if (!result.find(function(item) { + return item.actualNode === nodes[i].actualNode; + }) && isNodeInContext(nodes[i], context)) { + result.push(nodes[i]); + } + } + } + axe.utils.select = function select(selector, context) { + 'use strict'; + var result = [], candidate; + for (var i = 0, l = context.include.length; i < l; i++) { + candidate = context.include[i]; + if (candidate.actualNode.nodeType === candidate.actualNode.ELEMENT_NODE && axe.utils.matchesSelector(candidate.actualNode, selector)) { + pushNode(result, [ candidate ], context); + } + pushNode(result, axe.utils.querySelectorAll(candidate, selector), context); + } + return result.sort(axe.utils.nodeSorter); + }; + 'use strict'; + axe.utils.toArray = function(thing) { + 'use strict'; + return Array.prototype.slice.call(thing); + }; + 'use strict'; + var uuid; + (function(_global) { + var _rng; + var _crypto = _global.crypto || _global.msCrypto; + if (!_rng && _crypto && _crypto.getRandomValues) { + var _rnds8 = new Uint8Array(16); + _rng = function whatwgRNG() { + _crypto.getRandomValues(_rnds8); + return _rnds8; + }; + } + if (!_rng) { + var _rnds = new Array(16); + _rng = function _rng() { + for (var i = 0, r; i < 16; i++) { + if ((i & 3) === 0) { + r = Math.random() * 4294967296; + } + _rnds[i] = r >>> ((i & 3) << 3) & 255; + } + return _rnds; + }; + } + var BufferClass = typeof _global.Buffer == 'function' ? _global.Buffer : Array; + var _byteToHex = []; + var _hexToByte = {}; + for (var i = 0; i < 256; i++) { + _byteToHex[i] = (i + 256).toString(16).substr(1); + _hexToByte[_byteToHex[i]] = i; + } + function parse(s, buf, offset) { + var i = buf && offset || 0, ii = 0; + buf = buf || []; + s.toLowerCase().replace(/[0-9a-f]{2}/g, function(oct) { + if (ii < 16) { + buf[i + ii++] = _hexToByte[oct]; + } + }); + while (ii < 16) { + buf[i + ii++] = 0; + } + return buf; + } + function unparse(buf, offset) { + var i = offset || 0, bth = _byteToHex; + return bth[buf[i++]] + bth[buf[i++]] + bth[buf[i++]] + bth[buf[i++]] + '-' + bth[buf[i++]] + bth[buf[i++]] + '-' + bth[buf[i++]] + bth[buf[i++]] + '-' + bth[buf[i++]] + bth[buf[i++]] + '-' + bth[buf[i++]] + bth[buf[i++]] + bth[buf[i++]] + bth[buf[i++]] + bth[buf[i++]] + bth[buf[i++]]; + } + var _seedBytes = _rng(); + var _nodeId = [ _seedBytes[0] | 1, _seedBytes[1], _seedBytes[2], _seedBytes[3], _seedBytes[4], _seedBytes[5] ]; + var _clockseq = (_seedBytes[6] << 8 | _seedBytes[7]) & 16383; + var _lastMSecs = 0, _lastNSecs = 0; + function v1(options, buf, offset) { + var i = buf && offset || 0; + var b = buf || []; + options = options || {}; + var clockseq = options.clockseq != null ? options.clockseq : _clockseq; + var msecs = options.msecs != null ? options.msecs : new Date().getTime(); + var nsecs = options.nsecs != null ? options.nsecs : _lastNSecs + 1; + var dt = msecs - _lastMSecs + (nsecs - _lastNSecs) / 1e4; + if (dt < 0 && options.clockseq == null) { + clockseq = clockseq + 1 & 16383; + } + if ((dt < 0 || msecs > _lastMSecs) && options.nsecs == null) { + nsecs = 0; + } + if (nsecs >= 1e4) { + throw new Error('uuid.v1(): Can\'t create more than 10M uuids/sec'); + } + _lastMSecs = msecs; + _lastNSecs = nsecs; + _clockseq = clockseq; + msecs += 122192928e5; + var tl = ((msecs & 268435455) * 1e4 + nsecs) % 4294967296; + b[i++] = tl >>> 24 & 255; + b[i++] = tl >>> 16 & 255; + b[i++] = tl >>> 8 & 255; + b[i++] = tl & 255; + var tmh = msecs / 4294967296 * 1e4 & 268435455; + b[i++] = tmh >>> 8 & 255; + b[i++] = tmh & 255; + b[i++] = tmh >>> 24 & 15 | 16; + b[i++] = tmh >>> 16 & 255; + b[i++] = clockseq >>> 8 | 128; + b[i++] = clockseq & 255; + var node = options.node || _nodeId; + for (var n = 0; n < 6; n++) { + b[i + n] = node[n]; + } + return buf ? buf : unparse(b); + } + function v4(options, buf, offset) { + var i = buf && offset || 0; + if (typeof options == 'string') { + buf = options == 'binary' ? new BufferClass(16) : null; + options = null; + } + options = options || {}; + var rnds = options.random || (options.rng || _rng)(); + rnds[6] = rnds[6] & 15 | 64; + rnds[8] = rnds[8] & 63 | 128; + if (buf) { + for (var ii = 0; ii < 16; ii++) { + buf[i + ii] = rnds[ii]; + } + } + return buf || unparse(rnds); + } + uuid = v4; + uuid.v1 = v1; + uuid.v4 = v4; + uuid.parse = parse; + uuid.unparse = unparse; + uuid.BufferClass = BufferClass; + })(window); + 'use strict'; + axe._load({ + data: { + rules: { + accesskeys: { + description: 'Ensures every accesskey attribute value is unique', + help: 'accesskey attribute value must be unique' + }, + 'area-alt': { + description: 'Ensures <area> elements of image maps have alternate text', + help: 'Active <area> elements must have alternate text' + }, + 'aria-allowed-attr': { + description: 'Ensures ARIA attributes are allowed for an element\'s role', + help: 'Elements must only use allowed ARIA attributes' + }, + 'aria-hidden-body': { + description: 'Ensures aria-hidden=\'true\' is not present on the document body.', + help: 'aria-hidden=\'true\' must not be present on the document body' + }, + 'aria-required-attr': { + description: 'Ensures elements with ARIA roles have all required ARIA attributes', + help: 'Required ARIA attributes must be provided' + }, + 'aria-required-children': { + description: 'Ensures elements with an ARIA role that require child roles contain them', + help: 'Certain ARIA roles must contain particular children' + }, + 'aria-required-parent': { + description: 'Ensures elements with an ARIA role that require parent roles are contained by them', + help: 'Certain ARIA roles must be contained by particular parents' + }, + 'aria-roles': { + description: 'Ensures all elements with a role attribute use a valid value', + help: 'ARIA roles used must conform to valid values' + }, + 'aria-valid-attr-value': { + description: 'Ensures all ARIA attributes have valid values', + help: 'ARIA attributes must conform to valid values' + }, + 'aria-valid-attr': { + description: 'Ensures attributes that begin with aria- are valid ARIA attributes', + help: 'ARIA attributes must conform to valid names' + }, + 'audio-caption': { + description: 'Ensures <audio> elements have captions', + help: '<audio> elements must have a captions track' + }, + blink: { + description: 'Ensures <blink> elements are not used', + help: '<blink> elements are deprecated and must not be used' + }, + 'button-name': { + description: 'Ensures buttons have discernible text', + help: 'Buttons must have discernible text' + }, + bypass: { + description: 'Ensures each page has at least one mechanism for a user to bypass navigation and jump straight to the content', + help: 'Page must have means to bypass repeated blocks' + }, + checkboxgroup: { + description: 'Ensures related <input type="checkbox"> elements have a group and that that group designation is consistent', + help: 'Checkbox inputs with the same name attribute value must be part of a group' + }, + 'color-contrast': { + description: 'Ensures the contrast between foreground and background colors meets WCAG 2 AA contrast ratio thresholds', + help: 'Elements must have sufficient color contrast' + }, + 'definition-list': { + description: 'Ensures <dl> elements are structured correctly', + help: '<dl> elements must only directly contain properly-ordered <dt> and <dd> groups, <script> or <template> elements' + }, + dlitem: { + description: 'Ensures <dt> and <dd> elements are contained by a <dl>', + help: '<dt> and <dd> elements must be contained by a <dl>' + }, + 'document-title': { + description: 'Ensures each HTML document contains a non-empty <title> element', + help: 'Documents must have <title> element to aid in navigation' + }, + 'duplicate-id': { + description: 'Ensures every id attribute value is unique', + help: 'id attribute value must be unique' + }, + 'empty-heading': { + description: 'Ensures headings have discernible text', + help: 'Headings must not be empty' + }, + 'frame-title-unique': { + description: 'Ensures <iframe> and <frame> elements contain a unique title attribute', + help: 'Frames must have a unique title attribute' + }, + 'frame-title': { + description: 'Ensures <iframe> and <frame> elements contain a non-empty title attribute', + help: 'Frames must have title attribute' + }, + 'heading-order': { + description: 'Ensures the order of headings is semantically correct', + help: 'Heading levels should only increase by one' + }, + 'hidden-content': { + description: 'Informs users about hidden content.', + help: 'Hidden content on the page cannot be analyzed' + }, + 'href-no-hash': { + description: 'Ensures that href values are valid link references to promote only using anchors as links', + help: 'Anchors must only be used as links with valid URLs or URL fragments' + }, + 'html-has-lang': { + description: 'Ensures every HTML document has a lang attribute', + help: '<html> element must have a lang attribute' + }, + 'html-lang-valid': { + description: 'Ensures the lang attribute of the <html> element has a valid value', + help: '<html> element must have a valid value for the lang attribute' + }, + 'image-alt': { + description: 'Ensures <img> elements have alternate text or a role of none or presentation', + help: 'Images must have alternate text' + }, + 'image-redundant-alt': { + description: 'Ensure button and link text is not repeated as image alternative', + help: 'Text of buttons and links should not be repeated in the image alternative' + }, + 'input-image-alt': { + description: 'Ensures <input type="image"> elements have alternate text', + help: 'Image buttons must have alternate text' + }, + 'label-title-only': { + description: 'Ensures that every form element is not solely labeled using the title or aria-describedby attributes', + help: 'Form elements should have a visible label' + }, + label: { + description: 'Ensures every form element has a label', + help: 'Form elements must have labels' + }, + 'layout-table': { + description: 'Ensures presentational <table> elements do not use <th>, <caption> elements or the summary attribute', + help: 'Layout tables must not use data table elements' + }, + 'link-in-text-block': { + description: 'Links can be distinguished without relying on color', + help: 'Links must be distinguished from surrounding text in a way that does not rely on color' + }, + 'link-name': { + description: 'Ensures links have discernible text', + help: 'Links must have discernible text' + }, + list: { + description: 'Ensures that lists are structured correctly', + help: '<ul> and <ol> must only directly contain <li>, <script> or <template> elements' + }, + listitem: { + description: 'Ensures <li> elements are used semantically', + help: '<li> elements must be contained in a <ul> or <ol>' + }, + marquee: { + description: 'Ensures <marquee> elements are not used', + help: '<marquee> elements are deprecated and must not be used' + }, + 'meta-refresh': { + description: 'Ensures <meta http-equiv="refresh"> is not used', + help: 'Timed refresh must not exist' + }, + 'meta-viewport-large': { + description: 'Ensures <meta name="viewport"> can scale a significant amount', + help: 'Users should be able to zoom and scale the text up to 500%' + }, + 'meta-viewport': { + description: 'Ensures <meta name="viewport"> does not disable text scaling and zooming', + help: 'Zooming and scaling must not be disabled' + }, + 'object-alt': { + description: 'Ensures <object> elements have alternate text', + help: '<object> elements must have alternate text' + }, + 'p-as-heading': { + description: 'Ensure p elements are not used to style headings', + help: 'Bold, italic text and font-size are not used to style p elements as a heading' + }, + radiogroup: { + description: 'Ensures related <input type="radio"> elements have a group and that the group designation is consistent', + help: 'Radio inputs with the same name attribute value must be part of a group' + }, + region: { + description: 'Ensures all content is contained within a landmark region', + help: 'Content should be contained in a landmark region' + }, + 'scope-attr-valid': { + description: 'Ensures the scope attribute is used correctly on tables', + help: 'scope attribute should be used correctly' + }, + 'server-side-image-map': { + description: 'Ensures that server-side image maps are not used', + help: 'Server-side image maps must not be used' + }, + 'skip-link': { + description: 'Ensures the first link on the page is a skip link', + help: 'The page should have a skip link as its first link' + }, + tabindex: { + description: 'Ensures tabindex attribute values are not greater than 0', + help: 'Elements should not have tabindex greater than zero' + }, + 'table-duplicate-name': { + description: 'Ensure that tables do not have the same summary and caption', + help: 'The <caption> element should not contain the same text as the summary attribute' + }, + 'table-fake-caption': { + description: 'Ensure that tables with a caption use the <caption> element.', + help: 'Data or header cells should not be used to give caption to a data table.' + }, + 'td-has-header': { + description: 'Ensure that each non-empty data cell in a large table has one or more table headers', + help: 'All non-empty td element in table larger than 3 by 3 must have an associated table header' + }, + 'td-headers-attr': { + description: 'Ensure that each cell in a table using the headers refers to another cell in that table', + help: 'All cells in a table element that use the headers attribute must only refer to other cells of that same table' + }, + 'th-has-data-cells': { + description: 'Ensure that each table header in a data table refers to data cells', + help: 'All th element and elements with role=columnheader/rowheader must data cells which it describes' + }, + 'valid-lang': { + description: 'Ensures lang attributes have valid values', + help: 'lang attribute must have a valid value' + }, + 'video-caption': { + description: 'Ensures <video> elements have captions', + help: '<video> elements must have captions' + }, + 'video-description': { + description: 'Ensures <video> elements have audio descriptions', + help: '<video> elements must have an audio description track' + } + }, + checks: { + accesskeys: { + impact: 'critical', + messages: { + pass: function anonymous(it) { + var out = 'Accesskey attribute value is unique'; + return out; + }, + fail: function anonymous(it) { + var out = 'Document has multiple elements with the same accesskey'; + return out; + } + } + }, + 'non-empty-alt': { + impact: 'critical', + messages: { + pass: function anonymous(it) { + var out = 'Element has a non-empty alt attribute'; + return out; + }, + fail: function anonymous(it) { + var out = 'Element has no alt attribute or the alt attribute is empty'; + return out; + } + } + }, + 'non-empty-title': { + impact: 'critical', + messages: { + pass: function anonymous(it) { + var out = 'Element has a title attribute'; + return out; + }, + fail: function anonymous(it) { + var out = 'Element has no title attribute or the title attribute is empty'; + return out; + } + } + }, + 'aria-label': { + impact: 'critical', + messages: { + pass: function anonymous(it) { + var out = 'aria-label attribute exists and is not empty'; + return out; + }, + fail: function anonymous(it) { + var out = 'aria-label attribute does not exist or is empty'; + return out; + } + } + }, + 'aria-labelledby': { + impact: 'critical', + messages: { + pass: function anonymous(it) { + var out = 'aria-labelledby attribute exists and references elements that are visible to screen readers'; + return out; + }, + fail: function anonymous(it) { + var out = 'aria-labelledby attribute does not exist, references elements that do not exist or references elements that are empty or not visible'; + return out; + } + } + }, + 'aria-allowed-attr': { + impact: 'critical', + messages: { + pass: function anonymous(it) { + var out = 'ARIA attributes are used correctly for the defined role'; + return out; + }, + fail: function anonymous(it) { + var out = 'ARIA attribute' + (it.data && it.data.length > 1 ? 's are' : ' is') + ' not allowed:'; + var arr1 = it.data; + if (arr1) { + var value, i1 = -1, l1 = arr1.length - 1; + while (i1 < l1) { + value = arr1[i1 += 1]; + out += ' ' + value; + } + } + return out; + } + } + }, + 'aria-hidden-body': { + impact: 'critical', + messages: { + pass: function anonymous(it) { + var out = 'No aria-hidden attribute is present on document body'; + return out; + }, + fail: function anonymous(it) { + var out = 'aria-hidden=true should not be present on the document body'; + return out; + } + } + }, + 'aria-required-attr': { + impact: 'critical', + messages: { + pass: function anonymous(it) { + var out = 'All required ARIA attributes are present'; + return out; + }, + fail: function anonymous(it) { + var out = 'Required ARIA attribute' + (it.data && it.data.length > 1 ? 's' : '') + ' not present:'; + var arr1 = it.data; + if (arr1) { + var value, i1 = -1, l1 = arr1.length - 1; + while (i1 < l1) { + value = arr1[i1 += 1]; + out += ' ' + value; + } + } + return out; + } + } + }, + 'aria-required-children': { + impact: 'critical', + messages: { + pass: function anonymous(it) { + var out = 'Required ARIA children are present'; + return out; + }, + fail: function anonymous(it) { + var out = 'Required ARIA ' + (it.data && it.data.length > 1 ? 'children' : 'child') + ' role not present:'; + var arr1 = it.data; + if (arr1) { + var value, i1 = -1, l1 = arr1.length - 1; + while (i1 < l1) { + value = arr1[i1 += 1]; + out += ' ' + value; + } + } + return out; + } + } + }, + 'aria-required-parent': { + impact: 'critical', + messages: { + pass: function anonymous(it) { + var out = 'Required ARIA parent role present'; + return out; + }, + fail: function anonymous(it) { + var out = 'Required ARIA parent' + (it.data && it.data.length > 1 ? 's' : '') + ' role not present:'; + var arr1 = it.data; + if (arr1) { + var value, i1 = -1, l1 = arr1.length - 1; + while (i1 < l1) { + value = arr1[i1 += 1]; + out += ' ' + value; + } + } + return out; + } + } + }, + invalidrole: { + impact: 'critical', + messages: { + pass: function anonymous(it) { + var out = 'ARIA role is valid'; + return out; + }, + fail: function anonymous(it) { + var out = 'Role must be one of the valid ARIA roles'; + return out; + } + } + }, + abstractrole: { + impact: 'serious', + messages: { + pass: function anonymous(it) { + var out = 'Abstract roles are not used'; + return out; + }, + fail: function anonymous(it) { + var out = 'Abstract roles cannot be directly used'; + return out; + } + } + }, + 'aria-valid-attr-value': { + impact: 'critical', + messages: { + pass: function anonymous(it) { + var out = 'ARIA attribute values are valid'; + return out; + }, + fail: function anonymous(it) { + var out = 'Invalid ARIA attribute value' + (it.data && it.data.length > 1 ? 's' : '') + ':'; + var arr1 = it.data; + if (arr1) { + var value, i1 = -1, l1 = arr1.length - 1; + while (i1 < l1) { + value = arr1[i1 += 1]; + out += ' ' + value; + } + } + return out; + } + } + }, + 'aria-valid-attr': { + impact: 'critical', + messages: { + pass: function anonymous(it) { + var out = 'ARIA attribute name' + (it.data && it.data.length > 1 ? 's' : '') + ' are valid'; + return out; + }, + fail: function anonymous(it) { + var out = 'Invalid ARIA attribute name' + (it.data && it.data.length > 1 ? 's' : '') + ':'; + var arr1 = it.data; + if (arr1) { + var value, i1 = -1, l1 = arr1.length - 1; + while (i1 < l1) { + value = arr1[i1 += 1]; + out += ' ' + value; + } + } + return out; + } + } + }, + caption: { + impact: 'critical', + messages: { + pass: function anonymous(it) { + var out = 'The multimedia element has a captions track'; + return out; + }, + fail: function anonymous(it) { + var out = 'The multimedia element does not have a captions track'; + return out; + }, + incomplete: function anonymous(it) { + var out = 'A captions track for this element could not be found'; + return out; + } + } + }, + 'is-on-screen': { + impact: 'minor', + messages: { + pass: function anonymous(it) { + var out = 'Element is not visible'; + return out; + }, + fail: function anonymous(it) { + var out = 'Element is visible'; + return out; + } + } + }, + 'non-empty-if-present': { + impact: 'critical', + messages: { + pass: function anonymous(it) { + var out = 'Element '; + if (it.data) { + out += 'has a non-empty value attribute'; + } else { + out += 'does not have a value attribute'; + } + return out; + }, + fail: function anonymous(it) { + var out = 'Element has a value attribute and the value attribute is empty'; + return out; + } + } + }, + 'non-empty-value': { + impact: 'critical', + messages: { + pass: function anonymous(it) { + var out = 'Element has a non-empty value attribute'; + return out; + }, + fail: function anonymous(it) { + var out = 'Element has no value attribute or the value attribute is empty'; + return out; + } + } + }, + 'button-has-visible-text': { + impact: 'critical', + messages: { + pass: function anonymous(it) { + var out = 'Element has inner text that is visible to screen readers'; + return out; + }, + fail: function anonymous(it) { + var out = 'Element does not have inner text that is visible to screen readers'; + return out; + } + } + }, + 'role-presentation': { + impact: 'moderate', + messages: { + pass: function anonymous(it) { + var out = 'Element\'s default semantics were overriden with role="presentation"'; + return out; + }, + fail: function anonymous(it) { + var out = 'Element\'s default semantics were not overridden with role="presentation"'; + return out; + } + } + }, + 'role-none': { + impact: 'moderate', + messages: { + pass: function anonymous(it) { + var out = 'Element\'s default semantics were overriden with role="none"'; + return out; + }, + fail: function anonymous(it) { + var out = 'Element\'s default semantics were not overridden with role="none"'; + return out; + } + } + }, + 'focusable-no-name': { + impact: 'serious', + messages: { + pass: function anonymous(it) { + var out = 'Element is not in tab order or has accessible text'; + return out; + }, + fail: function anonymous(it) { + var out = 'Element is in tab order and does not have accessible text'; + return out; + } + } + }, + 'internal-link-present': { + impact: 'critical', + messages: { + pass: function anonymous(it) { + var out = 'Valid skip link found'; + return out; + }, + fail: function anonymous(it) { + var out = 'No valid skip link found'; + return out; + } + } + }, + 'header-present': { + impact: 'moderate', + messages: { + pass: function anonymous(it) { + var out = 'Page has a header'; + return out; + }, + fail: function anonymous(it) { + var out = 'Page does not have a header'; + return out; + } + } + }, + landmark: { + impact: 'serious', + messages: { + pass: function anonymous(it) { + var out = 'Page has a landmark region'; + return out; + }, + fail: function anonymous(it) { + var out = 'Page does not have a landmark region'; + return out; + } + } + }, + 'group-labelledby': { + impact: 'critical', + messages: { + pass: function anonymous(it) { + var out = 'All elements with the name "' + it.data.name + '" reference the same element with aria-labelledby'; + return out; + }, + fail: function anonymous(it) { + var out = 'All elements with the name "' + it.data.name + '" do not reference the same element with aria-labelledby'; + return out; + } + } + }, + fieldset: { + impact: 'critical', + messages: { + pass: function anonymous(it) { + var out = 'Element is contained in a fieldset'; + return out; + }, + fail: function anonymous(it) { + var out = ''; + var code = it.data && it.data.failureCode; + if (code === 'no-legend') { + out += 'Fieldset does not have a legend as its first child'; + } else if (code === 'empty-legend') { + out += 'Legend does not have text that is visible to screen readers'; + } else if (code === 'mixed-inputs') { + out += 'Fieldset contains unrelated inputs'; + } else if (code === 'no-group-label') { + out += 'ARIA group does not have aria-label or aria-labelledby'; + } else if (code === 'group-mixed-inputs') { + out += 'ARIA group contains unrelated inputs'; + } else { + out += 'Element does not have a containing fieldset or ARIA group'; + } + return out; + } + } + }, + 'color-contrast': { + impact: 'serious', + messages: { + pass: function anonymous(it) { + var out = 'Element has sufficient color contrast of ' + it.data.contrastRatio; + return out; + }, + fail: function anonymous(it) { + var out = 'Element has insufficient color contrast of ' + it.data.contrastRatio + ' (foreground color: ' + it.data.fgColor + ', background color: ' + it.data.bgColor + ', font size: ' + it.data.fontSize + ', font weight: ' + it.data.fontWeight + ')'; + return out; + }, + incomplete: { + bgImage: 'Element\'s background color could not be determined due to a background image', + bgGradient: 'Element\'s background color could not be determined due to a background gradient', + imgNode: 'Element\'s background color could not be determined because element contains an image node', + bgOverlap: 'Element\'s background color could not be determined because it is overlapped by another element', + fgAlpha: 'Element\'s foreground color could not be determined because of alpha transparency', + elmPartiallyObscured: 'Element\'s background color could not be determined because it\'s partially obscured by another element', + equalRatio: 'Element has a 1:1 contrast ratio with the background', + default: 'Unable to determine contrast ratio' + } + } + }, + 'structured-dlitems': { + impact: 'serious', + messages: { + pass: function anonymous(it) { + var out = 'When not empty, element has both <dt> and <dd> elements'; + return out; + }, + fail: function anonymous(it) { + var out = 'When not empty, element does not have at least one <dt> element followed by at least one <dd> element'; + return out; + } + } + }, + 'only-dlitems': { + impact: 'serious', + messages: { + pass: function anonymous(it) { + var out = 'List element only has direct children that are allowed inside <dt> or <dd> elements'; + return out; + }, + fail: function anonymous(it) { + var out = 'List element has direct children that are not allowed inside <dt> or <dd> elements'; + return out; + } + } + }, + dlitem: { + impact: 'serious', + messages: { + pass: function anonymous(it) { + var out = 'Description list item has a <dl> parent element'; + return out; + }, + fail: function anonymous(it) { + var out = 'Description list item does not have a <dl> parent element'; + return out; + } + } + }, + 'doc-has-title': { + impact: 'moderate', + messages: { + pass: function anonymous(it) { + var out = 'Document has a non-empty <title> element'; + return out; + }, + fail: function anonymous(it) { + var out = 'Document does not have a non-empty <title> element'; + return out; + } + } + }, + 'duplicate-id': { + impact: 'moderate', + messages: { + pass: function anonymous(it) { + var out = 'Document has no elements that share the same id attribute'; + return out; + }, + fail: function anonymous(it) { + var out = 'Document has multiple elements with the same id attribute: ' + it.data; + return out; + } + } + }, + 'has-visible-text': { + impact: 'moderate', + messages: { + pass: function anonymous(it) { + var out = 'Element has text that is visible to screen readers'; + return out; + }, + fail: function anonymous(it) { + var out = 'Element does not have text that is visible to screen readers'; + return out; + } + } + }, + 'unique-frame-title': { + impact: 'serious', + messages: { + pass: function anonymous(it) { + var out = 'Element\'s title attribute is unique'; + return out; + }, + fail: function anonymous(it) { + var out = 'Element\'s title attribute is not unique'; + return out; + } + } + }, + 'heading-order': { + impact: 'minor', + messages: { + pass: function anonymous(it) { + var out = 'Heading order valid'; + return out; + }, + fail: function anonymous(it) { + var out = 'Heading order invalid'; + return out; + } + } + }, + 'hidden-content': { + impact: 'minor', + messages: { + pass: function anonymous(it) { + var out = 'All content on the page has been analyzed.'; + return out; + }, + fail: function anonymous(it) { + var out = 'There were problems analyzing the content on this page.'; + return out; + }, + incomplete: function anonymous(it) { + var out = 'There is hidden content on the page that was not analyzed. You will need to trigger the display of this content in order to analyze it.'; + return out; + } + } + }, + 'href-no-hash': { + impact: 'moderate', + messages: { + pass: function anonymous(it) { + var out = 'Anchor does not have an href value of #'; + return out; + }, + fail: function anonymous(it) { + var out = 'Anchor has an href value of #'; + return out; + } + } + }, + 'has-lang': { + impact: 'serious', + messages: { + pass: function anonymous(it) { + var out = 'The <html> element has a lang attribute'; + return out; + }, + fail: function anonymous(it) { + var out = 'The <html> element does not have a lang attribute'; + return out; + } + } + }, + 'valid-lang': { + impact: 'serious', + messages: { + pass: function anonymous(it) { + var out = 'Value of lang attribute is included in the list of valid languages'; + return out; + }, + fail: function anonymous(it) { + var out = 'Value of lang attribute not included in the list of valid languages'; + return out; + } + } + }, + 'has-alt': { + impact: 'critical', + messages: { + pass: function anonymous(it) { + var out = 'Element has an alt attribute'; + return out; + }, + fail: function anonymous(it) { + var out = 'Element does not have an alt attribute'; + return out; + } + } + }, + 'duplicate-img-label': { + impact: 'minor', + messages: { + pass: function anonymous(it) { + var out = 'Element does not duplicate existing text in <img> alt text'; + return out; + }, + fail: function anonymous(it) { + var out = 'Element contains <img> element with alt text that duplicates existing text'; + return out; + } + } + }, + 'title-only': { + impact: 'serious', + messages: { + pass: function anonymous(it) { + var out = 'Form element does not solely use title attribute for its label'; + return out; + }, + fail: function anonymous(it) { + var out = 'Only title used to generate label for form element'; + return out; + } + } + }, + 'implicit-label': { + impact: 'critical', + messages: { + pass: function anonymous(it) { + var out = 'Form element has an implicit (wrapped) <label>'; + return out; + }, + fail: function anonymous(it) { + var out = 'Form element does not have an implicit (wrapped) <label>'; + return out; + } + } + }, + 'explicit-label': { + impact: 'critical', + messages: { + pass: function anonymous(it) { + var out = 'Form element has an explicit <label>'; + return out; + }, + fail: function anonymous(it) { + var out = 'Form element does not have an explicit <label>'; + return out; + } + } + }, + 'help-same-as-label': { + impact: 'minor', + messages: { + pass: function anonymous(it) { + var out = 'Help text (title or aria-describedby) does not duplicate label text'; + return out; + }, + fail: function anonymous(it) { + var out = 'Help text (title or aria-describedby) text is the same as the label text'; + return out; + } + } + }, + 'multiple-label': { + impact: 'serious', + messages: { + pass: function anonymous(it) { + var out = 'Form element does not have multiple <label> elements'; + return out; + }, + fail: function anonymous(it) { + var out = 'Form element has multiple <label> elements'; + return out; + } + } + }, + 'has-th': { + impact: 'serious', + messages: { + pass: function anonymous(it) { + var out = 'Layout table does not use <th> elements'; + return out; + }, + fail: function anonymous(it) { + var out = 'Layout table uses <th> elements'; + return out; + } + } + }, + 'has-caption': { + impact: 'serious', + messages: { + pass: function anonymous(it) { + var out = 'Layout table does not use <caption> element'; + return out; + }, + fail: function anonymous(it) { + var out = 'Layout table uses <caption> element'; + return out; + } + } + }, + 'has-summary': { + impact: 'serious', + messages: { + pass: function anonymous(it) { + var out = 'Layout table does not use summary attribute'; + return out; + }, + fail: function anonymous(it) { + var out = 'Layout table uses summary attribute'; + return out; + } + } + }, + 'link-in-text-block': { + impact: 'critical', + messages: { + pass: function anonymous(it) { + var out = 'Links can be distinguished from surrounding text in a way that does not rely on color'; + return out; + }, + fail: function anonymous(it) { + var out = 'Links can not be distinguished from surrounding text in a way that does not rely on color'; + return out; + }, + incomplete: { + bgContrast: 'Element\'s contrast ratio could not be determined. Check for a distinct hover/focus style', + bgImage: 'Element\'s contrast ratio could not be determined due to a background image', + bgGradient: 'Element\'s contrast ratio could not be determined due to a background gradient', + imgNode: 'Element\'s contrast ratio could not be determined because element contains an image node', + bgOverlap: 'Element\'s contrast ratio could not be determined because of element overlap', + default: 'Unable to determine contrast ratio' + } + } + }, + 'only-listitems': { + impact: 'serious', + messages: { + pass: function anonymous(it) { + var out = 'List element only has direct children that are allowed inside <li> elements'; + return out; + }, + fail: function anonymous(it) { + var out = 'List element has direct children that are not allowed inside <li> elements'; + return out; + } + } + }, + listitem: { + impact: 'critical', + messages: { + pass: function anonymous(it) { + var out = 'List item has a <ul>, <ol> or role="list" parent element'; + return out; + }, + fail: function anonymous(it) { + var out = 'List item does not have a <ul>, <ol> or role="list" parent element'; + return out; + } + } + }, + 'meta-refresh': { + impact: 'critical', + messages: { + pass: function anonymous(it) { + var out = '<meta> tag does not immediately refresh the page'; + return out; + }, + fail: function anonymous(it) { + var out = '<meta> tag forces timed refresh of page'; + return out; + } + } + }, + 'meta-viewport-large': { + impact: 'minor', + messages: { + pass: function anonymous(it) { + var out = '<meta> tag does not prevent significant zooming'; + return out; + }, + fail: function anonymous(it) { + var out = '<meta> tag limits zooming'; + return out; + } + } + }, + 'meta-viewport': { + impact: 'critical', + messages: { + pass: function anonymous(it) { + var out = '<meta> tag does not disable zooming'; + return out; + }, + fail: function anonymous(it) { + var out = '<meta> tag disables zooming'; + return out; + } + } + }, + 'p-as-heading': { + impact: 'critical', + messages: { + pass: function anonymous(it) { + var out = '<p> elements are not styled as headings'; + return out; + }, + fail: function anonymous(it) { + var out = 'Heading elements should be used instead of styled p elements'; + return out; + } + } + }, + region: { + impact: 'moderate', + messages: { + pass: function anonymous(it) { + var out = 'Content contained by ARIA landmark'; + return out; + }, + fail: function anonymous(it) { + var out = 'Content not contained by an ARIA landmark'; + return out; + } + } + }, + 'html5-scope': { + impact: 'serious', + messages: { + pass: function anonymous(it) { + var out = 'Scope attribute is only used on table header elements (<th>)'; + return out; + }, + fail: function anonymous(it) { + var out = 'In HTML 5, scope attributes may only be used on table header elements (<th>)'; + return out; + } + } + }, + 'scope-value': { + impact: 'critical', + messages: { + pass: function anonymous(it) { + var out = 'Scope attribute is used correctly'; + return out; + }, + fail: function anonymous(it) { + var out = 'The value of the scope attribute may only be \'row\' or \'col\''; + return out; + } + } + }, + exists: { + impact: 'minor', + messages: { + pass: function anonymous(it) { + var out = 'Element does not exist'; + return out; + }, + fail: function anonymous(it) { + var out = 'Element exists'; + return out; + } + } + }, + 'skip-link': { + impact: 'critical', + messages: { + pass: function anonymous(it) { + var out = 'Valid skip link found'; + return out; + }, + fail: function anonymous(it) { + var out = 'No valid skip link found'; + return out; + } + } + }, + tabindex: { + impact: 'serious', + messages: { + pass: function anonymous(it) { + var out = 'Element does not have a tabindex greater than 0'; + return out; + }, + fail: function anonymous(it) { + var out = 'Element has a tabindex greater than 0'; + return out; + } + } + }, + 'same-caption-summary': { + impact: 'moderate', + messages: { + pass: function anonymous(it) { + var out = 'Content of summary attribute and <caption> are not duplicated'; + return out; + }, + fail: function anonymous(it) { + var out = 'Content of summary attribute and <caption> element are identical'; + return out; + } + } + }, + 'caption-faked': { + impact: 'critical', + messages: { + pass: function anonymous(it) { + var out = 'The first row of a table is not used as a caption'; + return out; + }, + fail: function anonymous(it) { + var out = 'The first row of the table should be a caption instead of a table cell'; + return out; + } + } + }, + 'td-has-header': { + impact: 'critical', + messages: { + pass: function anonymous(it) { + var out = 'All non-empty data cells have table headers'; + return out; + }, + fail: function anonymous(it) { + var out = 'Some non-empty data cells do not have table headers'; + return out; + } + } + }, + 'td-headers-attr': { + impact: 'serious', + messages: { + pass: function anonymous(it) { + var out = 'The headers attribute is exclusively used to refer to other cells in the table'; + return out; + }, + fail: function anonymous(it) { + var out = 'The headers attribute is not exclusively used to refer to other cells in the table'; + return out; + } + } + }, + 'th-has-data-cells': { + impact: 'critical', + messages: { + pass: function anonymous(it) { + var out = 'All table header cells refer to data cells'; + return out; + }, + fail: function anonymous(it) { + var out = 'Not all table header cells refer to data cells'; + return out; + }, + incomplete: function anonymous(it) { + var out = 'Table data cells are missing or empty'; + return out; + } + } + }, + description: { + impact: 'serious', + messages: { + pass: function anonymous(it) { + var out = 'The multimedia element has an audio description track'; + return out; + }, + fail: function anonymous(it) { + var out = 'The multimedia element does not have an audio description track'; + return out; + }, + incomplete: function anonymous(it) { + var out = 'An audio description track for this element could not be found'; + return out; + } + } + } + }, + failureSummaries: { + any: { + failureMessage: function anonymous(it) { + var out = 'Fix any of the following:'; + var arr1 = it; + if (arr1) { + var value, i1 = -1, l1 = arr1.length - 1; + while (i1 < l1) { + value = arr1[i1 += 1]; + out += '\n ' + value.split('\n').join('\n '); + } + } + return out; + } + }, + none: { + failureMessage: function anonymous(it) { + var out = 'Fix all of the following:'; + var arr1 = it; + if (arr1) { + var value, i1 = -1, l1 = arr1.length - 1; + while (i1 < l1) { + value = arr1[i1 += 1]; + out += '\n ' + value.split('\n').join('\n '); + } + } + return out; + } + } + }, + incompleteFallbackMessage: function anonymous(it) { + var out = 'aXe couldn\'t tell the reason. Time to break out the element inspector!'; + return out; + } + }, + rules: [ { + id: 'accesskeys', + selector: '[accesskey]', + excludeHidden: false, + tags: [ 'wcag2a', 'wcag211', 'cat.keyboard' ], + all: [], + any: [], + none: [ 'accesskeys' ] + }, { + id: 'area-alt', + selector: 'map area[href]', + excludeHidden: false, + tags: [ 'cat.text-alternatives', 'wcag2a', 'wcag111', 'section508', 'section508.22.a' ], + all: [], + any: [ 'non-empty-alt', 'non-empty-title', 'aria-label', 'aria-labelledby' ], + none: [] + }, { + id: 'aria-allowed-attr', + matches: function matches(node) { + var role = node.getAttribute('role'); + if (!role) { + role = axe.commons.aria.implicitRole(node); + } + var allowed = axe.commons.aria.allowedAttr(role); + if (role && allowed) { + var aria = /^aria-/; + if (node.hasAttributes()) { + var attrs = node.attributes; + for (var i = 0, l = attrs.length; i < l; i++) { + if (aria.test(attrs[i].name)) { + return true; + } + } + } + } + return false; + }, + tags: [ 'cat.aria', 'wcag2a', 'wcag411', 'wcag412' ], + all: [], + any: [ 'aria-allowed-attr' ], + none: [] + }, { + id: 'aria-hidden-body', + selector: 'body', + excludeHidden: false, + tags: [ 'cat.aria', 'wcag2a', 'wcag412' ], + all: [], + any: [ 'aria-hidden-body' ], + none: [] + }, { + id: 'aria-required-attr', + selector: '[role]', + tags: [ 'cat.aria', 'wcag2a', 'wcag411', 'wcag412' ], + all: [], + any: [ 'aria-required-attr' ], + none: [] + }, { + id: 'aria-required-children', + selector: '[role]', + tags: [ 'cat.aria', 'wcag2a', 'wcag131' ], + all: [], + any: [ 'aria-required-children' ], + none: [] + }, { + id: 'aria-required-parent', + selector: '[role]', + tags: [ 'cat.aria', 'wcag2a', 'wcag131' ], + all: [], + any: [ 'aria-required-parent' ], + none: [] + }, { + id: 'aria-roles', + selector: '[role]', + tags: [ 'cat.aria', 'wcag2a', 'wcag131', 'wcag411', 'wcag412' ], + all: [], + any: [], + none: [ 'invalidrole', 'abstractrole' ] + }, { + id: 'aria-valid-attr-value', + matches: function matches(node) { + var aria = /^aria-/; + if (node.hasAttributes()) { + var attrs = node.attributes; + for (var i = 0, l = attrs.length; i < l; i++) { + if (aria.test(attrs[i].name)) { + return true; + } + } + } + return false; + }, + tags: [ 'cat.aria', 'wcag2a', 'wcag131', 'wcag411', 'wcag412' ], + all: [], + any: [ { + options: [], + id: 'aria-valid-attr-value' + } ], + none: [] + }, { + id: 'aria-valid-attr', + matches: function matches(node) { + var aria = /^aria-/; + if (node.hasAttributes()) { + var attrs = node.attributes; + for (var i = 0, l = attrs.length; i < l; i++) { + if (aria.test(attrs[i].name)) { + return true; + } + } + } + return false; + }, + tags: [ 'cat.aria', 'wcag2a', 'wcag411' ], + all: [], + any: [ { + options: [], + id: 'aria-valid-attr' + } ], + none: [] + }, { + id: 'audio-caption', + selector: 'audio', + excludeHidden: false, + tags: [ 'cat.time-and-media', 'wcag2a', 'wcag122', 'section508', 'section508.22.a' ], + all: [], + any: [], + none: [ 'caption' ] + }, { + id: 'blink', + selector: 'blink', + excludeHidden: false, + tags: [ 'cat.time-and-media', 'wcag2a', 'wcag222', 'section508', 'section508.22.j' ], + all: [], + any: [], + none: [ 'is-on-screen' ] + }, { + id: 'button-name', + selector: 'button, [role="button"], input[type="button"], input[type="submit"], input[type="reset"]', + tags: [ 'cat.name-role-value', 'wcag2a', 'wcag412', 'section508', 'section508.22.a' ], + all: [], + any: [ 'non-empty-if-present', 'non-empty-value', 'button-has-visible-text', 'aria-label', 'aria-labelledby', 'role-presentation', 'role-none' ], + none: [ 'focusable-no-name' ] + }, { + id: 'bypass', + selector: 'html', + pageLevel: true, + matches: function matches(node) { + return !!node.querySelector('a[href]'); + }, + tags: [ 'cat.keyboard', 'wcag2a', 'wcag241', 'section508', 'section508.22.o' ], + all: [], + any: [ 'internal-link-present', 'header-present', 'landmark' ], + none: [] + }, { + id: 'checkboxgroup', + selector: 'input[type=checkbox][name]', + tags: [ 'cat.forms', 'best-practice' ], + all: [], + any: [ 'group-labelledby', 'fieldset' ], + none: [] + }, { + id: 'color-contrast', + matches: function matches(node) { + var nodeName = node.nodeName.toUpperCase(), nodeType = node.type, doc = document; + if (node.getAttribute('aria-disabled') === 'true' || axe.commons.dom.findUp(node, '[aria-disabled="true"]')) { + return false; + } + if (nodeName === 'INPUT') { + return [ 'hidden', 'range', 'color', 'checkbox', 'radio', 'image' ].indexOf(nodeType) === -1 && !node.disabled; + } + if (nodeName === 'SELECT') { + return !!node.options.length && !node.disabled; + } + if (nodeName === 'TEXTAREA') { + return !node.disabled; + } + if (nodeName === 'OPTION') { + return false; + } + if (nodeName === 'BUTTON' && node.disabled || axe.commons.dom.findUp(node, 'button[disabled]')) { + return false; + } + if (nodeName === 'FIELDSET' && node.disabled || axe.commons.dom.findUp(node, 'fieldset[disabled]')) { + return false; + } + var nodeParentLabel = axe.commons.dom.findUp(node, 'label'); + if (nodeName === 'LABEL' || nodeParentLabel) { + var relevantNode = node; + if (nodeParentLabel) { + relevantNode = nodeParentLabel; + } + var candidate = relevantNode.htmlFor && doc.getElementById(relevantNode.htmlFor); + if (candidate && candidate.disabled) { + return false; + } + var candidate = node.querySelector('input:not([type="hidden"]):not([type="image"])' + ':not([type="button"]):not([type="submit"]):not([type="reset"]), select, textarea'); + if (candidate && candidate.disabled) { + return false; + } + } + if (node.id) { + var candidate = doc.querySelector('[aria-labelledby~=' + axe.commons.utils.escapeSelector(node.id) + ']'); + if (candidate && candidate.disabled) { + return false; + } + } + if (axe.commons.text.visible(node, false, true) === '') { + return false; + } + var range = document.createRange(), childNodes = node.childNodes, length = childNodes.length, child, index; + for (index = 0; index < length; index++) { + child = childNodes[index]; + if (child.nodeType === 3 && axe.commons.text.sanitize(child.nodeValue) !== '') { + range.selectNodeContents(child); + } + } + var rects = range.getClientRects(); + length = rects.length; + for (index = 0; index < length; index++) { + if (axe.commons.dom.visuallyOverlaps(rects[index], node)) { + return true; + } + } + return false; + }, + excludeHidden: false, + options: { + noScroll: false + }, + tags: [ 'cat.color', 'wcag2aa', 'wcag143' ], + all: [], + any: [ 'color-contrast' ], + none: [] + }, { + id: 'definition-list', + selector: 'dl', + matches: function matches(node) { + return !node.getAttribute('role'); + }, + tags: [ 'cat.structure', 'wcag2a', 'wcag131' ], + all: [], + any: [], + none: [ 'structured-dlitems', 'only-dlitems' ] + }, { + id: 'dlitem', + selector: 'dd, dt', + matches: function matches(node) { + return !node.getAttribute('role'); + }, + tags: [ 'cat.structure', 'wcag2a', 'wcag131' ], + all: [], + any: [ 'dlitem' ], + none: [] + }, { + id: 'document-title', + selector: 'html', + matches: function matches(node) { + return node.ownerDocument.defaultView.self === node.ownerDocument.defaultView.top; + }, + tags: [ 'cat.text-alternatives', 'wcag2a', 'wcag242' ], + all: [], + any: [ 'doc-has-title' ], + none: [] + }, { + id: 'duplicate-id', + selector: '[id]', + excludeHidden: false, + tags: [ 'cat.parsing', 'wcag2a', 'wcag411' ], + all: [], + any: [ 'duplicate-id' ], + none: [] + }, { + id: 'empty-heading', + selector: 'h1, h2, h3, h4, h5, h6, [role="heading"]', + enabled: true, + tags: [ 'cat.name-role-value', 'best-practice' ], + all: [], + any: [ 'has-visible-text', 'role-presentation', 'role-none' ], + none: [] + }, { + id: 'frame-title-unique', + selector: 'frame[title], iframe[title]', + matches: function matches(node) { + var title = node.getAttribute('title'); + return !!(title ? axe.commons.text.sanitize(title).trim() : ''); + }, + tags: [ 'cat.text-alternatives', 'best-practice' ], + all: [], + any: [], + none: [ 'unique-frame-title' ] + }, { + id: 'frame-title', + selector: 'frame, iframe', + tags: [ 'cat.text-alternatives', 'wcag2a', 'wcag241', 'section508', 'section508.22.i' ], + all: [], + any: [ 'aria-label', 'aria-labelledby', 'non-empty-title', 'role-presentation', 'role-none' ], + none: [] + }, { + id: 'heading-order', + selector: 'h1,h2,h3,h4,h5,h6,[role=heading]', + enabled: false, + tags: [ 'cat.semantics', 'best-practice' ], + all: [], + any: [ 'heading-order' ], + none: [] + }, { + id: 'hidden-content', + selector: '*', + excludeHidden: false, + tags: [ 'experimental', 'review-item' ], + all: [], + any: [ 'hidden-content' ], + none: [], + enabled: false + }, { + id: 'href-no-hash', + selector: 'a[href]', + enabled: false, + tags: [ 'cat.semantics', 'best-practice' ], + all: [], + any: [ 'href-no-hash' ], + none: [] + }, { + id: 'html-has-lang', + selector: 'html', + tags: [ 'cat.language', 'wcag2a', 'wcag311' ], + all: [], + any: [ 'has-lang' ], + none: [] + }, { + id: 'html-lang-valid', + selector: 'html[lang]', + tags: [ 'cat.language', 'wcag2a', 'wcag311' ], + all: [], + any: [], + none: [ 'valid-lang' ] + }, { + id: 'image-alt', + selector: 'img, [role=\'img\']', + tags: [ 'cat.text-alternatives', 'wcag2a', 'wcag111', 'section508', 'section508.22.a' ], + all: [], + any: [ 'has-alt', 'aria-label', 'aria-labelledby', 'non-empty-title', 'role-presentation', 'role-none' ], + none: [] + }, { + id: 'image-redundant-alt', + selector: 'button, [role="button"], a[href], p, li, td, th', + tags: [ 'cat.text-alternatives', 'best-practice' ], + all: [], + any: [], + none: [ 'duplicate-img-label' ] + }, { + id: 'input-image-alt', + selector: 'input[type="image"]', + tags: [ 'cat.text-alternatives', 'wcag2a', 'wcag111', 'section508', 'section508.22.a' ], + all: [], + any: [ 'non-empty-alt', 'aria-label', 'aria-labelledby', 'non-empty-title' ], + none: [] + }, { + id: 'label-title-only', + selector: 'input, select, textarea', + matches: function matches(node) { + if (node.nodeName.toLowerCase() !== 'input') { + return true; + } + var t = node.getAttribute('type').toLowerCase(); + if (t === 'hidden' || t === 'image' || t === 'button' || t === 'submit' || t === 'reset') { + return false; + } + return true; + }, + enabled: false, + tags: [ 'cat.forms', 'best-practice' ], + all: [], + any: [], + none: [ 'title-only' ] + }, { + id: 'label', + selector: 'input, select, textarea', + matches: function matches(node) { + if (node.nodeName.toLowerCase() !== 'input') { + return true; + } + var t = node.getAttribute('type').toLowerCase(); + if (t === 'hidden' || t === 'image' || t === 'button' || t === 'submit' || t === 'reset') { + return false; + } + return true; + }, + tags: [ 'cat.forms', 'wcag2a', 'wcag332', 'wcag131', 'section508', 'section508.22.n' ], + all: [], + any: [ 'aria-label', 'aria-labelledby', 'implicit-label', 'explicit-label', 'non-empty-title' ], + none: [ 'help-same-as-label', 'multiple-label' ] + }, { + id: 'layout-table', + selector: 'table', + matches: function matches(node) { + return !axe.commons.table.isDataTable(node); + }, + tags: [ 'cat.semantics', 'wcag2a', 'wcag131' ], + all: [], + any: [], + none: [ 'has-th', 'has-caption', 'has-summary' ] + }, { + id: 'link-in-text-block', + selector: 'a[href], *[role=link]', + matches: function matches(node) { + var text = axe.commons.text.sanitize(node.textContent); + var role = node.getAttribute('role'); + if (role && role !== 'link') { + return false; + } + if (!text) { + return false; + } + if (!axe.commons.dom.isVisible(node, false)) { + return false; + } + return axe.commons.dom.isInTextBlock(node); + }, + excludeHidden: false, + tags: [ 'cat.color', 'experimental', 'wcag2a', 'wcag141' ], + all: [ 'link-in-text-block' ], + any: [], + none: [] + }, { + id: 'link-name', + selector: 'a[href], [role=link][href]', + matches: function matches(node) { + return node.getAttribute('role') !== 'button'; + }, + tags: [ 'cat.name-role-value', 'wcag2a', 'wcag111', 'wcag412', 'section508', 'section508.22.a' ], + all: [], + any: [ 'has-visible-text', 'aria-label', 'aria-labelledby', 'role-presentation', 'role-none' ], + none: [ 'focusable-no-name' ] + }, { + id: 'list', + selector: 'ul, ol', + matches: function matches(node) { + return !node.getAttribute('role'); + }, + tags: [ 'cat.structure', 'wcag2a', 'wcag131' ], + all: [], + any: [], + none: [ 'only-listitems' ] + }, { + id: 'listitem', + selector: 'li', + matches: function matches(node) { + return !node.getAttribute('role'); + }, + tags: [ 'cat.structure', 'wcag2a', 'wcag131' ], + all: [], + any: [ 'listitem' ], + none: [] + }, { + id: 'marquee', + selector: 'marquee', + excludeHidden: false, + tags: [ 'cat.parsing', 'wcag2a', 'wcag222' ], + all: [], + any: [], + none: [ 'is-on-screen' ] + }, { + id: 'meta-refresh', + selector: 'meta[http-equiv="refresh"]', + excludeHidden: false, + tags: [ 'cat.time', 'wcag2a', 'wcag2aaa', 'wcag221', 'wcag224', 'wcag325' ], + all: [], + any: [ 'meta-refresh' ], + none: [] + }, { + id: 'meta-viewport-large', + selector: 'meta[name="viewport"]', + excludeHidden: false, + tags: [ 'cat.sensory-and-visual-cues', 'best-practice' ], + all: [], + any: [ { + options: { + scaleMinimum: 5, + lowerBound: 2 + }, + id: 'meta-viewport-large' + } ], + none: [] + }, { + id: 'meta-viewport', + selector: 'meta[name="viewport"]', + excludeHidden: false, + tags: [ 'cat.sensory-and-visual-cues', 'wcag2aa', 'wcag144' ], + all: [], + any: [ { + options: { + scaleMinimum: 2 + }, + id: 'meta-viewport' + } ], + none: [] + }, { + id: 'object-alt', + selector: 'object', + tags: [ 'cat.text-alternatives', 'wcag2a', 'wcag111', 'section508', 'section508.22.a' ], + all: [], + any: [ 'has-visible-text', 'aria-label', 'aria-labelledby', 'non-empty-title' ], + none: [] + }, { + id: 'p-as-heading', + selector: 'p', + matches: function matches(node) { + var children = Array.from(node.parentNode.childNodes); + var nodeText = node.textContent.trim(); + var isSentence = /[.!?:;](?![.!?:;])/g; + if (nodeText.length === 0 || (nodeText.match(isSentence) || []).length >= 2) { + return false; + } + var siblingsAfter = children.slice(children.indexOf(node) + 1).filter(function(elm) { + return elm.nodeName.toUpperCase() === 'P' && elm.textContent.trim() !== ''; + }); + return siblingsAfter.length !== 0; + }, + tags: [ 'cat.semantics', 'wcag2a', 'wcag131', 'experimental' ], + all: [ { + options: { + margins: [ { + weight: 150, + italic: true + }, { + weight: 150, + size: 1.15 + }, { + italic: true, + size: 1.15 + }, { + size: 1.4 + } ] + }, + id: 'p-as-heading' + } ], + any: [], + none: [] + }, { + id: 'radiogroup', + selector: 'input[type=radio][name]', + tags: [ 'cat.forms', 'best-practice' ], + all: [], + any: [ 'group-labelledby', 'fieldset' ], + none: [] + }, { + id: 'region', + selector: 'html', + pageLevel: true, + enabled: false, + tags: [ 'cat.keyboard', 'best-practice' ], + all: [], + any: [ 'region' ], + none: [] + }, { + id: 'scope-attr-valid', + selector: 'td[scope], th[scope]', + enabled: true, + tags: [ 'cat.tables', 'best-practice' ], + all: [ 'html5-scope', 'scope-value' ], + any: [], + none: [] + }, { + id: 'server-side-image-map', + selector: 'img[ismap]', + tags: [ 'cat.text-alternatives', 'wcag2a', 'wcag211', 'section508', 'section508.22.f' ], + all: [], + any: [], + none: [ 'exists' ] + }, { + id: 'skip-link', + selector: 'a[href]', + pageLevel: true, + enabled: false, + tags: [ 'cat.keyboard', 'best-practice' ], + all: [], + any: [ 'skip-link' ], + none: [] + }, { + id: 'tabindex', + selector: '[tabindex]', + tags: [ 'cat.keyboard', 'best-practice' ], + all: [], + any: [ 'tabindex' ], + none: [] + }, { + id: 'table-duplicate-name', + selector: 'table', + tags: [ 'cat.tables', 'best-practice' ], + all: [], + any: [], + none: [ 'same-caption-summary' ] + }, { + id: 'table-fake-caption', + selector: 'table', + matches: function matches(node) { + return axe.commons.table.isDataTable(node); + }, + tags: [ 'cat.tables', 'experimental', 'wcag2a', 'wcag131', 'section508', 'section508.22.g' ], + all: [ 'caption-faked' ], + any: [], + none: [] + }, { + id: 'td-has-header', + selector: 'table', + matches: function matches(node) { + if (axe.commons.table.isDataTable(node)) { + var tableArray = axe.commons.table.toArray(node); + return tableArray.length >= 3 && tableArray[0].length >= 3 && tableArray[1].length >= 3 && tableArray[2].length >= 3; + } + return false; + }, + tags: [ 'cat.tables', 'experimental', 'wcag2a', 'wcag131', 'section508', 'section508.22.g' ], + all: [ 'td-has-header' ], + any: [], + none: [] + }, { + id: 'td-headers-attr', + selector: 'table', + tags: [ 'cat.tables', 'wcag2a', 'wcag131', 'section508', 'section508.22.g' ], + all: [ 'td-headers-attr' ], + any: [], + none: [] + }, { + id: 'th-has-data-cells', + selector: 'table', + matches: function matches(node) { + return axe.commons.table.isDataTable(node); + }, + tags: [ 'cat.tables', 'wcag2a', 'wcag131', 'section508', 'section508.22.g' ], + all: [ 'th-has-data-cells' ], + any: [], + none: [] + }, { + id: 'valid-lang', + selector: '[lang], [xml\\:lang]', + matches: function matches(node) { + return node.nodeName.toLowerCase() !== 'html'; + }, + tags: [ 'cat.language', 'wcag2aa', 'wcag312' ], + all: [], + any: [], + none: [ 'valid-lang' ] + }, { + id: 'video-caption', + selector: 'video', + excludeHidden: false, + tags: [ 'cat.text-alternatives', 'wcag2a', 'wcag122', 'wcag123', 'section508', 'section508.22.a' ], + all: [], + any: [], + none: [ 'caption' ] + }, { + id: 'video-description', + selector: 'video', + excludeHidden: false, + tags: [ 'cat.text-alternatives', 'wcag2aa', 'wcag125', 'section508', 'section508.22.b' ], + all: [], + any: [], + none: [ 'description' ] + } ], + checks: [ { + id: 'abstractrole', + evaluate: function evaluate(node, options) { + return axe.commons.aria.getRoleType(node.getAttribute('role')) === 'abstract'; + } + }, { + id: 'aria-allowed-attr', + evaluate: function evaluate(node, options) { + var invalid = []; + var attr, attrName, allowed, role = node.getAttribute('role'), attrs = node.attributes; + if (!role) { + role = axe.commons.aria.implicitRole(node); + } + allowed = axe.commons.aria.allowedAttr(role); + if (role && allowed) { + for (var i = 0, l = attrs.length; i < l; i++) { + attr = attrs[i]; + attrName = attr.name; + if (axe.commons.aria.validateAttr(attrName) && allowed.indexOf(attrName) === -1) { + invalid.push(attrName + '="' + attr.nodeValue + '"'); + } + } + } + if (invalid.length) { + this.data(invalid); + return false; + } + return true; + } + }, { + id: 'aria-hidden-body', + evaluate: function evaluate(node, options) { + return node.getAttribute('aria-hidden') !== 'true'; + } + }, { + id: 'invalidrole', + evaluate: function evaluate(node, options) { + return !axe.commons.aria.isValidRole(node.getAttribute('role')); + } + }, { + id: 'aria-required-attr', + evaluate: function evaluate(node, options) { + var missing = []; + if (node.hasAttributes()) { + var attr, role = node.getAttribute('role'), required = axe.commons.aria.requiredAttr(role); + if (role && required) { + for (var i = 0, l = required.length; i < l; i++) { + attr = required[i]; + if (!node.getAttribute(attr)) { + missing.push(attr); + } + } + } + } + if (missing.length) { + this.data(missing); + return false; + } + return true; + } + }, { + id: 'aria-required-children', + evaluate: function evaluate(node, options) { + var requiredOwned = axe.commons.aria.requiredOwned, implicitNodes = axe.commons.aria.implicitNodes, matchesSelector = axe.commons.utils.matchesSelector, idrefs = axe.commons.dom.idrefs; + function owns(node, role, ariaOwned) { + if (node === null) { + return false; + } + var implicit = implicitNodes(role), selector = [ '[role="' + role + '"]' ]; + if (implicit) { + selector = selector.concat(implicit); + } + selector = selector.join(','); + return ariaOwned ? matchesSelector(node, selector) || !!node.querySelector(selector) : !!node.querySelector(selector); + } + function ariaOwns(nodes, role) { + var index, length; + for (index = 0, length = nodes.length; index < length; index++) { + if (nodes[index] === null) { + continue; + } + if (owns(nodes[index], role, true)) { + return true; + } + } + return false; + } + function missingRequiredChildren(node, childRoles, all) { + var i, l = childRoles.length, missing = [], ownedElements = idrefs(node, 'aria-owns'); + for (i = 0; i < l; i++) { + var r = childRoles[i]; + if (owns(node, r) || ariaOwns(ownedElements, r)) { + if (!all) { + return null; + } + } else { + if (all) { + missing.push(r); + } + } + } + if (missing.length) { + return missing; + } + if (!all && childRoles.length) { + return childRoles; + } + return null; + } + var role = node.getAttribute('role'); + var required = requiredOwned(role); + if (!required) { + return true; + } + var all = false; + var childRoles = required.one; + if (!childRoles) { + var all = true; + childRoles = required.all; + } + var missing = missingRequiredChildren(node, childRoles, all); + if (!missing) { + return true; + } + this.data(missing); + return false; + } + }, { + id: 'aria-required-parent', + evaluate: function evaluate(node, options) { + function getSelector(role) { + var impliedNative = axe.commons.aria.implicitNodes(role) || []; + return impliedNative.concat('[role="' + role + '"]').join(','); + } + function getMissingContext(element, requiredContext, includeElement) { + var index, length, role = element.getAttribute('role'), missing = []; + if (!requiredContext) { + requiredContext = axe.commons.aria.requiredContext(role); + } + if (!requiredContext) { + return null; + } + for (index = 0, length = requiredContext.length; index < length; index++) { + if (includeElement && axe.utils.matchesSelector(element, getSelector(requiredContext[index]))) { + return null; + } + if (axe.commons.dom.findUp(element, getSelector(requiredContext[index]))) { + return null; + } else { + missing.push(requiredContext[index]); + } + } + return missing; + } + function getAriaOwners(element) { + var owners = [], o = null; + while (element) { + if (element.id) { + o = document.querySelector('[aria-owns~=' + axe.commons.utils.escapeSelector(element.id) + ']'); + if (o) { + owners.push(o); + } + } + element = element.parentNode; + } + return owners.length ? owners : null; + } + var missingParents = getMissingContext(node); + if (!missingParents) { + return true; + } + var owners = getAriaOwners(node); + if (owners) { + for (var i = 0, l = owners.length; i < l; i++) { + missingParents = getMissingContext(owners[i], missingParents, true); + if (!missingParents) { + return true; + } + } + } + this.data(missingParents); + return false; + } + }, { + id: 'aria-valid-attr-value', + evaluate: function evaluate(node, options) { + options = Array.isArray(options) ? options : []; + var invalid = [], aria = /^aria-/; + var attr, attrName, attrs = node.attributes; + for (var i = 0, l = attrs.length; i < l; i++) { + attr = attrs[i]; + attrName = attr.name; + if (options.indexOf(attrName) === -1 && aria.test(attrName) && !axe.commons.aria.validateAttrValue(node, attrName)) { + invalid.push(attrName + '="' + attr.nodeValue + '"'); + } + } + if (invalid.length) { + this.data(invalid); + return false; + } + return true; + }, + options: [] + }, { + id: 'aria-valid-attr', + evaluate: function evaluate(node, options) { + options = Array.isArray(options) ? options : []; + var invalid = [], aria = /^aria-/; + var attr, attrs = node.attributes; + for (var i = 0, l = attrs.length; i < l; i++) { + attr = attrs[i].name; + if (options.indexOf(attr) === -1 && aria.test(attr) && !axe.commons.aria.validateAttr(attr)) { + invalid.push(attr); + } + } + if (invalid.length) { + this.data(invalid); + return false; + } + return true; + }, + options: [] + }, { + id: 'color-contrast', + evaluate: function evaluate(node, options) { + if (!axe.commons.dom.isVisible(node, false)) { + return true; + } + var noScroll = !!(options || {}).noScroll; + var bgNodes = [], bgColor = axe.commons.color.getBackgroundColor(node, bgNodes, noScroll), fgColor = axe.commons.color.getForegroundColor(node, noScroll); + var nodeStyle = window.getComputedStyle(node); + var fontSize = parseFloat(nodeStyle.getPropertyValue('font-size')); + var fontWeight = nodeStyle.getPropertyValue('font-weight'); + var bold = [ 'bold', 'bolder', '600', '700', '800', '900' ].indexOf(fontWeight) !== -1; + var cr = axe.commons.color.hasValidContrastRatio(bgColor, fgColor, fontSize, bold); + var truncatedResult = Math.floor(cr.contrastRatio * 100) / 100; + var missing; + if (bgColor === null) { + missing = axe.commons.color.incompleteData.get('bgColor'); + } + var equalRatio = false; + if (truncatedResult === 1) { + equalRatio = true; + missing = axe.commons.color.incompleteData.set('bgColor', 'equalRatio'); + } + var data = { + fgColor: fgColor ? fgColor.toHexString() : undefined, + bgColor: bgColor ? bgColor.toHexString() : undefined, + contrastRatio: cr ? truncatedResult : undefined, + fontSize: (fontSize * 72 / 96).toFixed(1) + 'pt', + fontWeight: bold ? 'bold' : 'normal', + missingData: missing + }; + this.data(data); + if (!cr.isValid || equalRatio) { + this.relatedNodes(bgNodes); + } + if (fgColor === null || bgColor === null || equalRatio) { + missing = null; + axe.commons.color.incompleteData.clear(); + return undefined; + } + return cr.isValid; + } + }, { + id: 'link-in-text-block', + evaluate: function evaluate(node, options) { + var color = axe.commons.color; + function getContrast(color1, color2) { + var c1lum = color1.getRelativeLuminance(); + var c2lum = color2.getRelativeLuminance(); + return (Math.max(c1lum, c2lum) + .05) / (Math.min(c1lum, c2lum) + .05); + } + var blockLike = [ 'block', 'list-item', 'table', 'flex', 'grid', 'inline-block' ]; + function isBlock(elm) { + var display = window.getComputedStyle(elm).getPropertyValue('display'); + return blockLike.indexOf(display) !== -1 || display.substr(0, 6) === 'table-'; + } + if (isBlock(node)) { + return false; + } + var parentBlock = node.parentNode; + while (parentBlock.nodeType === 1 && !isBlock(parentBlock)) { + parentBlock = parentBlock.parentNode; + } + if (color.elementIsDistinct(node, parentBlock)) { + return true; + } else { + var nodeColor, parentColor; + nodeColor = color.getForegroundColor(node); + parentColor = color.getForegroundColor(parentBlock); + if (!nodeColor || !parentColor) { + return undefined; + } + var contrast = getContrast(nodeColor, parentColor); + if (contrast === 1) { + return true; + } else if (contrast >= 3) { + axe.commons.color.incompleteData.set('fgColor', 'bgContrast'); + this.data({ + missingData: axe.commons.color.incompleteData.get('fgColor') + }); + axe.commons.color.incompleteData.clear(); + return undefined; + } + nodeColor = color.getBackgroundColor(node); + parentColor = color.getBackgroundColor(parentBlock); + if (!nodeColor || !parentColor || getContrast(nodeColor, parentColor) >= 3) { + var reason = void 0; + if (!nodeColor || !parentColor) { + reason = axe.commons.color.incompleteData.get('bgColor'); + } else { + reason = 'bgContrast'; + } + axe.commons.color.incompleteData.set('fgColor', reason); + this.data({ + missingData: axe.commons.color.incompleteData.get('fgColor') + }); + axe.commons.color.incompleteData.clear(); + return undefined; + } + } + return false; + } + }, { + id: 'fieldset', + evaluate: function evaluate(node, options) { + var failureCode, self = this; + function getUnrelatedElements(parent, name) { + return axe.commons.utils.toArray(parent.querySelectorAll('select,textarea,button,input:not([name="' + name + '"]):not([type="hidden"])')); + } + function checkFieldset(group, name) { + var firstNode = group.firstElementChild; + if (!firstNode || firstNode.nodeName.toUpperCase() !== 'LEGEND') { + self.relatedNodes([ group ]); + failureCode = 'no-legend'; + return false; + } + if (!axe.commons.text.accessibleText(firstNode)) { + self.relatedNodes([ firstNode ]); + failureCode = 'empty-legend'; + return false; + } + var otherElements = getUnrelatedElements(group, name); + if (otherElements.length) { + self.relatedNodes(otherElements); + failureCode = 'mixed-inputs'; + return false; + } + return true; + } + function checkARIAGroup(group, name) { + var hasLabelledByText = axe.commons.dom.idrefs(group, 'aria-labelledby').some(function(element) { + return element && axe.commons.text.accessibleText(element); + }); + var ariaLabel = group.getAttribute('aria-label'); + if (!hasLabelledByText && !(ariaLabel && axe.commons.text.sanitize(ariaLabel))) { + self.relatedNodes(group); + failureCode = 'no-group-label'; + return false; + } + var otherElements = getUnrelatedElements(group, name); + if (otherElements.length) { + self.relatedNodes(otherElements); + failureCode = 'group-mixed-inputs'; + return false; + } + return true; + } + function spliceCurrentNode(nodes, current) { + return axe.commons.utils.toArray(nodes).filter(function(candidate) { + return candidate !== current; + }); + } + function runCheck(element) { + var name = axe.commons.utils.escapeSelector(node.name); + var matchingNodes = document.querySelectorAll('input[type="' + axe.commons.utils.escapeSelector(node.type) + '"][name="' + name + '"]'); + if (matchingNodes.length < 2) { + return true; + } + var fieldset = axe.commons.dom.findUp(element, 'fieldset'); + var group = axe.commons.dom.findUp(element, '[role="group"]' + (node.type === 'radio' ? ',[role="radiogroup"]' : '')); + if (!group && !fieldset) { + failureCode = 'no-group'; + self.relatedNodes(spliceCurrentNode(matchingNodes, element)); + return false; + } + return fieldset ? checkFieldset(fieldset, name) : checkARIAGroup(group, name); + } + var data = { + name: node.getAttribute('name'), + type: node.getAttribute('type') + }; + var result = runCheck(node); + if (!result) { + data.failureCode = failureCode; + } + this.data(data); + return result; + }, + after: function after(results, options) { + var seen = {}; + return results.filter(function(result) { + if (result.result) { + return true; + } + var data = result.data; + if (data) { + seen[data.type] = seen[data.type] || {}; + if (!seen[data.type][data.name]) { + seen[data.type][data.name] = [ data ]; + return true; + } + var hasBeenSeen = seen[data.type][data.name].some(function(candidate) { + return candidate.failureCode === data.failureCode; + }); + if (!hasBeenSeen) { + seen[data.type][data.name].push(data); + } + return !hasBeenSeen; + } + return false; + }); + } + }, { + id: 'group-labelledby', + evaluate: function evaluate(node, options) { + this.data({ + name: node.getAttribute('name'), + type: node.getAttribute('type') + }); + var matchingNodes = document.querySelectorAll('input[type="' + axe.commons.utils.escapeSelector(node.type) + '"][name="' + axe.commons.utils.escapeSelector(node.name) + '"]'); + if (matchingNodes.length <= 1) { + return true; + } + return [].map.call(matchingNodes, function(m) { + var l = m.getAttribute('aria-labelledby'); + return l ? l.split(/\s+/) : []; + }).reduce(function(prev, curr) { + return prev.filter(function(n) { + return curr.indexOf(n) !== -1; + }); + }).filter(function(n) { + var labelNode = document.getElementById(n); + return labelNode && axe.commons.text.accessibleText(labelNode); + }).length !== 0; + }, + after: function after(results, options) { + var seen = {}; + return results.filter(function(result) { + var data = result.data; + if (data) { + seen[data.type] = seen[data.type] || {}; + if (!seen[data.type][data.name]) { + seen[data.type][data.name] = true; + return true; + } + } + return false; + }); + } + }, { + id: 'accesskeys', + evaluate: function evaluate(node, options) { + if (axe.commons.dom.isVisible(node, false)) { + this.data(node.getAttribute('accesskey')); + this.relatedNodes([ node ]); + } + return true; + }, + after: function after(results, options) { + var seen = {}; + return results.filter(function(r) { + if (!r.data) { + return false; + } + var key = r.data.toUpperCase(); + if (!seen[key]) { + seen[key] = r; + r.relatedNodes = []; + return true; + } + seen[key].relatedNodes.push(r.relatedNodes[0]); + return false; + }).map(function(r) { + r.result = !!r.relatedNodes.length; + return r; + }); + } + }, { + id: 'focusable-no-name', + evaluate: function evaluate(node, options) { + var tabIndex = node.getAttribute('tabindex'), isFocusable = axe.commons.dom.isFocusable(node) && tabIndex > -1; + if (!isFocusable) { + return false; + } + return !axe.commons.text.accessibleText(node); + } + }, { + id: 'tabindex', + evaluate: function evaluate(node, options) { + return node.tabIndex <= 0; + } + }, { + id: 'duplicate-img-label', + evaluate: function evaluate(node, options) { + var imgs = node.querySelectorAll('img'); + var text = axe.commons.text.visible(node, true).toLowerCase(); + if (text === '') { + return false; + } + for (var i = 0, len = imgs.length; i < len; i++) { + var img = imgs[i]; + var imgAlt = axe.commons.text.accessibleText(img).toLowerCase(); + if (imgAlt === text && img.getAttribute('role') !== 'presentation' && axe.commons.dom.isVisible(img)) { + return true; + } + } + return false; + } + }, { + id: 'explicit-label', + evaluate: function evaluate(node, options) { + if (node.id) { + var label = document.querySelector('label[for="' + axe.commons.utils.escapeSelector(node.id) + '"]'); + if (label) { + return !!axe.commons.text.accessibleText(label); + } + } + return false; + } + }, { + id: 'help-same-as-label', + evaluate: function evaluate(node, options) { + var labelText = axe.commons.text.label(node), check = node.getAttribute('title'); + if (!labelText) { + return false; + } + if (!check) { + check = ''; + if (node.getAttribute('aria-describedby')) { + var ref = axe.commons.dom.idrefs(node, 'aria-describedby'); + check = ref.map(function(thing) { + return thing ? axe.commons.text.accessibleText(thing) : ''; + }).join(''); + } + } + return axe.commons.text.sanitize(check) === axe.commons.text.sanitize(labelText); + }, + enabled: false + }, { + id: 'implicit-label', + evaluate: function evaluate(node, options) { + var label = axe.commons.dom.findUp(node, 'label'); + if (label) { + return !!axe.commons.text.accessibleText(label); + } + return false; + } + }, { + id: 'multiple-label', + evaluate: function evaluate(node, options) { + var labels = [].slice.call(document.querySelectorAll('label[for="' + axe.commons.utils.escapeSelector(node.id) + '"]')), parent = node.parentNode; + if (labels.length) { + labels = labels.filter(function(label, index) { + if (index === 0 && !axe.commons.dom.isVisible(label, true) || axe.commons.dom.isVisible(label, true)) { + return label; + } + }); + } + while (parent) { + if (parent.tagName === 'LABEL' && labels.indexOf(parent) === -1) { + labels.push(parent); + } + parent = parent.parentNode; + } + this.relatedNodes(labels); + return labels.length > 1; + } + }, { + id: 'title-only', + evaluate: function evaluate(node, options) { + var labelText = axe.commons.text.label(node); + return !labelText && !!(node.getAttribute('title') || node.getAttribute('aria-describedby')); + } + }, { + id: 'has-lang', + evaluate: function evaluate(node, options) { + return !!(node.getAttribute('lang') || node.getAttribute('xml:lang') || '').trim(); + } + }, { + id: 'valid-lang', + evaluate: function evaluate(node, options) { + function getBaseLang(lang) { + return lang.trim().split('-')[0].toLowerCase(); + } + var langs, invalid; + langs = (options ? options : axe.commons.utils.validLangs()).map(getBaseLang); + invalid = [ 'lang', 'xml:lang' ].reduce(function(invalid, langAttr) { + var langVal = node.getAttribute(langAttr); + if (typeof langVal !== 'string') { + return invalid; + } + var baselangVal = getBaseLang(langVal); + if (baselangVal !== '' && langs.indexOf(baselangVal) === -1) { + invalid.push(langAttr + '="' + node.getAttribute(langAttr) + '"'); + } + return invalid; + }, []); + if (invalid.length) { + this.data(invalid); + return true; + } + return false; + } + }, { + id: 'dlitem', + evaluate: function evaluate(node, options) { + return node.parentNode.tagName === 'DL'; + } + }, { + id: 'has-listitem', + evaluate: function evaluate(node, options) { + var children = node.children; + if (children.length === 0) { + return true; + } + for (var i = 0; i < children.length; i++) { + if (children[i].nodeName.toUpperCase() === 'LI') { + return false; + } + } + return true; + } + }, { + id: 'listitem', + evaluate: function evaluate(node, options) { + if ([ 'UL', 'OL' ].indexOf(node.parentNode.nodeName.toUpperCase()) !== -1) { + return true; + } + return node.parentNode.getAttribute('role') === 'list'; + } + }, { + id: 'only-dlitems', + evaluate: function evaluate(node, options) { + var child, nodeName, bad = [], children = node.childNodes, permitted = [ 'STYLE', 'META', 'LINK', 'MAP', 'AREA', 'SCRIPT', 'DATALIST', 'TEMPLATE' ], hasNonEmptyTextNode = false; + for (var i = 0; i < children.length; i++) { + child = children[i]; + var nodeName = child.nodeName.toUpperCase(); + if (child.nodeType === 1 && nodeName !== 'DT' && nodeName !== 'DD' && permitted.indexOf(nodeName) === -1) { + bad.push(child); + } else if (child.nodeType === 3 && child.nodeValue.trim() !== '') { + hasNonEmptyTextNode = true; + } + } + if (bad.length) { + this.relatedNodes(bad); + } + var retVal = !!bad.length || hasNonEmptyTextNode; + return retVal; + } + }, { + id: 'only-listitems', + evaluate: function evaluate(node, options) { + var child, nodeName, bad = [], children = node.childNodes, permitted = [ 'STYLE', 'META', 'LINK', 'MAP', 'AREA', 'SCRIPT', 'DATALIST', 'TEMPLATE' ], hasNonEmptyTextNode = false; + for (var i = 0; i < children.length; i++) { + child = children[i]; + nodeName = child.nodeName.toUpperCase(); + if (child.nodeType === 1 && nodeName !== 'LI' && permitted.indexOf(nodeName) === -1) { + bad.push(child); + } else if (child.nodeType === 3 && child.nodeValue.trim() !== '') { + hasNonEmptyTextNode = true; + } + } + if (bad.length) { + this.relatedNodes(bad); + } + return !!bad.length || hasNonEmptyTextNode; + } + }, { + id: 'structured-dlitems', + evaluate: function evaluate(node, options) { + var children = node.children; + if (!children || !children.length) { + return false; + } + var hasDt = false, hasDd = false, nodeName; + for (var i = 0; i < children.length; i++) { + nodeName = children[i].nodeName.toUpperCase(); + if (nodeName === 'DT') { + hasDt = true; + } + if (hasDt && nodeName === 'DD') { + return false; + } + if (nodeName === 'DD') { + hasDd = true; + } + } + return hasDt || hasDd; + } + }, { + id: 'caption', + evaluate: function evaluate(node, options) { + var tracks = node.querySelectorAll('track'); + if (tracks.length) { + for (var i = 0; i < tracks.length; i++) { + var kind = tracks[i].getAttribute('kind'); + if (kind && kind === 'captions') { + return false; + } + } + return true; + } + return undefined; + } + }, { + id: 'description', + evaluate: function evaluate(node, options) { + var tracks = node.querySelectorAll('track'); + if (tracks.length) { + for (var i = 0; i < tracks.length; i++) { + var kind = tracks[i].getAttribute('kind'); + if (kind && kind === 'descriptions') { + return false; + } + } + return true; + } + return undefined; + } + }, { + id: 'meta-viewport-large', + evaluate: function evaluate(node, options) { + options = options || {}; + var params, content = node.getAttribute('content') || '', parsedParams = content.split(/[;,]/), result = {}, minimum = options.scaleMinimum || 2, lowerBound = options.lowerBound || false; + for (var i = 0, l = parsedParams.length; i < l; i++) { + params = parsedParams[i].split('='); + var key = params.shift().toLowerCase(); + if (key && params.length) { + result[key.trim()] = params.shift().trim().toLowerCase(); + } + } + if (lowerBound && result['maximum-scale'] && parseFloat(result['maximum-scale']) < lowerBound) { + return true; + } + if (!lowerBound && result['user-scalable'] === 'no') { + return false; + } + if (result['maximum-scale'] && parseFloat(result['maximum-scale']) < minimum) { + return false; + } + return true; + }, + options: { + scaleMinimum: 5, + lowerBound: 2 + } + }, { + id: 'meta-viewport', + evaluate: function evaluate(node, options) { + options = options || {}; + var params, content = node.getAttribute('content') || '', parsedParams = content.split(/[;,]/), result = {}, minimum = options.scaleMinimum || 2, lowerBound = options.lowerBound || false; + for (var i = 0, l = parsedParams.length; i < l; i++) { + params = parsedParams[i].split('='); + var key = params.shift().toLowerCase(); + if (key && params.length) { + result[key.trim()] = params.shift().trim().toLowerCase(); + } + } + if (lowerBound && result['maximum-scale'] && parseFloat(result['maximum-scale']) < lowerBound) { + return true; + } + if (!lowerBound && result['user-scalable'] === 'no') { + return false; + } + if (result['maximum-scale'] && parseFloat(result['maximum-scale']) < minimum) { + return false; + } + return true; + }, + options: { + scaleMinimum: 2 + } + }, { + id: 'header-present', + evaluate: function evaluate(node, options) { + return !!node.querySelector('h1, h2, h3, h4, h5, h6, [role="heading"]'); + } + }, { + id: 'heading-order', + evaluate: function evaluate(node, options) { + var ariaHeadingLevel = node.getAttribute('aria-level'); + if (ariaHeadingLevel !== null) { + this.data(parseInt(ariaHeadingLevel, 10)); + return true; + } + var headingLevel = node.tagName.match(/H(\d)/); + if (headingLevel) { + this.data(parseInt(headingLevel[1], 10)); + return true; + } + return true; + }, + after: function after(results, options) { + if (results.length < 2) { + return results; + } + var prevLevel = results[0].data; + for (var i = 1; i < results.length; i++) { + if (results[i].result && results[i].data > prevLevel + 1) { + results[i].result = false; + } + prevLevel = results[i].data; + } + return results; + } + }, { + id: 'href-no-hash', + evaluate: function evaluate(node, options) { + var href = node.getAttribute('href'); + if (href === '#') { + return false; + } + return true; + } + }, { + id: 'internal-link-present', + evaluate: function evaluate(node, options) { + return !!node.querySelector('a[href^="#"]'); + } + }, { + id: 'landmark', + evaluate: function evaluate(node, options) { + return node.getElementsByTagName('main').length > 0 || !!node.querySelector('[role="main"]'); + } + }, { + id: 'meta-refresh', + evaluate: function evaluate(node, options) { + var content = node.getAttribute('content') || '', parsedParams = content.split(/[;,]/); + return content === '' || parsedParams[0] === '0'; + } + }, { + id: 'p-as-heading', + evaluate: function evaluate(node, options) { + var siblings = Array.from(node.parentNode.children); + var currentIndex = siblings.indexOf(node); + options = options || {}; + var margins = options.margins || []; + var nextSibling = siblings.slice(currentIndex + 1).find(function(elm) { + return elm.nodeName.toUpperCase() === 'P'; + }); + var prevSibling = siblings.slice(0, currentIndex).reverse().find(function(elm) { + return elm.nodeName.toUpperCase() === 'P'; + }); + function getTextContainer(elm) { + var nextNode = elm; + var outerText = elm.textContent.trim(); + var innerText = outerText; + while (innerText === outerText && nextNode !== undefined) { + var i = -1; + elm = nextNode; + if (elm.children.length === 0) { + return elm; + } + do { + i++; + innerText = elm.children[i].textContent.trim(); + } while (innerText === '' && i + 1 < elm.children.length); + nextNode = elm.children[i]; + } + return elm; + } + function normalizeFontWeight(weight) { + switch (weight) { + case 'lighter': + return 100; + + case 'normal': + return 400; + + case 'bold': + return 700; + + case 'bolder': + return 900; + } + weight = parseInt(weight); + return !isNaN(weight) ? weight : 400; + } + function getStyleValues(node) { + var style = window.getComputedStyle(getTextContainer(node)); + return { + fontWeight: normalizeFontWeight(style.getPropertyValue('font-weight')), + fontSize: parseInt(style.getPropertyValue('font-size')), + isItalic: style.getPropertyValue('font-style') === 'italic' + }; + } + function isHeaderStyle(styleA, styleB, margins) { + return margins.reduce(function(out, margin) { + return out || (!margin.size || styleA.fontSize / margin.size > styleB.fontSize) && (!margin.weight || styleA.fontWeight - margin.weight > styleB.fontWeight) && (!margin.italic || styleA.isItalic && !styleB.isItalic); + }, false); + } + var currStyle = getStyleValues(node); + var nextStyle = nextSibling ? getStyleValues(nextSibling) : null; + var prevStyle = prevSibling ? getStyleValues(prevSibling) : null; + if (!nextStyle || !isHeaderStyle(currStyle, nextStyle, margins)) { + return true; + } + var blockquote = axe.commons.dom.findUp(node, 'blockquote'); + if (blockquote && blockquote.nodeName.toUpperCase() === 'BLOCKQUOTE') { + return undefined; + } + if (prevStyle && !isHeaderStyle(currStyle, prevStyle, margins)) { + return undefined; + } + return false; + }, + options: { + margins: [ { + weight: 150, + italic: true + }, { + weight: 150, + size: 1.15 + }, { + italic: true, + size: 1.15 + }, { + size: 1.4 + } ] + } + }, { + id: 'region', + evaluate: function evaluate(node, options) { + var landmarkRoles = axe.commons.aria.getRolesByType('landmark'), firstLink = node.querySelector('a[href]'); + function isSkipLink(n) { + return firstLink && axe.commons.dom.isFocusable(axe.commons.dom.getElementByReference(firstLink, 'href')) && firstLink === n; + } + function isLandmark(n) { + var role = n.getAttribute('role'); + return role && landmarkRoles.indexOf(role) !== -1; + } + function checkRegion(n) { + if (isLandmark(n)) { + return null; + } + if (isSkipLink(n)) { + return getViolatingChildren(n); + } + if (axe.commons.dom.isVisible(n, true) && (axe.commons.text.visible(n, true, true) || axe.commons.dom.isVisualContent(n))) { + return n; + } + return getViolatingChildren(n); + } + function getViolatingChildren(n) { + var children = axe.commons.utils.toArray(n.children); + if (children.length === 0) { + return []; + } + return children.map(checkRegion).filter(function(c) { + return c !== null; + }).reduce(function(a, b) { + return a.concat(b); + }, []); + } + var v = getViolatingChildren(node); + this.relatedNodes(v); + return !v.length; + }, + after: function after(results, options) { + return [ results[0] ]; + } + }, { + id: 'skip-link', + evaluate: function evaluate(node, options) { + return axe.commons.dom.isFocusable(axe.commons.dom.getElementByReference(node, 'href')); + }, + after: function after(results, options) { + return [ results[0] ]; + } + }, { + id: 'unique-frame-title', + evaluate: function evaluate(node, options) { + var title = axe.commons.text.sanitize(node.title).trim().toLowerCase(); + this.data(title); + return true; + }, + after: function after(results, options) { + var titles = {}; + results.forEach(function(r) { + titles[r.data] = titles[r.data] !== undefined ? ++titles[r.data] : 0; + }); + results.forEach(function(r) { + r.result = !!titles[r.data]; + }); + return results; + } + }, { + id: 'aria-label', + evaluate: function evaluate(node, options) { + var label = node.getAttribute('aria-label'); + return !!(label ? axe.commons.text.sanitize(label).trim() : ''); + } + }, { + id: 'aria-labelledby', + evaluate: function evaluate(node, options) { + var getIdRefs = axe.commons.dom.idrefs; + return getIdRefs(node, 'aria-labelledby').some(function(elm) { + return elm && axe.commons.text.accessibleText(elm, true); + }); + } + }, { + id: 'button-has-visible-text', + evaluate: function evaluate(node, options) { + var nodeName = node.nodeName.toUpperCase(); + var role = node.getAttribute('role'); + var label = void 0; + if (nodeName === 'BUTTON' || role === 'button' && nodeName !== 'INPUT') { + label = axe.commons.text.accessibleText(node); + this.data(label); + return !!label; + } else { + return false; + } + } + }, { + id: 'doc-has-title', + evaluate: function evaluate(node, options) { + var title = document.title; + return !!(title ? axe.commons.text.sanitize(title).trim() : ''); + } + }, { + id: 'duplicate-id', + evaluate: function evaluate(node, options) { + if (!node.id.trim()) { + return true; + } + var matchingNodes = document.querySelectorAll('[id="' + axe.commons.utils.escapeSelector(node.id) + '"]'); + var related = []; + for (var i = 0; i < matchingNodes.length; i++) { + if (matchingNodes[i] !== node) { + related.push(matchingNodes[i]); + } + } + if (related.length) { + this.relatedNodes(related); + } + this.data(node.getAttribute('id')); + return matchingNodes.length <= 1; + }, + after: function after(results, options) { + var uniqueIds = []; + return results.filter(function(r) { + if (uniqueIds.indexOf(r.data) === -1) { + uniqueIds.push(r.data); + return true; + } + return false; + }); + } + }, { + id: 'exists', + evaluate: function evaluate(node, options) { + return true; + } + }, { + id: 'has-alt', + evaluate: function evaluate(node, options) { + var nn = node.nodeName.toLowerCase(); + return node.hasAttribute('alt') && (nn === 'img' || nn === 'input' || nn === 'area'); + } + }, { + id: 'has-visible-text', + evaluate: function evaluate(node, options) { + return axe.commons.text.accessibleText(node).length > 0; + } + }, { + id: 'is-on-screen', + evaluate: function evaluate(node, options) { + return axe.commons.dom.isVisible(node, false) && !axe.commons.dom.isOffscreen(node); + } + }, { + id: 'non-empty-alt', + evaluate: function evaluate(node, options) { + var label = node.getAttribute('alt'); + return !!(label ? axe.commons.text.sanitize(label).trim() : ''); + } + }, { + id: 'non-empty-if-present', + evaluate: function evaluate(node, options) { + var nodeName = node.nodeName.toUpperCase(); + var type = (node.getAttribute('type') || '').toLowerCase(); + var label = node.getAttribute('value'); + this.data(label); + if (nodeName === 'INPUT' && [ 'submit', 'reset' ].indexOf(type) !== -1) { + return label === null; + } + return false; + } + }, { + id: 'non-empty-title', + evaluate: function evaluate(node, options) { + var title = node.getAttribute('title'); + return !!(title ? axe.commons.text.sanitize(title).trim() : ''); + } + }, { + id: 'non-empty-value', + evaluate: function evaluate(node, options) { + var label = node.getAttribute('value'); + return !!(label ? axe.commons.text.sanitize(label).trim() : ''); + } + }, { + id: 'role-none', + evaluate: function evaluate(node, options) { + return node.getAttribute('role') === 'none'; + } + }, { + id: 'role-presentation', + evaluate: function evaluate(node, options) { + return node.getAttribute('role') === 'presentation'; + } + }, { + id: 'caption-faked', + evaluate: function evaluate(node, options) { + var table = axe.commons.table.toGrid(node); + var firstRow = table[0]; + if (table.length <= 1 || firstRow.length <= 1 || node.rows.length <= 1) { + return true; + } + return firstRow.reduce(function(out, curr, i) { + return out || curr !== firstRow[i + 1] && firstRow[i + 1] !== undefined; + }, false); + } + }, { + id: 'has-caption', + evaluate: function evaluate(node, options) { + return !!node.caption; + } + }, { + id: 'has-summary', + evaluate: function evaluate(node, options) { + return !!node.summary; + } + }, { + id: 'has-th', + evaluate: function evaluate(node, options) { + var row, cell, badCells = []; + for (var rowIndex = 0, rowLength = node.rows.length; rowIndex < rowLength; rowIndex++) { + row = node.rows[rowIndex]; + for (var cellIndex = 0, cellLength = row.cells.length; cellIndex < cellLength; cellIndex++) { + cell = row.cells[cellIndex]; + if (cell.nodeName.toUpperCase() === 'TH' || [ 'rowheader', 'columnheader' ].indexOf(cell.getAttribute('role')) !== -1) { + badCells.push(cell); + } + } + } + if (badCells.length) { + this.relatedNodes(badCells); + return true; + } + return false; + } + }, { + id: 'html5-scope', + evaluate: function evaluate(node, options) { + if (!axe.commons.dom.isHTML5(document)) { + return true; + } + return node.nodeName.toUpperCase() === 'TH'; + } + }, { + id: 'same-caption-summary', + evaluate: function evaluate(node, options) { + return !!(node.summary && node.caption) && node.summary === axe.commons.text.accessibleText(node.caption); + } + }, { + id: 'scope-value', + evaluate: function evaluate(node, options) { + options = options || {}; + var value = node.getAttribute('scope').toLowerCase(); + var validVals = [ 'row', 'col', 'rowgroup', 'colgroup' ] || options.values; + return validVals.indexOf(value) !== -1; + } + }, { + id: 'td-has-header', + evaluate: function evaluate(node, options) { + var tableUtils = axe.commons.table; + var badCells = []; + var cells = tableUtils.getAllCells(node); + cells.forEach(function(cell) { + if (axe.commons.dom.hasContent(cell) && tableUtils.isDataCell(cell) && !axe.commons.aria.label(cell)) { + var hasHeaders = tableUtils.getHeaders(cell); + hasHeaders = hasHeaders.reduce(function(hasHeaders, header) { + return hasHeaders || header !== null && !!axe.commons.dom.hasContent(header); + }, false); + if (!hasHeaders) { + badCells.push(cell); + } + } + }); + if (badCells.length) { + this.relatedNodes(badCells); + return false; + } + return true; + } + }, { + id: 'td-headers-attr', + evaluate: function evaluate(node, options) { + var cells = []; + for (var rowIndex = 0, rowLength = node.rows.length; rowIndex < rowLength; rowIndex++) { + var row = node.rows[rowIndex]; + for (var cellIndex = 0, cellLength = row.cells.length; cellIndex < cellLength; cellIndex++) { + cells.push(row.cells[cellIndex]); + } + } + var ids = cells.reduce(function(ids, cell) { + if (cell.id) { + ids.push(cell.id); + } + return ids; + }, []); + var badCells = cells.reduce(function(badCells, cell) { + var isSelf, notOfTable; + var headers = (cell.getAttribute('headers') || '').split(/\s/).reduce(function(headers, header) { + header = header.trim(); + if (header) { + headers.push(header); + } + return headers; + }, []); + if (headers.length !== 0) { + if (cell.id) { + isSelf = headers.indexOf(cell.id.trim()) !== -1; + } + notOfTable = headers.reduce(function(fail, header) { + return fail || ids.indexOf(header) === -1; + }, false); + if (isSelf || notOfTable) { + badCells.push(cell); + } + } + return badCells; + }, []); + if (badCells.length > 0) { + this.relatedNodes(badCells); + return false; + } else { + return true; + } + } + }, { + id: 'th-has-data-cells', + evaluate: function evaluate(node, options) { + var tableUtils = axe.commons.table; + var cells = tableUtils.getAllCells(node); + var checkResult = this; + var reffedHeaders = []; + cells.forEach(function(cell) { + var headers = cell.getAttribute('headers'); + if (headers) { + reffedHeaders = reffedHeaders.concat(headers.split(/\s+/)); + } + var ariaLabel = cell.getAttribute('aria-labelledby'); + if (ariaLabel) { + reffedHeaders = reffedHeaders.concat(ariaLabel.split(/\s+/)); + } + }); + var headers = cells.filter(function(cell) { + if (axe.commons.text.sanitize(cell.textContent) === '') { + return false; + } + return cell.nodeName.toUpperCase() === 'TH' || [ 'rowheader', 'columnheader' ].indexOf(cell.getAttribute('role')) !== -1; + }); + var tableGrid = tableUtils.toGrid(node); + var out = headers.reduce(function(res, header) { + if (header.id && reffedHeaders.indexOf(header.id) !== -1) { + return !res ? res : true; + } + var hasCell = false; + var pos = tableUtils.getCellPosition(header, tableGrid); + if (tableUtils.isColumnHeader(header)) { + hasCell = tableUtils.traverse('down', pos, tableGrid).reduce(function(out, cell) { + return out || axe.commons.dom.hasContent(cell) && !tableUtils.isColumnHeader(cell); + }, false); + } + if (!hasCell && tableUtils.isRowHeader(header)) { + hasCell = tableUtils.traverse('right', pos, tableGrid).reduce(function(out, cell) { + return out || axe.commons.dom.hasContent(cell) && !tableUtils.isRowHeader(cell); + }, false); + } + if (!hasCell) { + checkResult.relatedNodes(header); + } + return res && hasCell; + }, true); + return out ? true : undefined; + } + }, { + id: 'hidden-content', + evaluate: function evaluate(node, options) { + var styles = window.getComputedStyle(node); + var whitelist = [ 'SCRIPT', 'HEAD', 'TITLE', 'NOSCRIPT', 'STYLE', 'TEMPLATE' ]; + if (!whitelist.includes(node.tagName.toUpperCase()) && axe.commons.dom.hasContent(node)) { + if (styles.getPropertyValue('display') === 'none') { + return undefined; + } else if (styles.getPropertyValue('visibility') === 'hidden') { + if (node.parentNode) { + var parentStyle = window.getComputedStyle(node.parentNode); + } + if (!parentStyle || parentStyle.getPropertyValue('visibility') !== 'hidden') { + return undefined; + } + } + } + return true; + } + } ], + commons: function() { + var commons = {}; + var aria = commons.aria = {}, lookupTables = aria._lut = {}; + lookupTables.attributes = { + 'aria-activedescendant': { + type: 'idref' + }, + 'aria-atomic': { + type: 'boolean', + values: [ 'true', 'false' ] + }, + 'aria-autocomplete': { + type: 'nmtoken', + values: [ 'inline', 'list', 'both', 'none' ] + }, + 'aria-busy': { + type: 'boolean', + values: [ 'true', 'false' ] + }, + 'aria-checked': { + type: 'nmtoken', + values: [ 'true', 'false', 'mixed', 'undefined' ] + }, + 'aria-colcount': { + type: 'int' + }, + 'aria-colindex': { + type: 'int' + }, + 'aria-colspan': { + type: 'int' + }, + 'aria-controls': { + type: 'idrefs' + }, + 'aria-current': { + type: 'nmtoken', + values: [ 'page', 'step', 'location', 'date', 'time', 'true', 'false' ] + }, + 'aria-describedby': { + type: 'idrefs' + }, + 'aria-disabled': { + type: 'boolean', + values: [ 'true', 'false' ] + }, + 'aria-dropeffect': { + type: 'nmtokens', + values: [ 'copy', 'move', 'reference', 'execute', 'popup', 'none' ] + }, + 'aria-expanded': { + type: 'nmtoken', + values: [ 'true', 'false', 'undefined' ] + }, + 'aria-flowto': { + type: 'idrefs' + }, + 'aria-grabbed': { + type: 'nmtoken', + values: [ 'true', 'false', 'undefined' ] + }, + 'aria-haspopup': { + type: 'boolean', + values: [ 'true', 'false' ] + }, + 'aria-hidden': { + type: 'boolean', + values: [ 'true', 'false' ] + }, + 'aria-invalid': { + type: 'nmtoken', + values: [ 'true', 'false', 'spelling', 'grammar' ] + }, + 'aria-label': { + type: 'string' + }, + 'aria-labelledby': { + type: 'idrefs' + }, + 'aria-level': { + type: 'int' + }, + 'aria-live': { + type: 'nmtoken', + values: [ 'off', 'polite', 'assertive' ] + }, + 'aria-multiline': { + type: 'boolean', + values: [ 'true', 'false' ] + }, + 'aria-multiselectable': { + type: 'boolean', + values: [ 'true', 'false' ] + }, + 'aria-orientation': { + type: 'nmtoken', + values: [ 'horizontal', 'vertical' ] + }, + 'aria-owns': { + type: 'idrefs' + }, + 'aria-posinset': { + type: 'int' + }, + 'aria-pressed': { + type: 'nmtoken', + values: [ 'true', 'false', 'mixed', 'undefined' ] + }, + 'aria-readonly': { + type: 'boolean', + values: [ 'true', 'false' ] + }, + 'aria-relevant': { + type: 'nmtokens', + values: [ 'additions', 'removals', 'text', 'all' ] + }, + 'aria-required': { + type: 'boolean', + values: [ 'true', 'false' ] + }, + 'aria-rowcount': { + type: 'int' + }, + 'aria-rowindex': { + type: 'int' + }, + 'aria-rowspan': { + type: 'int' + }, + 'aria-selected': { + type: 'nmtoken', + values: [ 'true', 'false', 'undefined' ] + }, + 'aria-setsize': { + type: 'int' + }, + 'aria-sort': { + type: 'nmtoken', + values: [ 'ascending', 'descending', 'other', 'none' ] + }, + 'aria-valuemax': { + type: 'decimal' + }, + 'aria-valuemin': { + type: 'decimal' + }, + 'aria-valuenow': { + type: 'decimal' + }, + 'aria-valuetext': { + type: 'string' + } + }; + lookupTables.globalAttributes = [ 'aria-atomic', 'aria-busy', 'aria-controls', 'aria-current', 'aria-describedby', 'aria-disabled', 'aria-dropeffect', 'aria-flowto', 'aria-grabbed', 'aria-haspopup', 'aria-hidden', 'aria-invalid', 'aria-label', 'aria-labelledby', 'aria-live', 'aria-owns', 'aria-relevant' ]; + lookupTables.role = { + alert: { + type: 'widget', + attributes: { + allowed: [ 'aria-expanded' ] + }, + owned: null, + nameFrom: [ 'author' ], + context: null + }, + alertdialog: { + type: 'widget', + attributes: { + allowed: [ 'aria-expanded' ] + }, + owned: null, + nameFrom: [ 'author' ], + context: null + }, + application: { + type: 'landmark', + attributes: { + allowed: [ 'aria-expanded' ] + }, + owned: null, + nameFrom: [ 'author' ], + context: null + }, + article: { + type: 'structure', + attributes: { + allowed: [ 'aria-expanded' ] + }, + owned: null, + nameFrom: [ 'author' ], + context: null, + implicit: [ 'article' ] + }, + banner: { + type: 'landmark', + attributes: { + allowed: [ 'aria-expanded' ] + }, + owned: null, + nameFrom: [ 'author' ], + context: null, + implicit: [ 'header' ] + }, + button: { + type: 'widget', + attributes: { + allowed: [ 'aria-expanded', 'aria-pressed' ] + }, + owned: null, + nameFrom: [ 'author', 'contents' ], + context: null, + implicit: [ 'button', 'input[type="button"]', 'input[type="image"]', 'input[type="reset"]', 'input[type="submit"]', 'summary' ] + }, + cell: { + type: 'structure', + attributes: { + allowed: [ 'aria-colindex', 'aria-colspan', 'aria-rowindex', 'aria-rowspan' ] + }, + owned: null, + nameFrom: [ 'author', 'contents' ], + context: [ 'row' ], + implicit: [ 'td', 'th' ] + }, + checkbox: { + type: 'widget', + attributes: { + required: [ 'aria-checked' ] + }, + owned: null, + nameFrom: [ 'author', 'contents' ], + context: null, + implicit: [ 'input[type="checkbox"]' ] + }, + columnheader: { + type: 'structure', + attributes: { + allowed: [ 'aria-expanded', 'aria-sort', 'aria-readonly', 'aria-selected', 'aria-required' ] + }, + owned: null, + nameFrom: [ 'author', 'contents' ], + context: [ 'row' ], + implicit: [ 'th' ] + }, + combobox: { + type: 'composite', + attributes: { + required: [ 'aria-expanded' ], + allowed: [ 'aria-autocomplete', 'aria-required', 'aria-activedescendant' ] + }, + owned: { + all: [ 'listbox', 'textbox' ] + }, + nameFrom: [ 'author' ], + context: null + }, + command: { + nameFrom: [ 'author' ], + type: 'abstract' + }, + complementary: { + type: 'landmark', + attributes: { + allowed: [ 'aria-expanded' ] + }, + owned: null, + nameFrom: [ 'author' ], + context: null, + implicit: [ 'aside' ] + }, + composite: { + nameFrom: [ 'author' ], + type: 'abstract' + }, + contentinfo: { + type: 'landmark', + attributes: { + allowed: [ 'aria-expanded' ] + }, + owned: null, + nameFrom: [ 'author' ], + context: null, + implicit: [ 'footer' ] + }, + definition: { + type: 'structure', + attributes: { + allowed: [ 'aria-expanded' ] + }, + owned: null, + nameFrom: [ 'author' ], + context: null, + implicit: [ 'dd' ] + }, + dialog: { + type: 'widget', + attributes: { + allowed: [ 'aria-expanded' ] + }, + owned: null, + nameFrom: [ 'author' ], + context: null, + implicit: [ 'dialog' ] + }, + directory: { + type: 'structure', + attributes: { + allowed: [ 'aria-expanded' ] + }, + owned: null, + nameFrom: [ 'author', 'contents' ], + context: null + }, + document: { + type: 'structure', + attributes: { + allowed: [ 'aria-expanded' ] + }, + owned: null, + nameFrom: [ 'author' ], + context: null, + implicit: [ 'body' ] + }, + form: { + type: 'landmark', + attributes: { + allowed: [ 'aria-expanded' ] + }, + owned: null, + nameFrom: [ 'author' ], + context: null, + implicit: [ 'form' ] + }, + grid: { + type: 'composite', + attributes: { + allowed: [ 'aria-level', 'aria-multiselectable', 'aria-readonly', 'aria-activedescendant', 'aria-expanded' ] + }, + owned: { + one: [ 'rowgroup', 'row' ] + }, + nameFrom: [ 'author' ], + context: null, + implicit: [ 'table' ] + }, + gridcell: { + type: 'widget', + attributes: { + allowed: [ 'aria-selected', 'aria-readonly', 'aria-expanded', 'aria-required' ] + }, + owned: null, + nameFrom: [ 'author', 'contents' ], + context: [ 'row' ], + implicit: [ 'td', 'th' ] + }, + group: { + type: 'structure', + attributes: { + allowed: [ 'aria-activedescendant', 'aria-expanded' ] + }, + owned: null, + nameFrom: [ 'author' ], + context: null, + implicit: [ 'details', 'optgroup' ] + }, + heading: { + type: 'structure', + attributes: { + allowed: [ 'aria-level', 'aria-expanded' ] + }, + owned: null, + nameFrom: [ 'author', 'contents' ], + context: null, + implicit: [ 'h1', 'h2', 'h3', 'h4', 'h5', 'h6' ] + }, + img: { + type: 'structure', + attributes: { + allowed: [ 'aria-expanded' ] + }, + owned: null, + nameFrom: [ 'author' ], + context: null, + implicit: [ 'img' ] + }, + input: { + nameFrom: [ 'author' ], + type: 'abstract' + }, + landmark: { + nameFrom: [ 'author' ], + type: 'abstract' + }, + link: { + type: 'widget', + attributes: { + allowed: [ 'aria-expanded' ] + }, + owned: null, + nameFrom: [ 'author', 'contents' ], + context: null, + implicit: [ 'a[href]' ] + }, + list: { + type: 'structure', + attributes: { + allowed: [ 'aria-expanded' ] + }, + owned: { + all: [ 'listitem' ] + }, + nameFrom: [ 'author' ], + context: null, + implicit: [ 'ol', 'ul', 'dl' ] + }, + listbox: { + type: 'composite', + attributes: { + allowed: [ 'aria-activedescendant', 'aria-multiselectable', 'aria-required', 'aria-expanded' ] + }, + owned: { + all: [ 'option' ] + }, + nameFrom: [ 'author' ], + context: null, + implicit: [ 'select' ] + }, + listitem: { + type: 'structure', + attributes: { + allowed: [ 'aria-level', 'aria-posinset', 'aria-setsize', 'aria-expanded' ] + }, + owned: null, + nameFrom: [ 'author', 'contents' ], + context: [ 'list' ], + implicit: [ 'li', 'dt' ] + }, + log: { + type: 'widget', + attributes: { + allowed: [ 'aria-expanded' ] + }, + owned: null, + nameFrom: [ 'author' ], + context: null + }, + main: { + type: 'landmark', + attributes: { + allowed: [ 'aria-expanded' ] + }, + owned: null, + nameFrom: [ 'author' ], + context: null, + implicit: [ 'main' ] + }, + marquee: { + type: 'widget', + attributes: { + allowed: [ 'aria-expanded' ] + }, + owned: null, + nameFrom: [ 'author' ], + context: null + }, + math: { + type: 'structure', + attributes: { + allowed: [ 'aria-expanded' ] + }, + owned: null, + nameFrom: [ 'author' ], + context: null, + implicit: [ 'math' ] + }, + menu: { + type: 'composite', + attributes: { + allowed: [ 'aria-activedescendant', 'aria-expanded' ] + }, + owned: { + one: [ 'menuitem', 'menuitemradio', 'menuitemcheckbox' ] + }, + nameFrom: [ 'author' ], + context: null, + implicit: [ 'menu[type="context"]' ] + }, + menubar: { + type: 'composite', + attributes: { + allowed: [ 'aria-activedescendant', 'aria-expanded' ] + }, + owned: null, + nameFrom: [ 'author' ], + context: null + }, + menuitem: { + type: 'widget', + attributes: null, + owned: null, + nameFrom: [ 'author', 'contents' ], + context: [ 'menu', 'menubar' ], + implicit: [ 'menuitem[type="command"]' ] + }, + menuitemcheckbox: { + type: 'widget', + attributes: { + required: [ 'aria-checked' ] + }, + owned: null, + nameFrom: [ 'author', 'contents' ], + context: [ 'menu', 'menubar' ], + implicit: [ 'menuitem[type="checkbox"]' ] + }, + menuitemradio: { + type: 'widget', + attributes: { + allowed: [ 'aria-selected', 'aria-posinset', 'aria-setsize' ], + required: [ 'aria-checked' ] + }, + owned: null, + nameFrom: [ 'author', 'contents' ], + context: [ 'menu', 'menubar' ], + implicit: [ 'menuitem[type="radio"]' ] + }, + navigation: { + type: 'landmark', + attributes: { + allowed: [ 'aria-expanded' ] + }, + owned: null, + nameFrom: [ 'author' ], + context: null, + implicit: [ 'nav' ] + }, + none: { + type: 'structure', + attributes: null, + owned: null, + nameFrom: [ 'author' ], + context: null + }, + note: { + type: 'structure', + attributes: { + allowed: [ 'aria-expanded' ] + }, + owned: null, + nameFrom: [ 'author' ], + context: null + }, + option: { + type: 'widget', + attributes: { + allowed: [ 'aria-selected', 'aria-posinset', 'aria-setsize', 'aria-checked' ] + }, + owned: null, + nameFrom: [ 'author', 'contents' ], + context: [ 'listbox' ], + implicit: [ 'option' ] + }, + presentation: { + type: 'structure', + attributes: null, + owned: null, + nameFrom: [ 'author' ], + context: null + }, + progressbar: { + type: 'widget', + attributes: { + allowed: [ 'aria-valuetext', 'aria-valuenow', 'aria-valuemax', 'aria-valuemin' ] + }, + owned: null, + nameFrom: [ 'author' ], + context: null, + implicit: [ 'progress' ] + }, + radio: { + type: 'widget', + attributes: { + allowed: [ 'aria-selected', 'aria-posinset', 'aria-setsize' ], + required: [ 'aria-checked' ] + }, + owned: null, + nameFrom: [ 'author', 'contents' ], + context: null, + implicit: [ 'input[type="radio"]' ] + }, + radiogroup: { + type: 'composite', + attributes: { + allowed: [ 'aria-activedescendant', 'aria-required', 'aria-expanded' ] + }, + owned: { + all: [ 'radio' ] + }, + nameFrom: [ 'author' ], + context: null + }, + range: { + nameFrom: [ 'author' ], + type: 'abstract' + }, + region: { + type: 'structure', + attributes: { + allowed: [ 'aria-expanded' ] + }, + owned: null, + nameFrom: [ 'author' ], + context: null, + implicit: [ 'section' ] + }, + roletype: { + type: 'abstract' + }, + row: { + type: 'structure', + attributes: { + allowed: [ 'aria-level', 'aria-selected', 'aria-activedescendant', 'aria-expanded' ] + }, + owned: { + one: [ 'cell', 'columnheader', 'rowheader', 'gridcell' ] + }, + nameFrom: [ 'author', 'contents' ], + context: [ 'rowgroup', 'grid', 'treegrid', 'table' ], + implicit: [ 'tr' ] + }, + rowgroup: { + type: 'structure', + attributes: { + allowed: [ 'aria-activedescendant', 'aria-expanded' ] + }, + owned: { + all: [ 'row' ] + }, + nameFrom: [ 'author', 'contents' ], + context: [ 'grid', 'table' ], + implicit: [ 'tbody', 'thead', 'tfoot' ] + }, + rowheader: { + type: 'structure', + attributes: { + allowed: [ 'aria-sort', 'aria-required', 'aria-readonly', 'aria-expanded', 'aria-selected' ] + }, + owned: null, + nameFrom: [ 'author', 'contents' ], + context: [ 'row' ], + implicit: [ 'th' ] + }, + scrollbar: { + type: 'widget', + attributes: { + required: [ 'aria-controls', 'aria-orientation', 'aria-valuenow', 'aria-valuemax', 'aria-valuemin' ], + allowed: [ 'aria-valuetext' ] + }, + owned: null, + nameFrom: [ 'author' ], + context: null + }, + search: { + type: 'landmark', + attributes: { + allowed: [ 'aria-expanded' ] + }, + owned: null, + nameFrom: [ 'author' ], + context: null + }, + searchbox: { + type: 'widget', + attributes: { + allowed: [ 'aria-activedescendant', 'aria-autocomplete', 'aria-multiline', 'aria-readonly', 'aria-required' ] + }, + owned: null, + nameFrom: [ 'author' ], + context: null, + implicit: [ 'input[type="search"]' ] + }, + section: { + nameFrom: [ 'author', 'contents' ], + type: 'abstract' + }, + sectionhead: { + nameFrom: [ 'author', 'contents' ], + type: 'abstract' + }, + select: { + nameFrom: [ 'author' ], + type: 'abstract' + }, + separator: { + type: 'structure', + attributes: { + allowed: [ 'aria-expanded', 'aria-orientation' ] + }, + owned: null, + nameFrom: [ 'author' ], + context: null, + implicit: [ 'hr' ] + }, + slider: { + type: 'widget', + attributes: { + allowed: [ 'aria-valuetext', 'aria-orientation' ], + required: [ 'aria-valuenow', 'aria-valuemax', 'aria-valuemin' ] + }, + owned: null, + nameFrom: [ 'author' ], + context: null, + implicit: [ 'input[type="range"]' ] + }, + spinbutton: { + type: 'widget', + attributes: { + allowed: [ 'aria-valuetext', 'aria-required' ], + required: [ 'aria-valuenow', 'aria-valuemax', 'aria-valuemin' ] + }, + owned: null, + nameFrom: [ 'author' ], + context: null, + implicit: [ 'input[type="number"]' ] + }, + status: { + type: 'widget', + attributes: { + allowed: [ 'aria-expanded' ] + }, + owned: null, + nameFrom: [ 'author' ], + context: null, + implicit: [ 'output' ] + }, + structure: { + type: 'abstract' + }, + switch: { + type: 'widget', + attributes: { + required: [ 'aria-checked' ] + }, + owned: null, + nameFrom: [ 'author', 'contents' ], + context: null + }, + tab: { + type: 'widget', + attributes: { + allowed: [ 'aria-selected', 'aria-expanded' ] + }, + owned: null, + nameFrom: [ 'author', 'contents' ], + context: [ 'tablist' ] + }, + table: { + type: 'structure', + attributes: { + allowed: [ 'aria-colcount', 'aria-rowcount' ] + }, + owned: { + one: [ 'rowgroup', 'row' ] + }, + nameFrom: [ 'author' ], + context: null, + implicit: [ 'table' ] + }, + tablist: { + type: 'composite', + attributes: { + allowed: [ 'aria-activedescendant', 'aria-expanded', 'aria-level', 'aria-multiselectable' ] + }, + owned: { + all: [ 'tab' ] + }, + nameFrom: [ 'author' ], + context: null + }, + tabpanel: { + type: 'widget', + attributes: { + allowed: [ 'aria-expanded' ] + }, + owned: null, + nameFrom: [ 'author' ], + context: null + }, + text: { + type: 'structure', + owned: null, + nameFrom: [ 'author', 'contents' ], + context: null + }, + textbox: { + type: 'widget', + attributes: { + allowed: [ 'aria-activedescendant', 'aria-autocomplete', 'aria-multiline', 'aria-readonly', 'aria-required' ] + }, + owned: null, + nameFrom: [ 'author' ], + context: null, + implicit: [ 'input[type="text"]', 'input[type="email"]', 'input[type="password"]', 'input[type="tel"]', 'input[type="url"]', 'input:not([type])', 'textarea' ] + }, + timer: { + type: 'widget', + attributes: { + allowed: [ 'aria-expanded' ] + }, + owned: null, + nameFrom: [ 'author' ], + context: null + }, + toolbar: { + type: 'structure', + attributes: { + allowed: [ 'aria-activedescendant', 'aria-expanded' ] + }, + owned: null, + nameFrom: [ 'author' ], + context: null, + implicit: [ 'menu[type="toolbar"]' ] + }, + tooltip: { + type: 'widget', + attributes: { + allowed: [ 'aria-expanded' ] + }, + owned: null, + nameFrom: [ 'author', 'contents' ], + context: null + }, + tree: { + type: 'composite', + attributes: { + allowed: [ 'aria-activedescendant', 'aria-multiselectable', 'aria-required', 'aria-expanded' ] + }, + owned: { + all: [ 'treeitem' ] + }, + nameFrom: [ 'author' ], + context: null + }, + treegrid: { + type: 'composite', + attributes: { + allowed: [ 'aria-activedescendant', 'aria-expanded', 'aria-level', 'aria-multiselectable', 'aria-readonly', 'aria-required' ] + }, + owned: { + all: [ 'treeitem' ] + }, + nameFrom: [ 'author' ], + context: null + }, + treeitem: { + type: 'widget', + attributes: { + allowed: [ 'aria-checked', 'aria-selected', 'aria-expanded', 'aria-level', 'aria-posinset', 'aria-setsize' ] + }, + owned: null, + nameFrom: [ 'author', 'contents' ], + context: [ 'treegrid', 'tree' ] + }, + widget: { + type: 'abstract' + }, + window: { + nameFrom: [ 'author' ], + type: 'abstract' + } + }; + var color = {}; + commons.color = color; + var dom = commons.dom = {}; + var table = commons.table = {}; + var text = commons.text = {}; + var utils = commons.utils = axe.utils; + aria.requiredAttr = function(role) { + 'use strict'; + var roles = lookupTables.role[role], attr = roles && roles.attributes && roles.attributes.required; + return attr || []; + }; + aria.allowedAttr = function(role) { + 'use strict'; + var roles = lookupTables.role[role], attr = roles && roles.attributes && roles.attributes.allowed || [], requiredAttr = roles && roles.attributes && roles.attributes.required || []; + return attr.concat(lookupTables.globalAttributes).concat(requiredAttr); + }; + aria.validateAttr = function(att) { + 'use strict'; + return !!lookupTables.attributes[att]; + }; + aria.validateAttrValue = function(node, attr) { + 'use strict'; + var matches, list, value = node.getAttribute(attr), attrInfo = lookupTables.attributes[attr]; + var doc = dom.getRootNode(node); + if (!attrInfo) { + return true; + } + switch (attrInfo.type) { + case 'boolean': + case 'nmtoken': + return typeof value === 'string' && attrInfo.values.indexOf(value.toLowerCase()) !== -1; + + case 'nmtokens': + list = axe.utils.tokenList(value); + return list.reduce(function(result, token) { + return result && attrInfo.values.indexOf(token) !== -1; + }, list.length !== 0); + + case 'idref': + return !!(value && doc.getElementById(value)); + + case 'idrefs': + list = axe.utils.tokenList(value); + return list.reduce(function(result, token) { + return !!(result && doc.getElementById(token)); + }, list.length !== 0); + + case 'string': + return true; + + case 'decimal': + matches = value.match(/^[-+]?([0-9]*)\.?([0-9]*)$/); + return !!(matches && (matches[1] || matches[2])); + + case 'int': + return /^[-+]?[0-9]+$/.test(value); + } + }; + aria.label = function(node) { + var ref, candidate; + if (node.actualNode.getAttribute('aria-labelledby')) { + ref = dom.idrefs(node.actualNode, 'aria-labelledby'); + candidate = ref.map(function(thing) { + var vNode = axe.utils.getNodeFromTree(axe._tree[0], thing); + return vNode ? text.visible(vNode, true) : ''; + }).join(' ').trim(); + if (candidate) { + return candidate; + } + } + candidate = node.actualNode.getAttribute('aria-label'); + if (candidate) { + candidate = text.sanitize(candidate).trim(); + if (candidate) { + return candidate; + } + } + return null; + }; + aria.isValidRole = function(role) { + 'use strict'; + if (lookupTables.role[role]) { + return true; + } + return false; + }; + aria.getRolesWithNameFromContents = function() { + return Object.keys(lookupTables.role).filter(function(r) { + return lookupTables.role[r].nameFrom && lookupTables.role[r].nameFrom.indexOf('contents') !== -1; + }); + }; + aria.getRolesByType = function(roleType) { + return Object.keys(lookupTables.role).filter(function(r) { + return lookupTables.role[r].type === roleType; + }); + }; + aria.getRoleType = function(role) { + var r = lookupTables.role[role]; + return r && r.type || null; + }; + aria.requiredOwned = function(role) { + 'use strict'; + var owned = null, roles = lookupTables.role[role]; + if (roles) { + owned = axe.utils.clone(roles.owned); + } + return owned; + }; + aria.requiredContext = function(role) { + 'use strict'; + var context = null, roles = lookupTables.role[role]; + if (roles) { + context = axe.utils.clone(roles.context); + } + return context; + }; + aria.implicitNodes = function(role) { + 'use strict'; + var implicit = null, roles = lookupTables.role[role]; + if (roles && roles.implicit) { + implicit = axe.utils.clone(roles.implicit); + } + return implicit; + }; + aria.implicitRole = function(node) { + 'use strict'; + var isValidImplicitRole = function isValidImplicitRole(set, role) { + var validForNodeType = function validForNodeType(implicitNodeTypeSelector) { + return axe.utils.matchesSelector(node, implicitNodeTypeSelector); + }; + if (role.implicit && role.implicit.some(validForNodeType)) { + set.push(role.name); + } + return set; + }; + var sortRolesByOptimalAriaContext = function sortRolesByOptimalAriaContext(roles, ariaAttributes) { + var getScore = function getScore(role) { + var allowedAriaAttributes = aria.allowedAttr(role); + return allowedAriaAttributes.reduce(function(score, attribute) { + return score + (ariaAttributes.indexOf(attribute) > -1 ? 1 : 0); + }, 0); + }; + var scored = roles.map(function(role) { + return { + score: getScore(role), + name: role + }; + }); + var sorted = scored.sort(function(scoredRoleA, scoredRoleB) { + return scoredRoleB.score - scoredRoleA.score; + }); + return sorted.map(function(sortedRole) { + return sortedRole.name; + }); + }; + var roles = Object.keys(lookupTables.role).map(function(role) { + var lookup = lookupTables.role[role]; + return { + name: role, + implicit: lookup && lookup.implicit + }; + }); + var availableImplicitRoles = roles.reduce(isValidImplicitRole, []); + if (!availableImplicitRoles.length) { + return null; + } + var nodeAttributes = node.attributes; + var ariaAttributes = []; + for (var i = 0, j = nodeAttributes.length; i < j; i++) { + var attr = nodeAttributes[i]; + if (attr.name.match(/^aria-/)) { + ariaAttributes.push(attr.name); + } + } + return sortRolesByOptimalAriaContext(availableImplicitRoles, ariaAttributes).shift(); + }; + color.Color = function(red, green, blue, alpha) { + this.red = red; + this.green = green; + this.blue = blue; + this.alpha = alpha; + this.toHexString = function() { + var redString = Math.round(this.red).toString(16); + var greenString = Math.round(this.green).toString(16); + var blueString = Math.round(this.blue).toString(16); + return '#' + (this.red > 15.5 ? redString : '0' + redString) + (this.green > 15.5 ? greenString : '0' + greenString) + (this.blue > 15.5 ? blueString : '0' + blueString); + }; + var rgbRegex = /^rgb\((\d+), (\d+), (\d+)\)$/; + var rgbaRegex = /^rgba\((\d+), (\d+), (\d+), (\d*(\.\d+)?)\)/; + this.parseRgbString = function(colorString) { + if (colorString === 'transparent') { + this.red = 0; + this.green = 0; + this.blue = 0; + this.alpha = 0; + return; + } + var match = colorString.match(rgbRegex); + if (match) { + this.red = parseInt(match[1], 10); + this.green = parseInt(match[2], 10); + this.blue = parseInt(match[3], 10); + this.alpha = 1; + return; + } + match = colorString.match(rgbaRegex); + if (match) { + this.red = parseInt(match[1], 10); + this.green = parseInt(match[2], 10); + this.blue = parseInt(match[3], 10); + this.alpha = parseFloat(match[4]); + return; + } + }; + this.getRelativeLuminance = function() { + var rSRGB = this.red / 255; + var gSRGB = this.green / 255; + var bSRGB = this.blue / 255; + var r = rSRGB <= .03928 ? rSRGB / 12.92 : Math.pow((rSRGB + .055) / 1.055, 2.4); + var g = gSRGB <= .03928 ? gSRGB / 12.92 : Math.pow((gSRGB + .055) / 1.055, 2.4); + var b = bSRGB <= .03928 ? bSRGB / 12.92 : Math.pow((bSRGB + .055) / 1.055, 2.4); + return .2126 * r + .7152 * g + .0722 * b; + }; + }; + color.flattenColors = function(fgColor, bgColor) { + var alpha = fgColor.alpha; + var r = (1 - alpha) * bgColor.red + alpha * fgColor.red; + var g = (1 - alpha) * bgColor.green + alpha * fgColor.green; + var b = (1 - alpha) * bgColor.blue + alpha * fgColor.blue; + var a = fgColor.alpha + bgColor.alpha * (1 - fgColor.alpha); + return new color.Color(r, g, b, a); + }; + color.getContrast = function(bgColor, fgColor) { + if (!fgColor || !bgColor) { + return null; + } + if (fgColor.alpha < 1) { + fgColor = color.flattenColors(fgColor, bgColor); + } + var bL = bgColor.getRelativeLuminance(); + var fL = fgColor.getRelativeLuminance(); + return (Math.max(fL, bL) + .05) / (Math.min(fL, bL) + .05); + }; + color.hasValidContrastRatio = function(bg, fg, fontSize, isBold) { + var contrast = color.getContrast(bg, fg); + var isSmallFont = isBold && Math.ceil(fontSize * 72) / 96 < 14 || !isBold && Math.ceil(fontSize * 72) / 96 < 18; + return { + isValid: isSmallFont && contrast >= 4.5 || !isSmallFont && contrast >= 3, + contrastRatio: contrast + }; + }; + function _getFonts(style) { + return style.getPropertyValue('font-family').split(/[,;]/g).map(function(font) { + return font.trim().toLowerCase(); + }); + } + function elementIsDistinct(node, ancestorNode) { + var nodeStyle = window.getComputedStyle(node); + if (nodeStyle.getPropertyValue('background-image') !== 'none') { + return true; + } + var hasBorder = [ 'border-bottom', 'border-top', 'outline' ].reduce(function(result, edge) { + var borderClr = new color.Color(); + borderClr.parseRgbString(nodeStyle.getPropertyValue(edge + '-color')); + return result || nodeStyle.getPropertyValue(edge + '-style') !== 'none' && parseFloat(nodeStyle.getPropertyValue(edge + '-width')) > 0 && borderClr.alpha !== 0; + }, false); + if (hasBorder) { + return true; + } + var parentStyle = window.getComputedStyle(ancestorNode); + if (_getFonts(nodeStyle)[0] !== _getFonts(parentStyle)[0]) { + return true; + } + var hasStyle = [ 'text-decoration-line', 'text-decoration-style', 'font-weight', 'font-style', 'font-size' ].reduce(function(result, cssProp) { + return result || nodeStyle.getPropertyValue(cssProp) !== parentStyle.getPropertyValue(cssProp); + }, false); + var tDec = nodeStyle.getPropertyValue('text-decoration'); + if (tDec.split(' ').length < 3) { + hasStyle = hasStyle || tDec !== parentStyle.getPropertyValue('text-decoration'); + } + return hasStyle; + } + color.elementIsDistinct = elementIsDistinct; + var graphicNodes = [ 'IMG', 'CANVAS', 'OBJECT', 'IFRAME', 'VIDEO', 'SVG' ]; + function elmHasImage(elm, style) { + var nodeName = elm.nodeName.toUpperCase(); + if (graphicNodes.includes(nodeName)) { + axe.commons.color.incompleteData.set('bgColor', 'imgNode'); + return true; + } + style = style || window.getComputedStyle(elm); + var bgImageStyle = style.getPropertyValue('background-image'); + var hasBgImage = bgImageStyle !== 'none'; + if (hasBgImage) { + var hasGradient = /gradient/.test(bgImageStyle); + axe.commons.color.incompleteData.set('bgColor', hasGradient ? 'bgGradient' : 'bgImage'); + } + return hasBgImage; + } + function getBgColor(elm, elmStyle) { + elmStyle = elmStyle || window.getComputedStyle(elm); + var bgColor = new color.Color(); + bgColor.parseRgbString(elmStyle.getPropertyValue('background-color')); + if (bgColor.alpha !== 0) { + var opacity = elmStyle.getPropertyValue('opacity'); + bgColor.alpha = bgColor.alpha * opacity; + } + return bgColor; + } + function contentOverlapping(targetElement, bgNode) { + var targetRect = targetElement.getClientRects()[0]; + var obscuringElements = document.elementsFromPoint(targetRect.left, targetRect.top); + if (obscuringElements) { + for (var i = 0; i < obscuringElements.length; i++) { + if (obscuringElements[i] !== targetElement && obscuringElements[i] === bgNode) { + return true; + } + } + } + return false; + } + function calculateObscuringAlpha(elmIndex, elmStack, originalElm) { + var totalAlpha = 0; + if (elmIndex > 0) { + for (var i = elmIndex - 1; i >= 0; i--) { + var bgElm = elmStack[i]; + var bgElmStyle = window.getComputedStyle(bgElm); + var bgColor = getBgColor(bgElm, bgElmStyle); + if (bgColor.alpha && contentOverlapping(originalElm, bgElm)) { + totalAlpha += bgColor.alpha; + } else { + elmStack.splice(i, 1); + } + } + } + return totalAlpha; + } + function elmPartiallyObscured(elm, bgElm, bgColor) { + var obscured = elm !== bgElm && !dom.visuallyContains(elm, bgElm) && bgColor.alpha !== 0; + if (obscured) { + axe.commons.color.incompleteData.set('bgColor', 'elmPartiallyObscured'); + } + return obscured; + } + function includeMissingElements(elmStack, elm) { + var elementMap = { + TD: 'TR', + INPUT: 'LABEL' + }; + var tagArray = elmStack.map(function(elm) { + return elm.tagName; + }); + var bgNodes = elmStack; + for (var candidate in elementMap) { + if (elementMap.hasOwnProperty(candidate)) { + if (elm.tagName === candidate) { + var ancestorMatch = axe.commons.dom.findUp(elm, elementMap[candidate]); + if (ancestorMatch && elmStack.indexOf(ancestorMatch) === -1) { + var overlaps = axe.commons.dom.visuallyOverlaps(elm.getBoundingClientRect(), ancestorMatch); + if (overlaps) { + bgNodes.splice(elmStack.indexOf(elm) + 1, 0, ancestorMatch); + } + } + } + if (elm.tagName === elementMap[candidate] && tagArray.indexOf(elm.tagName) === -1) { + bgNodes.splice(tagArray.indexOf(candidate) + 1, 0, elm); + } + } + } + return bgNodes; + } + function sortPageBackground(elmStack) { + var bodyIndex = elmStack.indexOf(document.body); + var bgNodes = elmStack; + if (bodyIndex > 1 && !elmHasImage(document.documentElement) && getBgColor(document.documentElement).alpha === 0) { + bgNodes.splice(bodyIndex, 1); + bgNodes.splice(elmStack.indexOf(document.documentElement), 1); + bgNodes.push(document.body); + } + return bgNodes; + } + color.getBackgroundStack = function(elm) { + var rect = elm.getBoundingClientRect(); + var x = void 0, y = void 0; + if (rect.left > window.innerWidth) { + return; + } + if (rect.top > window.innerHeight) { + return; + } + x = Math.min(Math.ceil(rect.left + rect.width / 2), window.innerWidth - 1); + y = Math.min(Math.ceil(rect.top + rect.height / 2), window.innerHeight - 1); + var elmStack = document.elementsFromPoint(x, y); + elmStack = includeMissingElements(elmStack, elm); + elmStack = dom.reduceToElementsBelowFloating(elmStack, elm); + elmStack = sortPageBackground(elmStack); + var elmIndex = elmStack.indexOf(elm); + if (calculateObscuringAlpha(elmIndex, elmStack, elm) >= .99) { + axe.commons.color.incompleteData.set('bgColor', 'bgOverlap'); + return null; + } + return elmIndex !== -1 ? elmStack : null; + }; + color.getBackgroundColor = function(elm) { + var bgElms = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : []; + var noScroll = arguments.length > 2 && arguments[2] !== undefined ? arguments[2] : false; + if (noScroll !== true) { + elm.scrollIntoView(); + } + var bgColors = []; + var elmStack = color.getBackgroundStack(elm); + (elmStack || []).some(function(bgElm) { + var bgElmStyle = window.getComputedStyle(bgElm); + var bgColor = getBgColor(bgElm, bgElmStyle); + if (elmPartiallyObscured(elm, bgElm, bgColor) || elmHasImage(bgElm, bgElmStyle)) { + bgColors = null; + bgElms.push(bgElm); + return true; + } + if (bgColor.alpha !== 0) { + bgElms.push(bgElm); + bgColors.push(bgColor); + return bgColor.alpha === 1; + } else { + return false; + } + }); + if (bgColors !== null && elmStack !== null) { + bgColors.push(new color.Color(255, 255, 255, 1)); + var colors = bgColors.reduce(color.flattenColors); + return colors; + } + return null; + }; + dom.isOpaque = function(node) { + var style = window.getComputedStyle(node); + return elmHasImage(node, style) || getBgColor(node, style).alpha === 1; + }; + color.getForegroundColor = function(node, noScroll) { + var nodeStyle = window.getComputedStyle(node); + var fgColor = new color.Color(); + fgColor.parseRgbString(nodeStyle.getPropertyValue('color')); + var opacity = nodeStyle.getPropertyValue('opacity'); + fgColor.alpha = fgColor.alpha * opacity; + if (fgColor.alpha === 1) { + return fgColor; + } + var bgColor = color.getBackgroundColor(node, [], noScroll); + if (bgColor === null) { + var reason = axe.commons.color.incompleteData.get('bgColor'); + axe.commons.color.incompleteData.set('fgColor', reason); + return null; + } + return color.flattenColors(fgColor, bgColor); + }; + color.incompleteData = function() { + var data = {}; + return { + set: function set(key, reason) { + if (typeof key !== 'string') { + throw new Error('Incomplete data: key must be a string'); + } + if (reason) { + data[key] = reason; + } + return data[key]; + }, + get: function get(key) { + return data[key]; + }, + clear: function clear() { + data = {}; + } + }; + }(); + dom.reduceToElementsBelowFloating = function(elements, targetNode) { + var floatingPositions = [ 'fixed', 'sticky' ], finalElements = [], targetFound = false, index, currentNode, style; + for (index = 0; index < elements.length; ++index) { + currentNode = elements[index]; + if (currentNode === targetNode) { + targetFound = true; + } + style = window.getComputedStyle(currentNode); + if (!targetFound && floatingPositions.indexOf(style.position) !== -1) { + finalElements = []; + continue; + } + finalElements.push(currentNode); + } + return finalElements; + }; + dom.findUp = function(element, target) { + 'use strict'; + var parent, doc = axe.commons.dom.getRootNode(element), matches; + matches = doc.querySelectorAll(target); + matches = axe.utils.toArray(matches); + if (doc === document && !matches.length) { + return null; + } + parent = element.assignedSlot ? element.assignedSlot : element.parentNode; + if (parent.nodeType === 11) { + parent = parent.host; + } + while (parent && matches.indexOf(parent) === -1) { + parent = parent.assignedSlot ? parent.assignedSlot : parent.parentNode; + if (parent && parent.nodeType === 11) { + parent = parent.host; + doc = axe.commons.dom.getRootNode(parent); + matches = doc.querySelectorAll(target); + matches = axe.utils.toArray(matches); + if (doc === document && !matches.length) { + return null; + } + } + } + return parent; + }; + dom.getElementByReference = function(node, attr) { + 'use strict'; + var candidate, fragment = node.getAttribute(attr), doc = document; + if (fragment && fragment.charAt(0) === '#') { + fragment = fragment.substring(1); + candidate = doc.getElementById(fragment); + if (candidate) { + return candidate; + } + candidate = doc.getElementsByName(fragment); + if (candidate.length) { + return candidate[0]; + } + } + return null; + }; + dom.getElementCoordinates = function(element) { + 'use strict'; + var scrollOffset = dom.getScrollOffset(document), xOffset = scrollOffset.left, yOffset = scrollOffset.top, coords = element.getBoundingClientRect(); + return { + top: coords.top + yOffset, + right: coords.right + xOffset, + bottom: coords.bottom + yOffset, + left: coords.left + xOffset, + width: coords.right - coords.left, + height: coords.bottom - coords.top + }; + }; + dom.getRootNode = function(node) { + var doc = node.getRootNode && node.getRootNode() || document; + if (doc === node) { + doc = document; + } + return doc; + }; + dom.getScrollOffset = function(element) { + 'use strict'; + if (!element.nodeType && element.document) { + element = element.document; + } + if (element.nodeType === 9) { + var docElement = element.documentElement, body = element.body; + return { + left: docElement && docElement.scrollLeft || body && body.scrollLeft || 0, + top: docElement && docElement.scrollTop || body && body.scrollTop || 0 + }; + } + return { + left: element.scrollLeft, + top: element.scrollTop + }; + }; + dom.getViewportSize = function(win) { + 'use strict'; + var body, doc = win.document, docElement = doc.documentElement; + if (win.innerWidth) { + return { + width: win.innerWidth, + height: win.innerHeight + }; + } + if (docElement) { + return { + width: docElement.clientWidth, + height: docElement.clientHeight + }; + } + body = doc.body; + return { + width: body.clientWidth, + height: body.clientHeight + }; + }; + dom.hasContent = function hasContent(elm) { + if (elm.actualNode.textContent.trim() || aria.label(elm)) { + return true; + } + var contentElms = axe.utils.querySelectorAll(elm, '*'); + for (var i = 0; i < contentElms.length; i++) { + if (aria.label(contentElms[i]) || dom.isVisualContent(contentElms[i].actualNode)) { + return true; + } + } + return false; + }; + dom.idrefs = function(node, attr) { + 'use strict'; + var index, length, doc = dom.getRootNode(node), result = [], idrefs = node.getAttribute(attr); + if (idrefs) { + idrefs = axe.utils.tokenList(idrefs); + for (index = 0, length = idrefs.length; index < length; index++) { + result.push(doc.getElementById(idrefs[index])); + } + } + return result; + }; + dom.isFocusable = function(el) { + 'use strict'; + if (!el || el.disabled || !dom.isVisible(el) && el.nodeName.toUpperCase() !== 'AREA') { + return false; + } + switch (el.nodeName.toUpperCase()) { + case 'A': + case 'AREA': + if (el.href) { + return true; + } + break; + + case 'INPUT': + return el.type !== 'hidden'; + + case 'TEXTAREA': + case 'SELECT': + case 'DETAILS': + case 'BUTTON': + return true; + } + var tabindex = el.getAttribute('tabindex'); + if (tabindex && !isNaN(parseInt(tabindex, 10))) { + return true; + } + return false; + }; + dom.isHTML5 = function(doc) { + var node = doc.doctype; + if (node === null) { + return false; + } + return node.name === 'html' && !node.publicId && !node.systemId; + }; + function walkDomNode(node, functor) { + 'use strict'; + var shouldWalk = functor(node); + node = node.firstChild; + while (node) { + if (shouldWalk !== false) { + walkDomNode(node, functor); + } + node = node.nextSibling; + } + } + var blockLike = [ 'block', 'list-item', 'table', 'flex', 'grid', 'inline-block' ]; + function isBlock(elm) { + 'use strict'; + var display = window.getComputedStyle(elm).getPropertyValue('display'); + return blockLike.indexOf(display) !== -1 || display.substr(0, 6) === 'table-'; + } + dom.isInTextBlock = function isInTextBlock(node) { + 'use strict'; + if (isBlock(node)) { + return false; + } + var parentBlock = node.parentNode; + while (parentBlock.nodeType === 1 && !isBlock(parentBlock)) { + parentBlock = parentBlock.parentNode; + } + var parentText = ''; + var linkText = ''; + var inBrBlock = 0; + walkDomNode(parentBlock, function(currNode) { + if (inBrBlock === 2) { + return false; + } + if (currNode.nodeType === 3) { + parentText += currNode.nodeValue; + } + if (currNode.nodeType !== 1) { + return; + } + var nodeName = (currNode.nodeName || '').toUpperCase(); + if ([ 'BR', 'HR' ].indexOf(nodeName) !== -1) { + if (inBrBlock === 0) { + parentText = ''; + linkText = ''; + } else { + inBrBlock = 2; + } + } else if (currNode.style.display === 'none' || currNode.style.overflow === 'hidden' || [ '', null, 'none' ].indexOf(currNode.style.float) === -1 || [ '', null, 'relative' ].indexOf(currNode.style.position) === -1) { + return false; + } else if (nodeName === 'A' && currNode.href || (currNode.getAttribute('role') || '').toLowerCase() === 'link') { + if (currNode === node) { + inBrBlock = 1; + } + linkText += currNode.textContent; + return false; + } + }); + parentText = axe.commons.text.sanitize(parentText); + linkText = axe.commons.text.sanitize(linkText); + return parentText.length > linkText.length; + }; + dom.isNode = function(candidate) { + 'use strict'; + return candidate instanceof Node; + }; + dom.isOffscreen = function(element) { + 'use strict'; + var noParentScrolled = function noParentScrolled(element, offset) { + element = element.parentNode; + while (element.nodeName.toLowerCase() !== 'html') { + if (element.scrollTop) { + offset += element.scrollTop; + if (offset >= 0) { + return false; + } + } + element = element.parentNode; + } + return true; + }; + var leftBoundary, docElement = document.documentElement, styl = window.getComputedStyle(element), dir = window.getComputedStyle(document.body || docElement).getPropertyValue('direction'), coords = dom.getElementCoordinates(element); + if (coords.bottom < 0 && (noParentScrolled(element, coords.bottom) || styl.position === 'absolute')) { + return true; + } + if (coords.left === 0 && coords.right === 0) { + return false; + } + if (dir === 'ltr') { + if (coords.right <= 0) { + return true; + } + } else { + leftBoundary = Math.max(docElement.scrollWidth, dom.getViewportSize(window).width); + if (coords.left >= leftBoundary) { + return true; + } + } + return false; + }; + function isClipped(clip) { + 'use strict'; + var matches = clip.match(/rect\s*\(([0-9]+)px,?\s*([0-9]+)px,?\s*([0-9]+)px,?\s*([0-9]+)px\s*\)/); + if (matches && matches.length === 5) { + return matches[3] - matches[1] <= 0 && matches[2] - matches[4] <= 0; + } + return false; + } + dom.isVisible = function(el, screenReader, recursed) { + 'use strict'; + var style, nodeName, parent; + if (el.nodeType === 9) { + return true; + } + if (el.nodeType === 11) { + el = el.host; + } + style = window.getComputedStyle(el, null); + if (style === null) { + return false; + } + nodeName = el.nodeName.toUpperCase(); + if (style.getPropertyValue('display') === 'none' || nodeName.toUpperCase() === 'STYLE' || nodeName.toUpperCase() === 'SCRIPT' || !screenReader && isClipped(style.getPropertyValue('clip')) || !recursed && (style.getPropertyValue('visibility') === 'hidden' || !screenReader && dom.isOffscreen(el)) || screenReader && el.getAttribute('aria-hidden') === 'true') { + return false; + } + parent = el.assignedSlot ? el.assignedSlot : el.parentNode; + if (parent) { + return dom.isVisible(parent, screenReader, true); + } + return false; + }; + var visualRoles = [ 'checkbox', 'img', 'radio', 'range', 'slider', 'spinbutton', 'textbox' ]; + dom.isVisualContent = function(candidate) { + var role = candidate.getAttribute('role'); + if (role) { + return visualRoles.indexOf(role) !== -1; + } + switch (candidate.tagName.toUpperCase()) { + case 'IMG': + case 'IFRAME': + case 'OBJECT': + case 'VIDEO': + case 'AUDIO': + case 'CANVAS': + case 'SVG': + case 'MATH': + case 'BUTTON': + case 'SELECT': + case 'TEXTAREA': + case 'KEYGEN': + case 'PROGRESS': + case 'METER': + return true; + + case 'INPUT': + return candidate.type !== 'hidden'; + + default: + return false; + } + }; + dom.visuallyContains = function(node, parent) { + var rectBound = node.getBoundingClientRect(); + var margin = .01; + var rect = { + top: rectBound.top + margin, + bottom: rectBound.bottom - margin, + left: rectBound.left + margin, + right: rectBound.right - margin + }; + var parentRect = parent.getBoundingClientRect(); + var parentTop = parentRect.top; + var parentLeft = parentRect.left; + var parentScrollArea = { + top: parentTop - parent.scrollTop, + bottom: parentTop - parent.scrollTop + parent.scrollHeight, + left: parentLeft - parent.scrollLeft, + right: parentLeft - parent.scrollLeft + parent.scrollWidth + }; + var style = window.getComputedStyle(parent); + if (style.getPropertyValue('display') === 'inline') { + return true; + } + if (rect.left < parentScrollArea.left && rect.left < parentRect.left || rect.top < parentScrollArea.top && rect.top < parentRect.top || rect.right > parentScrollArea.right && rect.right > parentRect.right || rect.bottom > parentScrollArea.bottom && rect.bottom > parentRect.bottom) { + return false; + } + if (rect.right > parentRect.right || rect.bottom > parentRect.bottom) { + return style.overflow === 'scroll' || style.overflow === 'auto' || style.overflow === 'hidden' || parent instanceof HTMLBodyElement || parent instanceof HTMLHtmlElement; + } + return true; + }; + dom.visuallyOverlaps = function(rect, parent) { + var parentRect = parent.getBoundingClientRect(); + var parentTop = parentRect.top; + var parentLeft = parentRect.left; + var parentScrollArea = { + top: parentTop - parent.scrollTop, + bottom: parentTop - parent.scrollTop + parent.scrollHeight, + left: parentLeft - parent.scrollLeft, + right: parentLeft - parent.scrollLeft + parent.scrollWidth + }; + if (rect.left > parentScrollArea.right && rect.left > parentRect.right || rect.top > parentScrollArea.bottom && rect.top > parentRect.bottom || rect.right < parentScrollArea.left && rect.right < parentRect.left || rect.bottom < parentScrollArea.top && rect.bottom < parentRect.top) { + return false; + } + var style = window.getComputedStyle(parent); + if (rect.left > parentRect.right || rect.top > parentRect.bottom) { + return style.overflow === 'scroll' || style.overflow === 'auto' || parent instanceof HTMLBodyElement || parent instanceof HTMLHtmlElement; + } + return true; + }; + table.getAllCells = function(tableElm) { + var rowIndex, cellIndex, rowLength, cellLength; + var cells = []; + for (rowIndex = 0, rowLength = tableElm.rows.length; rowIndex < rowLength; rowIndex++) { + for (cellIndex = 0, cellLength = tableElm.rows[rowIndex].cells.length; cellIndex < cellLength; cellIndex++) { + cells.push(tableElm.rows[rowIndex].cells[cellIndex]); + } + } + return cells; + }; + table.getCellPosition = function(cell, tableGrid) { + var rowIndex, index; + if (!tableGrid) { + tableGrid = table.toGrid(dom.findUp(cell, 'table')); + } + for (rowIndex = 0; rowIndex < tableGrid.length; rowIndex++) { + if (tableGrid[rowIndex]) { + index = tableGrid[rowIndex].indexOf(cell); + if (index !== -1) { + return { + x: index, + y: rowIndex + }; + } + } + } + }; + table.getHeaders = function(cell) { + if (cell.hasAttribute('headers')) { + return commons.dom.idrefs(cell, 'headers'); + } + var tableGrid = commons.table.toGrid(commons.dom.findUp(cell, 'table')); + var position = commons.table.getCellPosition(cell, tableGrid); + var rowHeaders = table.traverse('left', position, tableGrid).filter(function(cell) { + return table.isRowHeader(cell); + }); + var colHeaders = table.traverse('up', position, tableGrid).filter(function(cell) { + return table.isColumnHeader(cell); + }); + return [].concat(rowHeaders, colHeaders).reverse(); + }; + table.getScope = function(cell) { + var scope = cell.getAttribute('scope'); + var role = cell.getAttribute('role'); + if (cell instanceof Element === false || [ 'TD', 'TH' ].indexOf(cell.nodeName.toUpperCase()) === -1) { + throw new TypeError('Expected TD or TH element'); + } + if (role === 'columnheader') { + return 'col'; + } else if (role === 'rowheader') { + return 'row'; + } else if (scope === 'col' || scope === 'row') { + return scope; + } else if (cell.nodeName.toUpperCase() !== 'TH') { + return false; + } + var tableGrid = table.toGrid(dom.findUp(cell, 'table')); + var pos = table.getCellPosition(cell); + var headerRow = tableGrid[pos.y].reduce(function(headerRow, cell) { + return headerRow && cell.nodeName.toUpperCase() === 'TH'; + }, true); + if (headerRow) { + return 'col'; + } + var headerCol = tableGrid.map(function(col) { + return col[pos.x]; + }).reduce(function(headerCol, cell) { + return headerCol && cell.nodeName.toUpperCase() === 'TH'; + }, true); + if (headerCol) { + return 'row'; + } + return 'auto'; + }; + table.isColumnHeader = function(node) { + return [ 'col', 'auto' ].indexOf(table.getScope(node)) !== -1; + }; + table.isDataCell = function(cell) { + if (!cell.children.length && !cell.textContent.trim()) { + return false; + } + return cell.nodeName.toUpperCase() === 'TD'; + }; + table.isDataTable = function(node) { + var role = node.getAttribute('role'); + if ((role === 'presentation' || role === 'none') && !dom.isFocusable(node)) { + return false; + } + if (node.getAttribute('contenteditable') === 'true' || dom.findUp(node, '[contenteditable="true"]')) { + return true; + } + if (role === 'grid' || role === 'treegrid' || role === 'table') { + return true; + } + if (commons.aria.getRoleType(role) === 'landmark') { + return true; + } + if (node.getAttribute('datatable') === '0') { + return false; + } + if (node.getAttribute('summary')) { + return true; + } + if (node.tHead || node.tFoot || node.caption) { + return true; + } + for (var childIndex = 0, childLength = node.children.length; childIndex < childLength; childIndex++) { + if (node.children[childIndex].nodeName.toUpperCase() === 'COLGROUP') { + return true; + } + } + var cells = 0; + var rowLength = node.rows.length; + var row, cell; + var hasBorder = false; + for (var rowIndex = 0; rowIndex < rowLength; rowIndex++) { + row = node.rows[rowIndex]; + for (var cellIndex = 0, cellLength = row.cells.length; cellIndex < cellLength; cellIndex++) { + cell = row.cells[cellIndex]; + if (cell.nodeName.toUpperCase() === 'TH') { + return true; + } + if (!hasBorder && (cell.offsetWidth !== cell.clientWidth || cell.offsetHeight !== cell.clientHeight)) { + hasBorder = true; + } + if (cell.getAttribute('scope') || cell.getAttribute('headers') || cell.getAttribute('abbr')) { + return true; + } + if ([ 'columnheader', 'rowheader' ].indexOf(cell.getAttribute('role')) !== -1) { + return true; + } + if (cell.children.length === 1 && cell.children[0].nodeName.toUpperCase() === 'ABBR') { + return true; + } + cells++; + } + } + if (node.getElementsByTagName('table').length) { + return false; + } + if (rowLength < 2) { + return false; + } + var sampleRow = node.rows[Math.ceil(rowLength / 2)]; + if (sampleRow.cells.length === 1 && sampleRow.cells[0].colSpan === 1) { + return false; + } + if (sampleRow.cells.length >= 5) { + return true; + } + if (hasBorder) { + return true; + } + var bgColor, bgImage; + for (rowIndex = 0; rowIndex < rowLength; rowIndex++) { + row = node.rows[rowIndex]; + if (bgColor && bgColor !== window.getComputedStyle(row).getPropertyValue('background-color')) { + return true; + } else { + bgColor = window.getComputedStyle(row).getPropertyValue('background-color'); + } + if (bgImage && bgImage !== window.getComputedStyle(row).getPropertyValue('background-image')) { + return true; + } else { + bgImage = window.getComputedStyle(row).getPropertyValue('background-image'); + } + } + if (rowLength >= 20) { + return true; + } + if (dom.getElementCoordinates(node).width > dom.getViewportSize(window).width * .95) { + return false; + } + if (cells < 10) { + return false; + } + if (node.querySelector('object, embed, iframe, applet')) { + return false; + } + return true; + }; + table.isHeader = function(cell) { + if (table.isColumnHeader(cell) || table.isRowHeader(cell)) { + return true; + } + if (cell.id) { + return !!document.querySelector('[headers~="' + axe.utils.escapeSelector(cell.id) + '"]'); + } + return false; + }; + table.isRowHeader = function(node) { + return [ 'row', 'auto' ].indexOf(table.getScope(node)) !== -1; + }; + table.toGrid = function(node) { + var table = []; + var rows = node.rows; + for (var i = 0, rowLength = rows.length; i < rowLength; i++) { + var cells = rows[i].cells; + table[i] = table[i] || []; + var columnIndex = 0; + for (var j = 0, cellLength = cells.length; j < cellLength; j++) { + for (var colSpan = 0; colSpan < cells[j].colSpan; colSpan++) { + for (var rowSpan = 0; rowSpan < cells[j].rowSpan; rowSpan++) { + table[i + rowSpan] = table[i + rowSpan] || []; + while (table[i + rowSpan][columnIndex]) { + columnIndex++; + } + table[i + rowSpan][columnIndex] = cells[j]; + } + columnIndex++; + } + } + } + return table; + }; + table.toArray = table.toGrid; + (function(table) { + var traverseTable = function traverseTable(dir, position, tableGrid, callback) { + var result; + var cell = tableGrid[position.y] ? tableGrid[position.y][position.x] : undefined; + if (!cell) { + return []; + } + if (typeof callback === 'function') { + result = callback(cell, position, tableGrid); + if (result === true) { + return [ cell ]; + } + } + result = traverseTable(dir, { + x: position.x + dir.x, + y: position.y + dir.y + }, tableGrid, callback); + result.unshift(cell); + return result; + }; + table.traverse = function(dir, startPos, tableGrid, callback) { + if (Array.isArray(startPos)) { + callback = tableGrid; + tableGrid = startPos; + startPos = { + x: 0, + y: 0 + }; + } + if (typeof dir === 'string') { + switch (dir) { + case 'left': + dir = { + x: -1, + y: 0 + }; + break; + + case 'up': + dir = { + x: 0, + y: -1 + }; + break; + + case 'right': + dir = { + x: 1, + y: 0 + }; + break; + + case 'down': + dir = { + x: 0, + y: 1 + }; + break; + } + } + return traverseTable(dir, { + x: startPos.x + dir.x, + y: startPos.y + dir.y + }, tableGrid, callback); + }; + })(table); + var defaultButtonValues = { + submit: 'Submit', + reset: 'Reset' + }; + var inputTypes = [ 'text', 'search', 'tel', 'url', 'email', 'date', 'time', 'number', 'range', 'color' ]; + var phrasingElements = [ 'A', 'EM', 'STRONG', 'SMALL', 'MARK', 'ABBR', 'DFN', 'I', 'B', 'S', 'U', 'CODE', 'VAR', 'SAMP', 'KBD', 'SUP', 'SUB', 'Q', 'CITE', 'SPAN', 'BDO', 'BDI', 'BR', 'WBR', 'INS', 'DEL', 'IMG', 'EMBED', 'OBJECT', 'IFRAME', 'MAP', 'AREA', 'SCRIPT', 'NOSCRIPT', 'RUBY', 'VIDEO', 'AUDIO', 'INPUT', 'TEXTAREA', 'SELECT', 'BUTTON', 'LABEL', 'OUTPUT', 'DATALIST', 'KEYGEN', 'PROGRESS', 'COMMAND', 'CANVAS', 'TIME', 'METER' ]; + function findLabel(element) { + var ref = null; + if (element.id) { + ref = document.querySelector('label[for="' + axe.utils.escapeSelector(element.id) + '"]'); + if (ref) { + return ref; + } + } + ref = dom.findUp(element, 'label'); + return ref; + } + function isButton(element) { + return [ 'button', 'reset', 'submit' ].indexOf(element.type) !== -1; + } + function isInput(element) { + var nodeName = element.nodeName.toUpperCase(); + return nodeName === 'TEXTAREA' || nodeName === 'SELECT' || nodeName === 'INPUT' && element.type.toLowerCase() !== 'hidden'; + } + function shouldCheckSubtree(element) { + return [ 'BUTTON', 'SUMMARY', 'A' ].indexOf(element.nodeName.toUpperCase()) !== -1; + } + function shouldNeverCheckSubtree(element) { + return [ 'TABLE', 'FIGURE' ].indexOf(element.nodeName.toUpperCase()) !== -1; + } + function formValueText(element) { + var nodeName = element.nodeName.toUpperCase(); + if (nodeName === 'INPUT') { + if (!element.hasAttribute('type') || inputTypes.indexOf(element.getAttribute('type').toLowerCase()) !== -1 && element.value) { + return element.value; + } + return ''; + } + if (nodeName === 'SELECT') { + var opts = element.options; + if (opts && opts.length) { + var returnText = ''; + for (var i = 0; i < opts.length; i++) { + if (opts[i].selected) { + returnText += ' ' + opts[i].text; + } + } + return text.sanitize(returnText); + } + return ''; + } + if (nodeName === 'TEXTAREA' && element.value) { + return element.value; + } + return ''; + } + function checkDescendant(element, nodeName) { + var candidate = element.querySelector(nodeName.toLowerCase()); + if (candidate) { + return text.accessibleText(candidate); + } + return ''; + } + function isEmbeddedControl(e) { + if (!e) { + return false; + } + switch (e.nodeName.toUpperCase()) { + case 'SELECT': + case 'TEXTAREA': + return true; + + case 'INPUT': + return !e.hasAttribute('type') || inputTypes.indexOf(e.getAttribute('type').toLowerCase()) !== -1; + + default: + return false; + } + } + function shouldCheckAlt(element) { + var nodeName = element.nodeName.toUpperCase(); + return nodeName === 'INPUT' && element.type.toLowerCase() === 'image' || [ 'IMG', 'APPLET', 'AREA' ].indexOf(nodeName) !== -1; + } + function nonEmptyText(t) { + return !!text.sanitize(t); + } + text.accessibleText = function(element, inLabelledByContext) { + var accessibleNameComputation; + var encounteredNodes = []; + function getInnerText(element, inLabelledByContext, inControlContext) { + var nodes = element.childNodes; + var returnText = ''; + var node; + for (var i = 0; i < nodes.length; i++) { + node = nodes[i]; + if (node.nodeType === 3) { + returnText += node.textContent; + } else if (node.nodeType === 1) { + if (phrasingElements.indexOf(node.nodeName.toUpperCase()) === -1) { + returnText += ' '; + } + returnText += accessibleNameComputation(nodes[i], inLabelledByContext, inControlContext); + } + } + return returnText; + } + function checkNative(element, inLabelledByContext, inControlContext) { + var returnText = ''; + var nodeName = element.nodeName.toUpperCase(); + if (shouldCheckSubtree(element)) { + returnText = getInnerText(element, false, false) || ''; + if (nonEmptyText(returnText)) { + return returnText; + } + } + if (nodeName === 'FIGURE') { + returnText = checkDescendant(element, 'figcaption'); + if (nonEmptyText(returnText)) { + return returnText; + } + } + if (nodeName === 'TABLE') { + returnText = checkDescendant(element, 'caption'); + if (nonEmptyText(returnText)) { + return returnText; + } + returnText = element.getAttribute('title') || element.getAttribute('summary') || ''; + if (nonEmptyText(returnText)) { + return returnText; + } + } + if (shouldCheckAlt(element)) { + return element.getAttribute('alt') || ''; + } + if (isInput(element) && !inControlContext) { + if (isButton(element)) { + return element.value || element.title || defaultButtonValues[element.type] || ''; + } + var labelElement = findLabel(element); + if (labelElement) { + return accessibleNameComputation(labelElement, inLabelledByContext, true); + } + } + return ''; + } + function checkARIA(element, inLabelledByContext, inControlContext) { + if (!inLabelledByContext && element.hasAttribute('aria-labelledby')) { + return text.sanitize(dom.idrefs(element, 'aria-labelledby').map(function(l) { + if (element === l) { + encounteredNodes.pop(); + } + return accessibleNameComputation(l, true, element !== l); + }).join(' ')); + } + if (!(inControlContext && isEmbeddedControl(element)) && element.hasAttribute('aria-label')) { + return text.sanitize(element.getAttribute('aria-label')); + } + return ''; + } + accessibleNameComputation = function accessibleNameComputation(element, inLabelledByContext, inControlContext) { + 'use strict'; + var returnText; + if (element === null || encounteredNodes.indexOf(element) !== -1) { + return ''; + } else if (!inLabelledByContext && !dom.isVisible(element, true)) { + return ''; + } + encounteredNodes.push(element); + var role = element.getAttribute('role'); + returnText = checkARIA(element, inLabelledByContext, inControlContext); + if (nonEmptyText(returnText)) { + return returnText; + } + returnText = checkNative(element, inLabelledByContext, inControlContext); + if (nonEmptyText(returnText)) { + return returnText; + } + if (inControlContext) { + returnText = formValueText(element); + if (nonEmptyText(returnText)) { + return returnText; + } + } + if (!shouldNeverCheckSubtree(element) && (!role || aria.getRolesWithNameFromContents().indexOf(role) !== -1)) { + returnText = getInnerText(element, inLabelledByContext, inControlContext); + if (nonEmptyText(returnText)) { + return returnText; + } + } + if (element.hasAttribute('title')) { + return element.getAttribute('title'); + } + return ''; + }; + return text.sanitize(accessibleNameComputation(element, inLabelledByContext)); + }; + text.label = function(node) { + var ref, candidate, doc; + candidate = aria.label(node); + if (candidate) { + return candidate; + } + if (node.actualNode.id) { + doc = axe.commons.dom.getRootNode(node.actualNode); + ref = doc.querySelector('label[for="' + axe.utils.escapeSelector(node.actualNode.id) + '"]'); + ref = axe.utils.getNodeFromTree(axe._tree[0], ref); + candidate = ref && text.visible(ref, true); + if (candidate) { + return candidate; + } + } + ref = dom.findUp(node.actualNode, 'label'); + ref = axe.utils.getNodeFromTree(axe._tree[0], ref); + candidate = ref && text.visible(ref, true); + if (candidate) { + return candidate; + } + return null; + }; + text.sanitize = function(str) { + 'use strict'; + return str.replace(/\r\n/g, '\n').replace(/\u00A0/g, ' ').replace(/[\s]{2,}/g, ' ').trim(); + }; + text.visible = function(element, screenReader, noRecursing) { + 'use strict'; + var index, child, nodeValue, childNodes = element.children, length = childNodes.length, result = ''; + for (index = 0; index < length; index++) { + child = childNodes[index]; + if (child.actualNode.nodeType === 3) { + nodeValue = child.actualNode.nodeValue; + if (nodeValue && dom.isVisible(element.actualNode, screenReader)) { + result += nodeValue; + } + } else if (!noRecursing) { + result += text.visible(child, screenReader); + } + } + return text.sanitize(result); + }; + axe.utils.toArray = function(thing) { + 'use strict'; + return Array.prototype.slice.call(thing); + }; + axe.utils.tokenList = function(str) { + 'use strict'; + return str.trim().replace(/\s{2,}/g, ' ').split(' '); + }; + var langs = [ 'aa', 'ab', 'ae', 'af', 'ak', 'am', 'an', 'ar', 'as', 'av', 'ay', 'az', 'ba', 'be', 'bg', 'bh', 'bi', 'bm', 'bn', 'bo', 'br', 'bs', 'ca', 'ce', 'ch', 'co', 'cr', 'cs', 'cu', 'cv', 'cy', 'da', 'de', 'dv', 'dz', 'ee', 'el', 'en', 'eo', 'es', 'et', 'eu', 'fa', 'ff', 'fi', 'fj', 'fo', 'fr', 'fy', 'ga', 'gd', 'gl', 'gn', 'gu', 'gv', 'ha', 'he', 'hi', 'ho', 'hr', 'ht', 'hu', 'hy', 'hz', 'ia', 'id', 'ie', 'ig', 'ii', 'ik', 'in', 'io', 'is', 'it', 'iu', 'iw', 'ja', 'ji', 'jv', 'jw', 'ka', 'kg', 'ki', 'kj', 'kk', 'kl', 'km', 'kn', 'ko', 'kr', 'ks', 'ku', 'kv', 'kw', 'ky', 'la', 'lb', 'lg', 'li', 'ln', 'lo', 'lt', 'lu', 'lv', 'mg', 'mh', 'mi', 'mk', 'ml', 'mn', 'mo', 'mr', 'ms', 'mt', 'my', 'na', 'nb', 'nd', 'ne', 'ng', 'nl', 'nn', 'no', 'nr', 'nv', 'ny', 'oc', 'oj', 'om', 'or', 'os', 'pa', 'pi', 'pl', 'ps', 'pt', 'qu', 'rm', 'rn', 'ro', 'ru', 'rw', 'sa', 'sc', 'sd', 'se', 'sg', 'sh', 'si', 'sk', 'sl', 'sm', 'sn', 'so', 'sq', 'sr', 'ss', 'st', 'su', 'sv', 'sw', 'ta', 'te', 'tg', 'th', 'ti', 'tk', 'tl', 'tn', 'to', 'tr', 'ts', 'tt', 'tw', 'ty', 'ug', 'uk', 'ur', 'uz', 've', 'vi', 'vo', 'wa', 'wo', 'xh', 'yi', 'yo', 'za', 'zh', 'zu', 'aaa', 'aab', 'aac', 'aad', 'aae', 'aaf', 'aag', 'aah', 'aai', 'aak', 'aal', 'aam', 'aan', 'aao', 'aap', 'aaq', 'aas', 'aat', 'aau', 'aav', 'aaw', 'aax', 'aaz', 'aba', 'abb', 'abc', 'abd', 'abe', 'abf', 'abg', 'abh', 'abi', 'abj', 'abl', 'abm', 'abn', 'abo', 'abp', 'abq', 'abr', 'abs', 'abt', 'abu', 'abv', 'abw', 'abx', 'aby', 'abz', 'aca', 'acb', 'acd', 'ace', 'acf', 'ach', 'aci', 'ack', 'acl', 'acm', 'acn', 'acp', 'acq', 'acr', 'acs', 'act', 'acu', 'acv', 'acw', 'acx', 'acy', 'acz', 'ada', 'adb', 'add', 'ade', 'adf', 'adg', 'adh', 'adi', 'adj', 'adl', 'adn', 'ado', 'adp', 'adq', 'adr', 'ads', 'adt', 'adu', 'adw', 'adx', 'ady', 'adz', 'aea', 'aeb', 'aec', 'aed', 'aee', 'aek', 'ael', 'aem', 'aen', 'aeq', 'aer', 'aes', 'aeu', 'aew', 'aey', 'aez', 'afa', 'afb', 'afd', 'afe', 'afg', 'afh', 'afi', 'afk', 'afn', 'afo', 'afp', 'afs', 'aft', 'afu', 'afz', 'aga', 'agb', 'agc', 'agd', 'age', 'agf', 'agg', 'agh', 'agi', 'agj', 'agk', 'agl', 'agm', 'agn', 'ago', 'agp', 'agq', 'agr', 'ags', 'agt', 'agu', 'agv', 'agw', 'agx', 'agy', 'agz', 'aha', 'ahb', 'ahg', 'ahh', 'ahi', 'ahk', 'ahl', 'ahm', 'ahn', 'aho', 'ahp', 'ahr', 'ahs', 'aht', 'aia', 'aib', 'aic', 'aid', 'aie', 'aif', 'aig', 'aih', 'aii', 'aij', 'aik', 'ail', 'aim', 'ain', 'aio', 'aip', 'aiq', 'air', 'ais', 'ait', 'aiw', 'aix', 'aiy', 'aja', 'ajg', 'aji', 'ajn', 'ajp', 'ajt', 'aju', 'ajw', 'ajz', 'akb', 'akc', 'akd', 'ake', 'akf', 'akg', 'akh', 'aki', 'akj', 'akk', 'akl', 'akm', 'ako', 'akp', 'akq', 'akr', 'aks', 'akt', 'aku', 'akv', 'akw', 'akx', 'aky', 'akz', 'ala', 'alc', 'ald', 'ale', 'alf', 'alg', 'alh', 'ali', 'alj', 'alk', 'all', 'alm', 'aln', 'alo', 'alp', 'alq', 'alr', 'als', 'alt', 'alu', 'alv', 'alw', 'alx', 'aly', 'alz', 'ama', 'amb', 'amc', 'ame', 'amf', 'amg', 'ami', 'amj', 'amk', 'aml', 'amm', 'amn', 'amo', 'amp', 'amq', 'amr', 'ams', 'amt', 'amu', 'amv', 'amw', 'amx', 'amy', 'amz', 'ana', 'anb', 'anc', 'and', 'ane', 'anf', 'ang', 'anh', 'ani', 'anj', 'ank', 'anl', 'anm', 'ann', 'ano', 'anp', 'anq', 'anr', 'ans', 'ant', 'anu', 'anv', 'anw', 'anx', 'any', 'anz', 'aoa', 'aob', 'aoc', 'aod', 'aoe', 'aof', 'aog', 'aoh', 'aoi', 'aoj', 'aok', 'aol', 'aom', 'aon', 'aor', 'aos', 'aot', 'aou', 'aox', 'aoz', 'apa', 'apb', 'apc', 'apd', 'ape', 'apf', 'apg', 'aph', 'api', 'apj', 'apk', 'apl', 'apm', 'apn', 'apo', 'app', 'apq', 'apr', 'aps', 'apt', 'apu', 'apv', 'apw', 'apx', 'apy', 'apz', 'aqa', 'aqc', 'aqd', 'aqg', 'aql', 'aqm', 'aqn', 'aqp', 'aqr', 'aqt', 'aqz', 'arb', 'arc', 'ard', 'are', 'arh', 'ari', 'arj', 'ark', 'arl', 'arn', 'aro', 'arp', 'arq', 'arr', 'ars', 'art', 'aru', 'arv', 'arw', 'arx', 'ary', 'arz', 'asa', 'asb', 'asc', 'asd', 'ase', 'asf', 'asg', 'ash', 'asi', 'asj', 'ask', 'asl', 'asn', 'aso', 'asp', 'asq', 'asr', 'ass', 'ast', 'asu', 'asv', 'asw', 'asx', 'asy', 'asz', 'ata', 'atb', 'atc', 'atd', 'ate', 'atg', 'ath', 'ati', 'atj', 'atk', 'atl', 'atm', 'atn', 'ato', 'atp', 'atq', 'atr', 'ats', 'att', 'atu', 'atv', 'atw', 'atx', 'aty', 'atz', 'aua', 'aub', 'auc', 'aud', 'aue', 'auf', 'aug', 'auh', 'aui', 'auj', 'auk', 'aul', 'aum', 'aun', 'auo', 'aup', 'auq', 'aur', 'aus', 'aut', 'auu', 'auw', 'aux', 'auy', 'auz', 'avb', 'avd', 'avi', 'avk', 'avl', 'avm', 'avn', 'avo', 'avs', 'avt', 'avu', 'avv', 'awa', 'awb', 'awc', 'awd', 'awe', 'awg', 'awh', 'awi', 'awk', 'awm', 'awn', 'awo', 'awr', 'aws', 'awt', 'awu', 'awv', 'aww', 'awx', 'awy', 'axb', 'axe', 'axg', 'axk', 'axl', 'axm', 'axx', 'aya', 'ayb', 'ayc', 'ayd', 'aye', 'ayg', 'ayh', 'ayi', 'ayk', 'ayl', 'ayn', 'ayo', 'ayp', 'ayq', 'ayr', 'ays', 'ayt', 'ayu', 'ayx', 'ayy', 'ayz', 'aza', 'azb', 'azc', 'azd', 'azg', 'azj', 'azm', 'azn', 'azo', 'azt', 'azz', 'baa', 'bab', 'bac', 'bad', 'bae', 'baf', 'bag', 'bah', 'bai', 'baj', 'bal', 'ban', 'bao', 'bap', 'bar', 'bas', 'bat', 'bau', 'bav', 'baw', 'bax', 'bay', 'baz', 'bba', 'bbb', 'bbc', 'bbd', 'bbe', 'bbf', 'bbg', 'bbh', 'bbi', 'bbj', 'bbk', 'bbl', 'bbm', 'bbn', 'bbo', 'bbp', 'bbq', 'bbr', 'bbs', 'bbt', 'bbu', 'bbv', 'bbw', 'bbx', 'bby', 'bbz', 'bca', 'bcb', 'bcc', 'bcd', 'bce', 'bcf', 'bcg', 'bch', 'bci', 'bcj', 'bck', 'bcl', 'bcm', 'bcn', 'bco', 'bcp', 'bcq', 'bcr', 'bcs', 'bct', 'bcu', 'bcv', 'bcw', 'bcy', 'bcz', 'bda', 'bdb', 'bdc', 'bdd', 'bde', 'bdf', 'bdg', 'bdh', 'bdi', 'bdj', 'bdk', 'bdl', 'bdm', 'bdn', 'bdo', 'bdp', 'bdq', 'bdr', 'bds', 'bdt', 'bdu', 'bdv', 'bdw', 'bdx', 'bdy', 'bdz', 'bea', 'beb', 'bec', 'bed', 'bee', 'bef', 'beg', 'beh', 'bei', 'bej', 'bek', 'bem', 'beo', 'bep', 'beq', 'ber', 'bes', 'bet', 'beu', 'bev', 'bew', 'bex', 'bey', 'bez', 'bfa', 'bfb', 'bfc', 'bfd', 'bfe', 'bff', 'bfg', 'bfh', 'bfi', 'bfj', 'bfk', 'bfl', 'bfm', 'bfn', 'bfo', 'bfp', 'bfq', 'bfr', 'bfs', 'bft', 'bfu', 'bfw', 'bfx', 'bfy', 'bfz', 'bga', 'bgb', 'bgc', 'bgd', 'bge', 'bgf', 'bgg', 'bgi', 'bgj', 'bgk', 'bgl', 'bgm', 'bgn', 'bgo', 'bgp', 'bgq', 'bgr', 'bgs', 'bgt', 'bgu', 'bgv', 'bgw', 'bgx', 'bgy', 'bgz', 'bha', 'bhb', 'bhc', 'bhd', 'bhe', 'bhf', 'bhg', 'bhh', 'bhi', 'bhj', 'bhk', 'bhl', 'bhm', 'bhn', 'bho', 'bhp', 'bhq', 'bhr', 'bhs', 'bht', 'bhu', 'bhv', 'bhw', 'bhx', 'bhy', 'bhz', 'bia', 'bib', 'bic', 'bid', 'bie', 'bif', 'big', 'bij', 'bik', 'bil', 'bim', 'bin', 'bio', 'bip', 'biq', 'bir', 'bit', 'biu', 'biv', 'biw', 'bix', 'biy', 'biz', 'bja', 'bjb', 'bjc', 'bjd', 'bje', 'bjf', 'bjg', 'bjh', 'bji', 'bjj', 'bjk', 'bjl', 'bjm', 'bjn', 'bjo', 'bjp', 'bjq', 'bjr', 'bjs', 'bjt', 'bju', 'bjv', 'bjw', 'bjx', 'bjy', 'bjz', 'bka', 'bkb', 'bkc', 'bkd', 'bkf', 'bkg', 'bkh', 'bki', 'bkj', 'bkk', 'bkl', 'bkm', 'bkn', 'bko', 'bkp', 'bkq', 'bkr', 'bks', 'bkt', 'bku', 'bkv', 'bkw', 'bkx', 'bky', 'bkz', 'bla', 'blb', 'blc', 'bld', 'ble', 'blf', 'blg', 'blh', 'bli', 'blj', 'blk', 'bll', 'blm', 'bln', 'blo', 'blp', 'blq', 'blr', 'bls', 'blt', 'blv', 'blw', 'blx', 'bly', 'blz', 'bma', 'bmb', 'bmc', 'bmd', 'bme', 'bmf', 'bmg', 'bmh', 'bmi', 'bmj', 'bmk', 'bml', 'bmm', 'bmn', 'bmo', 'bmp', 'bmq', 'bmr', 'bms', 'bmt', 'bmu', 'bmv', 'bmw', 'bmx', 'bmy', 'bmz', 'bna', 'bnb', 'bnc', 'bnd', 'bne', 'bnf', 'bng', 'bni', 'bnj', 'bnk', 'bnl', 'bnm', 'bnn', 'bno', 'bnp', 'bnq', 'bnr', 'bns', 'bnt', 'bnu', 'bnv', 'bnw', 'bnx', 'bny', 'bnz', 'boa', 'bob', 'boe', 'bof', 'bog', 'boh', 'boi', 'boj', 'bok', 'bol', 'bom', 'bon', 'boo', 'bop', 'boq', 'bor', 'bot', 'bou', 'bov', 'bow', 'box', 'boy', 'boz', 'bpa', 'bpb', 'bpd', 'bpg', 'bph', 'bpi', 'bpj', 'bpk', 'bpl', 'bpm', 'bpn', 'bpo', 'bpp', 'bpq', 'bpr', 'bps', 'bpt', 'bpu', 'bpv', 'bpw', 'bpx', 'bpy', 'bpz', 'bqa', 'bqb', 'bqc', 'bqd', 'bqf', 'bqg', 'bqh', 'bqi', 'bqj', 'bqk', 'bql', 'bqm', 'bqn', 'bqo', 'bqp', 'bqq', 'bqr', 'bqs', 'bqt', 'bqu', 'bqv', 'bqw', 'bqx', 'bqy', 'bqz', 'bra', 'brb', 'brc', 'brd', 'brf', 'brg', 'brh', 'bri', 'brj', 'brk', 'brl', 'brm', 'brn', 'bro', 'brp', 'brq', 'brr', 'brs', 'brt', 'bru', 'brv', 'brw', 'brx', 'bry', 'brz', 'bsa', 'bsb', 'bsc', 'bse', 'bsf', 'bsg', 'bsh', 'bsi', 'bsj', 'bsk', 'bsl', 'bsm', 'bsn', 'bso', 'bsp', 'bsq', 'bsr', 'bss', 'bst', 'bsu', 'bsv', 'bsw', 'bsx', 'bsy', 'bta', 'btb', 'btc', 'btd', 'bte', 'btf', 'btg', 'bth', 'bti', 'btj', 'btk', 'btl', 'btm', 'btn', 'bto', 'btp', 'btq', 'btr', 'bts', 'btt', 'btu', 'btv', 'btw', 'btx', 'bty', 'btz', 'bua', 'bub', 'buc', 'bud', 'bue', 'buf', 'bug', 'buh', 'bui', 'buj', 'buk', 'bum', 'bun', 'buo', 'bup', 'buq', 'bus', 'but', 'buu', 'buv', 'buw', 'bux', 'buy', 'buz', 'bva', 'bvb', 'bvc', 'bvd', 'bve', 'bvf', 'bvg', 'bvh', 'bvi', 'bvj', 'bvk', 'bvl', 'bvm', 'bvn', 'bvo', 'bvp', 'bvq', 'bvr', 'bvt', 'bvu', 'bvv', 'bvw', 'bvx', 'bvy', 'bvz', 'bwa', 'bwb', 'bwc', 'bwd', 'bwe', 'bwf', 'bwg', 'bwh', 'bwi', 'bwj', 'bwk', 'bwl', 'bwm', 'bwn', 'bwo', 'bwp', 'bwq', 'bwr', 'bws', 'bwt', 'bwu', 'bww', 'bwx', 'bwy', 'bwz', 'bxa', 'bxb', 'bxc', 'bxd', 'bxe', 'bxf', 'bxg', 'bxh', 'bxi', 'bxj', 'bxk', 'bxl', 'bxm', 'bxn', 'bxo', 'bxp', 'bxq', 'bxr', 'bxs', 'bxu', 'bxv', 'bxw', 'bxx', 'bxz', 'bya', 'byb', 'byc', 'byd', 'bye', 'byf', 'byg', 'byh', 'byi', 'byj', 'byk', 'byl', 'bym', 'byn', 'byo', 'byp', 'byq', 'byr', 'bys', 'byt', 'byv', 'byw', 'byx', 'byy', 'byz', 'bza', 'bzb', 'bzc', 'bzd', 'bze', 'bzf', 'bzg', 'bzh', 'bzi', 'bzj', 'bzk', 'bzl', 'bzm', 'bzn', 'bzo', 'bzp', 'bzq', 'bzr', 'bzs', 'bzt', 'bzu', 'bzv', 'bzw', 'bzx', 'bzy', 'bzz', 'caa', 'cab', 'cac', 'cad', 'cae', 'caf', 'cag', 'cah', 'cai', 'caj', 'cak', 'cal', 'cam', 'can', 'cao', 'cap', 'caq', 'car', 'cas', 'cau', 'cav', 'caw', 'cax', 'cay', 'caz', 'cba', 'cbb', 'cbc', 'cbd', 'cbe', 'cbg', 'cbh', 'cbi', 'cbj', 'cbk', 'cbl', 'cbn', 'cbo', 'cbq', 'cbr', 'cbs', 'cbt', 'cbu', 'cbv', 'cbw', 'cby', 'cca', 'ccc', 'ccd', 'cce', 'ccg', 'cch', 'ccj', 'ccl', 'ccm', 'ccn', 'cco', 'ccp', 'ccq', 'ccr', 'ccs', 'cda', 'cdc', 'cdd', 'cde', 'cdf', 'cdg', 'cdh', 'cdi', 'cdj', 'cdm', 'cdn', 'cdo', 'cdr', 'cds', 'cdy', 'cdz', 'cea', 'ceb', 'ceg', 'cek', 'cel', 'cen', 'cet', 'cfa', 'cfd', 'cfg', 'cfm', 'cga', 'cgc', 'cgg', 'cgk', 'chb', 'chc', 'chd', 'chf', 'chg', 'chh', 'chj', 'chk', 'chl', 'chm', 'chn', 'cho', 'chp', 'chq', 'chr', 'cht', 'chw', 'chx', 'chy', 'chz', 'cia', 'cib', 'cic', 'cid', 'cie', 'cih', 'cik', 'cim', 'cin', 'cip', 'cir', 'ciw', 'ciy', 'cja', 'cje', 'cjh', 'cji', 'cjk', 'cjm', 'cjn', 'cjo', 'cjp', 'cjr', 'cjs', 'cjv', 'cjy', 'cka', 'ckb', 'ckh', 'ckl', 'ckn', 'cko', 'ckq', 'ckr', 'cks', 'ckt', 'cku', 'ckv', 'ckx', 'cky', 'ckz', 'cla', 'clc', 'cld', 'cle', 'clh', 'cli', 'clj', 'clk', 'cll', 'clm', 'clo', 'clt', 'clu', 'clw', 'cly', 'cma', 'cmc', 'cme', 'cmg', 'cmi', 'cmk', 'cml', 'cmm', 'cmn', 'cmo', 'cmr', 'cms', 'cmt', 'cna', 'cnb', 'cnc', 'cng', 'cnh', 'cni', 'cnk', 'cnl', 'cno', 'cns', 'cnt', 'cnu', 'cnw', 'cnx', 'coa', 'cob', 'coc', 'cod', 'coe', 'cof', 'cog', 'coh', 'coj', 'cok', 'col', 'com', 'con', 'coo', 'cop', 'coq', 'cot', 'cou', 'cov', 'cow', 'cox', 'coy', 'coz', 'cpa', 'cpb', 'cpc', 'cpe', 'cpf', 'cpg', 'cpi', 'cpn', 'cpo', 'cpp', 'cps', 'cpu', 'cpx', 'cpy', 'cqd', 'cqu', 'cra', 'crb', 'crc', 'crd', 'crf', 'crg', 'crh', 'cri', 'crj', 'crk', 'crl', 'crm', 'crn', 'cro', 'crp', 'crq', 'crr', 'crs', 'crt', 'crv', 'crw', 'crx', 'cry', 'crz', 'csa', 'csb', 'csc', 'csd', 'cse', 'csf', 'csg', 'csh', 'csi', 'csj', 'csk', 'csl', 'csm', 'csn', 'cso', 'csq', 'csr', 'css', 'cst', 'csu', 'csv', 'csw', 'csy', 'csz', 'cta', 'ctc', 'ctd', 'cte', 'ctg', 'cth', 'ctl', 'ctm', 'ctn', 'cto', 'ctp', 'cts', 'ctt', 'ctu', 'ctz', 'cua', 'cub', 'cuc', 'cug', 'cuh', 'cui', 'cuj', 'cuk', 'cul', 'cum', 'cuo', 'cup', 'cuq', 'cur', 'cus', 'cut', 'cuu', 'cuv', 'cuw', 'cux', 'cvg', 'cvn', 'cwa', 'cwb', 'cwd', 'cwe', 'cwg', 'cwt', 'cya', 'cyb', 'cyo', 'czh', 'czk', 'czn', 'czo', 'czt', 'daa', 'dac', 'dad', 'dae', 'daf', 'dag', 'dah', 'dai', 'daj', 'dak', 'dal', 'dam', 'dao', 'dap', 'daq', 'dar', 'das', 'dau', 'dav', 'daw', 'dax', 'day', 'daz', 'dba', 'dbb', 'dbd', 'dbe', 'dbf', 'dbg', 'dbi', 'dbj', 'dbl', 'dbm', 'dbn', 'dbo', 'dbp', 'dbq', 'dbr', 'dbt', 'dbu', 'dbv', 'dbw', 'dby', 'dcc', 'dcr', 'dda', 'ddd', 'dde', 'ddg', 'ddi', 'ddj', 'ddn', 'ddo', 'ddr', 'dds', 'ddw', 'dec', 'ded', 'dee', 'def', 'deg', 'deh', 'dei', 'dek', 'del', 'dem', 'den', 'dep', 'deq', 'der', 'des', 'dev', 'dez', 'dga', 'dgb', 'dgc', 'dgd', 'dge', 'dgg', 'dgh', 'dgi', 'dgk', 'dgl', 'dgn', 'dgo', 'dgr', 'dgs', 'dgt', 'dgu', 'dgw', 'dgx', 'dgz', 'dha', 'dhd', 'dhg', 'dhi', 'dhl', 'dhm', 'dhn', 'dho', 'dhr', 'dhs', 'dhu', 'dhv', 'dhw', 'dhx', 'dia', 'dib', 'dic', 'did', 'dif', 'dig', 'dih', 'dii', 'dij', 'dik', 'dil', 'dim', 'din', 'dio', 'dip', 'diq', 'dir', 'dis', 'dit', 'diu', 'diw', 'dix', 'diy', 'diz', 'dja', 'djb', 'djc', 'djd', 'dje', 'djf', 'dji', 'djj', 'djk', 'djl', 'djm', 'djn', 'djo', 'djr', 'dju', 'djw', 'dka', 'dkk', 'dkl', 'dkr', 'dks', 'dkx', 'dlg', 'dlk', 'dlm', 'dln', 'dma', 'dmb', 'dmc', 'dmd', 'dme', 'dmg', 'dmk', 'dml', 'dmm', 'dmn', 'dmo', 'dmr', 'dms', 'dmu', 'dmv', 'dmw', 'dmx', 'dmy', 'dna', 'dnd', 'dne', 'dng', 'dni', 'dnj', 'dnk', 'dnn', 'dnr', 'dnt', 'dnu', 'dnv', 'dnw', 'dny', 'doa', 'dob', 'doc', 'doe', 'dof', 'doh', 'doi', 'dok', 'dol', 'don', 'doo', 'dop', 'doq', 'dor', 'dos', 'dot', 'dov', 'dow', 'dox', 'doy', 'doz', 'dpp', 'dra', 'drb', 'drc', 'drd', 'dre', 'drg', 'drh', 'dri', 'drl', 'drn', 'dro', 'drq', 'drr', 'drs', 'drt', 'dru', 'drw', 'dry', 'dsb', 'dse', 'dsh', 'dsi', 'dsl', 'dsn', 'dso', 'dsq', 'dta', 'dtb', 'dtd', 'dth', 'dti', 'dtk', 'dtm', 'dtn', 'dto', 'dtp', 'dtr', 'dts', 'dtt', 'dtu', 'dty', 'dua', 'dub', 'duc', 'dud', 'due', 'duf', 'dug', 'duh', 'dui', 'duj', 'duk', 'dul', 'dum', 'dun', 'duo', 'dup', 'duq', 'dur', 'dus', 'duu', 'duv', 'duw', 'dux', 'duy', 'duz', 'dva', 'dwa', 'dwl', 'dwr', 'dws', 'dwu', 'dww', 'dwy', 'dya', 'dyb', 'dyd', 'dyg', 'dyi', 'dym', 'dyn', 'dyo', 'dyu', 'dyy', 'dza', 'dzd', 'dze', 'dzg', 'dzl', 'dzn', 'eaa', 'ebg', 'ebk', 'ebo', 'ebr', 'ebu', 'ecr', 'ecs', 'ecy', 'eee', 'efa', 'efe', 'efi', 'ega', 'egl', 'ego', 'egx', 'egy', 'ehu', 'eip', 'eit', 'eiv', 'eja', 'eka', 'ekc', 'eke', 'ekg', 'eki', 'ekk', 'ekl', 'ekm', 'eko', 'ekp', 'ekr', 'eky', 'ele', 'elh', 'eli', 'elk', 'elm', 'elo', 'elp', 'elu', 'elx', 'ema', 'emb', 'eme', 'emg', 'emi', 'emk', 'emm', 'emn', 'emo', 'emp', 'ems', 'emu', 'emw', 'emx', 'emy', 'ena', 'enb', 'enc', 'end', 'enf', 'enh', 'enl', 'enm', 'enn', 'eno', 'enq', 'enr', 'enu', 'env', 'enw', 'enx', 'eot', 'epi', 'era', 'erg', 'erh', 'eri', 'erk', 'ero', 'err', 'ers', 'ert', 'erw', 'ese', 'esg', 'esh', 'esi', 'esk', 'esl', 'esm', 'esn', 'eso', 'esq', 'ess', 'esu', 'esx', 'esy', 'etb', 'etc', 'eth', 'etn', 'eto', 'etr', 'ets', 'ett', 'etu', 'etx', 'etz', 'euq', 'eve', 'evh', 'evn', 'ewo', 'ext', 'eya', 'eyo', 'eza', 'eze', 'faa', 'fab', 'fad', 'faf', 'fag', 'fah', 'fai', 'faj', 'fak', 'fal', 'fam', 'fan', 'fap', 'far', 'fat', 'fau', 'fax', 'fay', 'faz', 'fbl', 'fcs', 'fer', 'ffi', 'ffm', 'fgr', 'fia', 'fie', 'fil', 'fip', 'fir', 'fit', 'fiu', 'fiw', 'fkk', 'fkv', 'fla', 'flh', 'fli', 'fll', 'fln', 'flr', 'fly', 'fmp', 'fmu', 'fnb', 'fng', 'fni', 'fod', 'foi', 'fom', 'fon', 'for', 'fos', 'fox', 'fpe', 'fqs', 'frc', 'frd', 'frk', 'frm', 'fro', 'frp', 'frq', 'frr', 'frs', 'frt', 'fse', 'fsl', 'fss', 'fub', 'fuc', 'fud', 'fue', 'fuf', 'fuh', 'fui', 'fuj', 'fum', 'fun', 'fuq', 'fur', 'fut', 'fuu', 'fuv', 'fuy', 'fvr', 'fwa', 'fwe', 'gaa', 'gab', 'gac', 'gad', 'gae', 'gaf', 'gag', 'gah', 'gai', 'gaj', 'gak', 'gal', 'gam', 'gan', 'gao', 'gap', 'gaq', 'gar', 'gas', 'gat', 'gau', 'gav', 'gaw', 'gax', 'gay', 'gaz', 'gba', 'gbb', 'gbc', 'gbd', 'gbe', 'gbf', 'gbg', 'gbh', 'gbi', 'gbj', 'gbk', 'gbl', 'gbm', 'gbn', 'gbo', 'gbp', 'gbq', 'gbr', 'gbs', 'gbu', 'gbv', 'gbw', 'gbx', 'gby', 'gbz', 'gcc', 'gcd', 'gce', 'gcf', 'gcl', 'gcn', 'gcr', 'gct', 'gda', 'gdb', 'gdc', 'gdd', 'gde', 'gdf', 'gdg', 'gdh', 'gdi', 'gdj', 'gdk', 'gdl', 'gdm', 'gdn', 'gdo', 'gdq', 'gdr', 'gds', 'gdt', 'gdu', 'gdx', 'gea', 'geb', 'gec', 'ged', 'geg', 'geh', 'gei', 'gej', 'gek', 'gel', 'gem', 'geq', 'ges', 'gev', 'gew', 'gex', 'gey', 'gez', 'gfk', 'gft', 'gfx', 'gga', 'ggb', 'ggd', 'gge', 'ggg', 'ggk', 'ggl', 'ggn', 'ggo', 'ggr', 'ggt', 'ggu', 'ggw', 'gha', 'ghc', 'ghe', 'ghh', 'ghk', 'ghl', 'ghn', 'gho', 'ghr', 'ghs', 'ght', 'gia', 'gib', 'gic', 'gid', 'gie', 'gig', 'gih', 'gil', 'gim', 'gin', 'gio', 'gip', 'giq', 'gir', 'gis', 'git', 'giu', 'giw', 'gix', 'giy', 'giz', 'gji', 'gjk', 'gjm', 'gjn', 'gjr', 'gju', 'gka', 'gke', 'gkn', 'gko', 'gkp', 'gku', 'glc', 'gld', 'glh', 'gli', 'glj', 'glk', 'gll', 'glo', 'glr', 'glu', 'glw', 'gly', 'gma', 'gmb', 'gmd', 'gme', 'gmg', 'gmh', 'gml', 'gmm', 'gmn', 'gmq', 'gmu', 'gmv', 'gmw', 'gmx', 'gmy', 'gmz', 'gna', 'gnb', 'gnc', 'gnd', 'gne', 'gng', 'gnh', 'gni', 'gnk', 'gnl', 'gnm', 'gnn', 'gno', 'gnq', 'gnr', 'gnt', 'gnu', 'gnw', 'gnz', 'goa', 'gob', 'goc', 'god', 'goe', 'gof', 'gog', 'goh', 'goi', 'goj', 'gok', 'gol', 'gom', 'gon', 'goo', 'gop', 'goq', 'gor', 'gos', 'got', 'gou', 'gow', 'gox', 'goy', 'goz', 'gpa', 'gpe', 'gpn', 'gqa', 'gqi', 'gqn', 'gqr', 'gqu', 'gra', 'grb', 'grc', 'grd', 'grg', 'grh', 'gri', 'grj', 'grk', 'grm', 'gro', 'grq', 'grr', 'grs', 'grt', 'gru', 'grv', 'grw', 'grx', 'gry', 'grz', 'gse', 'gsg', 'gsl', 'gsm', 'gsn', 'gso', 'gsp', 'gss', 'gsw', 'gta', 'gti', 'gtu', 'gua', 'gub', 'guc', 'gud', 'gue', 'guf', 'gug', 'guh', 'gui', 'guk', 'gul', 'gum', 'gun', 'guo', 'gup', 'guq', 'gur', 'gus', 'gut', 'guu', 'guv', 'guw', 'gux', 'guz', 'gva', 'gvc', 'gve', 'gvf', 'gvj', 'gvl', 'gvm', 'gvn', 'gvo', 'gvp', 'gvr', 'gvs', 'gvy', 'gwa', 'gwb', 'gwc', 'gwd', 'gwe', 'gwf', 'gwg', 'gwi', 'gwj', 'gwm', 'gwn', 'gwr', 'gwt', 'gwu', 'gww', 'gwx', 'gxx', 'gya', 'gyb', 'gyd', 'gye', 'gyf', 'gyg', 'gyi', 'gyl', 'gym', 'gyn', 'gyr', 'gyy', 'gza', 'gzi', 'gzn', 'haa', 'hab', 'hac', 'had', 'hae', 'haf', 'hag', 'hah', 'hai', 'haj', 'hak', 'hal', 'ham', 'han', 'hao', 'hap', 'haq', 'har', 'has', 'hav', 'haw', 'hax', 'hay', 'haz', 'hba', 'hbb', 'hbn', 'hbo', 'hbu', 'hca', 'hch', 'hdn', 'hds', 'hdy', 'hea', 'hed', 'heg', 'heh', 'hei', 'hem', 'hgm', 'hgw', 'hhi', 'hhr', 'hhy', 'hia', 'hib', 'hid', 'hif', 'hig', 'hih', 'hii', 'hij', 'hik', 'hil', 'him', 'hio', 'hir', 'hit', 'hiw', 'hix', 'hji', 'hka', 'hke', 'hkk', 'hks', 'hla', 'hlb', 'hld', 'hle', 'hlt', 'hlu', 'hma', 'hmb', 'hmc', 'hmd', 'hme', 'hmf', 'hmg', 'hmh', 'hmi', 'hmj', 'hmk', 'hml', 'hmm', 'hmn', 'hmp', 'hmq', 'hmr', 'hms', 'hmt', 'hmu', 'hmv', 'hmw', 'hmx', 'hmy', 'hmz', 'hna', 'hnd', 'hne', 'hnh', 'hni', 'hnj', 'hnn', 'hno', 'hns', 'hnu', 'hoa', 'hob', 'hoc', 'hod', 'hoe', 'hoh', 'hoi', 'hoj', 'hok', 'hol', 'hom', 'hoo', 'hop', 'hor', 'hos', 'hot', 'hov', 'how', 'hoy', 'hoz', 'hpo', 'hps', 'hra', 'hrc', 'hre', 'hrk', 'hrm', 'hro', 'hrp', 'hrr', 'hrt', 'hru', 'hrw', 'hrx', 'hrz', 'hsb', 'hsh', 'hsl', 'hsn', 'hss', 'hti', 'hto', 'hts', 'htu', 'htx', 'hub', 'huc', 'hud', 'hue', 'huf', 'hug', 'huh', 'hui', 'huj', 'huk', 'hul', 'hum', 'huo', 'hup', 'huq', 'hur', 'hus', 'hut', 'huu', 'huv', 'huw', 'hux', 'huy', 'huz', 'hvc', 'hve', 'hvk', 'hvn', 'hvv', 'hwa', 'hwc', 'hwo', 'hya', 'hyx', 'iai', 'ian', 'iap', 'iar', 'iba', 'ibb', 'ibd', 'ibe', 'ibg', 'ibh', 'ibi', 'ibl', 'ibm', 'ibn', 'ibr', 'ibu', 'iby', 'ica', 'ich', 'icl', 'icr', 'ida', 'idb', 'idc', 'idd', 'ide', 'idi', 'idr', 'ids', 'idt', 'idu', 'ifa', 'ifb', 'ife', 'iff', 'ifk', 'ifm', 'ifu', 'ify', 'igb', 'ige', 'igg', 'igl', 'igm', 'ign', 'igo', 'igs', 'igw', 'ihb', 'ihi', 'ihp', 'ihw', 'iin', 'iir', 'ijc', 'ije', 'ijj', 'ijn', 'ijo', 'ijs', 'ike', 'iki', 'ikk', 'ikl', 'iko', 'ikp', 'ikr', 'iks', 'ikt', 'ikv', 'ikw', 'ikx', 'ikz', 'ila', 'ilb', 'ilg', 'ili', 'ilk', 'ill', 'ilm', 'ilo', 'ilp', 'ils', 'ilu', 'ilv', 'ilw', 'ima', 'ime', 'imi', 'iml', 'imn', 'imo', 'imr', 'ims', 'imy', 'inb', 'inc', 'ine', 'ing', 'inh', 'inj', 'inl', 'inm', 'inn', 'ino', 'inp', 'ins', 'int', 'inz', 'ior', 'iou', 'iow', 'ipi', 'ipo', 'iqu', 'iqw', 'ira', 'ire', 'irh', 'iri', 'irk', 'irn', 'iro', 'irr', 'iru', 'irx', 'iry', 'isa', 'isc', 'isd', 'ise', 'isg', 'ish', 'isi', 'isk', 'ism', 'isn', 'iso', 'isr', 'ist', 'isu', 'itb', 'itc', 'itd', 'ite', 'iti', 'itk', 'itl', 'itm', 'ito', 'itr', 'its', 'itt', 'itv', 'itw', 'itx', 'ity', 'itz', 'ium', 'ivb', 'ivv', 'iwk', 'iwm', 'iwo', 'iws', 'ixc', 'ixl', 'iya', 'iyo', 'iyx', 'izh', 'izi', 'izr', 'izz', 'jaa', 'jab', 'jac', 'jad', 'jae', 'jaf', 'jah', 'jaj', 'jak', 'jal', 'jam', 'jan', 'jao', 'jaq', 'jar', 'jas', 'jat', 'jau', 'jax', 'jay', 'jaz', 'jbe', 'jbi', 'jbj', 'jbk', 'jbn', 'jbo', 'jbr', 'jbt', 'jbu', 'jbw', 'jcs', 'jct', 'jda', 'jdg', 'jdt', 'jeb', 'jee', 'jeg', 'jeh', 'jei', 'jek', 'jel', 'jen', 'jer', 'jet', 'jeu', 'jgb', 'jge', 'jgk', 'jgo', 'jhi', 'jhs', 'jia', 'jib', 'jic', 'jid', 'jie', 'jig', 'jih', 'jii', 'jil', 'jim', 'jio', 'jiq', 'jit', 'jiu', 'jiv', 'jiy', 'jje', 'jjr', 'jka', 'jkm', 'jko', 'jkp', 'jkr', 'jku', 'jle', 'jls', 'jma', 'jmb', 'jmc', 'jmd', 'jmi', 'jml', 'jmn', 'jmr', 'jms', 'jmw', 'jmx', 'jna', 'jnd', 'jng', 'jni', 'jnj', 'jnl', 'jns', 'job', 'jod', 'jog', 'jor', 'jos', 'jow', 'jpa', 'jpr', 'jpx', 'jqr', 'jra', 'jrb', 'jrr', 'jrt', 'jru', 'jsl', 'jua', 'jub', 'juc', 'jud', 'juh', 'jui', 'juk', 'jul', 'jum', 'jun', 'juo', 'jup', 'jur', 'jus', 'jut', 'juu', 'juw', 'juy', 'jvd', 'jvn', 'jwi', 'jya', 'jye', 'jyy', 'kaa', 'kab', 'kac', 'kad', 'kae', 'kaf', 'kag', 'kah', 'kai', 'kaj', 'kak', 'kam', 'kao', 'kap', 'kaq', 'kar', 'kav', 'kaw', 'kax', 'kay', 'kba', 'kbb', 'kbc', 'kbd', 'kbe', 'kbf', 'kbg', 'kbh', 'kbi', 'kbj', 'kbk', 'kbl', 'kbm', 'kbn', 'kbo', 'kbp', 'kbq', 'kbr', 'kbs', 'kbt', 'kbu', 'kbv', 'kbw', 'kbx', 'kby', 'kbz', 'kca', 'kcb', 'kcc', 'kcd', 'kce', 'kcf', 'kcg', 'kch', 'kci', 'kcj', 'kck', 'kcl', 'kcm', 'kcn', 'kco', 'kcp', 'kcq', 'kcr', 'kcs', 'kct', 'kcu', 'kcv', 'kcw', 'kcx', 'kcy', 'kcz', 'kda', 'kdc', 'kdd', 'kde', 'kdf', 'kdg', 'kdh', 'kdi', 'kdj', 'kdk', 'kdl', 'kdm', 'kdn', 'kdo', 'kdp', 'kdq', 'kdr', 'kdt', 'kdu', 'kdv', 'kdw', 'kdx', 'kdy', 'kdz', 'kea', 'keb', 'kec', 'ked', 'kee', 'kef', 'keg', 'keh', 'kei', 'kej', 'kek', 'kel', 'kem', 'ken', 'keo', 'kep', 'keq', 'ker', 'kes', 'ket', 'keu', 'kev', 'kew', 'kex', 'key', 'kez', 'kfa', 'kfb', 'kfc', 'kfd', 'kfe', 'kff', 'kfg', 'kfh', 'kfi', 'kfj', 'kfk', 'kfl', 'kfm', 'kfn', 'kfo', 'kfp', 'kfq', 'kfr', 'kfs', 'kft', 'kfu', 'kfv', 'kfw', 'kfx', 'kfy', 'kfz', 'kga', 'kgb', 'kgc', 'kgd', 'kge', 'kgf', 'kgg', 'kgh', 'kgi', 'kgj', 'kgk', 'kgl', 'kgm', 'kgn', 'kgo', 'kgp', 'kgq', 'kgr', 'kgs', 'kgt', 'kgu', 'kgv', 'kgw', 'kgx', 'kgy', 'kha', 'khb', 'khc', 'khd', 'khe', 'khf', 'khg', 'khh', 'khi', 'khj', 'khk', 'khl', 'khn', 'kho', 'khp', 'khq', 'khr', 'khs', 'kht', 'khu', 'khv', 'khw', 'khx', 'khy', 'khz', 'kia', 'kib', 'kic', 'kid', 'kie', 'kif', 'kig', 'kih', 'kii', 'kij', 'kil', 'kim', 'kio', 'kip', 'kiq', 'kis', 'kit', 'kiu', 'kiv', 'kiw', 'kix', 'kiy', 'kiz', 'kja', 'kjb', 'kjc', 'kjd', 'kje', 'kjf', 'kjg', 'kjh', 'kji', 'kjj', 'kjk', 'kjl', 'kjm', 'kjn', 'kjo', 'kjp', 'kjq', 'kjr', 'kjs', 'kjt', 'kju', 'kjv', 'kjx', 'kjy', 'kjz', 'kka', 'kkb', 'kkc', 'kkd', 'kke', 'kkf', 'kkg', 'kkh', 'kki', 'kkj', 'kkk', 'kkl', 'kkm', 'kkn', 'kko', 'kkp', 'kkq', 'kkr', 'kks', 'kkt', 'kku', 'kkv', 'kkw', 'kkx', 'kky', 'kkz', 'kla', 'klb', 'klc', 'kld', 'kle', 'klf', 'klg', 'klh', 'kli', 'klj', 'klk', 'kll', 'klm', 'kln', 'klo', 'klp', 'klq', 'klr', 'kls', 'klt', 'klu', 'klv', 'klw', 'klx', 'kly', 'klz', 'kma', 'kmb', 'kmc', 'kmd', 'kme', 'kmf', 'kmg', 'kmh', 'kmi', 'kmj', 'kmk', 'kml', 'kmm', 'kmn', 'kmo', 'kmp', 'kmq', 'kmr', 'kms', 'kmt', 'kmu', 'kmv', 'kmw', 'kmx', 'kmy', 'kmz', 'kna', 'knb', 'knc', 'knd', 'kne', 'knf', 'kng', 'kni', 'knj', 'knk', 'knl', 'knm', 'knn', 'kno', 'knp', 'knq', 'knr', 'kns', 'knt', 'knu', 'knv', 'knw', 'knx', 'kny', 'knz', 'koa', 'koc', 'kod', 'koe', 'kof', 'kog', 'koh', 'koi', 'koj', 'kok', 'kol', 'koo', 'kop', 'koq', 'kos', 'kot', 'kou', 'kov', 'kow', 'kox', 'koy', 'koz', 'kpa', 'kpb', 'kpc', 'kpd', 'kpe', 'kpf', 'kpg', 'kph', 'kpi', 'kpj', 'kpk', 'kpl', 'kpm', 'kpn', 'kpo', 'kpp', 'kpq', 'kpr', 'kps', 'kpt', 'kpu', 'kpv', 'kpw', 'kpx', 'kpy', 'kpz', 'kqa', 'kqb', 'kqc', 'kqd', 'kqe', 'kqf', 'kqg', 'kqh', 'kqi', 'kqj', 'kqk', 'kql', 'kqm', 'kqn', 'kqo', 'kqp', 'kqq', 'kqr', 'kqs', 'kqt', 'kqu', 'kqv', 'kqw', 'kqx', 'kqy', 'kqz', 'kra', 'krb', 'krc', 'krd', 'kre', 'krf', 'krh', 'kri', 'krj', 'krk', 'krl', 'krm', 'krn', 'kro', 'krp', 'krr', 'krs', 'krt', 'kru', 'krv', 'krw', 'krx', 'kry', 'krz', 'ksa', 'ksb', 'ksc', 'ksd', 'kse', 'ksf', 'ksg', 'ksh', 'ksi', 'ksj', 'ksk', 'ksl', 'ksm', 'ksn', 'kso', 'ksp', 'ksq', 'ksr', 'kss', 'kst', 'ksu', 'ksv', 'ksw', 'ksx', 'ksy', 'ksz', 'kta', 'ktb', 'ktc', 'ktd', 'kte', 'ktf', 'ktg', 'kth', 'kti', 'ktj', 'ktk', 'ktl', 'ktm', 'ktn', 'kto', 'ktp', 'ktq', 'ktr', 'kts', 'ktt', 'ktu', 'ktv', 'ktw', 'ktx', 'kty', 'ktz', 'kub', 'kuc', 'kud', 'kue', 'kuf', 'kug', 'kuh', 'kui', 'kuj', 'kuk', 'kul', 'kum', 'kun', 'kuo', 'kup', 'kuq', 'kus', 'kut', 'kuu', 'kuv', 'kuw', 'kux', 'kuy', 'kuz', 'kva', 'kvb', 'kvc', 'kvd', 'kve', 'kvf', 'kvg', 'kvh', 'kvi', 'kvj', 'kvk', 'kvl', 'kvm', 'kvn', 'kvo', 'kvp', 'kvq', 'kvr', 'kvs', 'kvt', 'kvu', 'kvv', 'kvw', 'kvx', 'kvy', 'kvz', 'kwa', 'kwb', 'kwc', 'kwd', 'kwe', 'kwf', 'kwg', 'kwh', 'kwi', 'kwj', 'kwk', 'kwl', 'kwm', 'kwn', 'kwo', 'kwp', 'kwq', 'kwr', 'kws', 'kwt', 'kwu', 'kwv', 'kww', 'kwx', 'kwy', 'kwz', 'kxa', 'kxb', 'kxc', 'kxd', 'kxe', 'kxf', 'kxh', 'kxi', 'kxj', 'kxk', 'kxl', 'kxm', 'kxn', 'kxo', 'kxp', 'kxq', 'kxr', 'kxs', 'kxt', 'kxu', 'kxv', 'kxw', 'kxx', 'kxy', 'kxz', 'kya', 'kyb', 'kyc', 'kyd', 'kye', 'kyf', 'kyg', 'kyh', 'kyi', 'kyj', 'kyk', 'kyl', 'kym', 'kyn', 'kyo', 'kyp', 'kyq', 'kyr', 'kys', 'kyt', 'kyu', 'kyv', 'kyw', 'kyx', 'kyy', 'kyz', 'kza', 'kzb', 'kzc', 'kzd', 'kze', 'kzf', 'kzg', 'kzh', 'kzi', 'kzj', 'kzk', 'kzl', 'kzm', 'kzn', 'kzo', 'kzp', 'kzq', 'kzr', 'kzs', 'kzt', 'kzu', 'kzv', 'kzw', 'kzx', 'kzy', 'kzz', 'laa', 'lab', 'lac', 'lad', 'lae', 'laf', 'lag', 'lah', 'lai', 'laj', 'lak', 'lal', 'lam', 'lan', 'lap', 'laq', 'lar', 'las', 'lau', 'law', 'lax', 'lay', 'laz', 'lba', 'lbb', 'lbc', 'lbe', 'lbf', 'lbg', 'lbi', 'lbj', 'lbk', 'lbl', 'lbm', 'lbn', 'lbo', 'lbq', 'lbr', 'lbs', 'lbt', 'lbu', 'lbv', 'lbw', 'lbx', 'lby', 'lbz', 'lcc', 'lcd', 'lce', 'lcf', 'lch', 'lcl', 'lcm', 'lcp', 'lcq', 'lcs', 'lda', 'ldb', 'ldd', 'ldg', 'ldh', 'ldi', 'ldj', 'ldk', 'ldl', 'ldm', 'ldn', 'ldo', 'ldp', 'ldq', 'lea', 'leb', 'lec', 'led', 'lee', 'lef', 'leg', 'leh', 'lei', 'lej', 'lek', 'lel', 'lem', 'len', 'leo', 'lep', 'leq', 'ler', 'les', 'let', 'leu', 'lev', 'lew', 'lex', 'ley', 'lez', 'lfa', 'lfn', 'lga', 'lgb', 'lgg', 'lgh', 'lgi', 'lgk', 'lgl', 'lgm', 'lgn', 'lgq', 'lgr', 'lgt', 'lgu', 'lgz', 'lha', 'lhh', 'lhi', 'lhl', 'lhm', 'lhn', 'lhp', 'lhs', 'lht', 'lhu', 'lia', 'lib', 'lic', 'lid', 'lie', 'lif', 'lig', 'lih', 'lii', 'lij', 'lik', 'lil', 'lio', 'lip', 'liq', 'lir', 'lis', 'liu', 'liv', 'liw', 'lix', 'liy', 'liz', 'lja', 'lje', 'lji', 'ljl', 'ljp', 'ljw', 'ljx', 'lka', 'lkb', 'lkc', 'lkd', 'lke', 'lkh', 'lki', 'lkj', 'lkl', 'lkm', 'lkn', 'lko', 'lkr', 'lks', 'lkt', 'lku', 'lky', 'lla', 'llb', 'llc', 'lld', 'lle', 'llf', 'llg', 'llh', 'lli', 'llj', 'llk', 'lll', 'llm', 'lln', 'llo', 'llp', 'llq', 'lls', 'llu', 'llx', 'lma', 'lmb', 'lmc', 'lmd', 'lme', 'lmf', 'lmg', 'lmh', 'lmi', 'lmj', 'lmk', 'lml', 'lmm', 'lmn', 'lmo', 'lmp', 'lmq', 'lmr', 'lmu', 'lmv', 'lmw', 'lmx', 'lmy', 'lmz', 'lna', 'lnb', 'lnd', 'lng', 'lnh', 'lni', 'lnj', 'lnl', 'lnm', 'lnn', 'lno', 'lns', 'lnu', 'lnw', 'lnz', 'loa', 'lob', 'loc', 'loe', 'lof', 'log', 'loh', 'loi', 'loj', 'lok', 'lol', 'lom', 'lon', 'loo', 'lop', 'loq', 'lor', 'los', 'lot', 'lou', 'lov', 'low', 'lox', 'loy', 'loz', 'lpa', 'lpe', 'lpn', 'lpo', 'lpx', 'lra', 'lrc', 'lre', 'lrg', 'lri', 'lrk', 'lrl', 'lrm', 'lrn', 'lro', 'lrr', 'lrt', 'lrv', 'lrz', 'lsa', 'lsd', 'lse', 'lsg', 'lsh', 'lsi', 'lsl', 'lsm', 'lso', 'lsp', 'lsr', 'lss', 'lst', 'lsy', 'ltc', 'ltg', 'lth', 'lti', 'ltn', 'lto', 'lts', 'ltu', 'lua', 'luc', 'lud', 'lue', 'luf', 'lui', 'luj', 'luk', 'lul', 'lum', 'lun', 'luo', 'lup', 'luq', 'lur', 'lus', 'lut', 'luu', 'luv', 'luw', 'luy', 'luz', 'lva', 'lvk', 'lvs', 'lvu', 'lwa', 'lwe', 'lwg', 'lwh', 'lwl', 'lwm', 'lwo', 'lwt', 'lwu', 'lww', 'lya', 'lyg', 'lyn', 'lzh', 'lzl', 'lzn', 'lzz', 'maa', 'mab', 'mad', 'mae', 'maf', 'mag', 'mai', 'maj', 'mak', 'mam', 'man', 'map', 'maq', 'mas', 'mat', 'mau', 'mav', 'maw', 'max', 'maz', 'mba', 'mbb', 'mbc', 'mbd', 'mbe', 'mbf', 'mbh', 'mbi', 'mbj', 'mbk', 'mbl', 'mbm', 'mbn', 'mbo', 'mbp', 'mbq', 'mbr', 'mbs', 'mbt', 'mbu', 'mbv', 'mbw', 'mbx', 'mby', 'mbz', 'mca', 'mcb', 'mcc', 'mcd', 'mce', 'mcf', 'mcg', 'mch', 'mci', 'mcj', 'mck', 'mcl', 'mcm', 'mcn', 'mco', 'mcp', 'mcq', 'mcr', 'mcs', 'mct', 'mcu', 'mcv', 'mcw', 'mcx', 'mcy', 'mcz', 'mda', 'mdb', 'mdc', 'mdd', 'mde', 'mdf', 'mdg', 'mdh', 'mdi', 'mdj', 'mdk', 'mdl', 'mdm', 'mdn', 'mdp', 'mdq', 'mdr', 'mds', 'mdt', 'mdu', 'mdv', 'mdw', 'mdx', 'mdy', 'mdz', 'mea', 'meb', 'mec', 'med', 'mee', 'mef', 'meg', 'meh', 'mei', 'mej', 'mek', 'mel', 'mem', 'men', 'meo', 'mep', 'meq', 'mer', 'mes', 'met', 'meu', 'mev', 'mew', 'mey', 'mez', 'mfa', 'mfb', 'mfc', 'mfd', 'mfe', 'mff', 'mfg', 'mfh', 'mfi', 'mfj', 'mfk', 'mfl', 'mfm', 'mfn', 'mfo', 'mfp', 'mfq', 'mfr', 'mfs', 'mft', 'mfu', 'mfv', 'mfw', 'mfx', 'mfy', 'mfz', 'mga', 'mgb', 'mgc', 'mgd', 'mge', 'mgf', 'mgg', 'mgh', 'mgi', 'mgj', 'mgk', 'mgl', 'mgm', 'mgn', 'mgo', 'mgp', 'mgq', 'mgr', 'mgs', 'mgt', 'mgu', 'mgv', 'mgw', 'mgx', 'mgy', 'mgz', 'mha', 'mhb', 'mhc', 'mhd', 'mhe', 'mhf', 'mhg', 'mhh', 'mhi', 'mhj', 'mhk', 'mhl', 'mhm', 'mhn', 'mho', 'mhp', 'mhq', 'mhr', 'mhs', 'mht', 'mhu', 'mhw', 'mhx', 'mhy', 'mhz', 'mia', 'mib', 'mic', 'mid', 'mie', 'mif', 'mig', 'mih', 'mii', 'mij', 'mik', 'mil', 'mim', 'min', 'mio', 'mip', 'miq', 'mir', 'mis', 'mit', 'miu', 'miw', 'mix', 'miy', 'miz', 'mja', 'mjb', 'mjc', 'mjd', 'mje', 'mjg', 'mjh', 'mji', 'mjj', 'mjk', 'mjl', 'mjm', 'mjn', 'mjo', 'mjp', 'mjq', 'mjr', 'mjs', 'mjt', 'mju', 'mjv', 'mjw', 'mjx', 'mjy', 'mjz', 'mka', 'mkb', 'mkc', 'mke', 'mkf', 'mkg', 'mkh', 'mki', 'mkj', 'mkk', 'mkl', 'mkm', 'mkn', 'mko', 'mkp', 'mkq', 'mkr', 'mks', 'mkt', 'mku', 'mkv', 'mkw', 'mkx', 'mky', 'mkz', 'mla', 'mlb', 'mlc', 'mld', 'mle', 'mlf', 'mlh', 'mli', 'mlj', 'mlk', 'mll', 'mlm', 'mln', 'mlo', 'mlp', 'mlq', 'mlr', 'mls', 'mlu', 'mlv', 'mlw', 'mlx', 'mlz', 'mma', 'mmb', 'mmc', 'mmd', 'mme', 'mmf', 'mmg', 'mmh', 'mmi', 'mmj', 'mmk', 'mml', 'mmm', 'mmn', 'mmo', 'mmp', 'mmq', 'mmr', 'mmt', 'mmu', 'mmv', 'mmw', 'mmx', 'mmy', 'mmz', 'mna', 'mnb', 'mnc', 'mnd', 'mne', 'mnf', 'mng', 'mnh', 'mni', 'mnj', 'mnk', 'mnl', 'mnm', 'mnn', 'mno', 'mnp', 'mnq', 'mnr', 'mns', 'mnt', 'mnu', 'mnv', 'mnw', 'mnx', 'mny', 'mnz', 'moa', 'moc', 'mod', 'moe', 'mof', 'mog', 'moh', 'moi', 'moj', 'mok', 'mom', 'moo', 'mop', 'moq', 'mor', 'mos', 'mot', 'mou', 'mov', 'mow', 'mox', 'moy', 'moz', 'mpa', 'mpb', 'mpc', 'mpd', 'mpe', 'mpg', 'mph', 'mpi', 'mpj', 'mpk', 'mpl', 'mpm', 'mpn', 'mpo', 'mpp', 'mpq', 'mpr', 'mps', 'mpt', 'mpu', 'mpv', 'mpw', 'mpx', 'mpy', 'mpz', 'mqa', 'mqb', 'mqc', 'mqe', 'mqf', 'mqg', 'mqh', 'mqi', 'mqj', 'mqk', 'mql', 'mqm', 'mqn', 'mqo', 'mqp', 'mqq', 'mqr', 'mqs', 'mqt', 'mqu', 'mqv', 'mqw', 'mqx', 'mqy', 'mqz', 'mra', 'mrb', 'mrc', 'mrd', 'mre', 'mrf', 'mrg', 'mrh', 'mrj', 'mrk', 'mrl', 'mrm', 'mrn', 'mro', 'mrp', 'mrq', 'mrr', 'mrs', 'mrt', 'mru', 'mrv', 'mrw', 'mrx', 'mry', 'mrz', 'msb', 'msc', 'msd', 'mse', 'msf', 'msg', 'msh', 'msi', 'msj', 'msk', 'msl', 'msm', 'msn', 'mso', 'msp', 'msq', 'msr', 'mss', 'mst', 'msu', 'msv', 'msw', 'msx', 'msy', 'msz', 'mta', 'mtb', 'mtc', 'mtd', 'mte', 'mtf', 'mtg', 'mth', 'mti', 'mtj', 'mtk', 'mtl', 'mtm', 'mtn', 'mto', 'mtp', 'mtq', 'mtr', 'mts', 'mtt', 'mtu', 'mtv', 'mtw', 'mtx', 'mty', 'mua', 'mub', 'muc', 'mud', 'mue', 'mug', 'muh', 'mui', 'muj', 'muk', 'mul', 'mum', 'mun', 'muo', 'mup', 'muq', 'mur', 'mus', 'mut', 'muu', 'muv', 'mux', 'muy', 'muz', 'mva', 'mvb', 'mvd', 'mve', 'mvf', 'mvg', 'mvh', 'mvi', 'mvk', 'mvl', 'mvm', 'mvn', 'mvo', 'mvp', 'mvq', 'mvr', 'mvs', 'mvt', 'mvu', 'mvv', 'mvw', 'mvx', 'mvy', 'mvz', 'mwa', 'mwb', 'mwc', 'mwd', 'mwe', 'mwf', 'mwg', 'mwh', 'mwi', 'mwj', 'mwk', 'mwl', 'mwm', 'mwn', 'mwo', 'mwp', 'mwq', 'mwr', 'mws', 'mwt', 'mwu', 'mwv', 'mww', 'mwx', 'mwy', 'mwz', 'mxa', 'mxb', 'mxc', 'mxd', 'mxe', 'mxf', 'mxg', 'mxh', 'mxi', 'mxj', 'mxk', 'mxl', 'mxm', 'mxn', 'mxo', 'mxp', 'mxq', 'mxr', 'mxs', 'mxt', 'mxu', 'mxv', 'mxw', 'mxx', 'mxy', 'mxz', 'myb', 'myc', 'myd', 'mye', 'myf', 'myg', 'myh', 'myi', 'myj', 'myk', 'myl', 'mym', 'myn', 'myo', 'myp', 'myq', 'myr', 'mys', 'myt', 'myu', 'myv', 'myw', 'myx', 'myy', 'myz', 'mza', 'mzb', 'mzc', 'mzd', 'mze', 'mzg', 'mzh', 'mzi', 'mzj', 'mzk', 'mzl', 'mzm', 'mzn', 'mzo', 'mzp', 'mzq', 'mzr', 'mzs', 'mzt', 'mzu', 'mzv', 'mzw', 'mzx', 'mzy', 'mzz', 'naa', 'nab', 'nac', 'nad', 'nae', 'naf', 'nag', 'nah', 'nai', 'naj', 'nak', 'nal', 'nam', 'nan', 'nao', 'nap', 'naq', 'nar', 'nas', 'nat', 'naw', 'nax', 'nay', 'naz', 'nba', 'nbb', 'nbc', 'nbd', 'nbe', 'nbf', 'nbg', 'nbh', 'nbi', 'nbj', 'nbk', 'nbm', 'nbn', 'nbo', 'nbp', 'nbq', 'nbr', 'nbs', 'nbt', 'nbu', 'nbv', 'nbw', 'nbx', 'nby', 'nca', 'ncb', 'ncc', 'ncd', 'nce', 'ncf', 'ncg', 'nch', 'nci', 'ncj', 'nck', 'ncl', 'ncm', 'ncn', 'nco', 'ncp', 'ncq', 'ncr', 'ncs', 'nct', 'ncu', 'ncx', 'ncz', 'nda', 'ndb', 'ndc', 'ndd', 'ndf', 'ndg', 'ndh', 'ndi', 'ndj', 'ndk', 'ndl', 'ndm', 'ndn', 'ndp', 'ndq', 'ndr', 'nds', 'ndt', 'ndu', 'ndv', 'ndw', 'ndx', 'ndy', 'ndz', 'nea', 'neb', 'nec', 'ned', 'nee', 'nef', 'neg', 'neh', 'nei', 'nej', 'nek', 'nem', 'nen', 'neo', 'neq', 'ner', 'nes', 'net', 'neu', 'nev', 'new', 'nex', 'ney', 'nez', 'nfa', 'nfd', 'nfl', 'nfr', 'nfu', 'nga', 'ngb', 'ngc', 'ngd', 'nge', 'ngf', 'ngg', 'ngh', 'ngi', 'ngj', 'ngk', 'ngl', 'ngm', 'ngn', 'ngo', 'ngp', 'ngq', 'ngr', 'ngs', 'ngt', 'ngu', 'ngv', 'ngw', 'ngx', 'ngy', 'ngz', 'nha', 'nhb', 'nhc', 'nhd', 'nhe', 'nhf', 'nhg', 'nhh', 'nhi', 'nhk', 'nhm', 'nhn', 'nho', 'nhp', 'nhq', 'nhr', 'nht', 'nhu', 'nhv', 'nhw', 'nhx', 'nhy', 'nhz', 'nia', 'nib', 'nic', 'nid', 'nie', 'nif', 'nig', 'nih', 'nii', 'nij', 'nik', 'nil', 'nim', 'nin', 'nio', 'niq', 'nir', 'nis', 'nit', 'niu', 'niv', 'niw', 'nix', 'niy', 'niz', 'nja', 'njb', 'njd', 'njh', 'nji', 'njj', 'njl', 'njm', 'njn', 'njo', 'njr', 'njs', 'njt', 'nju', 'njx', 'njy', 'njz', 'nka', 'nkb', 'nkc', 'nkd', 'nke', 'nkf', 'nkg', 'nkh', 'nki', 'nkj', 'nkk', 'nkm', 'nkn', 'nko', 'nkp', 'nkq', 'nkr', 'nks', 'nkt', 'nku', 'nkv', 'nkw', 'nkx', 'nkz', 'nla', 'nlc', 'nle', 'nlg', 'nli', 'nlj', 'nlk', 'nll', 'nln', 'nlo', 'nlq', 'nlr', 'nlu', 'nlv', 'nlw', 'nlx', 'nly', 'nlz', 'nma', 'nmb', 'nmc', 'nmd', 'nme', 'nmf', 'nmg', 'nmh', 'nmi', 'nmj', 'nmk', 'nml', 'nmm', 'nmn', 'nmo', 'nmp', 'nmq', 'nmr', 'nms', 'nmt', 'nmu', 'nmv', 'nmw', 'nmx', 'nmy', 'nmz', 'nna', 'nnb', 'nnc', 'nnd', 'nne', 'nnf', 'nng', 'nnh', 'nni', 'nnj', 'nnk', 'nnl', 'nnm', 'nnn', 'nnp', 'nnq', 'nnr', 'nns', 'nnt', 'nnu', 'nnv', 'nnw', 'nnx', 'nny', 'nnz', 'noa', 'noc', 'nod', 'noe', 'nof', 'nog', 'noh', 'noi', 'noj', 'nok', 'nol', 'nom', 'non', 'noo', 'nop', 'noq', 'nos', 'not', 'nou', 'nov', 'now', 'noy', 'noz', 'npa', 'npb', 'npg', 'nph', 'npi', 'npl', 'npn', 'npo', 'nps', 'npu', 'npx', 'npy', 'nqg', 'nqk', 'nql', 'nqm', 'nqn', 'nqo', 'nqq', 'nqy', 'nra', 'nrb', 'nrc', 'nre', 'nrf', 'nrg', 'nri', 'nrk', 'nrl', 'nrm', 'nrn', 'nrp', 'nrr', 'nrt', 'nru', 'nrx', 'nrz', 'nsa', 'nsc', 'nsd', 'nse', 'nsf', 'nsg', 'nsh', 'nsi', 'nsk', 'nsl', 'nsm', 'nsn', 'nso', 'nsp', 'nsq', 'nsr', 'nss', 'nst', 'nsu', 'nsv', 'nsw', 'nsx', 'nsy', 'nsz', 'ntd', 'nte', 'ntg', 'nti', 'ntj', 'ntk', 'ntm', 'nto', 'ntp', 'ntr', 'nts', 'ntu', 'ntw', 'ntx', 'nty', 'ntz', 'nua', 'nub', 'nuc', 'nud', 'nue', 'nuf', 'nug', 'nuh', 'nui', 'nuj', 'nuk', 'nul', 'num', 'nun', 'nuo', 'nup', 'nuq', 'nur', 'nus', 'nut', 'nuu', 'nuv', 'nuw', 'nux', 'nuy', 'nuz', 'nvh', 'nvm', 'nvo', 'nwa', 'nwb', 'nwc', 'nwe', 'nwg', 'nwi', 'nwm', 'nwo', 'nwr', 'nwx', 'nwy', 'nxa', 'nxd', 'nxe', 'nxg', 'nxi', 'nxk', 'nxl', 'nxm', 'nxn', 'nxo', 'nxq', 'nxr', 'nxu', 'nxx', 'nyb', 'nyc', 'nyd', 'nye', 'nyf', 'nyg', 'nyh', 'nyi', 'nyj', 'nyk', 'nyl', 'nym', 'nyn', 'nyo', 'nyp', 'nyq', 'nyr', 'nys', 'nyt', 'nyu', 'nyv', 'nyw', 'nyx', 'nyy', 'nza', 'nzb', 'nzi', 'nzk', 'nzm', 'nzs', 'nzu', 'nzy', 'nzz', 'oaa', 'oac', 'oar', 'oav', 'obi', 'obk', 'obl', 'obm', 'obo', 'obr', 'obt', 'obu', 'oca', 'och', 'oco', 'ocu', 'oda', 'odk', 'odt', 'odu', 'ofo', 'ofs', 'ofu', 'ogb', 'ogc', 'oge', 'ogg', 'ogo', 'ogu', 'oht', 'ohu', 'oia', 'oin', 'ojb', 'ojc', 'ojg', 'ojp', 'ojs', 'ojv', 'ojw', 'oka', 'okb', 'okd', 'oke', 'okg', 'okh', 'oki', 'okj', 'okk', 'okl', 'okm', 'okn', 'oko', 'okr', 'oks', 'oku', 'okv', 'okx', 'ola', 'old', 'ole', 'olk', 'olm', 'olo', 'olr', 'olt', 'olu', 'oma', 'omb', 'omc', 'ome', 'omg', 'omi', 'omk', 'oml', 'omn', 'omo', 'omp', 'omq', 'omr', 'omt', 'omu', 'omv', 'omw', 'omx', 'ona', 'onb', 'one', 'ong', 'oni', 'onj', 'onk', 'onn', 'ono', 'onp', 'onr', 'ons', 'ont', 'onu', 'onw', 'onx', 'ood', 'oog', 'oon', 'oor', 'oos', 'opa', 'opk', 'opm', 'opo', 'opt', 'opy', 'ora', 'orc', 'ore', 'org', 'orh', 'orn', 'oro', 'orr', 'ors', 'ort', 'oru', 'orv', 'orw', 'orx', 'ory', 'orz', 'osa', 'osc', 'osi', 'oso', 'osp', 'ost', 'osu', 'osx', 'ota', 'otb', 'otd', 'ote', 'oti', 'otk', 'otl', 'otm', 'otn', 'oto', 'otq', 'otr', 'ots', 'ott', 'otu', 'otw', 'otx', 'oty', 'otz', 'oua', 'oub', 'oue', 'oui', 'oum', 'oun', 'ovd', 'owi', 'owl', 'oyb', 'oyd', 'oym', 'oyy', 'ozm', 'paa', 'pab', 'pac', 'pad', 'pae', 'paf', 'pag', 'pah', 'pai', 'pak', 'pal', 'pam', 'pao', 'pap', 'paq', 'par', 'pas', 'pat', 'pau', 'pav', 'paw', 'pax', 'pay', 'paz', 'pbb', 'pbc', 'pbe', 'pbf', 'pbg', 'pbh', 'pbi', 'pbl', 'pbn', 'pbo', 'pbp', 'pbr', 'pbs', 'pbt', 'pbu', 'pbv', 'pby', 'pbz', 'pca', 'pcb', 'pcc', 'pcd', 'pce', 'pcf', 'pcg', 'pch', 'pci', 'pcj', 'pck', 'pcl', 'pcm', 'pcn', 'pcp', 'pcr', 'pcw', 'pda', 'pdc', 'pdi', 'pdn', 'pdo', 'pdt', 'pdu', 'pea', 'peb', 'ped', 'pee', 'pef', 'peg', 'peh', 'pei', 'pej', 'pek', 'pel', 'pem', 'peo', 'pep', 'peq', 'pes', 'pev', 'pex', 'pey', 'pez', 'pfa', 'pfe', 'pfl', 'pga', 'pgd', 'pgg', 'pgi', 'pgk', 'pgl', 'pgn', 'pgs', 'pgu', 'pgy', 'pgz', 'pha', 'phd', 'phg', 'phh', 'phi', 'phk', 'phl', 'phm', 'phn', 'pho', 'phq', 'phr', 'pht', 'phu', 'phv', 'phw', 'pia', 'pib', 'pic', 'pid', 'pie', 'pif', 'pig', 'pih', 'pii', 'pij', 'pil', 'pim', 'pin', 'pio', 'pip', 'pir', 'pis', 'pit', 'piu', 'piv', 'piw', 'pix', 'piy', 'piz', 'pjt', 'pka', 'pkb', 'pkc', 'pkg', 'pkh', 'pkn', 'pko', 'pkp', 'pkr', 'pks', 'pkt', 'pku', 'pla', 'plb', 'plc', 'pld', 'ple', 'plf', 'plg', 'plh', 'plj', 'plk', 'pll', 'pln', 'plo', 'plp', 'plq', 'plr', 'pls', 'plt', 'plu', 'plv', 'plw', 'ply', 'plz', 'pma', 'pmb', 'pmc', 'pmd', 'pme', 'pmf', 'pmh', 'pmi', 'pmj', 'pmk', 'pml', 'pmm', 'pmn', 'pmo', 'pmq', 'pmr', 'pms', 'pmt', 'pmu', 'pmw', 'pmx', 'pmy', 'pmz', 'pna', 'pnb', 'pnc', 'pne', 'png', 'pnh', 'pni', 'pnj', 'pnk', 'pnl', 'pnm', 'pnn', 'pno', 'pnp', 'pnq', 'pnr', 'pns', 'pnt', 'pnu', 'pnv', 'pnw', 'pnx', 'pny', 'pnz', 'poc', 'pod', 'poe', 'pof', 'pog', 'poh', 'poi', 'pok', 'pom', 'pon', 'poo', 'pop', 'poq', 'pos', 'pot', 'pov', 'pow', 'pox', 'poy', 'poz', 'ppa', 'ppe', 'ppi', 'ppk', 'ppl', 'ppm', 'ppn', 'ppo', 'ppp', 'ppq', 'ppr', 'pps', 'ppt', 'ppu', 'pqa', 'pqe', 'pqm', 'pqw', 'pra', 'prb', 'prc', 'prd', 'pre', 'prf', 'prg', 'prh', 'pri', 'prk', 'prl', 'prm', 'prn', 'pro', 'prp', 'prq', 'prr', 'prs', 'prt', 'pru', 'prw', 'prx', 'pry', 'prz', 'psa', 'psc', 'psd', 'pse', 'psg', 'psh', 'psi', 'psl', 'psm', 'psn', 'pso', 'psp', 'psq', 'psr', 'pss', 'pst', 'psu', 'psw', 'psy', 'pta', 'pth', 'pti', 'ptn', 'pto', 'ptp', 'ptq', 'ptr', 'ptt', 'ptu', 'ptv', 'ptw', 'pty', 'pua', 'pub', 'puc', 'pud', 'pue', 'puf', 'pug', 'pui', 'puj', 'puk', 'pum', 'puo', 'pup', 'puq', 'pur', 'put', 'puu', 'puw', 'pux', 'puy', 'puz', 'pwa', 'pwb', 'pwg', 'pwi', 'pwm', 'pwn', 'pwo', 'pwr', 'pww', 'pxm', 'pye', 'pym', 'pyn', 'pys', 'pyu', 'pyx', 'pyy', 'pzn', 'qaa..qtz', 'qua', 'qub', 'quc', 'qud', 'quf', 'qug', 'quh', 'qui', 'quk', 'qul', 'qum', 'qun', 'qup', 'quq', 'qur', 'qus', 'quv', 'quw', 'qux', 'quy', 'quz', 'qva', 'qvc', 'qve', 'qvh', 'qvi', 'qvj', 'qvl', 'qvm', 'qvn', 'qvo', 'qvp', 'qvs', 'qvw', 'qvy', 'qvz', 'qwa', 'qwc', 'qwe', 'qwh', 'qwm', 'qws', 'qwt', 'qxa', 'qxc', 'qxh', 'qxl', 'qxn', 'qxo', 'qxp', 'qxq', 'qxr', 'qxs', 'qxt', 'qxu', 'qxw', 'qya', 'qyp', 'raa', 'rab', 'rac', 'rad', 'raf', 'rag', 'rah', 'rai', 'raj', 'rak', 'ral', 'ram', 'ran', 'rao', 'rap', 'raq', 'rar', 'ras', 'rat', 'rau', 'rav', 'raw', 'rax', 'ray', 'raz', 'rbb', 'rbk', 'rbl', 'rbp', 'rcf', 'rdb', 'rea', 'reb', 'ree', 'reg', 'rei', 'rej', 'rel', 'rem', 'ren', 'rer', 'res', 'ret', 'rey', 'rga', 'rge', 'rgk', 'rgn', 'rgr', 'rgs', 'rgu', 'rhg', 'rhp', 'ria', 'rie', 'rif', 'ril', 'rim', 'rin', 'rir', 'rit', 'riu', 'rjg', 'rji', 'rjs', 'rka', 'rkb', 'rkh', 'rki', 'rkm', 'rkt', 'rkw', 'rma', 'rmb', 'rmc', 'rmd', 'rme', 'rmf', 'rmg', 'rmh', 'rmi', 'rmk', 'rml', 'rmm', 'rmn', 'rmo', 'rmp', 'rmq', 'rmr', 'rms', 'rmt', 'rmu', 'rmv', 'rmw', 'rmx', 'rmy', 'rmz', 'rna', 'rnd', 'rng', 'rnl', 'rnn', 'rnp', 'rnr', 'rnw', 'roa', 'rob', 'roc', 'rod', 'roe', 'rof', 'rog', 'rol', 'rom', 'roo', 'rop', 'ror', 'rou', 'row', 'rpn', 'rpt', 'rri', 'rro', 'rrt', 'rsb', 'rsi', 'rsl', 'rsm', 'rtc', 'rth', 'rtm', 'rts', 'rtw', 'rub', 'ruc', 'rue', 'ruf', 'rug', 'ruh', 'rui', 'ruk', 'ruo', 'rup', 'ruq', 'rut', 'ruu', 'ruy', 'ruz', 'rwa', 'rwk', 'rwm', 'rwo', 'rwr', 'rxd', 'rxw', 'ryn', 'rys', 'ryu', 'rzh', 'saa', 'sab', 'sac', 'sad', 'sae', 'saf', 'sah', 'sai', 'saj', 'sak', 'sal', 'sam', 'sao', 'sap', 'saq', 'sar', 'sas', 'sat', 'sau', 'sav', 'saw', 'sax', 'say', 'saz', 'sba', 'sbb', 'sbc', 'sbd', 'sbe', 'sbf', 'sbg', 'sbh', 'sbi', 'sbj', 'sbk', 'sbl', 'sbm', 'sbn', 'sbo', 'sbp', 'sbq', 'sbr', 'sbs', 'sbt', 'sbu', 'sbv', 'sbw', 'sbx', 'sby', 'sbz', 'sca', 'scb', 'sce', 'scf', 'scg', 'sch', 'sci', 'sck', 'scl', 'scn', 'sco', 'scp', 'scq', 'scs', 'sct', 'scu', 'scv', 'scw', 'scx', 'sda', 'sdb', 'sdc', 'sde', 'sdf', 'sdg', 'sdh', 'sdj', 'sdk', 'sdl', 'sdm', 'sdn', 'sdo', 'sdp', 'sdr', 'sds', 'sdt', 'sdu', 'sdv', 'sdx', 'sdz', 'sea', 'seb', 'sec', 'sed', 'see', 'sef', 'seg', 'seh', 'sei', 'sej', 'sek', 'sel', 'sem', 'sen', 'seo', 'sep', 'seq', 'ser', 'ses', 'set', 'seu', 'sev', 'sew', 'sey', 'sez', 'sfb', 'sfe', 'sfm', 'sfs', 'sfw', 'sga', 'sgb', 'sgc', 'sgd', 'sge', 'sgg', 'sgh', 'sgi', 'sgj', 'sgk', 'sgl', 'sgm', 'sgn', 'sgo', 'sgp', 'sgr', 'sgs', 'sgt', 'sgu', 'sgw', 'sgx', 'sgy', 'sgz', 'sha', 'shb', 'shc', 'shd', 'she', 'shg', 'shh', 'shi', 'shj', 'shk', 'shl', 'shm', 'shn', 'sho', 'shp', 'shq', 'shr', 'shs', 'sht', 'shu', 'shv', 'shw', 'shx', 'shy', 'shz', 'sia', 'sib', 'sid', 'sie', 'sif', 'sig', 'sih', 'sii', 'sij', 'sik', 'sil', 'sim', 'sio', 'sip', 'siq', 'sir', 'sis', 'sit', 'siu', 'siv', 'siw', 'six', 'siy', 'siz', 'sja', 'sjb', 'sjd', 'sje', 'sjg', 'sjk', 'sjl', 'sjm', 'sjn', 'sjo', 'sjp', 'sjr', 'sjs', 'sjt', 'sju', 'sjw', 'ska', 'skb', 'skc', 'skd', 'ske', 'skf', 'skg', 'skh', 'ski', 'skj', 'skk', 'skm', 'skn', 'sko', 'skp', 'skq', 'skr', 'sks', 'skt', 'sku', 'skv', 'skw', 'skx', 'sky', 'skz', 'sla', 'slc', 'sld', 'sle', 'slf', 'slg', 'slh', 'sli', 'slj', 'sll', 'slm', 'sln', 'slp', 'slq', 'slr', 'sls', 'slt', 'slu', 'slw', 'slx', 'sly', 'slz', 'sma', 'smb', 'smc', 'smd', 'smf', 'smg', 'smh', 'smi', 'smj', 'smk', 'sml', 'smm', 'smn', 'smp', 'smq', 'smr', 'sms', 'smt', 'smu', 'smv', 'smw', 'smx', 'smy', 'smz', 'snb', 'snc', 'sne', 'snf', 'sng', 'snh', 'sni', 'snj', 'snk', 'snl', 'snm', 'snn', 'sno', 'snp', 'snq', 'snr', 'sns', 'snu', 'snv', 'snw', 'snx', 'sny', 'snz', 'soa', 'sob', 'soc', 'sod', 'soe', 'sog', 'soh', 'soi', 'soj', 'sok', 'sol', 'son', 'soo', 'sop', 'soq', 'sor', 'sos', 'sou', 'sov', 'sow', 'sox', 'soy', 'soz', 'spb', 'spc', 'spd', 'spe', 'spg', 'spi', 'spk', 'spl', 'spm', 'spn', 'spo', 'spp', 'spq', 'spr', 'sps', 'spt', 'spu', 'spv', 'spx', 'spy', 'sqa', 'sqh', 'sqj', 'sqk', 'sqm', 'sqn', 'sqo', 'sqq', 'sqr', 'sqs', 'sqt', 'squ', 'sra', 'srb', 'src', 'sre', 'srf', 'srg', 'srh', 'sri', 'srk', 'srl', 'srm', 'srn', 'sro', 'srq', 'srr', 'srs', 'srt', 'sru', 'srv', 'srw', 'srx', 'sry', 'srz', 'ssa', 'ssb', 'ssc', 'ssd', 'sse', 'ssf', 'ssg', 'ssh', 'ssi', 'ssj', 'ssk', 'ssl', 'ssm', 'ssn', 'sso', 'ssp', 'ssq', 'ssr', 'sss', 'sst', 'ssu', 'ssv', 'ssx', 'ssy', 'ssz', 'sta', 'stb', 'std', 'ste', 'stf', 'stg', 'sth', 'sti', 'stj', 'stk', 'stl', 'stm', 'stn', 'sto', 'stp', 'stq', 'str', 'sts', 'stt', 'stu', 'stv', 'stw', 'sty', 'sua', 'sub', 'suc', 'sue', 'sug', 'sui', 'suj', 'suk', 'sul', 'sum', 'suq', 'sur', 'sus', 'sut', 'suv', 'suw', 'sux', 'suy', 'suz', 'sva', 'svb', 'svc', 'sve', 'svk', 'svm', 'svr', 'svs', 'svx', 'swb', 'swc', 'swf', 'swg', 'swh', 'swi', 'swj', 'swk', 'swl', 'swm', 'swn', 'swo', 'swp', 'swq', 'swr', 'sws', 'swt', 'swu', 'swv', 'sww', 'swx', 'swy', 'sxb', 'sxc', 'sxe', 'sxg', 'sxk', 'sxl', 'sxm', 'sxn', 'sxo', 'sxr', 'sxs', 'sxu', 'sxw', 'sya', 'syb', 'syc', 'syd', 'syi', 'syk', 'syl', 'sym', 'syn', 'syo', 'syr', 'sys', 'syw', 'syx', 'syy', 'sza', 'szb', 'szc', 'szd', 'sze', 'szg', 'szl', 'szn', 'szp', 'szs', 'szv', 'szw', 'taa', 'tab', 'tac', 'tad', 'tae', 'taf', 'tag', 'tai', 'taj', 'tak', 'tal', 'tan', 'tao', 'tap', 'taq', 'tar', 'tas', 'tau', 'tav', 'taw', 'tax', 'tay', 'taz', 'tba', 'tbb', 'tbc', 'tbd', 'tbe', 'tbf', 'tbg', 'tbh', 'tbi', 'tbj', 'tbk', 'tbl', 'tbm', 'tbn', 'tbo', 'tbp', 'tbq', 'tbr', 'tbs', 'tbt', 'tbu', 'tbv', 'tbw', 'tbx', 'tby', 'tbz', 'tca', 'tcb', 'tcc', 'tcd', 'tce', 'tcf', 'tcg', 'tch', 'tci', 'tck', 'tcl', 'tcm', 'tcn', 'tco', 'tcp', 'tcq', 'tcs', 'tct', 'tcu', 'tcw', 'tcx', 'tcy', 'tcz', 'tda', 'tdb', 'tdc', 'tdd', 'tde', 'tdf', 'tdg', 'tdh', 'tdi', 'tdj', 'tdk', 'tdl', 'tdm', 'tdn', 'tdo', 'tdq', 'tdr', 'tds', 'tdt', 'tdu', 'tdv', 'tdx', 'tdy', 'tea', 'teb', 'tec', 'ted', 'tee', 'tef', 'teg', 'teh', 'tei', 'tek', 'tem', 'ten', 'teo', 'tep', 'teq', 'ter', 'tes', 'tet', 'teu', 'tev', 'tew', 'tex', 'tey', 'tfi', 'tfn', 'tfo', 'tfr', 'tft', 'tga', 'tgb', 'tgc', 'tgd', 'tge', 'tgf', 'tgg', 'tgh', 'tgi', 'tgj', 'tgn', 'tgo', 'tgp', 'tgq', 'tgr', 'tgs', 'tgt', 'tgu', 'tgv', 'tgw', 'tgx', 'tgy', 'tgz', 'thc', 'thd', 'the', 'thf', 'thh', 'thi', 'thk', 'thl', 'thm', 'thn', 'thp', 'thq', 'thr', 'ths', 'tht', 'thu', 'thv', 'thw', 'thx', 'thy', 'thz', 'tia', 'tic', 'tid', 'tie', 'tif', 'tig', 'tih', 'tii', 'tij', 'tik', 'til', 'tim', 'tin', 'tio', 'tip', 'tiq', 'tis', 'tit', 'tiu', 'tiv', 'tiw', 'tix', 'tiy', 'tiz', 'tja', 'tjg', 'tji', 'tjl', 'tjm', 'tjn', 'tjo', 'tjs', 'tju', 'tjw', 'tka', 'tkb', 'tkd', 'tke', 'tkf', 'tkg', 'tkk', 'tkl', 'tkm', 'tkn', 'tkp', 'tkq', 'tkr', 'tks', 'tkt', 'tku', 'tkv', 'tkw', 'tkx', 'tkz', 'tla', 'tlb', 'tlc', 'tld', 'tlf', 'tlg', 'tlh', 'tli', 'tlj', 'tlk', 'tll', 'tlm', 'tln', 'tlo', 'tlp', 'tlq', 'tlr', 'tls', 'tlt', 'tlu', 'tlv', 'tlw', 'tlx', 'tly', 'tma', 'tmb', 'tmc', 'tmd', 'tme', 'tmf', 'tmg', 'tmh', 'tmi', 'tmj', 'tmk', 'tml', 'tmm', 'tmn', 'tmo', 'tmp', 'tmq', 'tmr', 'tms', 'tmt', 'tmu', 'tmv', 'tmw', 'tmy', 'tmz', 'tna', 'tnb', 'tnc', 'tnd', 'tne', 'tnf', 'tng', 'tnh', 'tni', 'tnk', 'tnl', 'tnm', 'tnn', 'tno', 'tnp', 'tnq', 'tnr', 'tns', 'tnt', 'tnu', 'tnv', 'tnw', 'tnx', 'tny', 'tnz', 'tob', 'toc', 'tod', 'toe', 'tof', 'tog', 'toh', 'toi', 'toj', 'tol', 'tom', 'too', 'top', 'toq', 'tor', 'tos', 'tou', 'tov', 'tow', 'tox', 'toy', 'toz', 'tpa', 'tpc', 'tpe', 'tpf', 'tpg', 'tpi', 'tpj', 'tpk', 'tpl', 'tpm', 'tpn', 'tpo', 'tpp', 'tpq', 'tpr', 'tpt', 'tpu', 'tpv', 'tpw', 'tpx', 'tpy', 'tpz', 'tqb', 'tql', 'tqm', 'tqn', 'tqo', 'tqp', 'tqq', 'tqr', 'tqt', 'tqu', 'tqw', 'tra', 'trb', 'trc', 'trd', 'tre', 'trf', 'trg', 'trh', 'tri', 'trj', 'trk', 'trl', 'trm', 'trn', 'tro', 'trp', 'trq', 'trr', 'trs', 'trt', 'tru', 'trv', 'trw', 'trx', 'try', 'trz', 'tsa', 'tsb', 'tsc', 'tsd', 'tse', 'tsf', 'tsg', 'tsh', 'tsi', 'tsj', 'tsk', 'tsl', 'tsm', 'tsp', 'tsq', 'tsr', 'tss', 'tst', 'tsu', 'tsv', 'tsw', 'tsx', 'tsy', 'tsz', 'tta', 'ttb', 'ttc', 'ttd', 'tte', 'ttf', 'ttg', 'tth', 'tti', 'ttj', 'ttk', 'ttl', 'ttm', 'ttn', 'tto', 'ttp', 'ttq', 'ttr', 'tts', 'ttt', 'ttu', 'ttv', 'ttw', 'tty', 'ttz', 'tua', 'tub', 'tuc', 'tud', 'tue', 'tuf', 'tug', 'tuh', 'tui', 'tuj', 'tul', 'tum', 'tun', 'tuo', 'tup', 'tuq', 'tus', 'tut', 'tuu', 'tuv', 'tuw', 'tux', 'tuy', 'tuz', 'tva', 'tvd', 'tve', 'tvk', 'tvl', 'tvm', 'tvn', 'tvo', 'tvs', 'tvt', 'tvu', 'tvw', 'tvy', 'twa', 'twb', 'twc', 'twd', 'twe', 'twf', 'twg', 'twh', 'twl', 'twm', 'twn', 'two', 'twp', 'twq', 'twr', 'twt', 'twu', 'tww', 'twx', 'twy', 'txa', 'txb', 'txc', 'txe', 'txg', 'txh', 'txi', 'txj', 'txm', 'txn', 'txo', 'txq', 'txr', 'txs', 'txt', 'txu', 'txx', 'txy', 'tya', 'tye', 'tyh', 'tyi', 'tyj', 'tyl', 'tyn', 'typ', 'tyr', 'tys', 'tyt', 'tyu', 'tyv', 'tyx', 'tyz', 'tza', 'tzh', 'tzj', 'tzl', 'tzm', 'tzn', 'tzo', 'tzx', 'uam', 'uan', 'uar', 'uba', 'ubi', 'ubl', 'ubr', 'ubu', 'uby', 'uda', 'ude', 'udg', 'udi', 'udj', 'udl', 'udm', 'udu', 'ues', 'ufi', 'uga', 'ugb', 'uge', 'ugn', 'ugo', 'ugy', 'uha', 'uhn', 'uis', 'uiv', 'uji', 'uka', 'ukg', 'ukh', 'ukk', 'ukl', 'ukp', 'ukq', 'uks', 'uku', 'ukw', 'uky', 'ula', 'ulb', 'ulc', 'ule', 'ulf', 'uli', 'ulk', 'ull', 'ulm', 'uln', 'ulu', 'ulw', 'uma', 'umb', 'umc', 'umd', 'umg', 'umi', 'umm', 'umn', 'umo', 'ump', 'umr', 'ums', 'umu', 'una', 'und', 'une', 'ung', 'unk', 'unm', 'unn', 'unp', 'unr', 'unu', 'unx', 'unz', 'uok', 'upi', 'upv', 'ura', 'urb', 'urc', 'ure', 'urf', 'urg', 'urh', 'uri', 'urj', 'urk', 'url', 'urm', 'urn', 'uro', 'urp', 'urr', 'urt', 'uru', 'urv', 'urw', 'urx', 'ury', 'urz', 'usa', 'ush', 'usi', 'usk', 'usp', 'usu', 'uta', 'ute', 'utp', 'utr', 'utu', 'uum', 'uun', 'uur', 'uuu', 'uve', 'uvh', 'uvl', 'uwa', 'uya', 'uzn', 'uzs', 'vaa', 'vae', 'vaf', 'vag', 'vah', 'vai', 'vaj', 'val', 'vam', 'van', 'vao', 'vap', 'var', 'vas', 'vau', 'vav', 'vay', 'vbb', 'vbk', 'vec', 'ved', 'vel', 'vem', 'veo', 'vep', 'ver', 'vgr', 'vgt', 'vic', 'vid', 'vif', 'vig', 'vil', 'vin', 'vis', 'vit', 'viv', 'vka', 'vki', 'vkj', 'vkk', 'vkl', 'vkm', 'vko', 'vkp', 'vkt', 'vku', 'vlp', 'vls', 'vma', 'vmb', 'vmc', 'vmd', 'vme', 'vmf', 'vmg', 'vmh', 'vmi', 'vmj', 'vmk', 'vml', 'vmm', 'vmp', 'vmq', 'vmr', 'vms', 'vmu', 'vmv', 'vmw', 'vmx', 'vmy', 'vmz', 'vnk', 'vnm', 'vnp', 'vor', 'vot', 'vra', 'vro', 'vrs', 'vrt', 'vsi', 'vsl', 'vsv', 'vto', 'vum', 'vun', 'vut', 'vwa', 'waa', 'wab', 'wac', 'wad', 'wae', 'waf', 'wag', 'wah', 'wai', 'waj', 'wak', 'wal', 'wam', 'wan', 'wao', 'wap', 'waq', 'war', 'was', 'wat', 'wau', 'wav', 'waw', 'wax', 'way', 'waz', 'wba', 'wbb', 'wbe', 'wbf', 'wbh', 'wbi', 'wbj', 'wbk', 'wbl', 'wbm', 'wbp', 'wbq', 'wbr', 'wbs', 'wbt', 'wbv', 'wbw', 'wca', 'wci', 'wdd', 'wdg', 'wdj', 'wdk', 'wdu', 'wdy', 'wea', 'wec', 'wed', 'weg', 'weh', 'wei', 'wem', 'wen', 'weo', 'wep', 'wer', 'wes', 'wet', 'weu', 'wew', 'wfg', 'wga', 'wgb', 'wgg', 'wgi', 'wgo', 'wgu', 'wgw', 'wgy', 'wha', 'whg', 'whk', 'whu', 'wib', 'wic', 'wie', 'wif', 'wig', 'wih', 'wii', 'wij', 'wik', 'wil', 'wim', 'win', 'wir', 'wit', 'wiu', 'wiv', 'wiw', 'wiy', 'wja', 'wji', 'wka', 'wkb', 'wkd', 'wkl', 'wku', 'wkw', 'wky', 'wla', 'wlc', 'wle', 'wlg', 'wli', 'wlk', 'wll', 'wlm', 'wlo', 'wlr', 'wls', 'wlu', 'wlv', 'wlw', 'wlx', 'wly', 'wma', 'wmb', 'wmc', 'wmd', 'wme', 'wmh', 'wmi', 'wmm', 'wmn', 'wmo', 'wms', 'wmt', 'wmw', 'wmx', 'wnb', 'wnc', 'wnd', 'wne', 'wng', 'wni', 'wnk', 'wnm', 'wnn', 'wno', 'wnp', 'wnu', 'wnw', 'wny', 'woa', 'wob', 'woc', 'wod', 'woe', 'wof', 'wog', 'woi', 'wok', 'wom', 'won', 'woo', 'wor', 'wos', 'wow', 'woy', 'wpc', 'wra', 'wrb', 'wrd', 'wrg', 'wrh', 'wri', 'wrk', 'wrl', 'wrm', 'wrn', 'wro', 'wrp', 'wrr', 'wrs', 'wru', 'wrv', 'wrw', 'wrx', 'wry', 'wrz', 'wsa', 'wsg', 'wsi', 'wsk', 'wsr', 'wss', 'wsu', 'wsv', 'wtf', 'wth', 'wti', 'wtk', 'wtm', 'wtw', 'wua', 'wub', 'wud', 'wuh', 'wul', 'wum', 'wun', 'wur', 'wut', 'wuu', 'wuv', 'wux', 'wuy', 'wwa', 'wwb', 'wwo', 'wwr', 'www', 'wxa', 'wxw', 'wya', 'wyb', 'wyi', 'wym', 'wyr', 'wyy', 'xaa', 'xab', 'xac', 'xad', 'xae', 'xag', 'xai', 'xaj', 'xak', 'xal', 'xam', 'xan', 'xao', 'xap', 'xaq', 'xar', 'xas', 'xat', 'xau', 'xav', 'xaw', 'xay', 'xba', 'xbb', 'xbc', 'xbd', 'xbe', 'xbg', 'xbi', 'xbj', 'xbm', 'xbn', 'xbo', 'xbp', 'xbr', 'xbw', 'xbx', 'xby', 'xcb', 'xcc', 'xce', 'xcg', 'xch', 'xcl', 'xcm', 'xcn', 'xco', 'xcr', 'xct', 'xcu', 'xcv', 'xcw', 'xcy', 'xda', 'xdc', 'xdk', 'xdm', 'xdo', 'xdy', 'xeb', 'xed', 'xeg', 'xel', 'xem', 'xep', 'xer', 'xes', 'xet', 'xeu', 'xfa', 'xga', 'xgb', 'xgd', 'xgf', 'xgg', 'xgi', 'xgl', 'xgm', 'xgn', 'xgr', 'xgu', 'xgw', 'xha', 'xhc', 'xhd', 'xhe', 'xhr', 'xht', 'xhu', 'xhv', 'xia', 'xib', 'xii', 'xil', 'xin', 'xip', 'xir', 'xis', 'xiv', 'xiy', 'xjb', 'xjt', 'xka', 'xkb', 'xkc', 'xkd', 'xke', 'xkf', 'xkg', 'xkh', 'xki', 'xkj', 'xkk', 'xkl', 'xkn', 'xko', 'xkp', 'xkq', 'xkr', 'xks', 'xkt', 'xku', 'xkv', 'xkw', 'xkx', 'xky', 'xkz', 'xla', 'xlb', 'xlc', 'xld', 'xle', 'xlg', 'xli', 'xln', 'xlo', 'xlp', 'xls', 'xlu', 'xly', 'xma', 'xmb', 'xmc', 'xmd', 'xme', 'xmf', 'xmg', 'xmh', 'xmj', 'xmk', 'xml', 'xmm', 'xmn', 'xmo', 'xmp', 'xmq', 'xmr', 'xms', 'xmt', 'xmu', 'xmv', 'xmw', 'xmx', 'xmy', 'xmz', 'xna', 'xnb', 'xnd', 'xng', 'xnh', 'xni', 'xnk', 'xnn', 'xno', 'xnr', 'xns', 'xnt', 'xnu', 'xny', 'xnz', 'xoc', 'xod', 'xog', 'xoi', 'xok', 'xom', 'xon', 'xoo', 'xop', 'xor', 'xow', 'xpa', 'xpc', 'xpe', 'xpg', 'xpi', 'xpj', 'xpk', 'xpm', 'xpn', 'xpo', 'xpp', 'xpq', 'xpr', 'xps', 'xpt', 'xpu', 'xpy', 'xqa', 'xqt', 'xra', 'xrb', 'xrd', 'xre', 'xrg', 'xri', 'xrm', 'xrn', 'xrq', 'xrr', 'xrt', 'xru', 'xrw', 'xsa', 'xsb', 'xsc', 'xsd', 'xse', 'xsh', 'xsi', 'xsj', 'xsl', 'xsm', 'xsn', 'xso', 'xsp', 'xsq', 'xsr', 'xss', 'xsu', 'xsv', 'xsy', 'xta', 'xtb', 'xtc', 'xtd', 'xte', 'xtg', 'xth', 'xti', 'xtj', 'xtl', 'xtm', 'xtn', 'xto', 'xtp', 'xtq', 'xtr', 'xts', 'xtt', 'xtu', 'xtv', 'xtw', 'xty', 'xtz', 'xua', 'xub', 'xud', 'xug', 'xuj', 'xul', 'xum', 'xun', 'xuo', 'xup', 'xur', 'xut', 'xuu', 'xve', 'xvi', 'xvn', 'xvo', 'xvs', 'xwa', 'xwc', 'xwd', 'xwe', 'xwg', 'xwj', 'xwk', 'xwl', 'xwo', 'xwr', 'xwt', 'xww', 'xxb', 'xxk', 'xxm', 'xxr', 'xxt', 'xya', 'xyb', 'xyj', 'xyk', 'xyl', 'xyt', 'xyy', 'xzh', 'xzm', 'xzp', 'yaa', 'yab', 'yac', 'yad', 'yae', 'yaf', 'yag', 'yah', 'yai', 'yaj', 'yak', 'yal', 'yam', 'yan', 'yao', 'yap', 'yaq', 'yar', 'yas', 'yat', 'yau', 'yav', 'yaw', 'yax', 'yay', 'yaz', 'yba', 'ybb', 'ybd', 'ybe', 'ybh', 'ybi', 'ybj', 'ybk', 'ybl', 'ybm', 'ybn', 'ybo', 'ybx', 'yby', 'ych', 'ycl', 'ycn', 'ycp', 'yda', 'ydd', 'yde', 'ydg', 'ydk', 'yds', 'yea', 'yec', 'yee', 'yei', 'yej', 'yel', 'yen', 'yer', 'yes', 'yet', 'yeu', 'yev', 'yey', 'yga', 'ygi', 'ygl', 'ygm', 'ygp', 'ygr', 'ygs', 'ygu', 'ygw', 'yha', 'yhd', 'yhl', 'yhs', 'yia', 'yif', 'yig', 'yih', 'yii', 'yij', 'yik', 'yil', 'yim', 'yin', 'yip', 'yiq', 'yir', 'yis', 'yit', 'yiu', 'yiv', 'yix', 'yiy', 'yiz', 'yka', 'ykg', 'yki', 'ykk', 'ykl', 'ykm', 'ykn', 'yko', 'ykr', 'ykt', 'yku', 'yky', 'yla', 'ylb', 'yle', 'ylg', 'yli', 'yll', 'ylm', 'yln', 'ylo', 'ylr', 'ylu', 'yly', 'yma', 'ymb', 'ymc', 'ymd', 'yme', 'ymg', 'ymh', 'ymi', 'ymk', 'yml', 'ymm', 'ymn', 'ymo', 'ymp', 'ymq', 'ymr', 'yms', 'ymt', 'ymx', 'ymz', 'yna', 'ynd', 'yne', 'yng', 'ynh', 'ynk', 'ynl', 'ynn', 'yno', 'ynq', 'yns', 'ynu', 'yob', 'yog', 'yoi', 'yok', 'yol', 'yom', 'yon', 'yos', 'yot', 'yox', 'yoy', 'ypa', 'ypb', 'ypg', 'yph', 'ypk', 'ypm', 'ypn', 'ypo', 'ypp', 'ypz', 'yra', 'yrb', 'yre', 'yri', 'yrk', 'yrl', 'yrm', 'yrn', 'yro', 'yrs', 'yrw', 'yry', 'ysc', 'ysd', 'ysg', 'ysl', 'ysn', 'yso', 'ysp', 'ysr', 'yss', 'ysy', 'yta', 'ytl', 'ytp', 'ytw', 'yty', 'yua', 'yub', 'yuc', 'yud', 'yue', 'yuf', 'yug', 'yui', 'yuj', 'yuk', 'yul', 'yum', 'yun', 'yup', 'yuq', 'yur', 'yut', 'yuu', 'yuw', 'yux', 'yuy', 'yuz', 'yva', 'yvt', 'ywa', 'ywg', 'ywl', 'ywn', 'ywq', 'ywr', 'ywt', 'ywu', 'yww', 'yxa', 'yxg', 'yxl', 'yxm', 'yxu', 'yxy', 'yyr', 'yyu', 'yyz', 'yzg', 'yzk', 'zaa', 'zab', 'zac', 'zad', 'zae', 'zaf', 'zag', 'zah', 'zai', 'zaj', 'zak', 'zal', 'zam', 'zao', 'zap', 'zaq', 'zar', 'zas', 'zat', 'zau', 'zav', 'zaw', 'zax', 'zay', 'zaz', 'zbc', 'zbe', 'zbl', 'zbt', 'zbw', 'zca', 'zch', 'zdj', 'zea', 'zeg', 'zeh', 'zen', 'zga', 'zgb', 'zgh', 'zgm', 'zgn', 'zgr', 'zhb', 'zhd', 'zhi', 'zhn', 'zhw', 'zhx', 'zia', 'zib', 'zik', 'zil', 'zim', 'zin', 'zir', 'ziw', 'ziz', 'zka', 'zkb', 'zkd', 'zkg', 'zkh', 'zkk', 'zkn', 'zko', 'zkp', 'zkr', 'zkt', 'zku', 'zkv', 'zkz', 'zle', 'zlj', 'zlm', 'zln', 'zlq', 'zls', 'zlw', 'zma', 'zmb', 'zmc', 'zmd', 'zme', 'zmf', 'zmg', 'zmh', 'zmi', 'zmj', 'zmk', 'zml', 'zmm', 'zmn', 'zmo', 'zmp', 'zmq', 'zmr', 'zms', 'zmt', 'zmu', 'zmv', 'zmw', 'zmx', 'zmy', 'zmz', 'zna', 'znd', 'zne', 'zng', 'znk', 'zns', 'zoc', 'zoh', 'zom', 'zoo', 'zoq', 'zor', 'zos', 'zpa', 'zpb', 'zpc', 'zpd', 'zpe', 'zpf', 'zpg', 'zph', 'zpi', 'zpj', 'zpk', 'zpl', 'zpm', 'zpn', 'zpo', 'zpp', 'zpq', 'zpr', 'zps', 'zpt', 'zpu', 'zpv', 'zpw', 'zpx', 'zpy', 'zpz', 'zqe', 'zra', 'zrg', 'zrn', 'zro', 'zrp', 'zrs', 'zsa', 'zsk', 'zsl', 'zsm', 'zsr', 'zsu', 'zte', 'ztg', 'ztl', 'ztm', 'ztn', 'ztp', 'ztq', 'zts', 'ztt', 'ztu', 'ztx', 'zty', 'zua', 'zuh', 'zum', 'zun', 'zuy', 'zwa', 'zxx', 'zyb', 'zyg', 'zyj', 'zyn', 'zyp', 'zza', 'zzj' ]; + axe.utils.validLangs = function() { + 'use strict'; + return langs; + }; + return commons; + }() + }); +})(typeof window === 'object' ? window : this); \ No newline at end of file
diff --git a/third_party/axe-core/axe.min.js b/third_party/axe-core/axe.min.js new file mode 100644 index 0000000..1cb6219 --- /dev/null +++ b/third_party/axe-core/axe.min.js
@@ -0,0 +1,42 @@ +/*! aXe v2.3.1 + * Copyright (c) 2017 Deque Systems, Inc. + * + * Your use of this Source Code Form is subject to the terms of the Mozilla Public + * License, v. 2.0. If a copy of the MPL was not distributed with this + * file, You can obtain one at http://mozilla.org/MPL/2.0/. + * + * This entire copyright notice must appear in every copy of this file you + * distribute or in any file that contains substantial portions of this source + * code. + */ +!function a(window){function b(a){this.name="SupportError",this.cause=a.cause,this.message="`"+a.cause+"` - feature unsupported in your environment.",a.ruleId&&(this.ruleId=a.ruleId,this.message+=" Skipping "+this.ruleId+" rule."),this.stack=(new Error).stack}function c(a){"use strict";var b;return a?(b=axe.utils.clone(a),b.commons=a.commons):b={},b.reporter=b.reporter||null,b.rules=b.rules||[],b.checks=b.checks||[],b.data=Object.assign({checks:{},rules:{}},b.data),b}function d(a,b,c){"use strict";var d,e;for(d=0,e=a.length;d<e;d++)b[c](a[d])}function e(a){this.brand="axe",this.application="axeAPI",this.tagExclude=["experimental"],this.defaultConfig=a,this._init()}function f(a,b,c){var d=a.brand,e=a.application;return axe.constants.helpUrlBase+d+"/"+(c||axe.version.substring(0,axe.version.lastIndexOf(".")))+"/"+b+"?application="+e}function g(a){"use strict";this.id=a.id,this.data=null,this.relatedNodes=[],this.result=null}function h(a){"use strict";return"string"==typeof a?new Function("return "+a+";")():a}function i(a){a&&(this.id=a.id,this.configure(a))}function j(a,b){"use strict";if(!axe.utils.isHidden(b)){axe.utils.findBy(a,"node",b)||a.push({node:b,include:[],exclude:[]})}}function k(a,b,c){"use strict";a.frames=a.frames||[];var d,e,f=document.querySelectorAll(c.shift());a:for(var g=0,h=f.length;g<h;g++){e=f[g];for(var i=0,j=a.frames.length;i<j;i++)if(a.frames[i].node===e){a.frames[i][b].push(c);break a}d={node:e,include:[],exclude:[]},c&&d[b].push(c),a.frames.push(d)}}function l(a){"use strict";if(a&&"object"===(void 0===a?"undefined":qa(a))||a instanceof NodeList){if(a instanceof Node)return{include:[a],exclude:[]};if(a.hasOwnProperty("include")||a.hasOwnProperty("exclude"))return{include:a.include&&+a.include.length?a.include:[document],exclude:a.exclude||[]};if(a.length===+a.length)return{include:a,exclude:[]}}return"string"==typeof a?{include:[a],exclude:[]}:{include:[document],exclude:[]}}function m(a,b){"use strict";for(var c,d,e=[],f=0,g=a[b].length;f<g;f++){if("string"==typeof(c=a[b][f])){d=Array.from(document.querySelectorAll(c)),e=e.concat(d.map(function(a){return axe.utils.getFlattenedTree(a)[0]}));break}!c||!c.length||c instanceof Node?c instanceof Node&&e.push(axe.utils.getFlattenedTree(c)[0]):c.length>1?k(a,b,c):(d=Array.from(document.querySelectorAll(c[0])),e=e.concat(d.map(function(a){return axe.utils.getFlattenedTree(a)[0]})))}return e.filter(function(a){return a})}function n(a){"use strict";if(0===a.include.length){if(0===a.frames.length){var b=axe.utils.respondable.isInFrame()?"frame":"page";return new Error("No elements found for include in "+b+" Context")}a.frames.forEach(function(a,b){if(0===a.include.length)return new Error("No elements found for include in Context of frame "+b)})}}function o(a){"use strict";var b=this;this.frames=[],this.initiator=!a||"boolean"!=typeof a.initiator||a.initiator,this.page=!1,a=l(a),this.exclude=a.exclude,this.include=a.include,this.include=m(this,"include"),this.exclude=m(this,"exclude"),axe.utils.select("frame, iframe",this).forEach(function(a){oa(a,b)&&j(b.frames,a.actualNode)}),1===this.include.length&&this.include[0].actualNode===document.documentElement&&(this.page=!0);var c=n(this);if(c instanceof Error)throw c}function p(a){"use strict";this.id=a.id,this.result=axe.constants.NA,this.pageLevel=a.pageLevel,this.impact=null,this.nodes=[]}function q(a,b){"use strict";this._audit=b,this.id=a.id,this.selector=a.selector||"*",this.excludeHidden="boolean"!=typeof a.excludeHidden||a.excludeHidden,this.enabled="boolean"!=typeof a.enabled||a.enabled,this.pageLevel="boolean"==typeof a.pageLevel&&a.pageLevel,this.any=a.any||[],this.all=a.all||[],this.none=a.none||[],this.tags=a.tags||[],a.matches&&(this.matches=h(a.matches))}function r(a){"use strict";return axe.utils.getAllChecks(a).map(function(b){var c=a._audit.checks[b.id||b];return c&&"function"==typeof c.after?c:null}).filter(Boolean)}function s(a,b){"use strict";var c=[];return a.forEach(function(a){axe.utils.getAllChecks(a).forEach(function(a){a.id===b&&c.push(a)})}),c}function t(a){"use strict";return a.filter(function(a){return!0!==a.filtered})}function u(a){"use strict";var b=["any","all","none"],c=a.nodes.filter(function(a){var c=0;return b.forEach(function(b){a[b]=t(a[b]),c+=a[b].length}),c>0});return a.pageLevel&&c.length&&(c=[c.reduce(function(a,c){if(a)return b.forEach(function(b){a[b].push.apply(a[b],c[b])}),a})]),c}function v(a,b){"use strict";if(!axe._audit)throw new Error("No audit configured");var c=axe.utils.queue(),d=[];Object.keys(axe.plugins).forEach(function(a){c.defer(function(b){var c=function(a){d.push(a),b()};try{axe.plugins[a].cleanup(b,c)}catch(a){c(a)}})}),axe.utils.toArray(document.querySelectorAll("frame, iframe")).forEach(function(a){c.defer(function(b,c){return axe.utils.sendCommandToFrame(a,{command:"cleanup-plugin"},b,c)})}),c.then(function(c){0===d.length?a(c):b(d)}).catch(b)}function w(a){"use strict";var b;if(!(b=axe._audit))throw new Error("No audit configured");a.reporter&&("function"==typeof a.reporter||ta[a.reporter])&&(b.reporter=a.reporter),a.checks&&a.checks.forEach(function(a){b.addCheck(a)}),a.rules&&a.rules.forEach(function(a){b.addRule(a)}),void 0!==a.branding?b.setBranding(a.branding):b._constructHelpUrls(),a.tagExclude&&(b.tagExclude=a.tagExclude)}function x(a,b,c){"use strict";var d=c,e=function(a){a instanceof Error==!1&&(a=new Error(a)),c(a)},f=a&&a.context||{};f.include&&!f.include.length&&(f.include=[document]);var g=a&&a.options||{};switch(a.command){case"rules":return A(f,g,d,e);case"cleanup-plugin":return v(d,e);default:if(axe._audit&&axe._audit.commands&&axe._audit.commands[a.command])return axe._audit.commands[a.command](a,c)}}function y(a){"use strict";this._run=a.run,this._collect=a.collect,this._registry={},a.commands.forEach(function(a){axe._audit.registerCommand(a)})}function z(){"use strict";var a=axe._audit;if(!a)throw new Error("No audit configured");a.resetRulesAndChecks()}function A(a,b,c,d){"use strict";try{a=new o(a)}catch(a){return d(a)}var e=axe.utils.queue(),f=axe._audit;b.performanceTimer&&axe.utils.performanceTimer.auditStart(),a.frames.length&&!1!==b.iframes&&e.defer(function(c,d){axe.utils.collectResultsFromFrames(a,b,"rules",null,c,d)}),e.defer(function(c,d){f.run(a,b,c,d)}),e.then(function(e){try{b.performanceTimer&&axe.utils.performanceTimer.auditEnd();var g=axe.utils.mergeResults(e.map(function(a){return{results:a}}));a.initiator&&(g=f.after(g,b),g.forEach(axe.utils.publishMetaData),g=g.map(axe.utils.finalizeRuleResult));try{c(g)}catch(a){axe.log(a)}}catch(a){d(a)}}).catch(d)}function B(a){"use strict";switch(!0){case"string"==typeof a:case Array.isArray(a):case Node&&a instanceof Node:case NodeList&&a instanceof NodeList:return!0;case"object"!==(void 0===a?"undefined":qa(a)):return!1;case void 0!==a.include:case void 0!==a.exclude:case"number"==typeof a.length:return!0;default:return!1}}function C(a,b,c){"use strict";var d=new TypeError("axe.run arguments are invalid");if(!B(a)){if(void 0!==c)throw d;c=b,b=a,a=document}if("object"!==(void 0===b?"undefined":qa(b))){if(void 0!==c)throw d;c=b,b={}}if("function"!=typeof c&&void 0!==c)throw d;return{context:a,options:b,callback:c||ua}}function D(a,b){"use strict";["any","all","none"].forEach(function(c){Array.isArray(a[c])&&a[c].filter(function(a){return Array.isArray(a.relatedNodes)}).forEach(function(a){a.relatedNodes=a.relatedNodes.map(function(a){var c={html:a.source};return b.elementRef&&!a.fromFrame&&(c.element=a.element),(!1!==b.selectors||a.fromFrame)&&(c.target=a.selector),b.xpath&&(c.xpath=a.xpath),c})})})}function E(a,b){return xa.reduce(function(c,d){return c[d]=(a[d]||[]).map(function(a){return b(a,d)}),c},{})}function F(a,b,c){var d=Object.assign({},b);d.nodes=(d[c]||[]).concat(),axe.constants.resultGroups.forEach(function(a){delete d[a]}),a[c].push(d)}function G(a,b,c){"use strict";var d=window.getComputedStyle(a,null),e=!1;return!!d&&(b.forEach(function(a){d.getPropertyValue(a.property)===a.value&&(e=!0)}),!!e||!(a.nodeName.toUpperCase()===c.toUpperCase()||!a.parentNode)&&G(a.parentNode,b,c))}function H(a,b){"use strict";return new Error(a+": "+axe.utils.getSelector(b))}function I(a,b,c,d,e,f){"use strict";var g=axe.utils.queue();a.frames.forEach(function(e){var f={options:b,command:c,parameter:d,context:{initiator:!1,page:a.page,include:e.include||[],exclude:e.exclude||[]}};g.defer(function(a,b){var c=e.node;axe.utils.sendCommandToFrame(c,f,function(b){if(b)return a({results:b,frameElement:c,frame:axe.utils.getSelector(c)});a(null)},b)})}),g.then(function(a){e(axe.utils.mergeResults(a,b))}).catch(f)}function J(a,b){if(b=b||300,a.length>b){var c=a.indexOf(">");a=a.substring(0,c+1)}return a}function K(a){var b=a.outerHTML;return b||"function"!=typeof XMLSerializer||(b=(new XMLSerializer).serializeToString(a)),J(b||"")}function L(a,b,c){this._fromFrame=!!c,this.spec=c||{},b&&b.absolutePaths&&(this._options={toRoot:!0}),this.source=void 0!==this.spec.source?this.spec.source:K(a),this._element=a}function M(a,b){return{shadowId:b,children:[],actualNode:a}}function N(a){var b=[];for(a=a.firstChild;a;)b.push(a),a=a.nextSibling;return b}function O(){var a=arguments.length>0&&void 0!==arguments[0]?arguments[0]:"";return 0!==a.length&&(a.match(/[0-9]/g)||"").length>=a.length/2}function P(a,b){return[a.substring(0,b),a.substring(b)]}function Q(a){var b=a,c="",d="",e="",f="",g="",h="";if(a.includes("#")){var i=P(a,a.indexOf("#")),j=ya(i,2);a=j[0],h=j[1]}if(a.includes("?")){var k=P(a,a.indexOf("?")),l=ya(k,2);a=l[0],g=l[1]}if(a.includes("://")){var m=a.split("://"),n=ya(m,2);c=n[0],a=n[1];var o=P(a,a.indexOf("/")),p=ya(o,2);d=p[0],a=p[1]}else if("//"===a.substr(0,2)){a=a.substr(2);var q=P(a,a.indexOf("/")),r=ya(q,2);d=r[0],a=r[1]}if("www."===d.substr(0,4)&&(d=d.substr(4)),d&&d.includes(":")){var s=P(d,d.indexOf(":")),t=ya(s,2);d=t[0],e=t[1]}return f=a,{original:b,protocol:c,domain:d,port:e,path:f,query:g,hash:h}}function R(a){if(Array.isArray(a)){for(var b=0,c=Array(a.length);b<a.length;b++)c[b]=a[b];return c}return Array.from(a)}function S(a){return!["focus","hover","hidden","visible","dirty","touched","valid","disable","enable","active","col-"].find(function(b){return a.includes(b)})}function T(a){return a.classList&&0!==a.classList.length?(a.parentNode&&Array.from(a.parentNode.children||"")||[]).reduce(function(b,c){return a===c?b:b.filter(function(a){return!c.classList.contains(a)})},Array.from(a.classList).filter(S)):[]}function U(a,b){var c=a.parentNode&&Array.from(a.parentNode.children||"")||[];if(c.find(function(c){return c!==a&&axe.utils.matchesSelector(c,b)}))return":nth-child("+(1+c.indexOf(a))+")";return""}function V(a,b){var c=a.nodeName.toLowerCase(),d=Array.from(a.classList)||[],e={nodeName:c,classList:d,isCustomElm:c.includes("-"),isCommonElm:Aa.includes(c),distinctClassList:T(a)};return[Ba.getCustomElm,Ba.getElmRoleProp,Ba.getUncommonElm,Ba.getElmNameProp,Ba.getDistinctClass,Ba.getFileRefProp,Ba.getCommonName].reduce(function(c,d){if(c.length===b)return c;var f=d(a,e);return f&&(f[0].match(/[a-z]/)?c.unshift(f):c.push(f)),c},[])}function W(a,b,c){var d=void 0,e=void 0,f=b.isUnique,g=void 0!==f&&f,h=Ba.getElmId(a),i=b.featureCount,j=void 0===i?2:i,k=b.minDepth,l=void 0===k?1:k,m=b.toRoot,n=void 0!==m&&m,o=b.childSelectors,p=void 0===o?[]:o;h?(d=h,g=!0):(d=V(a,j).join(""),d+=U(a,d),g=b.isUnique||1===c.querySelectorAll(d).length,g||a!==document.documentElement||(d+=":root"),e=0!==l||!g);var q=[d].concat(R(p));return a.parentElement&&11!==a.parentElement.nodeType&&(n||e)?W(a.parentNode,{toRoot:n,isUnique:g,childSelectors:q,featureCount:1,minDepth:l-1},c):q.join(" > ")}function X(a,b){var c,d;if(!a)return[];if(!b&&9===a.nodeType)return b=[{str:"html"}];if(b=b||[],a.parentNode&&a.parentNode!==a&&(b=X(a.parentNode,b)),a.previousSibling){d=1,c=a.previousSibling;do{1===c.nodeType&&c.nodeName===a.nodeName&&d++,c=c.previousSibling}while(c);1===d&&(d=null)}else if(a.nextSibling){c=a.nextSibling;do{1===c.nodeType&&c.nodeName===a.nodeName?(d=1,c=null):(d=null,c=c.previousSibling)}while(c)}if(1===a.nodeType){var e={};e.str=a.nodeName.toLowerCase(),a.getAttribute&&a.getAttribute("id")&&1===a.ownerDocument.querySelectorAll("#"+axe.utils.escapeSelector(a.id)).length&&(e.id=a.getAttribute("id")),d>1&&(e.count=d),b.push(e)}return b}function Y(a){return a.reduce(function(a,b){return b.id?"/"+b.str+"[@id='"+b.id+"']":a+"/"+b.str+(b.count>0?"["+b.count+"]":"")},"")}function Z(a){"use strict";if(Ca&&Ca.parentNode)return void 0===Ca.styleSheet?Ca.appendChild(document.createTextNode(a)):Ca.styleSheet.cssText+=a,Ca;if(a){var b=document.head||document.getElementsByTagName("head")[0];return Ca=document.createElement("style"),Ca.type="text/css",void 0===Ca.styleSheet?Ca.appendChild(document.createTextNode(a)):Ca.styleSheet.cssText=a,b.appendChild(Ca),Ca}}function $(a,b,c,d){"use strict";var e=axe.utils.getXpath(c),f={element:c,selector:d,xpath:e};a.forEach(function(a){a.node=axe.utils.DqElement.fromFrame(a.node,b,f);var c=axe.utils.getAllChecks(a);c.length&&c.forEach(function(a){a.relatedNodes=a.relatedNodes.map(function(a){return axe.utils.DqElement.fromFrame(a,b,f)})})})}function _(a,b){"use strict";for(var c,d,e=b[0].node,f=0,g=a.length;f<g;f++)if(d=a[f].node,(c=axe.utils.nodeSorter({actualNode:d.element},{actualNode:e.element}))>0||0===c&&e.selector.length<d.selector.length)return void a.splice.apply(a,[f,0].concat(b));a.push.apply(a,b)}function aa(a){"use strict";return a&&a.results?Array.isArray(a.results)?a.results.length?a.results:null:[a.results]:null}function ba(a,b){function c(a){return a.incomplete&&a.incomplete.default?a.incomplete.default:ra.incompleteFallbackMessage()}if(!a||!a.missingData)return c(b);try{var d=b.incomplete[a.missingData[0].reason];if(!d)throw new Error;return d}catch(d){return"string"==typeof a.missingData?b.incomplete[a.missingData]:c(b)}}function ca(a,b){"use strict";return function(c){var d=a[c.id]||{},e=d.messages||{},f=Object.assign({},d);delete f.messages,void 0===c.result?"object"===qa(e.incomplete)?f.message=function(){return ba(c.data,e)}:f.message=e.incomplete:f.message=c.result===b?e.pass:e.fail,axe.utils.extendMetaData(c,f)}}function da(a,b){return 1===a.nodeType&&("*"===b.tag||a.nodeName.toLowerCase()===b.tag)}function ea(a,b){return!b.classes||b.classes.reduce(function(b,c){return b&&a.className&&a.className.match(c.regexp)},!0)}function fa(a,b){return!b.attributes||b.attributes.reduce(function(b,c){var d=a.getAttribute(c.key);return b&&null!==d&&(!c.value||c.test(d))},!0)}function ga(a,b){return!b.id||a.id===b.id}function ha(a,b){return!(b.pseudos&&!b.pseudos.reduce(function(b,c){if("not"===c.name)return b&&!Ea([a],c.expressions,!1).length;throw new Error("the pseudo selector "+c.name+" has not yet been implemented")},!0))}function ia(a,b,c){var d=[];return a=Array.isArray(a)?a:[a],a.forEach(function(a){da(a.actualNode,b)&&ea(a.actualNode,b)&&fa(a.actualNode,b)&&ga(a.actualNode,b)&&ha(a,b)&&d.push(a),c&&(d=d.concat(ia(a.children.filter(function(c){return!b.id||c.shadowId===a.shadowId}),b,c)))}),d}function ja(a){/*! Credit Mootools Copyright Mootools, MIT License */ +if(a)return a.map(function(a){var b,c,d=a.name.replace(Ga,""),e=(a.value||"").replace(Ga,"");switch(a.operator){case"^=":c=new RegExp("^"+Fa(e));break;case"$=":c=new RegExp(Fa(e)+"$");break;case"~=":c=new RegExp("(^|\\s)"+Fa(e)+"(\\s|$)");break;case"|=":c=new RegExp("^"+Fa(e)+"(-|$)");break;case"=":b=function(a){return e===a};break;case"*=":b=function(a){return a&&a.indexOf(e)>-1};break;case"!=":b=function(a){return e!==a};break;default:b=function(a){return!!a}}return""===e&&/^[*$^]=$/.test(a.operator)&&(b=function(){return!1}),b||(b=function(a){return a&&c.test(a)}),{key:d,value:e,test:b}})}function ka(a){if(a)return a.map(function(a){return a=a.replace(Ga,""),{value:a,regexp:new RegExp("(^|\\s)"+Fa(a)+"(\\s|$)")}})}function la(a){if(a)return a.map(function(a){var b;return"not"===a.name&&(b=axe.utils.cssParser.parse(a.value),b=b.selectors?b.selectors:[b],b=Da(b)),{name:a.name,expressions:b,value:a.value}})}function ma(a,b){"use strict";var c,d,e=axe._audit&&axe._audit.tagExclude?axe._audit.tagExclude:[];return b.include||b.exclude?(c=b.include||[],c=Array.isArray(c)?c:[c],d=b.exclude||[],d=Array.isArray(d)?d:[d],d=d.concat(e.filter(function(a){return-1===c.indexOf(a)}))):(c=Array.isArray(b)?b:[b],d=e.filter(function(a){return-1===c.indexOf(a)})),!!(c.some(function(b){return-1!==a.tags.indexOf(b)})||0===c.length&&!1!==a.enabled)&&d.every(function(b){return-1===a.tags.indexOf(b)})}function na(a){"use strict";return a.sort(function(a,b){return axe.utils.contains(a,b)?1:-1})[0]}function oa(a,b){"use strict";var c=b.include&&na(b.include.filter(function(b){return axe.utils.contains(b,a)})),d=b.exclude&&na(b.exclude.filter(function(b){return axe.utils.contains(b,a)}));return!!(!d&&c||d&&axe.utils.contains(d,c))}function pa(a,b,c){"use strict";for(var d=0,e=b.length;d<e;d++)!a.find(function(a){return a.actualNode===b[d].actualNode})&&oa(b[d],c)&&a.push(b[d])}var document=window.document,qa="function"==typeof Symbol&&"symbol"==typeof Symbol.iterator?function(a){return typeof a}:function(a){return a&&"function"==typeof Symbol&&a.constructor===Symbol&&a!==Symbol.prototype?"symbol":typeof a},axe=axe||{};axe.version="2.3.1","function"==typeof define&&define.amd&&define([],function(){"use strict";return axe}),"object"===("undefined"==typeof module?"undefined":qa(module))&&module.exports&&"function"==typeof a.toString&&(axe.source="("+a.toString()+')(typeof window === "object" ? window : this);',module.exports=axe),"function"==typeof window.getComputedStyle&&(window.axe=axe);var commons;b.prototype=Object.create(Error.prototype),b.prototype.constructor=b;var utils=axe.utils={},ra={},qa="function"==typeof Symbol&&"symbol"==typeof Symbol.iterator?function(a){return typeof a}:function(a){return a&&"function"==typeof Symbol&&a.constructor===Symbol&&a!==Symbol.prototype?"symbol":typeof a};e.prototype._init=function(){var a=c(this.defaultConfig);axe.commons=commons=a.commons,this.reporter=a.reporter,this.commands={},this.rules=[],this.checks={},d(a.rules,this,"addRule"),d(a.checks,this,"addCheck"),this.data={},this.data.checks=a.data&&a.data.checks||{},this.data.rules=a.data&&a.data.rules||{},this.data.failureSummaries=a.data&&a.data.failureSummaries||{},this.data.incompleteFallbackMessage=a.data&&a.data.incompleteFallbackMessage||"",this._constructHelpUrls()},e.prototype.registerCommand=function(a){"use strict";this.commands[a.id]=a.callback},e.prototype.addRule=function(a){"use strict";a.metadata&&(this.data.rules[a.id]=a.metadata);var b=this.getRule(a.id);b?b.configure(a):this.rules.push(new q(a,this))},e.prototype.addCheck=function(a){"use strict";var b=a.metadata;"object"===(void 0===b?"undefined":qa(b))&&(this.data.checks[a.id]=b,"object"===qa(b.messages)&&Object.keys(b.messages).filter(function(a){return b.messages.hasOwnProperty(a)&&"string"==typeof b.messages[a]}).forEach(function(a){0===b.messages[a].indexOf("function")&&(b.messages[a]=new Function("return "+b.messages[a]+";")())})),this.checks[a.id]?this.checks[a.id].configure(a):this.checks[a.id]=new i(a)},e.prototype.run=function(a,b,c,d){"use strict";this.validateOptions(b),axe._tree=axe.utils.getFlattenedTree(document.body);var e=axe.utils.queue();this.rules.forEach(function(c){if(axe.utils.ruleShouldRun(c,a,b)){if(b.performanceTimer){var d="mark_rule_end_"+c.id,f="mark_rule_start_"+c.id;axe.utils.performanceTimer.mark(f)}e.defer(function(e,g){c.run(a,b,function(a){b.performanceTimer&&(axe.utils.performanceTimer.mark(d),axe.utils.performanceTimer.measure("rule_"+c.id,f,d)),e(a)},function(a){if(b.debug)g(a);else{var d=Object.assign(new p(c),{result:axe.constants.CANTTELL,description:"An error occured while running this rule",message:a.message,help:a.stack||a.message,error:a});e(d)}})})}}),e.then(function(a){axe._tree=void 0,c(a.filter(function(a){return!!a}))}).catch(d)},e.prototype.after=function(a,b){"use strict";var c=this.rules;return a.map(function(a){return axe.utils.findBy(c,"id",a.id).after(a,b)})},e.prototype.getRule=function(a){return this.rules.find(function(b){return b.id===a})},e.prototype.validateOptions=function(a){"use strict";var b=this;if("object"===qa(a.runOnly)){var c=a.runOnly;if("rule"===c.type&&Array.isArray(c.value))c.value.forEach(function(a){if(!b.getRule(a))throw new Error("unknown rule `"+a+"` in options.runOnly")});else if(Array.isArray(c.value)&&c.value.length>0){var d=[].concat(c.value);if(b.rules.forEach(function(a){var b,c,e;if(d)for(c=0,e=a.tags.length;c<e;c++)-1!==(b=d.indexOf(a.tags[c]))&&d.splice(b,1)}),0!==d.length)throw new Error("could not find tags `"+d.join("`, `")+"`")}}return"object"===qa(a.rules)&&Object.keys(a.rules).forEach(function(a){if(!b.getRule(a))throw new Error("unknown rule `"+a+"` in options.rules")}),a},e.prototype.setBranding=function(a){"use strict";var b={brand:this.brand,application:this.application};a&&a.hasOwnProperty("brand")&&a.brand&&"string"==typeof a.brand&&(this.brand=a.brand),a&&a.hasOwnProperty("application")&&a.application&&"string"==typeof a.application&&(this.application=a.application),this._constructHelpUrls(b)},e.prototype._constructHelpUrls=function(){var a=this,b=arguments.length>0&&void 0!==arguments[0]?arguments[0]:null,c=axe.version.substring(0,axe.version.lastIndexOf("."));this.rules.forEach(function(d){a.data.rules[d.id]||(a.data.rules[d.id]={});var e=a.data.rules[d.id];("string"!=typeof e.helpUrl||b&&e.helpUrl===f(b,d.id,c))&&(e.helpUrl=f(a,d.id,c))})},e.prototype.resetRulesAndChecks=function(){"use strict";this._init()},i.prototype.enabled=!0,i.prototype.run=function(a,b,c,d){"use strict";b=b||{};var e=b.hasOwnProperty("enabled")?b.enabled:this.enabled,f=b.options||this.options;if(e){var h,i=new g(this),j=axe.utils.checkHelper(i,b,c,d);try{h=this.evaluate.call(j,a.actualNode,f,a)}catch(a){return void d(a)}j.isAsync||(i.result=h,setTimeout(function(){c(i)},0))}else c(null)},i.prototype.configure=function(a){var b=this;["options","enabled"].filter(function(b){return a.hasOwnProperty(b)}).forEach(function(c){return b[c]=a[c]}),["evaluate","after"].filter(function(b){return a.hasOwnProperty(b)}).forEach(function(c){return b[c]=h(a[c])})};var qa="function"==typeof Symbol&&"symbol"==typeof Symbol.iterator?function(a){return typeof a}:function(a){return a&&"function"==typeof Symbol&&a.constructor===Symbol&&a!==Symbol.prototype?"symbol":typeof a};q.prototype.matches=function(){"use strict";return!0},q.prototype.gather=function(a){"use strict";var b=axe.utils.select(this.selector,a);return this.excludeHidden?b.filter(function(a){return!axe.utils.isHidden(a.actualNode)}):b},q.prototype.runChecks=function(a,b,c,d,e){"use strict";var f=this,g=axe.utils.queue();this[a].forEach(function(a){var d=f._audit.checks[a.id||a],e=axe.utils.getCheckOption(d,f.id,c);g.defer(function(a,c){d.run(b,e,a,c)})}),g.then(function(b){b=b.filter(function(a){return a}),d({type:a,results:b})}).catch(e)},q.prototype.run=function(a,c,d,e){var f=this,g=axe.utils.queue(),h=new p(this),i=void 0;try{i=this.gather(a).filter(function(a){return f.matches(a.actualNode)})}catch(a){return void e(new b({cause:a,ruleId:this.id}))}c.performanceTimer&&axe.log("gather (",i.length,"):",axe.utils.performanceTimer.timeElapsed()+"ms"),i.forEach(function(a){g.defer(function(b,d){var e=axe.utils.queue();e.defer(function(b,d){f.runChecks("any",a,c,b,d)}),e.defer(function(b,d){f.runChecks("all",a,c,b,d)}),e.defer(function(b,d){f.runChecks("none",a,c,b,d)}),e.then(function(d){if(d.length){var e=!1,f={};d.forEach(function(a){var b=a.results.filter(function(a){return a});f[a.type]=b,b.length&&(e=!0)}),e&&(f.node=new axe.utils.DqElement(a.actualNode,c),h.nodes.push(f))}b()}).catch(function(a){return d(a)})})}),g.then(function(){return d(h)}).catch(function(a){return e(a)})},q.prototype.after=function(a,b){"use strict";var c=r(this),d=this.id;return c.forEach(function(c){var e=s(a.nodes,c.id),f=axe.utils.getCheckOption(c,d,b),g=c.after(e,f);e.forEach(function(a){-1===g.indexOf(a)&&(a.filtered=!0)})}),a.nodes=u(a),a},q.prototype.configure=function(a){"use strict";a.hasOwnProperty("selector")&&(this.selector=a.selector),a.hasOwnProperty("excludeHidden")&&(this.excludeHidden="boolean"!=typeof a.excludeHidden||a.excludeHidden),a.hasOwnProperty("enabled")&&(this.enabled="boolean"!=typeof a.enabled||a.enabled),a.hasOwnProperty("pageLevel")&&(this.pageLevel="boolean"==typeof a.pageLevel&&a.pageLevel),a.hasOwnProperty("any")&&(this.any=a.any),a.hasOwnProperty("all")&&(this.all=a.all),a.hasOwnProperty("none")&&(this.none=a.none),a.hasOwnProperty("tags")&&(this.tags=a.tags),a.hasOwnProperty("matches")&&("string"==typeof a.matches?this.matches=new Function("return "+a.matches+";")():this.matches=a.matches)},function(axe){var a=[{name:"NA",value:"inapplicable",priority:0,group:"inapplicable"},{name:"PASS",value:"passed",priority:1,group:"passes"},{name:"CANTTELL",value:"cantTell",priority:2,group:"incomplete"},{name:"FAIL",value:"failed",priority:3,group:"violations"}],b={helpUrlBase:"https://dequeuniversity.com/rules/",results:[],resultGroups:[],resultGroupMap:{},impact:Object.freeze(["minor","moderate","serious","critical"])};a.forEach(function(a){var c=a.name,d=a.value,e=a.priority,f=a.group;b[c]=d,b[c+"_PRIO"]=e,b[c+"_GROUP"]=f,b.results[e]=d,b.resultGroups[e]=f,b.resultGroupMap[d]=f}),Object.freeze(b.results),Object.freeze(b.resultGroups),Object.freeze(b.resultGroupMap),Object.freeze(b),Object.defineProperty(axe,"constants",{value:b,enumerable:!0,configurable:!1,writable:!1})}(axe);var qa="function"==typeof Symbol&&"symbol"==typeof Symbol.iterator?function(a){return typeof a}:function(a){return a&&"function"==typeof Symbol&&a.constructor===Symbol&&a!==Symbol.prototype?"symbol":typeof a};axe.log=function(){"use strict";"object"===("undefined"==typeof console?"undefined":qa(console))&&console.log&&Function.prototype.apply.call(console.log,console,arguments)};var qa="function"==typeof Symbol&&"symbol"==typeof Symbol.iterator?function(a){return typeof a}:function(a){return a&&"function"==typeof Symbol&&a.constructor===Symbol&&a!==Symbol.prototype?"symbol":typeof a};axe.a11yCheck=function(a,b,c){"use strict";"function"==typeof b&&(c=b,b={}),b&&"object"===(void 0===b?"undefined":qa(b))||(b={});var d=axe._audit;if(!d)throw new Error("No audit configured");b.reporter=b.reporter||d.reporter||"v2",b.performanceTimer&&axe.utils.performanceTimer.start();var e=axe.getReporter(b.reporter);axe._runRules(a,b,function(a){var d=e(a,b,c);void 0!==d&&(b.performanceTimer&&axe.utils.performanceTimer.end(),c(d))},axe.log)},axe.cleanup=v,axe.configure=w,axe.getRules=function(a){"use strict";a=a||[];var b=a.length?axe._audit.rules.filter(function(b){return!!a.filter(function(a){return-1!==b.tags.indexOf(a)}).length}):axe._audit.rules,c=axe._audit.data.rules||{};return b.map(function(a){var b=c[a.id]||{};return{ruleId:a.id,description:b.description,help:b.help,helpUrl:b.helpUrl,tags:a.tags}})},axe._load=function(a){"use strict";axe.utils.respondable.subscribe("axe.ping",function(a,b,c){c({axe:!0})}),axe.utils.respondable.subscribe("axe.start",x),axe._audit=new e(a)};var axe=axe||{};axe.plugins={},y.prototype.run=function(){"use strict";return this._run.apply(this,arguments)},y.prototype.collect=function(){"use strict";return this._collect.apply(this,arguments)},y.prototype.cleanup=function(a){"use strict";var b=axe.utils.queue(),c=this;Object.keys(this._registry).forEach(function(a){b.defer(function(b){c._registry[a].cleanup(b)})}),b.then(function(){a()})},y.prototype.add=function(a){"use strict";this._registry[a.id]=a},axe.registerPlugin=function(a){"use strict";axe.plugins[a.id]=new y(a)};var sa,ta={};axe.getReporter=function(a){"use strict";return"string"==typeof a&&ta[a]?ta[a]:"function"==typeof a?a:sa},axe.addReporter=function(a,b,c){"use strict";ta[a]=b,c&&(sa=b)},axe.reset=z,axe._runRules=A;var qa="function"==typeof Symbol&&"symbol"==typeof Symbol.iterator?function(a){return typeof a}:function(a){return a&&"function"==typeof Symbol&&a.constructor===Symbol&&a!==Symbol.prototype?"symbol":typeof a},ua=function(){};axe.run=function(a,b,c){"use strict";if(!axe._audit)throw new Error("No audit configured");var d=C(a,b,c);a=d.context,b=d.options,c=d.callback,b.reporter=b.reporter||axe._audit.reporter||"v1",b.performanceTimer&&axe.utils.performanceTimer.start();var e=void 0,f=ua,g=ua;return window.Promise&&c===ua&&(e=new Promise(function(a,b){f=b,g=a})),axe._runRules(a,b,function(a){var d=function(a){try{c(null,a)}catch(a){axe.log(a)}g(a)};b.performanceTimer&&axe.utils.performanceTimer.end();try{var e=axe.getReporter(b.reporter),h=e(a,b,d);void 0!==h&&d(h)}catch(a){c(a),f(a)}},function(a){c(a),f(a)}),e},ra.failureSummary=function(a){"use strict";var b={};return b.none=a.none.concat(a.all),b.any=a.any,Object.keys(b).map(function(a){if(b[a].length){var c=axe._audit.data.failureSummaries[a];return c&&"function"==typeof c.failureMessage?c.failureMessage(b[a].map(function(a){return a.message||""})):void 0}}).filter(function(a){return void 0!==a}).join("\n\n")},ra.incompleteFallbackMessage=function(){"use strict";return axe._audit.data.incompleteFallbackMessage()};var qa="function"==typeof Symbol&&"symbol"==typeof Symbol.iterator?function(a){return typeof a}:function(a){return a&&"function"==typeof Symbol&&a.constructor===Symbol&&a!==Symbol.prototype?"symbol":typeof a},va=axe.constants.resultGroups;ra.processAggregate=function(a,b){var c=axe.utils.aggregateResult(a);return c.timestamp=(new Date).toISOString(),c.url=window.location.href,va.forEach(function(a){c[a]=(c[a]||[]).map(function(a){return a=Object.assign({},a),Array.isArray(a.nodes)&&a.nodes.length>0&&(a.nodes=a.nodes.map(function(a){return"object"===qa(a.node)&&(a.html=a.node.source,b.elementRef&&!a.node.fromFrame&&(a.element=a.node.element),(!1!==b.selectors||a.node.fromFrame)&&(a.target=a.node.selector),b.xpath&&(a.xpath=a.node.xpath)),delete a.result,delete a.node,D(a,b),a})),va.forEach(function(b){return delete a[b]}),delete a.pageLevel,delete a.result,a})}),c},axe.addReporter("na",function(a,b,c){"use strict";"function"==typeof b&&(c=b,b={});var d=ra.processAggregate(a,b);c({violations:d.violations,passes:d.passes,incomplete:d.incomplete,inapplicable:d.inapplicable,timestamp:d.timestamp,url:d.url})}),axe.addReporter("no-passes",function(a,b,c){"use strict";"function"==typeof b&&(c=b,b={});var d=ra.processAggregate(a,b);c({violations:d.violations,timestamp:d.timestamp,url:d.url})}),axe.addReporter("raw",function(a,b,c){"use strict";"function"==typeof b&&(c=b,b={}),c(a)}),axe.addReporter("v1",function(a,b,c){"use strict";"function"==typeof b&&(c=b,b={});var d=ra.processAggregate(a,b);d.violations.forEach(function(a){return a.nodes.forEach(function(a){a.failureSummary=ra.failureSummary(a)})}),c({violations:d.violations,passes:d.passes,incomplete:d.incomplete,inapplicable:d.inapplicable,timestamp:d.timestamp,url:d.url})}),axe.addReporter("v2",function(a,b,c){"use strict";"function"==typeof b&&(c=b,b={});var d=ra.processAggregate(a,b);c({violations:d.violations,passes:d.passes,incomplete:d.incomplete,inapplicable:d.inapplicable,timestamp:d.timestamp,url:d.url})},!0),axe.utils.aggregate=function(a,b,c){b=b.slice(),c&&b.push(c);var d=b.map(function(b){return a.indexOf(b)}).sort();return a[d.pop()]};var wa=[];wa[axe.constants.PASS_PRIO]=!0,wa[axe.constants.CANTTELL_PRIO]=null,wa[axe.constants.FAIL_PRIO]=!1;var xa=["any","all","none"];axe.utils.aggregateChecks=function(a){var b=Object.assign({},a);E(b,function(a,b){var c=wa.indexOf(a.result);a.priority=-1!==c?c:axe.constants.CANTTELL_PRIO,"none"===b&&(a.priority=4-a.priority)});var c=E(b,function(a){return a.priority});b.priority=Math.max(c.all.reduce(function(a,b){return Math.max(a,b)},0),c.none.reduce(function(a,b){return Math.max(a,b)},0),c.any.reduce(function(a,b){return Math.min(a,b)},4)%4);var d=[];return xa.forEach(function(a){b[a]=b[a].filter(function(a){return a.priority===b.priority}),b[a].forEach(function(a){return d.push(a.impact)})}),b.priority===axe.constants.FAIL_PRIO?b.impact=axe.utils.aggregate(axe.constants.impact,d):b.impact=null,E(b,function(a){delete a.result,delete a.priority}),b.result=axe.constants.results[b.priority],delete b.priority,b},axe.utils.aggregateResult=function(a){var b={};return axe.constants.resultGroups.forEach(function(a){return b[a]=[]}),a.forEach(function(a){a.error?F(b,a,axe.constants.CANTTELL_GROUP):a.result===axe.constants.NA?F(b,a,axe.constants.NA_GROUP):axe.constants.resultGroups.forEach(function(c){Array.isArray(a[c])&&a[c].length>0&&F(b,a,c)})}),b},function(){axe.utils.aggregateRule=function(a){var b={};a=a.map(function(a){if(a.any&&a.all&&a.none)return axe.utils.aggregateChecks(a);if(Array.isArray(a.node))return axe.utils.finalizeRuleResult(a);throw new TypeError("Invalid Result type")});var c=a.map(function(a){return a.result});b.result=axe.utils.aggregate(axe.constants.results,c,b.result),axe.constants.resultGroups.forEach(function(a){return b[a]=[]}),a.forEach(function(a){var c=axe.constants.resultGroupMap[a.result];b[c].push(a)});var d=axe.constants.FAIL_GROUP;if(b[d].length>0){var e=b[d].map(function(a){return a.impact});b.impact=axe.utils.aggregate(axe.constants.impact,e)||null}else b.impact=null;return b}}(),axe.utils.areStylesSet=G,axe.utils.checkHelper=function(a,b,c,d){"use strict";return{isAsync:!1,async:function(){return this.isAsync=!0,function(b){b instanceof Error==!1?(a.value=b,c(a)):d(b)}},data:function(b){a.data=b},relatedNodes:function(c){c=c instanceof Node?[c]:axe.utils.toArray(c),a.relatedNodes=c.map(function(a){return new axe.utils.DqElement(a,b)})}}};var qa="function"==typeof Symbol&&"symbol"==typeof Symbol.iterator?function(a){return typeof a}:function(a){return a&&"function"==typeof Symbol&&a.constructor===Symbol&&a!==Symbol.prototype?"symbol":typeof a};axe.utils.clone=function(a){"use strict";var b,c,d=a;if(null!==a&&"object"===(void 0===a?"undefined":qa(a)))if(Array.isArray(a))for(d=[],b=0,c=a.length;b<c;b++)d[b]=axe.utils.clone(a[b]);else{d={};for(b in a)d[b]=axe.utils.clone(a[b])}return d},axe.utils.sendCommandToFrame=function(a,b,c,d){"use strict";var e=a.contentWindow;if(!e)return axe.log("Frame does not have a content window",a),void c(null);var f=setTimeout(function(){f=setTimeout(function(){var e=H("No response from frame",a);b.debug?d(e):(axe.log(e),c(null))},0)},500);axe.utils.respondable(e,"axe.ping",null,void 0,function(){clearTimeout(f),f=setTimeout(function(){d(H("Axe in frame timed out",a))},3e4),axe.utils.respondable(e,"axe.start",b,void 0,function(a){clearTimeout(f),a instanceof Error==!1?c(a):d(a)})})},axe.utils.collectResultsFromFrames=I,axe.utils.contains=function(a,b){"use strict";function c(a,b){return a.shadowId===b.shadowId||!!a.children.find(function(a){return c(a,b)})}return a.shadowId||b.shadowId?c(a,b):"function"==typeof a.actualNode.contains?a.actualNode.contains(b.actualNode):!!(16&a.actualNode.compareDocumentPosition(b.actualNode))},function(axe){/*! + * The copyright below covers the code within this function block only + * + * Copyright (c) 2013 Dulin Marat + * + * Permission is hereby granted, free of charge, to any person obtaining a copy + * of this software and associated documentation files (the "Software"), to deal + * in the Software without restriction, including without limitation the rights + * to use, copy, modify, merge, publish, distribute, sublicense, and/or sell + * copies of the Software, and to permit persons to whom the Software is + * furnished to do so, subject to the following conditions: + * + * The above copyright notice and this permission notice shall be included in + * all copies or substantial portions of the Software. + * + * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR + * IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, + * FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE + * AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER + * LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, + * OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN + * THE SOFTWARE. + */ +function a(){this.pseudos={},this.attrEqualityMods={},this.ruleNestingOperators={},this.substitutesEnabled=!1}function b(a){return a>="a"&&a<="z"||a>="A"&&a<="Z"||"-"===a||"_"===a}function c(a){return a>="a"&&a<="z"||a>="A"&&a<="Z"||a>="0"&&a<="9"||"-"===a||"_"===a}function d(a){return a>="a"&&a<="f"||a>="A"&&a<="F"||a>="0"&&a<="9"}function e(a,e,g,j,k,l){var m,n,o,p,q;return p=a.length,m=null,o=function(b,c){var f,g,h;for(h="",e++,m=a.charAt(e);e<p;){if(m===b)return e++,h;if("\\"===m)if(e++,(m=a.charAt(e))===b)h+=b;else if(f=c[m])h+=f;else{if(d(m)){for(g=m,e++,m=a.charAt(e);d(m);)g+=m,e++,m=a.charAt(e);" "===m&&(e++,m=a.charAt(e)),h+=String.fromCharCode(parseInt(g,16));continue}h+=m}else h+=m;e++,m=a.charAt(e)}return h},n=function(){var b="";for(m=a.charAt(e);e<p;){if(c(m))b+=m;else{if("\\"!==m)return b;if(++e>=p)throw Error("Expected symbol but end of file reached.");if(m=a.charAt(e),f[m])b+=m;else{if(d(m)){var g=m;for(e++,m=a.charAt(e);d(m);)g+=m,e++,m=a.charAt(e);" "===m&&(e++,m=a.charAt(e)),b+=String.fromCharCode(parseInt(g,16));continue}b+=m}}e++,m=a.charAt(e)}return b},q=function(){m=a.charAt(e);for(var b=!1;" "===m||"\t"===m||"\n"===m||"\r"===m||"\f"===m;)b=!0,e++,m=a.charAt(e);return b},this.parse=function(){var b=this.parseSelector();if(e<p)throw Error('Rule expected but "'+a.charAt(e)+'" found.');return b},this.parseSelector=function(){var b,c=b=this.parseSingleSelector();for(m=a.charAt(e);","===m;){if(e++,q(),"selectors"!==b.type&&(b={type:"selectors",selectors:[c]}),!(c=this.parseSingleSelector()))throw Error('Rule expected after ",".');b.selectors.push(c)}return b},this.parseSingleSelector=function(){q();var b={type:"ruleSet"},c=this.parseRule();if(!c)return null;for(var d=b;c&&(c.type="rule",d.rule=c,d=c,q(),m=a.charAt(e),!(e>=p||","===m||")"===m));)if(k[m]){var f=m;if(e++,q(),!(c=this.parseRule()))throw Error('Rule expected after "'+f+'".');c.nestingOperator=f}else(c=this.parseRule())&&(c.nestingOperator=null);return b},this.parseRule=function(){for(var c=null;e<p;)if("*"===(m=a.charAt(e)))e++,(c=c||{}).tagName="*";else if(b(m)||"\\"===m)(c=c||{}).tagName=n();else if("."===m)e++,c=c||{},(c.classNames=c.classNames||[]).push(n());else if("#"===m)e++,(c=c||{}).id=n();else if("["===m){e++,q();var d={name:n()};if(q(),"]"===m)e++;else{var f="";if(j[m]&&(f=m,e++,m=a.charAt(e)),e>=p)throw Error('Expected "=" but end of file reached.');if("="!==m)throw Error('Expected "=" but "'+m+'" found.');d.operator=f+"=",e++,q();var k="";if(d.valueType="string",'"'===m)k=o('"',i);else if("'"===m)k=o("'",h);else if(l&&"$"===m)e++,k=n(),d.valueType="substitute";else{for(;e<p&&"]"!==m;)k+=m,e++,m=a.charAt(e);k=k.trim()}if(q(),e>=p)throw Error('Expected "]" but end of file reached.');if("]"!==m)throw Error('Expected "]" but "'+m+'" found.');e++,d.value=k}c=c||{},(c.attrs=c.attrs||[]).push(d)}else{if(":"!==m)break;e++;var r=n(),s={name:r};if("("===m){e++;var t="";if(q(),"selector"===g[r])s.valueType="selector",t=this.parseSelector();else{if(s.valueType=g[r]||"string",'"'===m)t=o('"',i);else if("'"===m)t=o("'",h);else if(l&&"$"===m)e++,t=n(),s.valueType="substitute";else{for(;e<p&&")"!==m;)t+=m,e++,m=a.charAt(e);t=t.trim()}q()}if(e>=p)throw Error('Expected ")" but end of file reached.');if(")"!==m)throw Error('Expected ")" but "'+m+'" found.');e++,s.value=t}c=c||{},(c.pseudos=c.pseudos||[]).push(s)}return c},this}a.prototype.registerSelectorPseudos=function(a){for(var b=0,c=arguments.length;b<c;b++)a=arguments[b],this.pseudos[a]="selector";return this},a.prototype.unregisterSelectorPseudos=function(a){for(var b=0,c=arguments.length;b<c;b++)a=arguments[b],delete this.pseudos[a];return this},a.prototype.registerNumericPseudos=function(a){for(var b=0,c=arguments.length;b<c;b++)a=arguments[b],this.pseudos[a]="numeric";return this},a.prototype.unregisterNumericPseudos=function(a){for(var b=0,c=arguments.length;b<c;b++)a=arguments[b],delete this.pseudos[a];return this},a.prototype.registerNestingOperators=function(a){for(var b=0,c=arguments.length;b<c;b++)a=arguments[b],this.ruleNestingOperators[a]=!0;return this},a.prototype.unregisterNestingOperators=function(a){for(var b=0,c=arguments.length;b<c;b++)a=arguments[b],delete this.ruleNestingOperators[a];return this},a.prototype.registerAttrEqualityMods=function(a){for(var b=0,c=arguments.length;b<c;b++)a=arguments[b],this.attrEqualityMods[a]=!0;return this},a.prototype.unregisterAttrEqualityMods=function(a){for(var b=0,c=arguments.length;b<c;b++)a=arguments[b],delete this.attrEqualityMods[a];return this},a.prototype.enableSubstitutes=function(){return this.substitutesEnabled=!0,this},a.prototype.disableSubstitutes=function(){return this.substitutesEnabled=!1,this};var f={"!":!0,'"':!0,"#":!0,$:!0,"%":!0,"&":!0,"'":!0,"(":!0,")":!0,"*":!0,"+":!0,",":!0,".":!0,"/":!0,";":!0,"<":!0,"=":!0,">":!0,"?":!0,"@":!0,"[":!0,"\\":!0,"]":!0,"^":!0,"`":!0,"{":!0,"|":!0,"}":!0,"~":!0},g={"\n":"\\n","\r":"\\r","\t":"\\t","\f":"\\f","\v":"\\v"},h={n:"\n",r:"\r",t:"\t",f:"\f","\\":"\\","'":"'"},i={n:"\n",r:"\r",t:"\t",f:"\f","\\":"\\",'"':'"'};a.prototype.parse=function(a){return new e(a,0,this.pseudos,this.attrEqualityMods,this.ruleNestingOperators,this.substitutesEnabled).parse()},a.prototype.escapeIdentifier=function(a){for(var b="",c=0,d=a.length;c<d;){var e=a.charAt(c);if(f[e])b+="\\"+e;else if("_"===e||"-"===e||e>="A"&&e<="Z"||e>="a"&&e<="z"||0!==c&&e>="0"&&e<="9")b+=e;else{var g=e.charCodeAt(0);if(55296==(63488&g)){var h=a.charCodeAt(c++);if(55296!=(64512&g)||56320!=(64512&h))throw Error("UCS-2(decode): illegal sequence");g=((1023&g)<<10)+(1023&h)+65536}b+="\\"+g.toString(16)+" "}c++}return b},a.prototype.escapeStr=function(a){for(var b,c,d="",e=0,f=a.length;e<f;)b=a.charAt(e),'"'===b?b='\\"':"\\"===b?b="\\\\":(c=g[b])&&(b=c),d+=b,e++;return'"'+d+'"'},a.prototype.render=function(a){return this._renderEntity(a).trim()},a.prototype._renderEntity=function(a){var b,c,d;switch(d="",a.type){case"ruleSet":for(b=a.rule,c=[];b;)b.nestingOperator&&c.push(b.nestingOperator),c.push(this._renderEntity(b)),b=b.rule;d=c.join(" ");break;case"selectors":d=a.selectors.map(this._renderEntity,this).join(", ");break;case"rule":a.tagName&&(d="*"===a.tagName?"*":this.escapeIdentifier(a.tagName)),a.id&&(d+="#"+this.escapeIdentifier(a.id)),a.classNames&&(d+=a.classNames.map(function(a){return"."+this.escapeIdentifier(a)},this).join("")),a.attrs&&(d+=a.attrs.map(function(a){return a.operator?"substitute"===a.valueType?"["+this.escapeIdentifier(a.name)+a.operator+"$"+a.value+"]":"["+this.escapeIdentifier(a.name)+a.operator+this.escapeStr(a.value)+"]":"["+this.escapeIdentifier(a.name)+"]"},this).join("")),a.pseudos&&(d+=a.pseudos.map(function(a){return a.valueType?"selector"===a.valueType?":"+this.escapeIdentifier(a.name)+"("+this._renderEntity(a.value)+")":"substitute"===a.valueType?":"+this.escapeIdentifier(a.name)+"($"+a.value+")":"numeric"===a.valueType?":"+this.escapeIdentifier(a.name)+"("+a.value+")":":"+this.escapeIdentifier(a.name)+"("+this.escapeIdentifier(a.value)+")":":"+this.escapeIdentifier(a.name)},this).join(""));break;default:throw Error('Unknown entity type: "'+a.type(NaN))}return d};var j=new a;j.registerNestingOperators(">"),axe.utils.cssParser=j}(axe),L.prototype={get selector(){return this.spec.selector||[axe.utils.getSelector(this.element,this._options)]},get xpath(){return this.spec.xpath||[axe.utils.getXpath(this.element)]},get element(){return this._element},get fromFrame(){return this._fromFrame},toJSON:function(){"use strict";return{selector:this.selector,source:this.source,xpath:this.xpath}}},L.fromFrame=function(a,b,c){return a.selector.unshift(c.selector),a.xpath.unshift(c.xpath),new axe.utils.DqElement(c.element,b,a)},axe.utils.DqElement=L,axe.utils.matchesSelector=function(){"use strict";function a(a){var b,c,d=a.Element.prototype,e=["matches","matchesSelector","mozMatchesSelector","webkitMatchesSelector","msMatchesSelector"],f=e.length;for(b=0;b<f;b++)if(c=e[b],d[c])return c}var b;return function(c,d){return b&&c[b]||(b=a(c.ownerDocument.defaultView)),c[b](d)}}(),axe.utils.escapeSelector=function(a){"use strict";for(var b,c=String(a),d=c.length,e=-1,f="",g=c.charCodeAt(0);++e<d;){if(0==(b=c.charCodeAt(e)))throw new Error("INVALID_CHARACTER_ERR");b>=1&&b<=31||b>=127&&b<=159||0==e&&b>=48&&b<=57||1==e&&b>=48&&b<=57&&45==g?f+="\\"+b.toString(16)+" ":f+=(1!=e||45!=b||45!=g)&&(b>=128||45==b||95==b||b>=48&&b<=57||b>=65&&b<=90||b>=97&&b<=122)?c.charAt(e):"\\"+c.charAt(e)}return f},axe.utils.extendMetaData=function(a,b){Object.assign(a,b),Object.keys(b).filter(function(a){return"function"==typeof b[a]}).forEach(function(c){a[c]=null;try{a[c]=b[c](a)}catch(a){}})},axe.utils.finalizeRuleResult=function(a){return Object.assign(a,axe.utils.aggregateRule(a.nodes)),delete a.nodes,a};var qa="function"==typeof Symbol&&"symbol"==typeof Symbol.iterator?function(a){return typeof a}:function(a){return a&&"function"==typeof Symbol&&a.constructor===Symbol&&a!==Symbol.prototype?"symbol":typeof a};axe.utils.findBy=function(a,b,c){if(Array.isArray(a))return a.find(function(a){return"object"===(void 0===a?"undefined":qa(a))&&a[b]===c})};var axe=axe||{utils:{}};axe.utils.getFlattenedTree=function(a,b){function c(a,c){var d=axe.utils.getFlattenedTree(c,b);return d&&(a=a.concat(d)),a}var d,e,f;if(a.documentElement&&(a=a.documentElement),f=a.nodeName.toLowerCase(),a.shadowRoot&&"marquee"!==f)return b="a"+Math.random().toString().substring(2),e=Array.from(a.shadowRoot.childNodes),e.reduce(c,[]);if("content"===f)return e=Array.from(a.getDistributedNodes()),e.reduce(c,[]);if("slot"===f){e=Array.from(a.assignedNodes()),e.length||(e=N(a));window.getComputedStyle(a);return e.reduce(c,[])}return 1===a.nodeType?(d=M(a,b),e=Array.from(a.childNodes),d.children=e.reduce(c,[]),[d]):3===a.nodeType?[M(a)]:void 0},axe.utils.getNodeFromTree=function(a,b){var c;return a.children.forEach(function(a){var d;a.actualNode===b?c=a:(d=axe.utils.getNodeFromTree(a,b))&&(c=d)}),c},axe.utils.getAllChecks=function(a){"use strict";return[].concat(a.any||[]).concat(a.all||[]).concat(a.none||[])},axe.utils.getCheckOption=function(a,b,c){var d=((c.rules&&c.rules[b]||{}).checks||{})[a.id],e=(c.checks||{})[a.id],f=a.enabled,g=a.options;return e&&(e.hasOwnProperty("enabled")&&(f=e.enabled),e.hasOwnProperty("options")&&(g=e.options)),d&&(d.hasOwnProperty("enabled")&&(f=d.enabled),d.hasOwnProperty("options")&&(g=d.options)),{enabled:f,options:g,absolutePaths:c.absolutePaths}};var ya=function(){function a(a,b){var c=[],d=!0,e=!1,f=void 0;try{for(var g,h=a[Symbol.iterator]();!(d=(g=h.next()).done)&&(c.push(g.value),!b||c.length!==b);d=!0);}catch(a){e=!0,f=a}finally{try{!d&&h.return&&h.return()}finally{if(e)throw f}}return c}return function(b,c){if(Array.isArray(b))return b;if(Symbol.iterator in Object(b))return a(b,c);throw new TypeError("Invalid attempt to destructure non-iterable instance")}}();axe.utils.getFriendlyUriEnd=function(){var a=arguments.length>0&&void 0!==arguments[0]?arguments[0]:"",b=arguments.length>1&&void 0!==arguments[1]?arguments[1]:{};if(!(a.length<=1||"data:"===a.substr(0,5)||"javascript:"===a.substr(0,11)||a.includes("?"))){var c=b.currentDomain,d=b.maxLength,e=void 0===d?25:d,f=Q(a),g=f.path,h=f.domain,i=f.hash,j=g.substr(g.substr(0,g.length-2).lastIndexOf("/")+1);if(i)return j&&(j+i).length<=e?j+i:j.length<2&&i.length>2&&i.length<=e?i:void 0;if(h&&h.length<e&&g.length<=1)return h+g;if(g==="/"+j&&h&&c&&h!==c&&(h+g).length<=e)return h+g;var k=j.lastIndexOf(".");return(-1===k||k>1)&&(-1!==k||j.length>2)&&j.length<=e&&!j.match(/index(\.[a-zA-Z]{2-4})?/)&&!O(j)?j:void 0}};var za=axe.utils.escapeSelector,Aa=["div","span","p","b","i","u","strong","em","h2","h3"],Ba={getElmId:function(a){if(a.id){var b=a.getRootNode&&a.getRootNode()||document,c="#"+za(a.id||"");return c.match(/player_uid_/)||1!==b.querySelectorAll(c).length?void 0:c}},getCustomElm:function(a,b){var c=b.isCustomElm,d=b.nodeName;if(c)return d},getElmRoleProp:function(a){if(a.hasAttribute("role"))return'[role="'+za(a.getAttribute("role"))+'"]'},getUncommonElm:function(a,b){var c=b.isCommonElm,d=b.isCustomElm,e=b.nodeName;if(!c&&!d)return e=za(e),"input"===e&&a.hasAttribute("type")&&(e+='[type="'+a.type+'"]'),e},getElmNameProp:function(a){if(!a.id&&a.name)return'[name="'+za(a.name)+'"]'},getDistinctClass:function(a,b){var c=b.distinctClassList;if(c.length>0&&c.length<3)return"."+c.map(za).join(".")},getFileRefProp:function(a){var b=void 0;if(a.hasAttribute("href"))b="href";else{if(!a.hasAttribute("src"))return;b="src"}var c=axe.utils.getFriendlyUriEnd(a.getAttribute(b));if(c)return"["+b+'$="'+encodeURI(c)+'"]'},getCommonName:function(a,b){var c=b.nodeName;if(b.isCommonElm)return c}};axe.utils.getSelector=function(a){var b=arguments.length>1&&void 0!==arguments[1]?arguments[1]:{};if(!a)return"";var c=a.getRootNode&&a.getRootNode()||document;if(11===c.nodeType){for(var d=[];11===c.nodeType;)d.push({elm:a,doc:c}),a=c.host,c=a.getRootNode();return d.push({elm:a,doc:c}),d.reverse().map(function(a){return W(a.elm,b,a.doc)})}return W(a,b,c)},axe.utils.getXpath=function(a){return Y(X(a))};var Ca;axe.utils.injectStyle=Z,axe.utils.isHidden=function(a,b){"use strict";var c;if(9===a.nodeType)return!1;11===a.nodeType&&(a=a.host);var d=window.getComputedStyle(a,null);return!d||!a.parentNode||"none"===d.getPropertyValue("display")||!b&&"hidden"===d.getPropertyValue("visibility")||"true"===a.getAttribute("aria-hidden")||(c=a.assignedSlot?a.assignedSlot:a.parentNode,axe.utils.isHidden(c,!0))},axe.utils.mergeResults=function(a,b){"use strict";var c=[];return a.forEach(function(a){var d=aa(a);d&&d.length&&d.forEach(function(d){d.nodes&&a.frame&&$(d.nodes,b,a.frameElement,a.frame);var e=axe.utils.findBy(c,"id",d.id);e?d.nodes.length&&_(e.nodes,d.nodes):c.push(d)})}),c},axe.utils.nodeSorter=function(a,b){"use strict";return a.actualNode===b.actualNode?0:4&a.actualNode.compareDocumentPosition(b.actualNode)?-1:1},utils.performanceTimer=function(){"use strict";function a(){if(window.performance&&window.performance)return window.performance.now()}var b=null,c=a();return{start:function(){this.mark("mark_axe_start")},end:function(){this.mark("mark_axe_end"),this.measure("axe","mark_axe_start","mark_axe_end"),this.logMeasures("axe")},auditStart:function(){this.mark("mark_audit_start")},auditEnd:function(){this.mark("mark_audit_end"),this.measure("audit_start_to_end","mark_audit_start","mark_audit_end"),this.logMeasures()},mark:function(a){window.performance&&void 0!==window.performance.mark&&window.performance.mark(a)},measure:function(a,b,c){window.performance&&void 0!==window.performance.measure&&window.performance.measure(a,b,c)},logMeasures:function(a){function b(a){axe.log("Measure "+a.name+" took "+a.duration+"ms")}if(window.performance&&void 0!==window.performance.getEntriesByType)for(var c=window.performance.getEntriesByType("measure"),d=0;d<c.length;++d){var e=c[d];if(e.name===a)return void b(e);b(e)}},timeElapsed:function(){return a()-c},reset:function(){b||(b=a()),c=a()}}}(),"function"!=typeof Object.assign&&function(){Object.assign=function(a){"use strict";if(void 0===a||null===a)throw new TypeError("Cannot convert undefined or null to object");for(var b=Object(a),c=1;c<arguments.length;c++){var d=arguments[c];if(void 0!==d&&null!==d)for(var e in d)d.hasOwnProperty(e)&&(b[e]=d[e])}return b}}(),Array.prototype.find||(Array.prototype.find=function(a){if(null===this)throw new TypeError("Array.prototype.find called on null or undefined");if("function"!=typeof a)throw new TypeError("predicate must be a function");for(var b,c=Object(this),d=c.length>>>0,e=arguments[1],f=0;f<d;f++)if(b=c[f],a.call(e,b,f,c))return b}),axe.utils.pollyfillElementsFromPoint=function(){if(document.elementsFromPoint)return document.elementsFromPoint;if(document.msElementsFromPoint)return document.msElementsFromPoint;var a=function(){var a=document.createElement("x");return a.style.cssText="pointer-events:auto","auto"===a.style.pointerEvents}(),b=a?"pointer-events":"visibility",c=a?"none":"hidden",d=document.createElement("style");return d.innerHTML=a?"* { pointer-events: all }":"* { visibility: visible }",function(a,e){var f,g,h,i=[],j=[];for(document.head.appendChild(d);(f=document.elementFromPoint(a,e))&&-1===i.indexOf(f);)i.push(f),j.push({value:f.style.getPropertyValue(b),priority:f.style.getPropertyPriority(b)}),f.style.setProperty(b,c,"important");for(g=j.length;h=j[--g];)i[g].style.setProperty(b,h.value?h.value:"",h.priority);return document.head.removeChild(d),i}},"function"==typeof window.addEventListener&&(document.elementsFromPoint=axe.utils.pollyfillElementsFromPoint()),Array.prototype.includes||(Array.prototype.includes=function(a){"use strict";var b=Object(this),c=parseInt(b.length,10)||0;if(0===c)return!1;var d,e=parseInt(arguments[1],10)||0;e>=0?d=e:(d=c+e)<0&&(d=0);for(var f;d<c;){if(f=b[d],a===f||a!==a&&f!==f)return!0;d++}return!1}),Array.prototype.some||(Array.prototype.some=function(a){"use strict";if(null==this)throw new TypeError("Array.prototype.some called on null or undefined");if("function"!=typeof a)throw new TypeError;for(var b=Object(this),c=b.length>>>0,d=arguments.length>=2?arguments[1]:void 0,e=0;e<c;e++)if(e in b&&a.call(d,b[e],e,b))return!0;return!1}),Array.from||(Array.from=function(){var a=Object.prototype.toString,b=function(b){return"function"==typeof b||"[object Function]"===a.call(b)},c=function(a){var b=Number(a);return isNaN(b)?0:0!==b&&isFinite(b)?(b>0?1:-1)*Math.floor(Math.abs(b)):b},d=Math.pow(2,53)-1,e=function(a){var b=c(a);return Math.min(Math.max(b,0),d)};return function(a){var c=this,d=Object(a);if(null==a)throw new TypeError("Array.from requires an array-like object - not null or undefined");var f,g=arguments.length>1?arguments[1]:void 0;if(void 0!==g){if(!b(g))throw new TypeError("Array.from: when provided, the second argument must be a function");arguments.length>2&&(f=arguments[2])}for(var h,i=e(d.length),j=b(c)?Object(new c(i)):new Array(i),k=0;k<i;)h=d[k],j[k]=g?void 0===f?g(h,k):g.call(f,h,k):h,k+=1;return j.length=i,j}}()),String.prototype.includes||(String.prototype.includes=function(a,b){return"number"!=typeof b&&(b=0),!(b+a.length>this.length)&&-1!==this.indexOf(a,b)});var qa="function"==typeof Symbol&&"symbol"==typeof Symbol.iterator?function(a){return typeof a}:function(a){return a&&"function"==typeof Symbol&&a.constructor===Symbol&&a!==Symbol.prototype?"symbol":typeof a};axe.utils.publishMetaData=function(a){"use strict";var b=axe._audit.data.checks||{},c=axe._audit.data.rules||{},d=axe.utils.findBy(axe._audit.rules,"id",a.id)||{};a.tags=axe.utils.clone(d.tags||[]);var e=ca(b,!0),f=ca(b,!1);a.nodes.forEach(function(a){a.any.forEach(e),a.all.forEach(e),a.none.forEach(f)}),axe.utils.extendMetaData(a,axe.utils.clone(c[a.id]||{}))};var Da=function(){},Ea=function(){},Fa=function(){/*! Credit: XRegExp 0.6.1 (c) 2007-2008 Steven Levithan <http://stevenlevithan.com/regex/xregexp/> MIT License */ +var a=/(?=[\-\[\]{}()*+?.\\\^$|,#\s])/g;return function(b){return b.replace(a,"\\")}}(),Ga=/\\/g;Da=function(a){return a.map(function(a){for(var b=[],c=a.rule;c;)b.push({tag:c.tagName?c.tagName.toLowerCase():"*",combinator:c.nestingOperator?c.nestingOperator:" ",id:c.id,attributes:ja(c.attrs),classes:ka(c.classNames),pseudos:la(c.pseudos)}),c=c.rule;return b})},Ea=function(a,b,c){return b.reduce(function(b,d){var e=a;return d.forEach(function(a,b){if(c=">"!==a.combinator&&c,-1===[" ",">"].indexOf(a.combinator))throw new Error("axe.utils.querySelectorAll does not support the combinator: "+a.combinator);e=e.reduce(function(d,e){return d.concat(ia(b?e.children:e,a,c))},[])}),b.concat(e)},[])},axe.utils.querySelectorAll=function(a,b){a=Array.isArray(a)?a:[a];var c=axe.utils.cssParser.parse(b);return c=c.selectors?c.selectors:[c],c=Da(c),Ea(a,c,!0)};var qa="function"==typeof Symbol&&"symbol"==typeof Symbol.iterator?function(a){return typeof a}:function(a){return a&&"function"==typeof Symbol&&a.constructor===Symbol&&a!==Symbol.prototype?"symbol":typeof a};!function(){"use strict";function a(){}function b(a){if("function"!=typeof a)throw new TypeError("Queue methods require functions as arguments")}function c(){function c(b){return function(c){g[b]=c,(i-=1)||j===a||(k=!0,j(g))}}function d(b){return j=a,m(b),g}function e(){for(var a=g.length;h<a;h++){var b=g[h];try{b.call(null,c(h),d)}catch(a){d(a)}}}var f,g=[],h=0,i=0,j=a,k=!1,l=function(a){f=a,setTimeout(function(){void 0!==f&&null!==f&&axe.log("Uncaught error (of queue)",f)},1)},m=l,n={defer:function(a){if("object"===(void 0===a?"undefined":qa(a))&&a.then&&a.catch){var c=a;a=function(a,b){c.then(a).catch(b)}}if(b(a),void 0===f){if(k)throw new Error("Queue already completed");return g.push(a),++i,e(),n}},then:function(c){if(b(c),j!==a)throw new Error("queue `then` already set");return f||(j=c,i||(k=!0,j(g))),n},catch:function(a){if(b(a),m!==l)throw new Error("queue `catch` already set");return f?(a(f),f=null):m=a,n},abort:d};return n}axe.utils.queue=c}();var qa="function"==typeof Symbol&&"symbol"==typeof Symbol.iterator?function(a){return typeof a}:function(a){return a&&"function"==typeof Symbol&&a.constructor===Symbol&&a!==Symbol.prototype?"symbol":typeof a};!function(a){"use strict";function b(){var a="axe",b="";return void 0!==axe&&axe._audit&&!axe._audit.application&&(a=axe._audit.application),void 0!==axe&&(b=axe.version),a+"."+b}function c(a){if("object"===(void 0===a?"undefined":qa(a))&&"string"==typeof a.uuid&&!0===a._respondable){var c=b();return a._source===c||"axe.x.y.z"===a._source||"axe.x.y.z"===c}return!1}function d(a,c,d,e,f,g){var h;d instanceof Error&&(h={name:d.name,message:d.message,stack:d.stack},d=void 0);var i={uuid:e,topic:c,message:d,error:h,_respondable:!0,_source:b(),_keepalive:f};"function"==typeof g&&(j[e]=g),a.postMessage(JSON.stringify(i),"*")}function e(a,b,c,e,f){d(a,b,c,Ha.v1(),e,f)}function f(a,b,c){return function(e,f,g){d(a,b,e,c,f,g)}}function g(a,b,c){var d=b.topic,e=k[d];if(e){var g=f(a,null,b.uuid);e(b.message,c,g)}}function h(a){var b=a.message||"Unknown error occurred",c=window[a.name]||Error;return a.stack&&(b+="\n"+a.stack.replace(a.message,"")),new c(b)}function i(a){var b;if("string"==typeof a){try{b=JSON.parse(a)}catch(a){}if(c(b))return"object"===qa(b.error)?b.error=h(b.error):b.error=void 0,b}}var j={},k={};e.subscribe=function(a,b){k[a]=b},e.isInFrame=function(a){return a=a||window,!!a.frameElement},"function"==typeof window.addEventListener&&window.addEventListener("message",function(a){var b=i(a.data);if(b){var c=b.uuid,e=b._keepalive,h=j[c];if(h){h(b.error||b.message,e,f(a.source,b.topic,c)),e||delete j[c]}if(!b.error)try{g(a.source,b,e)}catch(e){d(a.source,b.topic,e,c,!1)}}},!1),a.respondable=e}(utils),axe.utils.ruleShouldRun=function(a,b,c){"use strict";var d=c.runOnly||{},e=(c.rules||{})[a.id];return!(a.pageLevel&&!b.page)&&("rule"===d.type?-1!==d.values.indexOf(a.id):e&&"boolean"==typeof e.enabled?e.enabled:"tag"===d.type&&d.values?ma(a,d.values):ma(a,[]))},axe.utils.select=function(a,b){"use strict";for(var c,d=[],e=0,f=b.include.length;e<f;e++)c=b.include[e],c.actualNode.nodeType===c.actualNode.ELEMENT_NODE&&axe.utils.matchesSelector(c.actualNode,a)&&pa(d,[c],b),pa(d,axe.utils.querySelectorAll(c,a),b);return d.sort(axe.utils.nodeSorter)},axe.utils.toArray=function(a){"use strict";return Array.prototype.slice.call(a)};var Ha;!function(a){function b(a,b,c){var d=b&&c||0,e=0;for(b=b||[],a.toLowerCase().replace(/[0-9a-f]{2}/g,function(a){e<16&&(b[d+e++]=l[a])});e<16;)b[d+e++]=0;return b}function c(a,b){var c=b||0,d=k;return d[a[c++]]+d[a[c++]]+d[a[c++]]+d[a[c++]]+"-"+d[a[c++]]+d[a[c++]]+"-"+d[a[c++]]+d[a[c++]]+"-"+d[a[c++]]+d[a[c++]]+"-"+d[a[c++]]+d[a[c++]]+d[a[c++]]+d[a[c++]]+d[a[c++]]+d[a[c++]]}function d(a,b,d){var e=b&&d||0,f=b||[];a=a||{};var g=null!=a.clockseq?a.clockseq:p,h=null!=a.msecs?a.msecs:(new Date).getTime(),i=null!=a.nsecs?a.nsecs:r+1,j=h-q+(i-r)/1e4;if(j<0&&null==a.clockseq&&(g=g+1&16383),(j<0||h>q)&&null==a.nsecs&&(i=0),i>=1e4)throw new Error("uuid.v1(): Can't create more than 10M uuids/sec");q=h,r=i,p=g,h+=122192928e5;var k=(1e4*(268435455&h)+i)%4294967296;f[e++]=k>>>24&255,f[e++]=k>>>16&255,f[e++]=k>>>8&255,f[e++]=255&k;var l=h/4294967296*1e4&268435455;f[e++]=l>>>8&255,f[e++]=255&l,f[e++]=l>>>24&15|16,f[e++]=l>>>16&255,f[e++]=g>>>8|128,f[e++]=255&g;for(var m=a.node||o,n=0;n<6;n++)f[e+n]=m[n];return b||c(f)}function e(a,b,d){var e=b&&d||0;"string"==typeof a&&(b="binary"==a?new j(16):null,a=null),a=a||{};var g=a.random||(a.rng||f)();if(g[6]=15&g[6]|64,g[8]=63&g[8]|128,b)for(var h=0;h<16;h++)b[e+h]=g[h];return b||c(g)}var f,g=a.crypto||a.msCrypto;if(!f&&g&&g.getRandomValues){var h=new Uint8Array(16);f=function(){return g.getRandomValues(h),h}}if(!f){var i=new Array(16);f=function(){for(var a,b=0;b<16;b++)0==(3&b)&&(a=4294967296*Math.random()),i[b]=a>>>((3&b)<<3)&255;return i}}for(var j="function"==typeof a.Buffer?a.Buffer:Array,k=[],l={},m=0;m<256;m++)k[m]=(m+256).toString(16).substr(1),l[k[m]]=m;var n=f(),o=[1|n[0],n[1],n[2],n[3],n[4],n[5]],p=16383&(n[6]<<8|n[7]),q=0,r=0;Ha=e,Ha.v1=d,Ha.v4=e,Ha.parse=b,Ha.unparse=c,Ha.BufferClass=j}(window),axe._load({data:{rules:{accesskeys:{description:"Ensures every accesskey attribute value is unique",help:"accesskey attribute value must be unique"},"area-alt":{description:"Ensures <area> elements of image maps have alternate text",help:"Active <area> elements must have alternate text"},"aria-allowed-attr":{description:"Ensures ARIA attributes are allowed for an element's role",help:"Elements must only use allowed ARIA attributes"},"aria-hidden-body":{description:"Ensures aria-hidden='true' is not present on the document body.",help:"aria-hidden='true' must not be present on the document body"},"aria-required-attr":{description:"Ensures elements with ARIA roles have all required ARIA attributes",help:"Required ARIA attributes must be provided"},"aria-required-children":{description:"Ensures elements with an ARIA role that require child roles contain them",help:"Certain ARIA roles must contain particular children"},"aria-required-parent":{description:"Ensures elements with an ARIA role that require parent roles are contained by them",help:"Certain ARIA roles must be contained by particular parents"},"aria-roles":{description:"Ensures all elements with a role attribute use a valid value",help:"ARIA roles used must conform to valid values"},"aria-valid-attr-value":{description:"Ensures all ARIA attributes have valid values",help:"ARIA attributes must conform to valid values"},"aria-valid-attr":{description:"Ensures attributes that begin with aria- are valid ARIA attributes",help:"ARIA attributes must conform to valid names"},"audio-caption":{description:"Ensures <audio> elements have captions",help:"<audio> elements must have a captions track"},blink:{description:"Ensures <blink> elements are not used",help:"<blink> elements are deprecated and must not be used"},"button-name":{description:"Ensures buttons have discernible text",help:"Buttons must have discernible text"},bypass:{description:"Ensures each page has at least one mechanism for a user to bypass navigation and jump straight to the content",help:"Page must have means to bypass repeated blocks"},checkboxgroup:{description:'Ensures related <input type="checkbox"> elements have a group and that that group designation is consistent',help:"Checkbox inputs with the same name attribute value must be part of a group"},"color-contrast":{description:"Ensures the contrast between foreground and background colors meets WCAG 2 AA contrast ratio thresholds",help:"Elements must have sufficient color contrast"},"definition-list":{description:"Ensures <dl> elements are structured correctly",help:"<dl> elements must only directly contain properly-ordered <dt> and <dd> groups, <script> or <template> elements"},dlitem:{description:"Ensures <dt> and <dd> elements are contained by a <dl>",help:"<dt> and <dd> elements must be contained by a <dl>"},"document-title":{description:"Ensures each HTML document contains a non-empty <title> element",help:"Documents must have <title> element to aid in navigation"},"duplicate-id":{description:"Ensures every id attribute value is unique",help:"id attribute value must be unique"},"empty-heading":{description:"Ensures headings have discernible text",help:"Headings must not be empty"},"frame-title-unique":{description:"Ensures <iframe> and <frame> elements contain a unique title attribute",help:"Frames must have a unique title attribute"},"frame-title":{description:"Ensures <iframe> and <frame> elements contain a non-empty title attribute",help:"Frames must have title attribute"},"heading-order":{description:"Ensures the order of headings is semantically correct",help:"Heading levels should only increase by one"},"hidden-content":{description:"Informs users about hidden content.",help:"Hidden content on the page cannot be analyzed"},"href-no-hash":{description:"Ensures that href values are valid link references to promote only using anchors as links",help:"Anchors must only be used as links with valid URLs or URL fragments"},"html-has-lang":{description:"Ensures every HTML document has a lang attribute",help:"<html> element must have a lang attribute"},"html-lang-valid":{description:"Ensures the lang attribute of the <html> element has a valid value",help:"<html> element must have a valid value for the lang attribute"},"image-alt":{description:"Ensures <img> elements have alternate text or a role of none or presentation",help:"Images must have alternate text"},"image-redundant-alt":{description:"Ensure button and link text is not repeated as image alternative",help:"Text of buttons and links should not be repeated in the image alternative"},"input-image-alt":{description:'Ensures <input type="image"> elements have alternate text',help:"Image buttons must have alternate text"},"label-title-only":{description:"Ensures that every form element is not solely labeled using the title or aria-describedby attributes",help:"Form elements should have a visible label"},label:{description:"Ensures every form element has a label",help:"Form elements must have labels"},"layout-table":{description:"Ensures presentational <table> elements do not use <th>, <caption> elements or the summary attribute",help:"Layout tables must not use data table elements"},"link-in-text-block":{description:"Links can be distinguished without relying on color",help:"Links must be distinguished from surrounding text in a way that does not rely on color"},"link-name":{description:"Ensures links have discernible text",help:"Links must have discernible text"},list:{description:"Ensures that lists are structured correctly",help:"<ul> and <ol> must only directly contain <li>, <script> or <template> elements"},listitem:{description:"Ensures <li> elements are used semantically",help:"<li> elements must be contained in a <ul> or <ol>"},marquee:{description:"Ensures <marquee> elements are not used",help:"<marquee> elements are deprecated and must not be used"},"meta-refresh":{description:'Ensures <meta http-equiv="refresh"> is not used',help:"Timed refresh must not exist"},"meta-viewport-large":{description:'Ensures <meta name="viewport"> can scale a significant amount',help:"Users should be able to zoom and scale the text up to 500%"},"meta-viewport":{description:'Ensures <meta name="viewport"> does not disable text scaling and zooming',help:"Zooming and scaling must not be disabled"},"object-alt":{description:"Ensures <object> elements have alternate text",help:"<object> elements must have alternate text"},"p-as-heading":{description:"Ensure p elements are not used to style headings",help:"Bold, italic text and font-size are not used to style p elements as a heading"},radiogroup:{description:'Ensures related <input type="radio"> elements have a group and that the group designation is consistent',help:"Radio inputs with the same name attribute value must be part of a group"},region:{description:"Ensures all content is contained within a landmark region",help:"Content should be contained in a landmark region"},"scope-attr-valid":{description:"Ensures the scope attribute is used correctly on tables",help:"scope attribute should be used correctly"},"server-side-image-map":{description:"Ensures that server-side image maps are not used",help:"Server-side image maps must not be used"},"skip-link":{description:"Ensures the first link on the page is a skip link",help:"The page should have a skip link as its first link"},tabindex:{description:"Ensures tabindex attribute values are not greater than 0",help:"Elements should not have tabindex greater than zero"},"table-duplicate-name":{description:"Ensure that tables do not have the same summary and caption",help:"The <caption> element should not contain the same text as the summary attribute"},"table-fake-caption":{description:"Ensure that tables with a caption use the <caption> element.",help:"Data or header cells should not be used to give caption to a data table."},"td-has-header":{description:"Ensure that each non-empty data cell in a large table has one or more table headers",help:"All non-empty td element in table larger than 3 by 3 must have an associated table header"},"td-headers-attr":{description:"Ensure that each cell in a table using the headers refers to another cell in that table",help:"All cells in a table element that use the headers attribute must only refer to other cells of that same table"},"th-has-data-cells":{description:"Ensure that each table header in a data table refers to data cells",help:"All th element and elements with role=columnheader/rowheader must data cells which it describes"},"valid-lang":{description:"Ensures lang attributes have valid values",help:"lang attribute must have a valid value"},"video-caption":{description:"Ensures <video> elements have captions",help:"<video> elements must have captions"},"video-description":{description:"Ensures <video> elements have audio descriptions",help:"<video> elements must have an audio description track"}},checks:{accesskeys:{impact:"critical",messages:{pass:function(a){return"Accesskey attribute value is unique"},fail:function(a){return"Document has multiple elements with the same accesskey"}}},"non-empty-alt":{impact:"critical",messages:{pass:function(a){return"Element has a non-empty alt attribute"},fail:function(a){return"Element has no alt attribute or the alt attribute is empty"}}},"non-empty-title":{impact:"critical",messages:{pass:function(a){return"Element has a title attribute"},fail:function(a){return"Element has no title attribute or the title attribute is empty"}}},"aria-label":{impact:"critical",messages:{pass:function(a){return"aria-label attribute exists and is not empty"},fail:function(a){return"aria-label attribute does not exist or is empty"}}},"aria-labelledby":{impact:"critical",messages:{pass:function(a){return"aria-labelledby attribute exists and references elements that are visible to screen readers"},fail:function(a){return"aria-labelledby attribute does not exist, references elements that do not exist or references elements that are empty or not visible"}}},"aria-allowed-attr":{impact:"critical",messages:{pass:function(a){return"ARIA attributes are used correctly for the defined role"},fail:function(a){var b="ARIA attribute"+(a.data&&a.data.length>1?"s are":" is")+" not allowed:",c=a.data;if(c)for(var d,e=-1,f=c.length-1;e<f;)d=c[e+=1],b+=" "+d;return b}}},"aria-hidden-body":{impact:"critical",messages:{pass:function(a){return"No aria-hidden attribute is present on document body"},fail:function(a){return"aria-hidden=true should not be present on the document body"}}},"aria-required-attr":{impact:"critical",messages:{pass:function(a){return"All required ARIA attributes are present"},fail:function(a){var b="Required ARIA attribute"+(a.data&&a.data.length>1?"s":"")+" not present:",c=a.data;if(c)for(var d,e=-1,f=c.length-1;e<f;)d=c[e+=1],b+=" "+d;return b}}},"aria-required-children":{impact:"critical",messages:{pass:function(a){return"Required ARIA children are present"},fail:function(a){var b="Required ARIA "+(a.data&&a.data.length>1?"children":"child")+" role not present:",c=a.data;if(c)for(var d,e=-1,f=c.length-1;e<f;)d=c[e+=1],b+=" "+d;return b}}},"aria-required-parent":{impact:"critical",messages:{pass:function(a){return"Required ARIA parent role present"},fail:function(a){var b="Required ARIA parent"+(a.data&&a.data.length>1?"s":"")+" role not present:",c=a.data;if(c)for(var d,e=-1,f=c.length-1;e<f;)d=c[e+=1],b+=" "+d;return b}}},invalidrole:{impact:"critical",messages:{pass:function(a){return"ARIA role is valid"},fail:function(a){return"Role must be one of the valid ARIA roles"}}},abstractrole:{impact:"serious",messages:{pass:function(a){return"Abstract roles are not used"},fail:function(a){return"Abstract roles cannot be directly used"}}},"aria-valid-attr-value":{impact:"critical",messages:{pass:function(a){return"ARIA attribute values are valid"},fail:function(a){var b="Invalid ARIA attribute value"+(a.data&&a.data.length>1?"s":"")+":",c=a.data;if(c)for(var d,e=-1,f=c.length-1;e<f;)d=c[e+=1],b+=" "+d;return b}}},"aria-valid-attr":{impact:"critical",messages:{pass:function(a){return"ARIA attribute name"+(a.data&&a.data.length>1?"s":"")+" are valid"},fail:function(a){var b="Invalid ARIA attribute name"+(a.data&&a.data.length>1?"s":"")+":",c=a.data;if(c)for(var d,e=-1,f=c.length-1;e<f;)d=c[e+=1],b+=" "+d;return b}}},caption:{impact:"critical",messages:{pass:function(a){return"The multimedia element has a captions track"},fail:function(a){return"The multimedia element does not have a captions track"},incomplete:function(a){return"A captions track for this element could not be found"}}},"is-on-screen":{impact:"minor",messages:{pass:function(a){return"Element is not visible"},fail:function(a){return"Element is visible"}}},"non-empty-if-present":{impact:"critical",messages:{pass:function(a){var b="Element ";return a.data?b+="has a non-empty value attribute":b+="does not have a value attribute",b},fail:function(a){return"Element has a value attribute and the value attribute is empty"}}},"non-empty-value":{impact:"critical",messages:{pass:function(a){return"Element has a non-empty value attribute"},fail:function(a){return"Element has no value attribute or the value attribute is empty"}}},"button-has-visible-text":{impact:"critical",messages:{pass:function(a){return"Element has inner text that is visible to screen readers"},fail:function(a){return"Element does not have inner text that is visible to screen readers"}}},"role-presentation":{impact:"moderate",messages:{pass:function(a){return'Element\'s default semantics were overriden with role="presentation"'},fail:function(a){return'Element\'s default semantics were not overridden with role="presentation"'}}},"role-none":{impact:"moderate",messages:{pass:function(a){return'Element\'s default semantics were overriden with role="none"'},fail:function(a){return'Element\'s default semantics were not overridden with role="none"'}}},"focusable-no-name":{impact:"serious",messages:{pass:function(a){return"Element is not in tab order or has accessible text"},fail:function(a){return"Element is in tab order and does not have accessible text"}}},"internal-link-present":{impact:"critical",messages:{pass:function(a){return"Valid skip link found"},fail:function(a){return"No valid skip link found"}}},"header-present":{impact:"moderate",messages:{pass:function(a){return"Page has a header"},fail:function(a){return"Page does not have a header"}}},landmark:{impact:"serious",messages:{pass:function(a){return"Page has a landmark region"},fail:function(a){return"Page does not have a landmark region"}}},"group-labelledby":{impact:"critical",messages:{pass:function(a){return'All elements with the name "'+a.data.name+'" reference the same element with aria-labelledby'},fail:function(a){return'All elements with the name "'+a.data.name+'" do not reference the same element with aria-labelledby'}}},fieldset:{impact:"critical",messages:{pass:function(a){return"Element is contained in a fieldset"},fail:function(a){var b="",c=a.data&&a.data.failureCode;return b+="no-legend"===c?"Fieldset does not have a legend as its first child":"empty-legend"===c?"Legend does not have text that is visible to screen readers":"mixed-inputs"===c?"Fieldset contains unrelated inputs":"no-group-label"===c?"ARIA group does not have aria-label or aria-labelledby":"group-mixed-inputs"===c?"ARIA group contains unrelated inputs":"Element does not have a containing fieldset or ARIA group"}}},"color-contrast":{impact:"serious",messages:{pass:function(a){return"Element has sufficient color contrast of "+a.data.contrastRatio},fail:function(a){return"Element has insufficient color contrast of "+a.data.contrastRatio+" (foreground color: "+a.data.fgColor+", background color: "+a.data.bgColor+", font size: "+a.data.fontSize+", font weight: "+a.data.fontWeight+")"},incomplete:{bgImage:"Element's background color could not be determined due to a background image",bgGradient:"Element's background color could not be determined due to a background gradient",imgNode:"Element's background color could not be determined because element contains an image node",bgOverlap:"Element's background color could not be determined because it is overlapped by another element",fgAlpha:"Element's foreground color could not be determined because of alpha transparency",elmPartiallyObscured:"Element's background color could not be determined because it's partially obscured by another element",equalRatio:"Element has a 1:1 contrast ratio with the background",default:"Unable to determine contrast ratio"}}},"structured-dlitems":{impact:"serious",messages:{pass:function(a){return"When not empty, element has both <dt> and <dd> elements"},fail:function(a){return"When not empty, element does not have at least one <dt> element followed by at least one <dd> element"}}},"only-dlitems":{impact:"serious",messages:{pass:function(a){return"List element only has direct children that are allowed inside <dt> or <dd> elements"},fail:function(a){return"List element has direct children that are not allowed inside <dt> or <dd> elements"}}},dlitem:{impact:"serious",messages:{pass:function(a){return"Description list item has a <dl> parent element"},fail:function(a){return"Description list item does not have a <dl> parent element"}}},"doc-has-title":{impact:"moderate",messages:{pass:function(a){return"Document has a non-empty <title> element"},fail:function(a){return"Document does not have a non-empty <title> element"}}},"duplicate-id":{impact:"moderate",messages:{pass:function(a){return"Document has no elements that share the same id attribute"},fail:function(a){return"Document has multiple elements with the same id attribute: "+a.data}}},"has-visible-text":{impact:"moderate",messages:{pass:function(a){return"Element has text that is visible to screen readers"},fail:function(a){return"Element does not have text that is visible to screen readers"}}},"unique-frame-title":{impact:"serious",messages:{pass:function(a){return"Element's title attribute is unique"},fail:function(a){return"Element's title attribute is not unique"}}},"heading-order":{impact:"minor",messages:{pass:function(a){return"Heading order valid"},fail:function(a){return"Heading order invalid"}}},"hidden-content":{impact:"minor",messages:{pass:function(a){return"All content on the page has been analyzed."},fail:function(a){return"There were problems analyzing the content on this page."},incomplete:function(a){return"There is hidden content on the page that was not analyzed. You will need to trigger the display of this content in order to analyze it."}}},"href-no-hash":{impact:"moderate",messages:{pass:function(a){return"Anchor does not have an href value of #"},fail:function(a){return"Anchor has an href value of #"}}},"has-lang":{impact:"serious",messages:{pass:function(a){return"The <html> element has a lang attribute"},fail:function(a){return"The <html> element does not have a lang attribute"}}},"valid-lang":{impact:"serious",messages:{pass:function(a){return"Value of lang attribute is included in the list of valid languages"},fail:function(a){return"Value of lang attribute not included in the list of valid languages"}}},"has-alt":{impact:"critical",messages:{pass:function(a){return"Element has an alt attribute"},fail:function(a){return"Element does not have an alt attribute"}}},"duplicate-img-label":{impact:"minor",messages:{pass:function(a){return"Element does not duplicate existing text in <img> alt text"},fail:function(a){return"Element contains <img> element with alt text that duplicates existing text"}}},"title-only":{impact:"serious",messages:{pass:function(a){return"Form element does not solely use title attribute for its label"},fail:function(a){return"Only title used to generate label for form element"}}},"implicit-label":{impact:"critical",messages:{pass:function(a){return"Form element has an implicit (wrapped) <label>"},fail:function(a){return"Form element does not have an implicit (wrapped) <label>"}}},"explicit-label":{impact:"critical",messages:{pass:function(a){return"Form element has an explicit <label>"},fail:function(a){return"Form element does not have an explicit <label>"}}},"help-same-as-label":{impact:"minor",messages:{pass:function(a){return"Help text (title or aria-describedby) does not duplicate label text"},fail:function(a){return"Help text (title or aria-describedby) text is the same as the label text"}}},"multiple-label":{impact:"serious",messages:{pass:function(a){return"Form element does not have multiple <label> elements"},fail:function(a){return"Form element has multiple <label> elements"}}},"has-th":{impact:"serious",messages:{pass:function(a){return"Layout table does not use <th> elements"},fail:function(a){return"Layout table uses <th> elements"}}},"has-caption":{impact:"serious",messages:{pass:function(a){return"Layout table does not use <caption> element"},fail:function(a){return"Layout table uses <caption> element"}}},"has-summary":{impact:"serious",messages:{pass:function(a){return"Layout table does not use summary attribute"},fail:function(a){return"Layout table uses summary attribute"}}},"link-in-text-block":{impact:"critical",messages:{pass:function(a){return"Links can be distinguished from surrounding text in a way that does not rely on color"},fail:function(a){return"Links can not be distinguished from surrounding text in a way that does not rely on color"},incomplete:{bgContrast:"Element's contrast ratio could not be determined. Check for a distinct hover/focus style",bgImage:"Element's contrast ratio could not be determined due to a background image",bgGradient:"Element's contrast ratio could not be determined due to a background gradient",imgNode:"Element's contrast ratio could not be determined because element contains an image node",bgOverlap:"Element's contrast ratio could not be determined because of element overlap",default:"Unable to determine contrast ratio"}}},"only-listitems":{impact:"serious",messages:{pass:function(a){return"List element only has direct children that are allowed inside <li> elements"},fail:function(a){return"List element has direct children that are not allowed inside <li> elements"}}},listitem:{impact:"critical",messages:{pass:function(a){return'List item has a <ul>, <ol> or role="list" parent element'},fail:function(a){return'List item does not have a <ul>, <ol> or role="list" parent element'}}},"meta-refresh":{impact:"critical",messages:{pass:function(a){return"<meta> tag does not immediately refresh the page"},fail:function(a){return"<meta> tag forces timed refresh of page"}}},"meta-viewport-large":{impact:"minor",messages:{pass:function(a){return"<meta> tag does not prevent significant zooming"},fail:function(a){return"<meta> tag limits zooming"}}},"meta-viewport":{impact:"critical",messages:{pass:function(a){return"<meta> tag does not disable zooming"},fail:function(a){return"<meta> tag disables zooming"}}},"p-as-heading":{impact:"critical",messages:{pass:function(a){return"<p> elements are not styled as headings"},fail:function(a){return"Heading elements should be used instead of styled p elements"}}},region:{impact:"moderate",messages:{pass:function(a){return"Content contained by ARIA landmark"},fail:function(a){return"Content not contained by an ARIA landmark"}}},"html5-scope":{impact:"serious",messages:{pass:function(a){return"Scope attribute is only used on table header elements (<th>)"},fail:function(a){return"In HTML 5, scope attributes may only be used on table header elements (<th>)"}}},"scope-value":{impact:"critical",messages:{pass:function(a){return"Scope attribute is used correctly"},fail:function(a){return"The value of the scope attribute may only be 'row' or 'col'"}}},exists:{impact:"minor",messages:{pass:function(a){return"Element does not exist"},fail:function(a){return"Element exists"}}},"skip-link":{impact:"critical",messages:{pass:function(a){return"Valid skip link found"},fail:function(a){return"No valid skip link found"}}},tabindex:{impact:"serious",messages:{pass:function(a){return"Element does not have a tabindex greater than 0"},fail:function(a){return"Element has a tabindex greater than 0"}}},"same-caption-summary":{impact:"moderate",messages:{pass:function(a){return"Content of summary attribute and <caption> are not duplicated"},fail:function(a){return"Content of summary attribute and <caption> element are identical"}}},"caption-faked":{impact:"critical",messages:{pass:function(a){return"The first row of a table is not used as a caption"},fail:function(a){return"The first row of the table should be a caption instead of a table cell"}}},"td-has-header":{impact:"critical",messages:{pass:function(a){return"All non-empty data cells have table headers"},fail:function(a){return"Some non-empty data cells do not have table headers"}}},"td-headers-attr":{impact:"serious",messages:{pass:function(a){return"The headers attribute is exclusively used to refer to other cells in the table"},fail:function(a){return"The headers attribute is not exclusively used to refer to other cells in the table"}}},"th-has-data-cells":{impact:"critical",messages:{pass:function(a){return"All table header cells refer to data cells"},fail:function(a){return"Not all table header cells refer to data cells"},incomplete:function(a){return"Table data cells are missing or empty"}}},description:{impact:"serious",messages:{pass:function(a){return"The multimedia element has an audio description track"},fail:function(a){return"The multimedia element does not have an audio description track"},incomplete:function(a){return"An audio description track for this element could not be found"}}}},failureSummaries:{any:{failureMessage:function(a){var b="Fix any of the following:",c=a;if(c)for(var d,e=-1,f=c.length-1;e<f;)d=c[e+=1],b+="\n "+d.split("\n").join("\n ");return b}},none:{failureMessage:function(a){ +var b="Fix all of the following:",c=a;if(c)for(var d,e=-1,f=c.length-1;e<f;)d=c[e+=1],b+="\n "+d.split("\n").join("\n ");return b}}},incompleteFallbackMessage:function(a){return"aXe couldn't tell the reason. Time to break out the element inspector!"}},rules:[{id:"accesskeys",selector:"[accesskey]",excludeHidden:!1,tags:["wcag2a","wcag211","cat.keyboard"],all:[],any:[],none:["accesskeys"]},{id:"area-alt",selector:"map area[href]",excludeHidden:!1,tags:["cat.text-alternatives","wcag2a","wcag111","section508","section508.22.a"],all:[],any:["non-empty-alt","non-empty-title","aria-label","aria-labelledby"],none:[]},{id:"aria-allowed-attr",matches:function(a){var b=a.getAttribute("role");b||(b=axe.commons.aria.implicitRole(a));var c=axe.commons.aria.allowedAttr(b);if(b&&c){var d=/^aria-/;if(a.hasAttributes())for(var e=a.attributes,f=0,g=e.length;f<g;f++)if(d.test(e[f].name))return!0}return!1},tags:["cat.aria","wcag2a","wcag411","wcag412"],all:[],any:["aria-allowed-attr"],none:[]},{id:"aria-hidden-body",selector:"body",excludeHidden:!1,tags:["cat.aria","wcag2a","wcag412"],all:[],any:["aria-hidden-body"],none:[]},{id:"aria-required-attr",selector:"[role]",tags:["cat.aria","wcag2a","wcag411","wcag412"],all:[],any:["aria-required-attr"],none:[]},{id:"aria-required-children",selector:"[role]",tags:["cat.aria","wcag2a","wcag131"],all:[],any:["aria-required-children"],none:[]},{id:"aria-required-parent",selector:"[role]",tags:["cat.aria","wcag2a","wcag131"],all:[],any:["aria-required-parent"],none:[]},{id:"aria-roles",selector:"[role]",tags:["cat.aria","wcag2a","wcag131","wcag411","wcag412"],all:[],any:[],none:["invalidrole","abstractrole"]},{id:"aria-valid-attr-value",matches:function(a){var b=/^aria-/;if(a.hasAttributes())for(var c=a.attributes,d=0,e=c.length;d<e;d++)if(b.test(c[d].name))return!0;return!1},tags:["cat.aria","wcag2a","wcag131","wcag411","wcag412"],all:[],any:[{options:[],id:"aria-valid-attr-value"}],none:[]},{id:"aria-valid-attr",matches:function(a){var b=/^aria-/;if(a.hasAttributes())for(var c=a.attributes,d=0,e=c.length;d<e;d++)if(b.test(c[d].name))return!0;return!1},tags:["cat.aria","wcag2a","wcag411"],all:[],any:[{options:[],id:"aria-valid-attr"}],none:[]},{id:"audio-caption",selector:"audio",excludeHidden:!1,tags:["cat.time-and-media","wcag2a","wcag122","section508","section508.22.a"],all:[],any:[],none:["caption"]},{id:"blink",selector:"blink",excludeHidden:!1,tags:["cat.time-and-media","wcag2a","wcag222","section508","section508.22.j"],all:[],any:[],none:["is-on-screen"]},{id:"button-name",selector:'button, [role="button"], input[type="button"], input[type="submit"], input[type="reset"]',tags:["cat.name-role-value","wcag2a","wcag412","section508","section508.22.a"],all:[],any:["non-empty-if-present","non-empty-value","button-has-visible-text","aria-label","aria-labelledby","role-presentation","role-none"],none:["focusable-no-name"]},{id:"bypass",selector:"html",pageLevel:!0,matches:function(a){return!!a.querySelector("a[href]")},tags:["cat.keyboard","wcag2a","wcag241","section508","section508.22.o"],all:[],any:["internal-link-present","header-present","landmark"],none:[]},{id:"checkboxgroup",selector:"input[type=checkbox][name]",tags:["cat.forms","best-practice"],all:[],any:["group-labelledby","fieldset"],none:[]},{id:"color-contrast",matches:function(a){var b=a.nodeName.toUpperCase(),c=a.type,d=document;if("true"===a.getAttribute("aria-disabled")||axe.commons.dom.findUp(a,'[aria-disabled="true"]'))return!1;if("INPUT"===b)return-1===["hidden","range","color","checkbox","radio","image"].indexOf(c)&&!a.disabled;if("SELECT"===b)return!!a.options.length&&!a.disabled;if("TEXTAREA"===b)return!a.disabled;if("OPTION"===b)return!1;if("BUTTON"===b&&a.disabled||axe.commons.dom.findUp(a,"button[disabled]"))return!1;if("FIELDSET"===b&&a.disabled||axe.commons.dom.findUp(a,"fieldset[disabled]"))return!1;var e=axe.commons.dom.findUp(a,"label");if("LABEL"===b||e){var f=a;e&&(f=e);var g=f.htmlFor&&d.getElementById(f.htmlFor);if(g&&g.disabled)return!1;var g=a.querySelector('input:not([type="hidden"]):not([type="image"]):not([type="button"]):not([type="submit"]):not([type="reset"]), select, textarea');if(g&&g.disabled)return!1}if(a.id){var g=d.querySelector("[aria-labelledby~="+axe.commons.utils.escapeSelector(a.id)+"]");if(g&&g.disabled)return!1}if(""===axe.commons.text.visible(a,!1,!0))return!1;var h,i,j=document.createRange(),k=a.childNodes,l=k.length;for(i=0;i<l;i++)h=k[i],3===h.nodeType&&""!==axe.commons.text.sanitize(h.nodeValue)&&j.selectNodeContents(h);var m=j.getClientRects();for(l=m.length,i=0;i<l;i++)if(axe.commons.dom.visuallyOverlaps(m[i],a))return!0;return!1},excludeHidden:!1,options:{noScroll:!1},tags:["cat.color","wcag2aa","wcag143"],all:[],any:["color-contrast"],none:[]},{id:"definition-list",selector:"dl",matches:function(a){return!a.getAttribute("role")},tags:["cat.structure","wcag2a","wcag131"],all:[],any:[],none:["structured-dlitems","only-dlitems"]},{id:"dlitem",selector:"dd, dt",matches:function(a){return!a.getAttribute("role")},tags:["cat.structure","wcag2a","wcag131"],all:[],any:["dlitem"],none:[]},{id:"document-title",selector:"html",matches:function(a){return a.ownerDocument.defaultView.self===a.ownerDocument.defaultView.top},tags:["cat.text-alternatives","wcag2a","wcag242"],all:[],any:["doc-has-title"],none:[]},{id:"duplicate-id",selector:"[id]",excludeHidden:!1,tags:["cat.parsing","wcag2a","wcag411"],all:[],any:["duplicate-id"],none:[]},{id:"empty-heading",selector:'h1, h2, h3, h4, h5, h6, [role="heading"]',enabled:!0,tags:["cat.name-role-value","best-practice"],all:[],any:["has-visible-text","role-presentation","role-none"],none:[]},{id:"frame-title-unique",selector:"frame[title], iframe[title]",matches:function(a){var b=a.getAttribute("title");return!!(b?axe.commons.text.sanitize(b).trim():"")},tags:["cat.text-alternatives","best-practice"],all:[],any:[],none:["unique-frame-title"]},{id:"frame-title",selector:"frame, iframe",tags:["cat.text-alternatives","wcag2a","wcag241","section508","section508.22.i"],all:[],any:["aria-label","aria-labelledby","non-empty-title","role-presentation","role-none"],none:[]},{id:"heading-order",selector:"h1,h2,h3,h4,h5,h6,[role=heading]",enabled:!1,tags:["cat.semantics","best-practice"],all:[],any:["heading-order"],none:[]},{id:"hidden-content",selector:"*",excludeHidden:!1,tags:["experimental","review-item"],all:[],any:["hidden-content"],none:[],enabled:!1},{id:"href-no-hash",selector:"a[href]",enabled:!1,tags:["cat.semantics","best-practice"],all:[],any:["href-no-hash"],none:[]},{id:"html-has-lang",selector:"html",tags:["cat.language","wcag2a","wcag311"],all:[],any:["has-lang"],none:[]},{id:"html-lang-valid",selector:"html[lang]",tags:["cat.language","wcag2a","wcag311"],all:[],any:[],none:["valid-lang"]},{id:"image-alt",selector:"img, [role='img']",tags:["cat.text-alternatives","wcag2a","wcag111","section508","section508.22.a"],all:[],any:["has-alt","aria-label","aria-labelledby","non-empty-title","role-presentation","role-none"],none:[]},{id:"image-redundant-alt",selector:'button, [role="button"], a[href], p, li, td, th',tags:["cat.text-alternatives","best-practice"],all:[],any:[],none:["duplicate-img-label"]},{id:"input-image-alt",selector:'input[type="image"]',tags:["cat.text-alternatives","wcag2a","wcag111","section508","section508.22.a"],all:[],any:["non-empty-alt","aria-label","aria-labelledby","non-empty-title"],none:[]},{id:"label-title-only",selector:"input, select, textarea",matches:function(a){if("input"!==a.nodeName.toLowerCase())return!0;var b=a.getAttribute("type").toLowerCase();return"hidden"!==b&&"image"!==b&&"button"!==b&&"submit"!==b&&"reset"!==b},enabled:!1,tags:["cat.forms","best-practice"],all:[],any:[],none:["title-only"]},{id:"label",selector:"input, select, textarea",matches:function(a){if("input"!==a.nodeName.toLowerCase())return!0;var b=a.getAttribute("type").toLowerCase();return"hidden"!==b&&"image"!==b&&"button"!==b&&"submit"!==b&&"reset"!==b},tags:["cat.forms","wcag2a","wcag332","wcag131","section508","section508.22.n"],all:[],any:["aria-label","aria-labelledby","implicit-label","explicit-label","non-empty-title"],none:["help-same-as-label","multiple-label"]},{id:"layout-table",selector:"table",matches:function(a){return!axe.commons.table.isDataTable(a)},tags:["cat.semantics","wcag2a","wcag131"],all:[],any:[],none:["has-th","has-caption","has-summary"]},{id:"link-in-text-block",selector:"a[href], *[role=link]",matches:function(a){var b=axe.commons.text.sanitize(a.textContent),c=a.getAttribute("role");return(!c||"link"===c)&&(!!b&&(!!axe.commons.dom.isVisible(a,!1)&&axe.commons.dom.isInTextBlock(a)))},excludeHidden:!1,tags:["cat.color","experimental","wcag2a","wcag141"],all:["link-in-text-block"],any:[],none:[]},{id:"link-name",selector:"a[href], [role=link][href]",matches:function(a){return"button"!==a.getAttribute("role")},tags:["cat.name-role-value","wcag2a","wcag111","wcag412","section508","section508.22.a"],all:[],any:["has-visible-text","aria-label","aria-labelledby","role-presentation","role-none"],none:["focusable-no-name"]},{id:"list",selector:"ul, ol",matches:function(a){return!a.getAttribute("role")},tags:["cat.structure","wcag2a","wcag131"],all:[],any:[],none:["only-listitems"]},{id:"listitem",selector:"li",matches:function(a){return!a.getAttribute("role")},tags:["cat.structure","wcag2a","wcag131"],all:[],any:["listitem"],none:[]},{id:"marquee",selector:"marquee",excludeHidden:!1,tags:["cat.parsing","wcag2a","wcag222"],all:[],any:[],none:["is-on-screen"]},{id:"meta-refresh",selector:'meta[http-equiv="refresh"]',excludeHidden:!1,tags:["cat.time","wcag2a","wcag2aaa","wcag221","wcag224","wcag325"],all:[],any:["meta-refresh"],none:[]},{id:"meta-viewport-large",selector:'meta[name="viewport"]',excludeHidden:!1,tags:["cat.sensory-and-visual-cues","best-practice"],all:[],any:[{options:{scaleMinimum:5,lowerBound:2},id:"meta-viewport-large"}],none:[]},{id:"meta-viewport",selector:'meta[name="viewport"]',excludeHidden:!1,tags:["cat.sensory-and-visual-cues","wcag2aa","wcag144"],all:[],any:[{options:{scaleMinimum:2},id:"meta-viewport"}],none:[]},{id:"object-alt",selector:"object",tags:["cat.text-alternatives","wcag2a","wcag111","section508","section508.22.a"],all:[],any:["has-visible-text","aria-label","aria-labelledby","non-empty-title"],none:[]},{id:"p-as-heading",selector:"p",matches:function(a){var b=Array.from(a.parentNode.childNodes),c=a.textContent.trim(),d=/[.!?:;](?![.!?:;])/g;return!(0===c.length||(c.match(d)||[]).length>=2)&&0!==b.slice(b.indexOf(a)+1).filter(function(a){return"P"===a.nodeName.toUpperCase()&&""!==a.textContent.trim()}).length},tags:["cat.semantics","wcag2a","wcag131","experimental"],all:[{options:{margins:[{weight:150,italic:!0},{weight:150,size:1.15},{italic:!0,size:1.15},{size:1.4}]},id:"p-as-heading"}],any:[],none:[]},{id:"radiogroup",selector:"input[type=radio][name]",tags:["cat.forms","best-practice"],all:[],any:["group-labelledby","fieldset"],none:[]},{id:"region",selector:"html",pageLevel:!0,enabled:!1,tags:["cat.keyboard","best-practice"],all:[],any:["region"],none:[]},{id:"scope-attr-valid",selector:"td[scope], th[scope]",enabled:!0,tags:["cat.tables","best-practice"],all:["html5-scope","scope-value"],any:[],none:[]},{id:"server-side-image-map",selector:"img[ismap]",tags:["cat.text-alternatives","wcag2a","wcag211","section508","section508.22.f"],all:[],any:[],none:["exists"]},{id:"skip-link",selector:"a[href]",pageLevel:!0,enabled:!1,tags:["cat.keyboard","best-practice"],all:[],any:["skip-link"],none:[]},{id:"tabindex",selector:"[tabindex]",tags:["cat.keyboard","best-practice"],all:[],any:["tabindex"],none:[]},{id:"table-duplicate-name",selector:"table",tags:["cat.tables","best-practice"],all:[],any:[],none:["same-caption-summary"]},{id:"table-fake-caption",selector:"table",matches:function(a){return axe.commons.table.isDataTable(a)},tags:["cat.tables","experimental","wcag2a","wcag131","section508","section508.22.g"],all:["caption-faked"],any:[],none:[]},{id:"td-has-header",selector:"table",matches:function(a){if(axe.commons.table.isDataTable(a)){var b=axe.commons.table.toArray(a);return b.length>=3&&b[0].length>=3&&b[1].length>=3&&b[2].length>=3}return!1},tags:["cat.tables","experimental","wcag2a","wcag131","section508","section508.22.g"],all:["td-has-header"],any:[],none:[]},{id:"td-headers-attr",selector:"table",tags:["cat.tables","wcag2a","wcag131","section508","section508.22.g"],all:["td-headers-attr"],any:[],none:[]},{id:"th-has-data-cells",selector:"table",matches:function(a){return axe.commons.table.isDataTable(a)},tags:["cat.tables","wcag2a","wcag131","section508","section508.22.g"],all:["th-has-data-cells"],any:[],none:[]},{id:"valid-lang",selector:"[lang], [xml\\:lang]",matches:function(a){return"html"!==a.nodeName.toLowerCase()},tags:["cat.language","wcag2aa","wcag312"],all:[],any:[],none:["valid-lang"]},{id:"video-caption",selector:"video",excludeHidden:!1,tags:["cat.text-alternatives","wcag2a","wcag122","wcag123","section508","section508.22.a"],all:[],any:[],none:["caption"]},{id:"video-description",selector:"video",excludeHidden:!1,tags:["cat.text-alternatives","wcag2aa","wcag125","section508","section508.22.b"],all:[],any:[],none:["description"]}],checks:[{id:"abstractrole",evaluate:function(a,b){return"abstract"===axe.commons.aria.getRoleType(a.getAttribute("role"))}},{id:"aria-allowed-attr",evaluate:function(a,b){var c,d,e,f=[],g=a.getAttribute("role"),h=a.attributes;if(g||(g=axe.commons.aria.implicitRole(a)),e=axe.commons.aria.allowedAttr(g),g&&e)for(var i=0,j=h.length;i<j;i++)c=h[i],d=c.name,axe.commons.aria.validateAttr(d)&&-1===e.indexOf(d)&&f.push(d+'="'+c.nodeValue+'"');return!f.length||(this.data(f),!1)}},{id:"aria-hidden-body",evaluate:function(a,b){return"true"!==a.getAttribute("aria-hidden")}},{id:"invalidrole",evaluate:function(a,b){return!axe.commons.aria.isValidRole(a.getAttribute("role"))}},{id:"aria-required-attr",evaluate:function(a,b){var c=[];if(a.hasAttributes()){var d,e=a.getAttribute("role"),f=axe.commons.aria.requiredAttr(e);if(e&&f)for(var g=0,h=f.length;g<h;g++)d=f[g],a.getAttribute(d)||c.push(d)}return!c.length||(this.data(c),!1)}},{id:"aria-required-children",evaluate:function(a,b){function c(a,b,c){if(null===a)return!1;var d=f(b),e=['[role="'+b+'"]'];return d&&(e=e.concat(d)),e=e.join(","),c?g(a,e)||!!a.querySelector(e):!!a.querySelector(e)}function d(a,b){var d,e;for(d=0,e=a.length;d<e;d++)if(null!==a[d]&&c(a[d],b,!0))return!0;return!1}var e=axe.commons.aria.requiredOwned,f=axe.commons.aria.implicitNodes,g=axe.commons.utils.matchesSelector,h=axe.commons.dom.idrefs,i=a.getAttribute("role"),j=e(i);if(!j)return!0;var k=!1,l=j.one;if(!l){var k=!0;l=j.all}var m=function(a,b,e){var f,g=b.length,i=[],j=h(a,"aria-owns");for(f=0;f<g;f++){var k=b[f];if(c(a,k)||d(j,k)){if(!e)return null}else e&&i.push(k)}return i.length?i:!e&&b.length?b:null}(a,l,k);return!m||(this.data(m),!1)}},{id:"aria-required-parent",evaluate:function(a,b){function c(a){return(axe.commons.aria.implicitNodes(a)||[]).concat('[role="'+a+'"]').join(",")}function d(a,b,d){var e,f,g=a.getAttribute("role"),h=[];if(b||(b=axe.commons.aria.requiredContext(g)),!b)return null;for(e=0,f=b.length;e<f;e++){if(d&&axe.utils.matchesSelector(a,c(b[e])))return null;if(axe.commons.dom.findUp(a,c(b[e])))return null;h.push(b[e])}return h}var e=d(a);if(!e)return!0;var f=function(a){for(var b=[],c=null;a;)a.id&&(c=document.querySelector("[aria-owns~="+axe.commons.utils.escapeSelector(a.id)+"]"))&&b.push(c),a=a.parentNode;return b.length?b:null}(a);if(f)for(var g=0,h=f.length;g<h;g++)if(!(e=d(f[g],e,!0)))return!0;return this.data(e),!1}},{id:"aria-valid-attr-value",evaluate:function(a,b){b=Array.isArray(b)?b:[];for(var c,d,e=[],f=/^aria-/,g=a.attributes,h=0,i=g.length;h<i;h++)c=g[h],d=c.name,-1===b.indexOf(d)&&f.test(d)&&!axe.commons.aria.validateAttrValue(a,d)&&e.push(d+'="'+c.nodeValue+'"');return!e.length||(this.data(e),!1)},options:[]},{id:"aria-valid-attr",evaluate:function(a,b){b=Array.isArray(b)?b:[];for(var c,d=[],e=/^aria-/,f=a.attributes,g=0,h=f.length;g<h;g++)c=f[g].name,-1===b.indexOf(c)&&e.test(c)&&!axe.commons.aria.validateAttr(c)&&d.push(c);return!d.length||(this.data(d),!1)},options:[]},{id:"color-contrast",evaluate:function(a,b){if(!axe.commons.dom.isVisible(a,!1))return!0;var c,d=!!(b||{}).noScroll,e=[],f=axe.commons.color.getBackgroundColor(a,e,d),g=axe.commons.color.getForegroundColor(a,d),h=window.getComputedStyle(a),i=parseFloat(h.getPropertyValue("font-size")),j=h.getPropertyValue("font-weight"),k=-1!==["bold","bolder","600","700","800","900"].indexOf(j),l=axe.commons.color.hasValidContrastRatio(f,g,i,k),m=Math.floor(100*l.contrastRatio)/100;null===f&&(c=axe.commons.color.incompleteData.get("bgColor"));var n=!1;1===m&&(n=!0,c=axe.commons.color.incompleteData.set("bgColor","equalRatio"));var o={fgColor:g?g.toHexString():void 0,bgColor:f?f.toHexString():void 0,contrastRatio:l?m:void 0,fontSize:(72*i/96).toFixed(1)+"pt",fontWeight:k?"bold":"normal",missingData:c};return this.data(o),l.isValid&&!n||this.relatedNodes(e),null===g||null===f||n?(c=null,void axe.commons.color.incompleteData.clear()):l.isValid}},{id:"link-in-text-block",evaluate:function(a,b){function c(a,b){var c=a.getRelativeLuminance(),d=b.getRelativeLuminance();return(Math.max(c,d)+.05)/(Math.min(c,d)+.05)}function d(a){var b=window.getComputedStyle(a).getPropertyValue("display");return-1!==f.indexOf(b)||"table-"===b.substr(0,6)}var e=axe.commons.color,f=["block","list-item","table","flex","grid","inline-block"];if(d(a))return!1;for(var g=a.parentNode;1===g.nodeType&&!d(g);)g=g.parentNode;if(e.elementIsDistinct(a,g))return!0;var h,i;if(h=e.getForegroundColor(a),i=e.getForegroundColor(g),h&&i){var j=c(h,i);if(1===j)return!0;if(j>=3)return axe.commons.color.incompleteData.set("fgColor","bgContrast"),this.data({missingData:axe.commons.color.incompleteData.get("fgColor")}),void axe.commons.color.incompleteData.clear();if(h=e.getBackgroundColor(a),i=e.getBackgroundColor(g),!h||!i||c(h,i)>=3){var k=void 0;return k=h&&i?"bgContrast":axe.commons.color.incompleteData.get("bgColor"),axe.commons.color.incompleteData.set("fgColor",k),this.data({missingData:axe.commons.color.incompleteData.get("fgColor")}),void axe.commons.color.incompleteData.clear()}return!1}}},{id:"fieldset",evaluate:function(a,b){function c(a,b){return axe.commons.utils.toArray(a.querySelectorAll('select,textarea,button,input:not([name="'+b+'"]):not([type="hidden"])'))}function d(a,b){var d=a.firstElementChild;if(!d||"LEGEND"!==d.nodeName.toUpperCase())return h.relatedNodes([a]),g="no-legend",!1;if(!axe.commons.text.accessibleText(d))return h.relatedNodes([d]),g="empty-legend",!1;var e=c(a,b);return!e.length||(h.relatedNodes(e),g="mixed-inputs",!1)}function e(a,b){var d=axe.commons.dom.idrefs(a,"aria-labelledby").some(function(a){return a&&axe.commons.text.accessibleText(a)}),e=a.getAttribute("aria-label");if(!(d||e&&axe.commons.text.sanitize(e)))return h.relatedNodes(a),g="no-group-label",!1;var f=c(a,b);return!f.length||(h.relatedNodes(f),g="group-mixed-inputs",!1)}function f(a,b){return axe.commons.utils.toArray(a).filter(function(a){return a!==b})}var g,h=this,i={name:a.getAttribute("name"),type:a.getAttribute("type")},j=function(b){var c=axe.commons.utils.escapeSelector(a.name),i=document.querySelectorAll('input[type="'+axe.commons.utils.escapeSelector(a.type)+'"][name="'+c+'"]');if(i.length<2)return!0;var j=axe.commons.dom.findUp(b,"fieldset"),k=axe.commons.dom.findUp(b,'[role="group"]'+("radio"===a.type?',[role="radiogroup"]':""));return k||j?j?d(j,c):e(k,c):(g="no-group",h.relatedNodes(f(i,b)),!1)}(a);return j||(i.failureCode=g),this.data(i),j},after:function(a,b){var c={};return a.filter(function(a){if(a.result)return!0;var b=a.data;if(b){if(c[b.type]=c[b.type]||{},!c[b.type][b.name])return c[b.type][b.name]=[b],!0;var d=c[b.type][b.name].some(function(a){return a.failureCode===b.failureCode});return d||c[b.type][b.name].push(b),!d}return!1})}},{id:"group-labelledby",evaluate:function(a,b){this.data({name:a.getAttribute("name"),type:a.getAttribute("type")});var c=document.querySelectorAll('input[type="'+axe.commons.utils.escapeSelector(a.type)+'"][name="'+axe.commons.utils.escapeSelector(a.name)+'"]');return c.length<=1||0!==[].map.call(c,function(a){var b=a.getAttribute("aria-labelledby");return b?b.split(/\s+/):[]}).reduce(function(a,b){return a.filter(function(a){return-1!==b.indexOf(a)})}).filter(function(a){var b=document.getElementById(a);return b&&axe.commons.text.accessibleText(b)}).length},after:function(a,b){var c={};return a.filter(function(a){var b=a.data;return!(!b||(c[b.type]=c[b.type]||{},c[b.type][b.name]))&&(c[b.type][b.name]=!0,!0)})}},{id:"accesskeys",evaluate:function(a,b){return axe.commons.dom.isVisible(a,!1)&&(this.data(a.getAttribute("accesskey")),this.relatedNodes([a])),!0},after:function(a,b){var c={};return a.filter(function(a){if(!a.data)return!1;var b=a.data.toUpperCase();return c[b]?(c[b].relatedNodes.push(a.relatedNodes[0]),!1):(c[b]=a,a.relatedNodes=[],!0)}).map(function(a){return a.result=!!a.relatedNodes.length,a})}},{id:"focusable-no-name",evaluate:function(a,b){var c=a.getAttribute("tabindex");return!!(axe.commons.dom.isFocusable(a)&&c>-1)&&!axe.commons.text.accessibleText(a)}},{id:"tabindex",evaluate:function(a,b){return a.tabIndex<=0}},{id:"duplicate-img-label",evaluate:function(a,b){var c=a.querySelectorAll("img"),d=axe.commons.text.visible(a,!0).toLowerCase();if(""===d)return!1;for(var e=0,f=c.length;e<f;e++){var g=c[e];if(axe.commons.text.accessibleText(g).toLowerCase()===d&&"presentation"!==g.getAttribute("role")&&axe.commons.dom.isVisible(g))return!0}return!1}},{id:"explicit-label",evaluate:function(a,b){if(a.id){var c=document.querySelector('label[for="'+axe.commons.utils.escapeSelector(a.id)+'"]');if(c)return!!axe.commons.text.accessibleText(c)}return!1}},{id:"help-same-as-label",evaluate:function(a,b){var c=axe.commons.text.label(a),d=a.getAttribute("title");if(!c)return!1;if(!d&&(d="",a.getAttribute("aria-describedby"))){d=axe.commons.dom.idrefs(a,"aria-describedby").map(function(a){return a?axe.commons.text.accessibleText(a):""}).join("")}return axe.commons.text.sanitize(d)===axe.commons.text.sanitize(c)},enabled:!1},{id:"implicit-label",evaluate:function(a,b){var c=axe.commons.dom.findUp(a,"label");return!!c&&!!axe.commons.text.accessibleText(c)}},{id:"multiple-label",evaluate:function(a,b){var c=[].slice.call(document.querySelectorAll('label[for="'+axe.commons.utils.escapeSelector(a.id)+'"]')),d=a.parentNode;for(c.length&&(c=c.filter(function(a,b){if(0===b&&!axe.commons.dom.isVisible(a,!0)||axe.commons.dom.isVisible(a,!0))return a}));d;)"LABEL"===d.tagName&&-1===c.indexOf(d)&&c.push(d),d=d.parentNode;return this.relatedNodes(c),c.length>1}},{id:"title-only",evaluate:function(a,b){return!(axe.commons.text.label(a)||!a.getAttribute("title")&&!a.getAttribute("aria-describedby"))}},{id:"has-lang",evaluate:function(a,b){return!!(a.getAttribute("lang")||a.getAttribute("xml:lang")||"").trim()}},{id:"valid-lang",evaluate:function(a,b){function c(a){return a.trim().split("-")[0].toLowerCase()}var d,e;return d=(b||axe.commons.utils.validLangs()).map(c),e=["lang","xml:lang"].reduce(function(b,e){var f=a.getAttribute(e);if("string"!=typeof f)return b;var g=c(f);return""!==g&&-1===d.indexOf(g)&&b.push(e+'="'+a.getAttribute(e)+'"'),b},[]),!!e.length&&(this.data(e),!0)}},{id:"dlitem",evaluate:function(a,b){return"DL"===a.parentNode.tagName}},{id:"has-listitem",evaluate:function(a,b){var c=a.children;if(0===c.length)return!0;for(var d=0;d<c.length;d++)if("LI"===c[d].nodeName.toUpperCase())return!1;return!0}},{id:"listitem",evaluate:function(a,b){return-1!==["UL","OL"].indexOf(a.parentNode.nodeName.toUpperCase())||"list"===a.parentNode.getAttribute("role")}},{id:"only-dlitems",evaluate:function(a,b){for(var c,d,e=[],f=a.childNodes,g=["STYLE","META","LINK","MAP","AREA","SCRIPT","DATALIST","TEMPLATE"],h=!1,i=0;i<f.length;i++){c=f[i];var d=c.nodeName.toUpperCase();1===c.nodeType&&"DT"!==d&&"DD"!==d&&-1===g.indexOf(d)?e.push(c):3===c.nodeType&&""!==c.nodeValue.trim()&&(h=!0)}return e.length&&this.relatedNodes(e),!!e.length||h}},{id:"only-listitems",evaluate:function(a,b){for(var c,d,e=[],f=a.childNodes,g=["STYLE","META","LINK","MAP","AREA","SCRIPT","DATALIST","TEMPLATE"],h=!1,i=0;i<f.length;i++)c=f[i],d=c.nodeName.toUpperCase(),1===c.nodeType&&"LI"!==d&&-1===g.indexOf(d)?e.push(c):3===c.nodeType&&""!==c.nodeValue.trim()&&(h=!0);return e.length&&this.relatedNodes(e),!!e.length||h}},{id:"structured-dlitems",evaluate:function(a,b){var c=a.children;if(!c||!c.length)return!1;for(var d,e=!1,f=!1,g=0;g<c.length;g++){if(d=c[g].nodeName.toUpperCase(),"DT"===d&&(e=!0),e&&"DD"===d)return!1;"DD"===d&&(f=!0)}return e||f}},{id:"caption",evaluate:function(a,b){var c=a.querySelectorAll("track");if(c.length){for(var d=0;d<c.length;d++){var e=c[d].getAttribute("kind");if(e&&"captions"===e)return!1}return!0}}},{id:"description",evaluate:function(a,b){var c=a.querySelectorAll("track");if(c.length){for(var d=0;d<c.length;d++){var e=c[d].getAttribute("kind");if(e&&"descriptions"===e)return!1}return!0}}},{id:"meta-viewport-large",evaluate:function(a,b){b=b||{};for(var c,d=a.getAttribute("content")||"",e=d.split(/[;,]/),f={},g=b.scaleMinimum||2,h=b.lowerBound||!1,i=0,j=e.length;i<j;i++){c=e[i].split("=");var k=c.shift().toLowerCase();k&&c.length&&(f[k.trim()]=c.shift().trim().toLowerCase())}return!!(h&&f["maximum-scale"]&&parseFloat(f["maximum-scale"])<h)||!(!h&&"no"===f["user-scalable"])&&!(f["maximum-scale"]&&parseFloat(f["maximum-scale"])<g)},options:{scaleMinimum:5,lowerBound:2}},{id:"meta-viewport",evaluate:function(a,b){b=b||{};for(var c,d=a.getAttribute("content")||"",e=d.split(/[;,]/),f={},g=b.scaleMinimum||2,h=b.lowerBound||!1,i=0,j=e.length;i<j;i++){c=e[i].split("=");var k=c.shift().toLowerCase();k&&c.length&&(f[k.trim()]=c.shift().trim().toLowerCase())}return!!(h&&f["maximum-scale"]&&parseFloat(f["maximum-scale"])<h)||!(!h&&"no"===f["user-scalable"])&&!(f["maximum-scale"]&&parseFloat(f["maximum-scale"])<g)},options:{scaleMinimum:2}},{id:"header-present",evaluate:function(a,b){return!!a.querySelector('h1, h2, h3, h4, h5, h6, [role="heading"]')}},{id:"heading-order",evaluate:function(a,b){var c=a.getAttribute("aria-level");if(null!==c)return this.data(parseInt(c,10)),!0;var d=a.tagName.match(/H(\d)/);return!d||(this.data(parseInt(d[1],10)),!0)},after:function(a,b){if(a.length<2)return a;for(var c=a[0].data,d=1;d<a.length;d++)a[d].result&&a[d].data>c+1&&(a[d].result=!1),c=a[d].data;return a}},{id:"href-no-hash",evaluate:function(a,b){return"#"!==a.getAttribute("href")}},{id:"internal-link-present",evaluate:function(a,b){return!!a.querySelector('a[href^="#"]')}},{id:"landmark",evaluate:function(a,b){return a.getElementsByTagName("main").length>0||!!a.querySelector('[role="main"]')}},{id:"meta-refresh",evaluate:function(a,b){var c=a.getAttribute("content")||"",d=c.split(/[;,]/);return""===c||"0"===d[0]}},{id:"p-as-heading",evaluate:function(a,b){function c(a){for(var b=a,c=a.textContent.trim(),d=c;d===c&&void 0!==b;){var e=-1;if(a=b,0===a.children.length)return a;do{e++,d=a.children[e].textContent.trim()}while(""===d&&e+1<a.children.length);b=a.children[e]}return a}function d(a){switch(a){case"lighter":return 100;case"normal":return 400;case"bold":return 700;case"bolder":return 900}return a=parseInt(a),isNaN(a)?400:a}function e(a){var b=window.getComputedStyle(c(a));return{fontWeight:d(b.getPropertyValue("font-weight")),fontSize:parseInt(b.getPropertyValue("font-size")),isItalic:"italic"===b.getPropertyValue("font-style")}}function f(a,b,c){return c.reduce(function(c,d){return c||(!d.size||a.fontSize/d.size>b.fontSize)&&(!d.weight||a.fontWeight-d.weight>b.fontWeight)&&(!d.italic||a.isItalic&&!b.isItalic)},!1)}var g=Array.from(a.parentNode.children),h=g.indexOf(a);b=b||{};var i=b.margins||[],j=g.slice(h+1).find(function(a){return"P"===a.nodeName.toUpperCase()}),k=g.slice(0,h).reverse().find(function(a){return"P"===a.nodeName.toUpperCase()}),l=e(a),m=j?e(j):null,n=k?e(k):null;if(!m||!f(l,m,i))return!0;var o=axe.commons.dom.findUp(a,"blockquote");return!!(o&&"BLOCKQUOTE"===o.nodeName.toUpperCase()||n&&!f(l,n,i))&&void 0},options:{margins:[{weight:150,italic:!0},{weight:150,size:1.15},{italic:!0,size:1.15},{size:1.4}]}},{id:"region",evaluate:function(a,b){function c(a){return h&&axe.commons.dom.isFocusable(axe.commons.dom.getElementByReference(h,"href"))&&h===a}function d(a){var b=a.getAttribute("role");return b&&-1!==g.indexOf(b)}function e(a){return d(a)?null:c(a)?f(a):axe.commons.dom.isVisible(a,!0)&&(axe.commons.text.visible(a,!0,!0)||axe.commons.dom.isVisualContent(a))?a:f(a)}function f(a){var b=axe.commons.utils.toArray(a.children);return 0===b.length?[]:b.map(e).filter(function(a){return null!==a}).reduce(function(a,b){return a.concat(b)},[])}var g=axe.commons.aria.getRolesByType("landmark"),h=a.querySelector("a[href]"),i=f(a);return this.relatedNodes(i),!i.length},after:function(a,b){return[a[0]]}},{id:"skip-link",evaluate:function(a,b){return axe.commons.dom.isFocusable(axe.commons.dom.getElementByReference(a,"href"))},after:function(a,b){return[a[0]]}},{id:"unique-frame-title",evaluate:function(a,b){var c=axe.commons.text.sanitize(a.title).trim().toLowerCase();return this.data(c),!0},after:function(a,b){var c={};return a.forEach(function(a){c[a.data]=void 0!==c[a.data]?++c[a.data]:0}),a.forEach(function(a){a.result=!!c[a.data]}),a}},{id:"aria-label",evaluate:function(a,b){var c=a.getAttribute("aria-label");return!!(c?axe.commons.text.sanitize(c).trim():"")}},{id:"aria-labelledby",evaluate:function(a,b){return(0,axe.commons.dom.idrefs)(a,"aria-labelledby").some(function(a){return a&&axe.commons.text.accessibleText(a,!0)})}},{id:"button-has-visible-text",evaluate:function(a,b){var c=a.nodeName.toUpperCase(),d=a.getAttribute("role"),e=void 0;return("BUTTON"===c||"button"===d&&"INPUT"!==c)&&(e=axe.commons.text.accessibleText(a),this.data(e),!!e)}},{id:"doc-has-title",evaluate:function(a,b){var c=document.title;return!!(c?axe.commons.text.sanitize(c).trim():"")}},{id:"duplicate-id",evaluate:function(a,b){if(!a.id.trim())return!0;for(var c=document.querySelectorAll('[id="'+axe.commons.utils.escapeSelector(a.id)+'"]'),d=[],e=0;e<c.length;e++)c[e]!==a&&d.push(c[e]);return d.length&&this.relatedNodes(d),this.data(a.getAttribute("id")),c.length<=1},after:function(a,b){var c=[];return a.filter(function(a){return-1===c.indexOf(a.data)&&(c.push(a.data),!0)})}},{id:"exists",evaluate:function(a,b){return!0}},{id:"has-alt",evaluate:function(a,b){var c=a.nodeName.toLowerCase();return a.hasAttribute("alt")&&("img"===c||"input"===c||"area"===c)}},{id:"has-visible-text",evaluate:function(a,b){return axe.commons.text.accessibleText(a).length>0}},{id:"is-on-screen",evaluate:function(a,b){return axe.commons.dom.isVisible(a,!1)&&!axe.commons.dom.isOffscreen(a)}},{id:"non-empty-alt",evaluate:function(a,b){var c=a.getAttribute("alt");return!!(c?axe.commons.text.sanitize(c).trim():"")}},{id:"non-empty-if-present",evaluate:function(a,b){var c=a.nodeName.toUpperCase(),d=(a.getAttribute("type")||"").toLowerCase(),e=a.getAttribute("value");return this.data(e),"INPUT"===c&&-1!==["submit","reset"].indexOf(d)&&null===e}},{id:"non-empty-title",evaluate:function(a,b){var c=a.getAttribute("title");return!!(c?axe.commons.text.sanitize(c).trim():"")}},{id:"non-empty-value",evaluate:function(a,b){var c=a.getAttribute("value");return!!(c?axe.commons.text.sanitize(c).trim():"")}},{id:"role-none",evaluate:function(a,b){return"none"===a.getAttribute("role")}},{id:"role-presentation",evaluate:function(a,b){return"presentation"===a.getAttribute("role")}},{id:"caption-faked",evaluate:function(a,b){var c=axe.commons.table.toGrid(a),d=c[0];return c.length<=1||d.length<=1||a.rows.length<=1||d.reduce(function(a,b,c){return a||b!==d[c+1]&&void 0!==d[c+1]},!1)}},{id:"has-caption",evaluate:function(a,b){return!!a.caption}},{id:"has-summary",evaluate:function(a,b){ +return!!a.summary}},{id:"has-th",evaluate:function(a,b){for(var c,d,e=[],f=0,g=a.rows.length;f<g;f++){c=a.rows[f];for(var h=0,i=c.cells.length;h<i;h++)d=c.cells[h],"TH"!==d.nodeName.toUpperCase()&&-1===["rowheader","columnheader"].indexOf(d.getAttribute("role"))||e.push(d)}return!!e.length&&(this.relatedNodes(e),!0)}},{id:"html5-scope",evaluate:function(a,b){return!axe.commons.dom.isHTML5(document)||"TH"===a.nodeName.toUpperCase()}},{id:"same-caption-summary",evaluate:function(a,b){return!(!a.summary||!a.caption)&&a.summary===axe.commons.text.accessibleText(a.caption)}},{id:"scope-value",evaluate:function(a,b){b=b||{};var c=a.getAttribute("scope").toLowerCase();return-1!==(["row","col","rowgroup","colgroup"]||b.values).indexOf(c)}},{id:"td-has-header",evaluate:function(a,b){var c=axe.commons.table,d=[];return c.getAllCells(a).forEach(function(a){if(axe.commons.dom.hasContent(a)&&c.isDataCell(a)&&!axe.commons.aria.label(a)){var b=c.getHeaders(a);(b=b.reduce(function(a,b){return a||null!==b&&!!axe.commons.dom.hasContent(b)},!1))||d.push(a)}}),!d.length||(this.relatedNodes(d),!1)}},{id:"td-headers-attr",evaluate:function(a,b){for(var c=[],d=0,e=a.rows.length;d<e;d++)for(var f=a.rows[d],g=0,h=f.cells.length;g<h;g++)c.push(f.cells[g]);var i=c.reduce(function(a,b){return b.id&&a.push(b.id),a},[]),j=c.reduce(function(a,b){var c,d,e=(b.getAttribute("headers")||"").split(/\s/).reduce(function(a,b){return b=b.trim(),b&&a.push(b),a},[]);return 0!==e.length&&(b.id&&(c=-1!==e.indexOf(b.id.trim())),d=e.reduce(function(a,b){return a||-1===i.indexOf(b)},!1),(c||d)&&a.push(b)),a},[]);return!(j.length>0)||(this.relatedNodes(j),!1)}},{id:"th-has-data-cells",evaluate:function(a,b){var c=axe.commons.table,d=c.getAllCells(a),e=this,f=[];d.forEach(function(a){var b=a.getAttribute("headers");b&&(f=f.concat(b.split(/\s+/)));var c=a.getAttribute("aria-labelledby");c&&(f=f.concat(c.split(/\s+/)))});var g=d.filter(function(a){return""!==axe.commons.text.sanitize(a.textContent)&&("TH"===a.nodeName.toUpperCase()||-1!==["rowheader","columnheader"].indexOf(a.getAttribute("role")))}),h=c.toGrid(a);return!!g.reduce(function(a,b){if(b.id&&-1!==f.indexOf(b.id))return!!a||a;var d=!1,g=c.getCellPosition(b,h);return c.isColumnHeader(b)&&(d=c.traverse("down",g,h).reduce(function(a,b){return a||axe.commons.dom.hasContent(b)&&!c.isColumnHeader(b)},!1)),!d&&c.isRowHeader(b)&&(d=c.traverse("right",g,h).reduce(function(a,b){return a||axe.commons.dom.hasContent(b)&&!c.isRowHeader(b)},!1)),d||e.relatedNodes(b),a&&d},!0)||void 0}},{id:"hidden-content",evaluate:function(a,b){var c=window.getComputedStyle(a);if(!["SCRIPT","HEAD","TITLE","NOSCRIPT","STYLE","TEMPLATE"].includes(a.tagName.toUpperCase())&&axe.commons.dom.hasContent(a)){if("none"===c.getPropertyValue("display"))return;if("hidden"===c.getPropertyValue("visibility")){if(a.parentNode)var d=window.getComputedStyle(a.parentNode);if(!d||"hidden"!==d.getPropertyValue("visibility"))return}}return!0}}],commons:function(){function a(a){return a.getPropertyValue("font-family").split(/[,;]/g).map(function(a){return a.trim().toLowerCase()})}function b(b,c){var d=window.getComputedStyle(b);if("none"!==d.getPropertyValue("background-image"))return!0;if(["border-bottom","border-top","outline"].reduce(function(a,b){var c=new y.Color;return c.parseRgbString(d.getPropertyValue(b+"-color")),a||"none"!==d.getPropertyValue(b+"-style")&&parseFloat(d.getPropertyValue(b+"-width"))>0&&0!==c.alpha},!1))return!0;var e=window.getComputedStyle(c);if(a(d)[0]!==a(e)[0])return!0;var f=["text-decoration-line","text-decoration-style","font-weight","font-style","font-size"].reduce(function(a,b){return a||d.getPropertyValue(b)!==e.getPropertyValue(b)},!1),g=d.getPropertyValue("text-decoration");return g.split(" ").length<3&&(f=f||g!==e.getPropertyValue("text-decoration")),f}function c(a,b){var c=a.nodeName.toUpperCase();if(C.includes(c))return axe.commons.color.incompleteData.set("bgColor","imgNode"),!0;b=b||window.getComputedStyle(a);var d=b.getPropertyValue("background-image"),e="none"!==d;if(e){var f=/gradient/.test(d);axe.commons.color.incompleteData.set("bgColor",f?"bgGradient":"bgImage")}return e}function d(a,b){b=b||window.getComputedStyle(a);var c=new y.Color;if(c.parseRgbString(b.getPropertyValue("background-color")),0!==c.alpha){var d=b.getPropertyValue("opacity");c.alpha=c.alpha*d}return c}function e(a,b){var c=a.getClientRects()[0],d=document.elementsFromPoint(c.left,c.top);if(d)for(var e=0;e<d.length;e++)if(d[e]!==a&&d[e]===b)return!0;return!1}function f(a,b,c){var f=0;if(a>0)for(var g=a-1;g>=0;g--){var h=b[g],i=window.getComputedStyle(h),j=d(h,i);j.alpha&&e(c,h)?f+=j.alpha:b.splice(g,1)}return f}function g(a,b,c){var d=a!==b&&!z.visuallyContains(a,b)&&0!==c.alpha;return d&&axe.commons.color.incompleteData.set("bgColor","elmPartiallyObscured"),d}function h(a,b){var c={TD:"TR",INPUT:"LABEL"},d=a.map(function(a){return a.tagName}),e=a;for(var f in c)if(c.hasOwnProperty(f)){if(b.tagName===f){var g=axe.commons.dom.findUp(b,c[f]);if(g&&-1===a.indexOf(g)){var h=axe.commons.dom.visuallyOverlaps(b.getBoundingClientRect(),g);h&&e.splice(a.indexOf(b)+1,0,g)}}b.tagName===c[f]&&-1===d.indexOf(b.tagName)&&e.splice(d.indexOf(f)+1,0,b)}return e}function i(a){var b=a.indexOf(document.body),e=a;return b>1&&!c(document.documentElement)&&0===d(document.documentElement).alpha&&(e.splice(b,1),e.splice(a.indexOf(document.documentElement),1),e.push(document.body)),e}function j(a,b){"use strict";var c=b(a);for(a=a.firstChild;a;)!1!==c&&j(a,b),a=a.nextSibling}function k(a){"use strict";var b=window.getComputedStyle(a).getPropertyValue("display");return-1!==D.indexOf(b)||"table-"===b.substr(0,6)}function l(a){"use strict";var b=a.match(/rect\s*\(([0-9]+)px,?\s*([0-9]+)px,?\s*([0-9]+)px,?\s*([0-9]+)px\s*\)/);return!(!b||5!==b.length)&&(b[3]-b[1]<=0&&b[2]-b[4]<=0)}function m(a){var b=null;return a.id&&(b=document.querySelector('label[for="'+axe.utils.escapeSelector(a.id)+'"]'))?b:b=z.findUp(a,"label")}function n(a){return-1!==["button","reset","submit"].indexOf(a.type)}function o(a){var b=a.nodeName.toUpperCase();return"TEXTAREA"===b||"SELECT"===b||"INPUT"===b&&"hidden"!==a.type.toLowerCase()}function p(a){return-1!==["BUTTON","SUMMARY","A"].indexOf(a.nodeName.toUpperCase())}function q(a){return-1!==["TABLE","FIGURE"].indexOf(a.nodeName.toUpperCase())}function r(a){var b=a.nodeName.toUpperCase();if("INPUT"===b)return!a.hasAttribute("type")||-1!==G.indexOf(a.getAttribute("type").toLowerCase())&&a.value?a.value:"";if("SELECT"===b){var c=a.options;if(c&&c.length){for(var d="",e=0;e<c.length;e++)c[e].selected&&(d+=" "+c[e].text);return B.sanitize(d)}return""}return"TEXTAREA"===b&&a.value?a.value:""}function s(a,b){var c=a.querySelector(b.toLowerCase());return c?B.accessibleText(c):""}function t(a){if(!a)return!1;switch(a.nodeName.toUpperCase()){case"SELECT":case"TEXTAREA":return!0;case"INPUT":return!a.hasAttribute("type")||-1!==G.indexOf(a.getAttribute("type").toLowerCase());default:return!1}}function u(a){var b=a.nodeName.toUpperCase();return"INPUT"===b&&"image"===a.type.toLowerCase()||-1!==["IMG","APPLET","AREA"].indexOf(b)}function v(a){return!!B.sanitize(a)}var commons={},w=commons.aria={},x=w._lut={};x.attributes={"aria-activedescendant":{type:"idref"},"aria-atomic":{type:"boolean",values:["true","false"]},"aria-autocomplete":{type:"nmtoken",values:["inline","list","both","none"]},"aria-busy":{type:"boolean",values:["true","false"]},"aria-checked":{type:"nmtoken",values:["true","false","mixed","undefined"]},"aria-colcount":{type:"int"},"aria-colindex":{type:"int"},"aria-colspan":{type:"int"},"aria-controls":{type:"idrefs"},"aria-current":{type:"nmtoken",values:["page","step","location","date","time","true","false"]},"aria-describedby":{type:"idrefs"},"aria-disabled":{type:"boolean",values:["true","false"]},"aria-dropeffect":{type:"nmtokens",values:["copy","move","reference","execute","popup","none"]},"aria-expanded":{type:"nmtoken",values:["true","false","undefined"]},"aria-flowto":{type:"idrefs"},"aria-grabbed":{type:"nmtoken",values:["true","false","undefined"]},"aria-haspopup":{type:"boolean",values:["true","false"]},"aria-hidden":{type:"boolean",values:["true","false"]},"aria-invalid":{type:"nmtoken",values:["true","false","spelling","grammar"]},"aria-label":{type:"string"},"aria-labelledby":{type:"idrefs"},"aria-level":{type:"int"},"aria-live":{type:"nmtoken",values:["off","polite","assertive"]},"aria-multiline":{type:"boolean",values:["true","false"]},"aria-multiselectable":{type:"boolean",values:["true","false"]},"aria-orientation":{type:"nmtoken",values:["horizontal","vertical"]},"aria-owns":{type:"idrefs"},"aria-posinset":{type:"int"},"aria-pressed":{type:"nmtoken",values:["true","false","mixed","undefined"]},"aria-readonly":{type:"boolean",values:["true","false"]},"aria-relevant":{type:"nmtokens",values:["additions","removals","text","all"]},"aria-required":{type:"boolean",values:["true","false"]},"aria-rowcount":{type:"int"},"aria-rowindex":{type:"int"},"aria-rowspan":{type:"int"},"aria-selected":{type:"nmtoken",values:["true","false","undefined"]},"aria-setsize":{type:"int"},"aria-sort":{type:"nmtoken",values:["ascending","descending","other","none"]},"aria-valuemax":{type:"decimal"},"aria-valuemin":{type:"decimal"},"aria-valuenow":{type:"decimal"},"aria-valuetext":{type:"string"}},x.globalAttributes=["aria-atomic","aria-busy","aria-controls","aria-current","aria-describedby","aria-disabled","aria-dropeffect","aria-flowto","aria-grabbed","aria-haspopup","aria-hidden","aria-invalid","aria-label","aria-labelledby","aria-live","aria-owns","aria-relevant"],x.role={alert:{type:"widget",attributes:{allowed:["aria-expanded"]},owned:null,nameFrom:["author"],context:null},alertdialog:{type:"widget",attributes:{allowed:["aria-expanded"]},owned:null,nameFrom:["author"],context:null},application:{type:"landmark",attributes:{allowed:["aria-expanded"]},owned:null,nameFrom:["author"],context:null},article:{type:"structure",attributes:{allowed:["aria-expanded"]},owned:null,nameFrom:["author"],context:null,implicit:["article"]},banner:{type:"landmark",attributes:{allowed:["aria-expanded"]},owned:null,nameFrom:["author"],context:null,implicit:["header"]},button:{type:"widget",attributes:{allowed:["aria-expanded","aria-pressed"]},owned:null,nameFrom:["author","contents"],context:null,implicit:["button",'input[type="button"]','input[type="image"]','input[type="reset"]','input[type="submit"]',"summary"]},cell:{type:"structure",attributes:{allowed:["aria-colindex","aria-colspan","aria-rowindex","aria-rowspan"]},owned:null,nameFrom:["author","contents"],context:["row"],implicit:["td","th"]},checkbox:{type:"widget",attributes:{required:["aria-checked"]},owned:null,nameFrom:["author","contents"],context:null,implicit:['input[type="checkbox"]']},columnheader:{type:"structure",attributes:{allowed:["aria-expanded","aria-sort","aria-readonly","aria-selected","aria-required"]},owned:null,nameFrom:["author","contents"],context:["row"],implicit:["th"]},combobox:{type:"composite",attributes:{required:["aria-expanded"],allowed:["aria-autocomplete","aria-required","aria-activedescendant"]},owned:{all:["listbox","textbox"]},nameFrom:["author"],context:null},command:{nameFrom:["author"],type:"abstract"},complementary:{type:"landmark",attributes:{allowed:["aria-expanded"]},owned:null,nameFrom:["author"],context:null,implicit:["aside"]},composite:{nameFrom:["author"],type:"abstract"},contentinfo:{type:"landmark",attributes:{allowed:["aria-expanded"]},owned:null,nameFrom:["author"],context:null,implicit:["footer"]},definition:{type:"structure",attributes:{allowed:["aria-expanded"]},owned:null,nameFrom:["author"],context:null,implicit:["dd"]},dialog:{type:"widget",attributes:{allowed:["aria-expanded"]},owned:null,nameFrom:["author"],context:null,implicit:["dialog"]},directory:{type:"structure",attributes:{allowed:["aria-expanded"]},owned:null,nameFrom:["author","contents"],context:null},document:{type:"structure",attributes:{allowed:["aria-expanded"]},owned:null,nameFrom:["author"],context:null,implicit:["body"]},form:{type:"landmark",attributes:{allowed:["aria-expanded"]},owned:null,nameFrom:["author"],context:null,implicit:["form"]},grid:{type:"composite",attributes:{allowed:["aria-level","aria-multiselectable","aria-readonly","aria-activedescendant","aria-expanded"]},owned:{one:["rowgroup","row"]},nameFrom:["author"],context:null,implicit:["table"]},gridcell:{type:"widget",attributes:{allowed:["aria-selected","aria-readonly","aria-expanded","aria-required"]},owned:null,nameFrom:["author","contents"],context:["row"],implicit:["td","th"]},group:{type:"structure",attributes:{allowed:["aria-activedescendant","aria-expanded"]},owned:null,nameFrom:["author"],context:null,implicit:["details","optgroup"]},heading:{type:"structure",attributes:{allowed:["aria-level","aria-expanded"]},owned:null,nameFrom:["author","contents"],context:null,implicit:["h1","h2","h3","h4","h5","h6"]},img:{type:"structure",attributes:{allowed:["aria-expanded"]},owned:null,nameFrom:["author"],context:null,implicit:["img"]},input:{nameFrom:["author"],type:"abstract"},landmark:{nameFrom:["author"],type:"abstract"},link:{type:"widget",attributes:{allowed:["aria-expanded"]},owned:null,nameFrom:["author","contents"],context:null,implicit:["a[href]"]},list:{type:"structure",attributes:{allowed:["aria-expanded"]},owned:{all:["listitem"]},nameFrom:["author"],context:null,implicit:["ol","ul","dl"]},listbox:{type:"composite",attributes:{allowed:["aria-activedescendant","aria-multiselectable","aria-required","aria-expanded"]},owned:{all:["option"]},nameFrom:["author"],context:null,implicit:["select"]},listitem:{type:"structure",attributes:{allowed:["aria-level","aria-posinset","aria-setsize","aria-expanded"]},owned:null,nameFrom:["author","contents"],context:["list"],implicit:["li","dt"]},log:{type:"widget",attributes:{allowed:["aria-expanded"]},owned:null,nameFrom:["author"],context:null},main:{type:"landmark",attributes:{allowed:["aria-expanded"]},owned:null,nameFrom:["author"],context:null,implicit:["main"]},marquee:{type:"widget",attributes:{allowed:["aria-expanded"]},owned:null,nameFrom:["author"],context:null},math:{type:"structure",attributes:{allowed:["aria-expanded"]},owned:null,nameFrom:["author"],context:null,implicit:["math"]},menu:{type:"composite",attributes:{allowed:["aria-activedescendant","aria-expanded"]},owned:{one:["menuitem","menuitemradio","menuitemcheckbox"]},nameFrom:["author"],context:null,implicit:['menu[type="context"]']},menubar:{type:"composite",attributes:{allowed:["aria-activedescendant","aria-expanded"]},owned:null,nameFrom:["author"],context:null},menuitem:{type:"widget",attributes:null,owned:null,nameFrom:["author","contents"],context:["menu","menubar"],implicit:['menuitem[type="command"]']},menuitemcheckbox:{type:"widget",attributes:{required:["aria-checked"]},owned:null,nameFrom:["author","contents"],context:["menu","menubar"],implicit:['menuitem[type="checkbox"]']},menuitemradio:{type:"widget",attributes:{allowed:["aria-selected","aria-posinset","aria-setsize"],required:["aria-checked"]},owned:null,nameFrom:["author","contents"],context:["menu","menubar"],implicit:['menuitem[type="radio"]']},navigation:{type:"landmark",attributes:{allowed:["aria-expanded"]},owned:null,nameFrom:["author"],context:null,implicit:["nav"]},none:{type:"structure",attributes:null,owned:null,nameFrom:["author"],context:null},note:{type:"structure",attributes:{allowed:["aria-expanded"]},owned:null,nameFrom:["author"],context:null},option:{type:"widget",attributes:{allowed:["aria-selected","aria-posinset","aria-setsize","aria-checked"]},owned:null,nameFrom:["author","contents"],context:["listbox"],implicit:["option"]},presentation:{type:"structure",attributes:null,owned:null,nameFrom:["author"],context:null},progressbar:{type:"widget",attributes:{allowed:["aria-valuetext","aria-valuenow","aria-valuemax","aria-valuemin"]},owned:null,nameFrom:["author"],context:null,implicit:["progress"]},radio:{type:"widget",attributes:{allowed:["aria-selected","aria-posinset","aria-setsize"],required:["aria-checked"]},owned:null,nameFrom:["author","contents"],context:null,implicit:['input[type="radio"]']},radiogroup:{type:"composite",attributes:{allowed:["aria-activedescendant","aria-required","aria-expanded"]},owned:{all:["radio"]},nameFrom:["author"],context:null},range:{nameFrom:["author"],type:"abstract"},region:{type:"structure",attributes:{allowed:["aria-expanded"]},owned:null,nameFrom:["author"],context:null,implicit:["section"]},roletype:{type:"abstract"},row:{type:"structure",attributes:{allowed:["aria-level","aria-selected","aria-activedescendant","aria-expanded"]},owned:{one:["cell","columnheader","rowheader","gridcell"]},nameFrom:["author","contents"],context:["rowgroup","grid","treegrid","table"],implicit:["tr"]},rowgroup:{type:"structure",attributes:{allowed:["aria-activedescendant","aria-expanded"]},owned:{all:["row"]},nameFrom:["author","contents"],context:["grid","table"],implicit:["tbody","thead","tfoot"]},rowheader:{type:"structure",attributes:{allowed:["aria-sort","aria-required","aria-readonly","aria-expanded","aria-selected"]},owned:null,nameFrom:["author","contents"],context:["row"],implicit:["th"]},scrollbar:{type:"widget",attributes:{required:["aria-controls","aria-orientation","aria-valuenow","aria-valuemax","aria-valuemin"],allowed:["aria-valuetext"]},owned:null,nameFrom:["author"],context:null},search:{type:"landmark",attributes:{allowed:["aria-expanded"]},owned:null,nameFrom:["author"],context:null},searchbox:{type:"widget",attributes:{allowed:["aria-activedescendant","aria-autocomplete","aria-multiline","aria-readonly","aria-required"]},owned:null,nameFrom:["author"],context:null,implicit:['input[type="search"]']},section:{nameFrom:["author","contents"],type:"abstract"},sectionhead:{nameFrom:["author","contents"],type:"abstract"},select:{nameFrom:["author"],type:"abstract"},separator:{type:"structure",attributes:{allowed:["aria-expanded","aria-orientation"]},owned:null,nameFrom:["author"],context:null,implicit:["hr"]},slider:{type:"widget",attributes:{allowed:["aria-valuetext","aria-orientation"],required:["aria-valuenow","aria-valuemax","aria-valuemin"]},owned:null,nameFrom:["author"],context:null,implicit:['input[type="range"]']},spinbutton:{type:"widget",attributes:{allowed:["aria-valuetext","aria-required"],required:["aria-valuenow","aria-valuemax","aria-valuemin"]},owned:null,nameFrom:["author"],context:null,implicit:['input[type="number"]']},status:{type:"widget",attributes:{allowed:["aria-expanded"]},owned:null,nameFrom:["author"],context:null,implicit:["output"]},structure:{type:"abstract"},switch:{type:"widget",attributes:{required:["aria-checked"]},owned:null,nameFrom:["author","contents"],context:null},tab:{type:"widget",attributes:{allowed:["aria-selected","aria-expanded"]},owned:null,nameFrom:["author","contents"],context:["tablist"]},table:{type:"structure",attributes:{allowed:["aria-colcount","aria-rowcount"]},owned:{one:["rowgroup","row"]},nameFrom:["author"],context:null,implicit:["table"]},tablist:{type:"composite",attributes:{allowed:["aria-activedescendant","aria-expanded","aria-level","aria-multiselectable"]},owned:{all:["tab"]},nameFrom:["author"],context:null},tabpanel:{type:"widget",attributes:{allowed:["aria-expanded"]},owned:null,nameFrom:["author"],context:null},text:{type:"structure",owned:null,nameFrom:["author","contents"],context:null},textbox:{type:"widget",attributes:{allowed:["aria-activedescendant","aria-autocomplete","aria-multiline","aria-readonly","aria-required"]},owned:null,nameFrom:["author"],context:null,implicit:['input[type="text"]','input[type="email"]','input[type="password"]','input[type="tel"]','input[type="url"]',"input:not([type])","textarea"]},timer:{type:"widget",attributes:{allowed:["aria-expanded"]},owned:null,nameFrom:["author"],context:null},toolbar:{type:"structure",attributes:{allowed:["aria-activedescendant","aria-expanded"]},owned:null,nameFrom:["author"],context:null,implicit:['menu[type="toolbar"]']},tooltip:{type:"widget",attributes:{allowed:["aria-expanded"]},owned:null,nameFrom:["author","contents"],context:null},tree:{type:"composite",attributes:{allowed:["aria-activedescendant","aria-multiselectable","aria-required","aria-expanded"]},owned:{all:["treeitem"]},nameFrom:["author"],context:null},treegrid:{type:"composite",attributes:{allowed:["aria-activedescendant","aria-expanded","aria-level","aria-multiselectable","aria-readonly","aria-required"]},owned:{all:["treeitem"]},nameFrom:["author"],context:null},treeitem:{type:"widget",attributes:{allowed:["aria-checked","aria-selected","aria-expanded","aria-level","aria-posinset","aria-setsize"]},owned:null,nameFrom:["author","contents"],context:["treegrid","tree"]},widget:{type:"abstract"},window:{nameFrom:["author"],type:"abstract"}};var y={};commons.color=y;var z=commons.dom={},A=commons.table={},B=commons.text={};commons.utils=axe.utils;w.requiredAttr=function(a){"use strict";var b=x.role[a];return b&&b.attributes&&b.attributes.required||[]},w.allowedAttr=function(a){"use strict";var b=x.role[a],c=b&&b.attributes&&b.attributes.allowed||[],d=b&&b.attributes&&b.attributes.required||[];return c.concat(x.globalAttributes).concat(d)},w.validateAttr=function(a){"use strict";return!!x.attributes[a]},w.validateAttrValue=function(a,b){"use strict";var c,d,e=a.getAttribute(b),f=x.attributes[b],g=z.getRootNode(a);if(!f)return!0;switch(f.type){case"boolean":case"nmtoken":return"string"==typeof e&&-1!==f.values.indexOf(e.toLowerCase());case"nmtokens":return d=axe.utils.tokenList(e),d.reduce(function(a,b){return a&&-1!==f.values.indexOf(b)},0!==d.length);case"idref":return!(!e||!g.getElementById(e));case"idrefs":return d=axe.utils.tokenList(e),d.reduce(function(a,b){return!(!a||!g.getElementById(b))},0!==d.length);case"string":return!0;case"decimal":return!(!(c=e.match(/^[-+]?([0-9]*)\.?([0-9]*)$/))||!c[1]&&!c[2]);case"int":return/^[-+]?[0-9]+$/.test(e)}},w.label=function(a){var b,c;return a.actualNode.getAttribute("aria-labelledby")&&(b=z.idrefs(a.actualNode,"aria-labelledby"),c=b.map(function(a){var b=axe.utils.getNodeFromTree(axe._tree[0],a);return b?B.visible(b,!0):""}).join(" ").trim())?c:(c=a.actualNode.getAttribute("aria-label"),c&&(c=B.sanitize(c).trim())?c:null)},w.isValidRole=function(a){"use strict";return!!x.role[a]},w.getRolesWithNameFromContents=function(){return Object.keys(x.role).filter(function(a){return x.role[a].nameFrom&&-1!==x.role[a].nameFrom.indexOf("contents")})},w.getRolesByType=function(a){return Object.keys(x.role).filter(function(b){return x.role[b].type===a})},w.getRoleType=function(a){var b=x.role[a];return b&&b.type||null},w.requiredOwned=function(a){"use strict";var b=null,c=x.role[a];return c&&(b=axe.utils.clone(c.owned)),b},w.requiredContext=function(a){"use strict";var b=null,c=x.role[a];return c&&(b=axe.utils.clone(c.context)),b},w.implicitNodes=function(a){"use strict";var b=null,c=x.role[a];return c&&c.implicit&&(b=axe.utils.clone(c.implicit)),b},w.implicitRole=function(a){"use strict";var b=function(b,c){var d=function(b){return axe.utils.matchesSelector(a,b)};return c.implicit&&c.implicit.some(d)&&b.push(c.name),b},c=Object.keys(x.role).map(function(a){var b=x.role[a];return{name:a,implicit:b&&b.implicit}}),d=c.reduce(b,[]);if(!d.length)return null;for(var e=a.attributes,f=[],g=0,h=e.length;g<h;g++){var i=e[g];i.name.match(/^aria-/)&&f.push(i.name)}return function(a,b){var c=function(a){return w.allowedAttr(a).reduce(function(a,c){return a+(b.indexOf(c)>-1?1:0)},0)};return a.map(function(a){return{score:c(a),name:a}}).sort(function(a,b){return b.score-a.score}).map(function(a){return a.name})}(d,f).shift()},y.Color=function(a,b,c,d){this.red=a,this.green=b,this.blue=c,this.alpha=d,this.toHexString=function(){var a=Math.round(this.red).toString(16),b=Math.round(this.green).toString(16),c=Math.round(this.blue).toString(16);return"#"+(this.red>15.5?a:"0"+a)+(this.green>15.5?b:"0"+b)+(this.blue>15.5?c:"0"+c)};var e=/^rgb\((\d+), (\d+), (\d+)\)$/,f=/^rgba\((\d+), (\d+), (\d+), (\d*(\.\d+)?)\)/;this.parseRgbString=function(a){if("transparent"===a)return this.red=0,this.green=0,this.blue=0,void(this.alpha=0);var b=a.match(e);return b?(this.red=parseInt(b[1],10),this.green=parseInt(b[2],10),this.blue=parseInt(b[3],10),void(this.alpha=1)):(b=a.match(f),b?(this.red=parseInt(b[1],10),this.green=parseInt(b[2],10),this.blue=parseInt(b[3],10),void(this.alpha=parseFloat(b[4]))):void 0)},this.getRelativeLuminance=function(){var a=this.red/255,b=this.green/255,c=this.blue/255;return.2126*(a<=.03928?a/12.92:Math.pow((a+.055)/1.055,2.4))+.7152*(b<=.03928?b/12.92:Math.pow((b+.055)/1.055,2.4))+.0722*(c<=.03928?c/12.92:Math.pow((c+.055)/1.055,2.4))}},y.flattenColors=function(a,b){var c=a.alpha,d=(1-c)*b.red+c*a.red,e=(1-c)*b.green+c*a.green,f=(1-c)*b.blue+c*a.blue,g=a.alpha+b.alpha*(1-a.alpha);return new y.Color(d,e,f,g)},y.getContrast=function(a,b){if(!b||!a)return null;b.alpha<1&&(b=y.flattenColors(b,a));var c=a.getRelativeLuminance(),d=b.getRelativeLuminance();return(Math.max(d,c)+.05)/(Math.min(d,c)+.05)},y.hasValidContrastRatio=function(a,b,c,d){var e=y.getContrast(a,b),f=d&&Math.ceil(72*c)/96<14||!d&&Math.ceil(72*c)/96<18;return{isValid:f&&e>=4.5||!f&&e>=3,contrastRatio:e}},y.elementIsDistinct=b;var C=["IMG","CANVAS","OBJECT","IFRAME","VIDEO","SVG"];y.getBackgroundStack=function(a){var b=a.getBoundingClientRect(),c=void 0,d=void 0;if(!(b.left>window.innerWidth||b.top>window.innerHeight)){c=Math.min(Math.ceil(b.left+b.width/2),window.innerWidth-1),d=Math.min(Math.ceil(b.top+b.height/2),window.innerHeight-1);var e=document.elementsFromPoint(c,d);e=h(e,a),e=z.reduceToElementsBelowFloating(e,a),e=i(e);var g=e.indexOf(a);return f(g,e,a)>=.99?(axe.commons.color.incompleteData.set("bgColor","bgOverlap"),null):-1!==g?e:null}},y.getBackgroundColor=function(a){var b=arguments.length>1&&void 0!==arguments[1]?arguments[1]:[];!0!==(arguments.length>2&&void 0!==arguments[2]&&arguments[2])&&a.scrollIntoView();var e=[],f=y.getBackgroundStack(a);if((f||[]).some(function(f){var h=window.getComputedStyle(f),i=d(f,h);return g(a,f,i)||c(f,h)?(e=null,b.push(f),!0):0!==i.alpha&&(b.push(f),e.push(i),1===i.alpha)}),null!==e&&null!==f){e.push(new y.Color(255,255,255,1));return e.reduce(y.flattenColors)}return null},z.isOpaque=function(a){var b=window.getComputedStyle(a);return c(a,b)||1===d(a,b).alpha},y.getForegroundColor=function(a,b){var c=window.getComputedStyle(a),d=new y.Color;d.parseRgbString(c.getPropertyValue("color"));var e=c.getPropertyValue("opacity");if(d.alpha=d.alpha*e,1===d.alpha)return d;var f=y.getBackgroundColor(a,[],b);if(null===f){var g=axe.commons.color.incompleteData.get("bgColor");return axe.commons.color.incompleteData.set("fgColor",g),null}return y.flattenColors(d,f)},y.incompleteData=function(){var a={};return{set:function(b,c){if("string"!=typeof b)throw new Error("Incomplete data: key must be a string");return c&&(a[b]=c),a[b]},get:function(b){return a[b]},clear:function(){a={}}}}(),z.reduceToElementsBelowFloating=function(a,b){var c,d,e,f=["fixed","sticky"],g=[],h=!1;for(c=0;c<a.length;++c)d=a[c],d===b&&(h=!0),e=window.getComputedStyle(d),h||-1===f.indexOf(e.position)?g.push(d):g=[];return g},z.findUp=function(a,b){"use strict";var c,d,e=axe.commons.dom.getRootNode(a);if(d=e.querySelectorAll(b),d=axe.utils.toArray(d),e===document&&!d.length)return null;for(c=a.assignedSlot?a.assignedSlot:a.parentNode,11===c.nodeType&&(c=c.host);c&&-1===d.indexOf(c);)if((c=c.assignedSlot?c.assignedSlot:c.parentNode)&&11===c.nodeType&&(c=c.host,e=axe.commons.dom.getRootNode(c),d=e.querySelectorAll(b),d=axe.utils.toArray(d),e===document&&!d.length))return null;return c},z.getElementByReference=function(a,b){"use strict";var c,d=a.getAttribute(b),e=document;if(d&&"#"===d.charAt(0)){if(d=d.substring(1),c=e.getElementById(d))return c;if(c=e.getElementsByName(d),c.length)return c[0]}return null},z.getElementCoordinates=function(a){"use strict";var b=z.getScrollOffset(document),c=b.left,d=b.top,e=a.getBoundingClientRect();return{top:e.top+d,right:e.right+c,bottom:e.bottom+d,left:e.left+c,width:e.right-e.left,height:e.bottom-e.top}},z.getRootNode=function(a){var b=a.getRootNode&&a.getRootNode()||document;return b===a&&(b=document),b},z.getScrollOffset=function(a){"use strict";if(!a.nodeType&&a.document&&(a=a.document),9===a.nodeType){var b=a.documentElement,c=a.body;return{left:b&&b.scrollLeft||c&&c.scrollLeft||0,top:b&&b.scrollTop||c&&c.scrollTop||0}}return{left:a.scrollLeft,top:a.scrollTop}},z.getViewportSize=function(a){"use strict";var b,c=a.document,d=c.documentElement;return a.innerWidth?{width:a.innerWidth,height:a.innerHeight}:d?{width:d.clientWidth,height:d.clientHeight}:(b=c.body,{width:b.clientWidth,height:b.clientHeight})},z.hasContent=function(a){if(a.actualNode.textContent.trim()||w.label(a))return!0;for(var b=axe.utils.querySelectorAll(a,"*"),c=0;c<b.length;c++)if(w.label(b[c])||z.isVisualContent(b[c].actualNode))return!0;return!1},z.idrefs=function(a,b){"use strict";var c,d,e=z.getRootNode(a),f=[],g=a.getAttribute(b);if(g)for(g=axe.utils.tokenList(g),c=0,d=g.length;c<d;c++)f.push(e.getElementById(g[c]));return f},z.isFocusable=function(a){"use strict";if(!a||a.disabled||!z.isVisible(a)&&"AREA"!==a.nodeName.toUpperCase())return!1;switch(a.nodeName.toUpperCase()){case"A":case"AREA":if(a.href)return!0;break;case"INPUT":return"hidden"!==a.type;case"TEXTAREA":case"SELECT":case"DETAILS":case"BUTTON":return!0}var b=a.getAttribute("tabindex");return!(!b||isNaN(parseInt(b,10)))},z.isHTML5=function(a){var b=a.doctype;return null!==b&&("html"===b.name&&!b.publicId&&!b.systemId)};var D=["block","list-item","table","flex","grid","inline-block"];z.isInTextBlock=function(a){"use strict";if(k(a))return!1;for(var b=a.parentNode;1===b.nodeType&&!k(b);)b=b.parentNode;var c="",d="",e=0;return j(b,function(b){if(2===e)return!1;if(3===b.nodeType&&(c+=b.nodeValue),1===b.nodeType){var f=(b.nodeName||"").toUpperCase();if(-1!==["BR","HR"].indexOf(f))0===e?(c="",d=""):e=2;else{if("none"===b.style.display||"hidden"===b.style.overflow||-1===["",null,"none"].indexOf(b.style.float)||-1===["",null,"relative"].indexOf(b.style.position))return!1;if("A"===f&&b.href||"link"===(b.getAttribute("role")||"").toLowerCase())return b===a&&(e=1),d+=b.textContent,!1}}}),c=axe.commons.text.sanitize(c),d=axe.commons.text.sanitize(d),c.length>d.length},z.isNode=function(a){"use strict";return a instanceof Node},z.isOffscreen=function(a){"use strict";var b,c=document.documentElement,d=window.getComputedStyle(a),e=window.getComputedStyle(document.body||c).getPropertyValue("direction"),f=z.getElementCoordinates(a);if(f.bottom<0&&(function(a,b){for(a=a.parentNode;"html"!==a.nodeName.toLowerCase();){if(a.scrollTop&&(b+=a.scrollTop)>=0)return!1;a=a.parentNode}return!0}(a,f.bottom)||"absolute"===d.position))return!0;if(0===f.left&&0===f.right)return!1;if("ltr"===e){if(f.right<=0)return!0}else if(b=Math.max(c.scrollWidth,z.getViewportSize(window).width),f.left>=b)return!0;return!1},z.isVisible=function(a,b,c){"use strict";var d,e,f;return 9===a.nodeType||(11===a.nodeType&&(a=a.host),null!==(d=window.getComputedStyle(a,null))&&(e=a.nodeName.toUpperCase(),!("none"===d.getPropertyValue("display")||"STYLE"===e.toUpperCase()||"SCRIPT"===e.toUpperCase()||!b&&l(d.getPropertyValue("clip"))||!c&&("hidden"===d.getPropertyValue("visibility")||!b&&z.isOffscreen(a))||b&&"true"===a.getAttribute("aria-hidden"))&&(!!(f=a.assignedSlot?a.assignedSlot:a.parentNode)&&z.isVisible(f,b,!0))))};var E=["checkbox","img","radio","range","slider","spinbutton","textbox"];z.isVisualContent=function(a){var b=a.getAttribute("role");if(b)return-1!==E.indexOf(b);switch(a.tagName.toUpperCase()){case"IMG":case"IFRAME":case"OBJECT":case"VIDEO":case"AUDIO":case"CANVAS":case"SVG":case"MATH":case"BUTTON":case"SELECT":case"TEXTAREA":case"KEYGEN":case"PROGRESS":case"METER":return!0;case"INPUT":return"hidden"!==a.type;default:return!1}}, +z.visuallyContains=function(a,b){var c=a.getBoundingClientRect(),d={top:c.top+.01,bottom:c.bottom-.01,left:c.left+.01,right:c.right-.01},e=b.getBoundingClientRect(),f=e.top,g=e.left,h={top:f-b.scrollTop,bottom:f-b.scrollTop+b.scrollHeight,left:g-b.scrollLeft,right:g-b.scrollLeft+b.scrollWidth},i=window.getComputedStyle(b);return"inline"===i.getPropertyValue("display")||!(d.left<h.left&&d.left<e.left||d.top<h.top&&d.top<e.top||d.right>h.right&&d.right>e.right||d.bottom>h.bottom&&d.bottom>e.bottom)&&(!(d.right>e.right||d.bottom>e.bottom)||("scroll"===i.overflow||"auto"===i.overflow||"hidden"===i.overflow||b instanceof HTMLBodyElement||b instanceof HTMLHtmlElement))},z.visuallyOverlaps=function(a,b){var c=b.getBoundingClientRect(),d=c.top,e=c.left,f={top:d-b.scrollTop,bottom:d-b.scrollTop+b.scrollHeight,left:e-b.scrollLeft,right:e-b.scrollLeft+b.scrollWidth};if(a.left>f.right&&a.left>c.right||a.top>f.bottom&&a.top>c.bottom||a.right<f.left&&a.right<c.left||a.bottom<f.top&&a.bottom<c.top)return!1;var g=window.getComputedStyle(b);return!(a.left>c.right||a.top>c.bottom)||("scroll"===g.overflow||"auto"===g.overflow||b instanceof HTMLBodyElement||b instanceof HTMLHtmlElement)},A.getAllCells=function(a){var b,c,d,e,f=[];for(b=0,d=a.rows.length;b<d;b++)for(c=0,e=a.rows[b].cells.length;c<e;c++)f.push(a.rows[b].cells[c]);return f},A.getCellPosition=function(a,b){var c,d;for(b||(b=A.toGrid(z.findUp(a,"table"))),c=0;c<b.length;c++)if(b[c]&&-1!==(d=b[c].indexOf(a)))return{x:d,y:c}},A.getHeaders=function(a){if(a.hasAttribute("headers"))return commons.dom.idrefs(a,"headers");var b=commons.table.toGrid(commons.dom.findUp(a,"table")),c=commons.table.getCellPosition(a,b);return[].concat(A.traverse("left",c,b).filter(function(a){return A.isRowHeader(a)}),A.traverse("up",c,b).filter(function(a){return A.isColumnHeader(a)})).reverse()},A.getScope=function(a){var b=a.getAttribute("scope"),c=a.getAttribute("role");if(a instanceof Element==!1||-1===["TD","TH"].indexOf(a.nodeName.toUpperCase()))throw new TypeError("Expected TD or TH element");if("columnheader"===c)return"col";if("rowheader"===c)return"row";if("col"===b||"row"===b)return b;if("TH"!==a.nodeName.toUpperCase())return!1;var d=A.toGrid(z.findUp(a,"table")),e=A.getCellPosition(a);return d[e.y].reduce(function(a,b){return a&&"TH"===b.nodeName.toUpperCase()},!0)?"col":d.map(function(a){return a[e.x]}).reduce(function(a,b){return a&&"TH"===b.nodeName.toUpperCase()},!0)?"row":"auto"},A.isColumnHeader=function(a){return-1!==["col","auto"].indexOf(A.getScope(a))},A.isDataCell=function(a){return!(!a.children.length&&!a.textContent.trim())&&"TD"===a.nodeName.toUpperCase()},A.isDataTable=function(a){var b=a.getAttribute("role");if(("presentation"===b||"none"===b)&&!z.isFocusable(a))return!1;if("true"===a.getAttribute("contenteditable")||z.findUp(a,'[contenteditable="true"]'))return!0;if("grid"===b||"treegrid"===b||"table"===b)return!0;if("landmark"===commons.aria.getRoleType(b))return!0;if("0"===a.getAttribute("datatable"))return!1;if(a.getAttribute("summary"))return!0;if(a.tHead||a.tFoot||a.caption)return!0;for(var c=0,d=a.children.length;c<d;c++)if("COLGROUP"===a.children[c].nodeName.toUpperCase())return!0;for(var e,f,g=0,h=a.rows.length,i=!1,j=0;j<h;j++){e=a.rows[j];for(var k=0,l=e.cells.length;k<l;k++){if(f=e.cells[k],"TH"===f.nodeName.toUpperCase())return!0;if(i||f.offsetWidth===f.clientWidth&&f.offsetHeight===f.clientHeight||(i=!0),f.getAttribute("scope")||f.getAttribute("headers")||f.getAttribute("abbr"))return!0;if(-1!==["columnheader","rowheader"].indexOf(f.getAttribute("role")))return!0;if(1===f.children.length&&"ABBR"===f.children[0].nodeName.toUpperCase())return!0;g++}}if(a.getElementsByTagName("table").length)return!1;if(h<2)return!1;var m=a.rows[Math.ceil(h/2)];if(1===m.cells.length&&1===m.cells[0].colSpan)return!1;if(m.cells.length>=5)return!0;if(i)return!0;var n,o;for(j=0;j<h;j++){if(e=a.rows[j],n&&n!==window.getComputedStyle(e).getPropertyValue("background-color"))return!0;if(n=window.getComputedStyle(e).getPropertyValue("background-color"),o&&o!==window.getComputedStyle(e).getPropertyValue("background-image"))return!0;o=window.getComputedStyle(e).getPropertyValue("background-image")}return h>=20||!(z.getElementCoordinates(a).width>.95*z.getViewportSize(window).width)&&(!(g<10)&&!a.querySelector("object, embed, iframe, applet"))},A.isHeader=function(a){return!(!A.isColumnHeader(a)&&!A.isRowHeader(a))||!!a.id&&!!document.querySelector('[headers~="'+axe.utils.escapeSelector(a.id)+'"]')},A.isRowHeader=function(a){return-1!==["row","auto"].indexOf(A.getScope(a))},A.toGrid=function(a){for(var b=[],c=a.rows,d=0,e=c.length;d<e;d++){var f=c[d].cells;b[d]=b[d]||[];for(var g=0,h=0,i=f.length;h<i;h++)for(var j=0;j<f[h].colSpan;j++){for(var k=0;k<f[h].rowSpan;k++){for(b[d+k]=b[d+k]||[];b[d+k][g];)g++;b[d+k][g]=f[h]}g++}}return b},A.toArray=A.toGrid,function(a){var b=function a(b,c,d,e){var f,g=d[c.y]?d[c.y][c.x]:void 0;return g?"function"==typeof e&&!0===(f=e(g,c,d))?[g]:(f=a(b,{x:c.x+b.x,y:c.y+b.y},d,e),f.unshift(g),f):[]};a.traverse=function(a,c,d,e){if(Array.isArray(c)&&(e=d,d=c,c={x:0,y:0}),"string"==typeof a)switch(a){case"left":a={x:-1,y:0};break;case"up":a={x:0,y:-1};break;case"right":a={x:1,y:0};break;case"down":a={x:0,y:1}}return b(a,{x:c.x+a.x,y:c.y+a.y},d,e)}}(A);var F={submit:"Submit",reset:"Reset"},G=["text","search","tel","url","email","date","time","number","range","color"],H=["A","EM","STRONG","SMALL","MARK","ABBR","DFN","I","B","S","U","CODE","VAR","SAMP","KBD","SUP","SUB","Q","CITE","SPAN","BDO","BDI","BR","WBR","INS","DEL","IMG","EMBED","OBJECT","IFRAME","MAP","AREA","SCRIPT","NOSCRIPT","RUBY","VIDEO","AUDIO","INPUT","TEXTAREA","SELECT","BUTTON","LABEL","OUTPUT","DATALIST","KEYGEN","PROGRESS","COMMAND","CANVAS","TIME","METER"];B.accessibleText=function(a,b){function c(a,b,c){for(var d,e=a.childNodes,g="",h=0;h<e.length;h++)d=e[h],3===d.nodeType?g+=d.textContent:1===d.nodeType&&(-1===H.indexOf(d.nodeName.toUpperCase())&&(g+=" "),g+=f(e[h],b,c));return g}function d(a,b,d){var e="",g=a.nodeName.toUpperCase();if(p(a)&&(e=c(a,!1,!1)||"",v(e)))return e;if("FIGURE"===g&&(e=s(a,"figcaption"),v(e)))return e;if("TABLE"===g){if(e=s(a,"caption"),v(e))return e;if(e=a.getAttribute("title")||a.getAttribute("summary")||"",v(e))return e}if(u(a))return a.getAttribute("alt")||"";if(o(a)&&!d){if(n(a))return a.value||a.title||F[a.type]||"";var h=m(a);if(h)return f(h,b,!0)}return""}function e(a,b,c){return!b&&a.hasAttribute("aria-labelledby")?B.sanitize(z.idrefs(a,"aria-labelledby").map(function(b){return a===b&&g.pop(),f(b,!0,a!==b)}).join(" ")):c&&t(a)||!a.hasAttribute("aria-label")?"":B.sanitize(a.getAttribute("aria-label"))}var f,g=[];return f=function(a,b,f){"use strict";var h;if(null===a||-1!==g.indexOf(a))return"";if(!b&&!z.isVisible(a,!0))return"";g.push(a);var i=a.getAttribute("role");return h=e(a,b,f),v(h)?h:(h=d(a,b,f),v(h)?h:f&&(h=r(a),v(h))?h:q(a)||i&&-1===w.getRolesWithNameFromContents().indexOf(i)||(h=c(a,b,f),!v(h))?a.hasAttribute("title")?a.getAttribute("title"):"":h)},B.sanitize(f(a,b))},B.label=function(a){var b,c,d;return(c=w.label(a))?c:a.actualNode.id&&(d=axe.commons.dom.getRootNode(a.actualNode),b=d.querySelector('label[for="'+axe.utils.escapeSelector(a.actualNode.id)+'"]'),b=axe.utils.getNodeFromTree(axe._tree[0],b),c=b&&B.visible(b,!0))?c:(b=z.findUp(a.actualNode,"label"),b=axe.utils.getNodeFromTree(axe._tree[0],b),(c=b&&B.visible(b,!0))||null)},B.sanitize=function(a){"use strict";return a.replace(/\r\n/g,"\n").replace(/\u00A0/g," ").replace(/[\s]{2,}/g," ").trim()},B.visible=function(a,b,c){"use strict";var d,e,f,g=a.children,h=g.length,i="";for(d=0;d<h;d++)e=g[d],3===e.actualNode.nodeType?(f=e.actualNode.nodeValue)&&z.isVisible(a.actualNode,b)&&(i+=f):c||(i+=B.visible(e,b));return B.sanitize(i)},axe.utils.toArray=function(a){"use strict";return Array.prototype.slice.call(a)},axe.utils.tokenList=function(a){"use strict";return a.trim().replace(/\s{2,}/g," ").split(" ")} +;var I=["aa","ab","ae","af","ak","am","an","ar","as","av","ay","az","ba","be","bg","bh","bi","bm","bn","bo","br","bs","ca","ce","ch","co","cr","cs","cu","cv","cy","da","de","dv","dz","ee","el","en","eo","es","et","eu","fa","ff","fi","fj","fo","fr","fy","ga","gd","gl","gn","gu","gv","ha","he","hi","ho","hr","ht","hu","hy","hz","ia","id","ie","ig","ii","ik","in","io","is","it","iu","iw","ja","ji","jv","jw","ka","kg","ki","kj","kk","kl","km","kn","ko","kr","ks","ku","kv","kw","ky","la","lb","lg","li","ln","lo","lt","lu","lv","mg","mh","mi","mk","ml","mn","mo","mr","ms","mt","my","na","nb","nd","ne","ng","nl","nn","no","nr","nv","ny","oc","oj","om","or","os","pa","pi","pl","ps","pt","qu","rm","rn","ro","ru","rw","sa","sc","sd","se","sg","sh","si","sk","sl","sm","sn","so","sq","sr","ss","st","su","sv","sw","ta","te","tg","th","ti","tk","tl","tn","to","tr","ts","tt","tw","ty","ug","uk","ur","uz","ve","vi","vo","wa","wo","xh","yi","yo","za","zh","zu","aaa","aab","aac","aad","aae","aaf","aag","aah","aai","aak","aal","aam","aan","aao","aap","aaq","aas","aat","aau","aav","aaw","aax","aaz","aba","abb","abc","abd","abe","abf","abg","abh","abi","abj","abl","abm","abn","abo","abp","abq","abr","abs","abt","abu","abv","abw","abx","aby","abz","aca","acb","acd","ace","acf","ach","aci","ack","acl","acm","acn","acp","acq","acr","acs","act","acu","acv","acw","acx","acy","acz","ada","adb","add","ade","adf","adg","adh","adi","adj","adl","adn","ado","adp","adq","adr","ads","adt","adu","adw","adx","ady","adz","aea","aeb","aec","aed","aee","aek","ael","aem","aen","aeq","aer","aes","aeu","aew","aey","aez","afa","afb","afd","afe","afg","afh","afi","afk","afn","afo","afp","afs","aft","afu","afz","aga","agb","agc","agd","age","agf","agg","agh","agi","agj","agk","agl","agm","agn","ago","agp","agq","agr","ags","agt","agu","agv","agw","agx","agy","agz","aha","ahb","ahg","ahh","ahi","ahk","ahl","ahm","ahn","aho","ahp","ahr","ahs","aht","aia","aib","aic","aid","aie","aif","aig","aih","aii","aij","aik","ail","aim","ain","aio","aip","aiq","air","ais","ait","aiw","aix","aiy","aja","ajg","aji","ajn","ajp","ajt","aju","ajw","ajz","akb","akc","akd","ake","akf","akg","akh","aki","akj","akk","akl","akm","ako","akp","akq","akr","aks","akt","aku","akv","akw","akx","aky","akz","ala","alc","ald","ale","alf","alg","alh","ali","alj","alk","all","alm","aln","alo","alp","alq","alr","als","alt","alu","alv","alw","alx","aly","alz","ama","amb","amc","ame","amf","amg","ami","amj","amk","aml","amm","amn","amo","amp","amq","amr","ams","amt","amu","amv","amw","amx","amy","amz","ana","anb","anc","and","ane","anf","ang","anh","ani","anj","ank","anl","anm","ann","ano","anp","anq","anr","ans","ant","anu","anv","anw","anx","any","anz","aoa","aob","aoc","aod","aoe","aof","aog","aoh","aoi","aoj","aok","aol","aom","aon","aor","aos","aot","aou","aox","aoz","apa","apb","apc","apd","ape","apf","apg","aph","api","apj","apk","apl","apm","apn","apo","app","apq","apr","aps","apt","apu","apv","apw","apx","apy","apz","aqa","aqc","aqd","aqg","aql","aqm","aqn","aqp","aqr","aqt","aqz","arb","arc","ard","are","arh","ari","arj","ark","arl","arn","aro","arp","arq","arr","ars","art","aru","arv","arw","arx","ary","arz","asa","asb","asc","asd","ase","asf","asg","ash","asi","asj","ask","asl","asn","aso","asp","asq","asr","ass","ast","asu","asv","asw","asx","asy","asz","ata","atb","atc","atd","ate","atg","ath","ati","atj","atk","atl","atm","atn","ato","atp","atq","atr","ats","att","atu","atv","atw","atx","aty","atz","aua","aub","auc","aud","aue","auf","aug","auh","aui","auj","auk","aul","aum","aun","auo","aup","auq","aur","aus","aut","auu","auw","aux","auy","auz","avb","avd","avi","avk","avl","avm","avn","avo","avs","avt","avu","avv","awa","awb","awc","awd","awe","awg","awh","awi","awk","awm","awn","awo","awr","aws","awt","awu","awv","aww","awx","awy","axb","axe","axg","axk","axl","axm","axx","aya","ayb","ayc","ayd","aye","ayg","ayh","ayi","ayk","ayl","ayn","ayo","ayp","ayq","ayr","ays","ayt","ayu","ayx","ayy","ayz","aza","azb","azc","azd","azg","azj","azm","azn","azo","azt","azz","baa","bab","bac","bad","bae","baf","bag","bah","bai","baj","bal","ban","bao","bap","bar","bas","bat","bau","bav","baw","bax","bay","baz","bba","bbb","bbc","bbd","bbe","bbf","bbg","bbh","bbi","bbj","bbk","bbl","bbm","bbn","bbo","bbp","bbq","bbr","bbs","bbt","bbu","bbv","bbw","bbx","bby","bbz","bca","bcb","bcc","bcd","bce","bcf","bcg","bch","bci","bcj","bck","bcl","bcm","bcn","bco","bcp","bcq","bcr","bcs","bct","bcu","bcv","bcw","bcy","bcz","bda","bdb","bdc","bdd","bde","bdf","bdg","bdh","bdi","bdj","bdk","bdl","bdm","bdn","bdo","bdp","bdq","bdr","bds","bdt","bdu","bdv","bdw","bdx","bdy","bdz","bea","beb","bec","bed","bee","bef","beg","beh","bei","bej","bek","bem","beo","bep","beq","ber","bes","bet","beu","bev","bew","bex","bey","bez","bfa","bfb","bfc","bfd","bfe","bff","bfg","bfh","bfi","bfj","bfk","bfl","bfm","bfn","bfo","bfp","bfq","bfr","bfs","bft","bfu","bfw","bfx","bfy","bfz","bga","bgb","bgc","bgd","bge","bgf","bgg","bgi","bgj","bgk","bgl","bgm","bgn","bgo","bgp","bgq","bgr","bgs","bgt","bgu","bgv","bgw","bgx","bgy","bgz","bha","bhb","bhc","bhd","bhe","bhf","bhg","bhh","bhi","bhj","bhk","bhl","bhm","bhn","bho","bhp","bhq","bhr","bhs","bht","bhu","bhv","bhw","bhx","bhy","bhz","bia","bib","bic","bid","bie","bif","big","bij","bik","bil","bim","bin","bio","bip","biq","bir","bit","biu","biv","biw","bix","biy","biz","bja","bjb","bjc","bjd","bje","bjf","bjg","bjh","bji","bjj","bjk","bjl","bjm","bjn","bjo","bjp","bjq","bjr","bjs","bjt","bju","bjv","bjw","bjx","bjy","bjz","bka","bkb","bkc","bkd","bkf","bkg","bkh","bki","bkj","bkk","bkl","bkm","bkn","bko","bkp","bkq","bkr","bks","bkt","bku","bkv","bkw","bkx","bky","bkz","bla","blb","blc","bld","ble","blf","blg","blh","bli","blj","blk","bll","blm","bln","blo","blp","blq","blr","bls","blt","blv","blw","blx","bly","blz","bma","bmb","bmc","bmd","bme","bmf","bmg","bmh","bmi","bmj","bmk","bml","bmm","bmn","bmo","bmp","bmq","bmr","bms","bmt","bmu","bmv","bmw","bmx","bmy","bmz","bna","bnb","bnc","bnd","bne","bnf","bng","bni","bnj","bnk","bnl","bnm","bnn","bno","bnp","bnq","bnr","bns","bnt","bnu","bnv","bnw","bnx","bny","bnz","boa","bob","boe","bof","bog","boh","boi","boj","bok","bol","bom","bon","boo","bop","boq","bor","bot","bou","bov","bow","box","boy","boz","bpa","bpb","bpd","bpg","bph","bpi","bpj","bpk","bpl","bpm","bpn","bpo","bpp","bpq","bpr","bps","bpt","bpu","bpv","bpw","bpx","bpy","bpz","bqa","bqb","bqc","bqd","bqf","bqg","bqh","bqi","bqj","bqk","bql","bqm","bqn","bqo","bqp","bqq","bqr","bqs","bqt","bqu","bqv","bqw","bqx","bqy","bqz","bra","brb","brc","brd","brf","brg","brh","bri","brj","brk","brl","brm","brn","bro","brp","brq","brr","brs","brt","bru","brv","brw","brx","bry","brz","bsa","bsb","bsc","bse","bsf","bsg","bsh","bsi","bsj","bsk","bsl","bsm","bsn","bso","bsp","bsq","bsr","bss","bst","bsu","bsv","bsw","bsx","bsy","bta","btb","btc","btd","bte","btf","btg","bth","bti","btj","btk","btl","btm","btn","bto","btp","btq","btr","bts","btt","btu","btv","btw","btx","bty","btz","bua","bub","buc","bud","bue","buf","bug","buh","bui","buj","buk","bum","bun","buo","bup","buq","bus","but","buu","buv","buw","bux","buy","buz","bva","bvb","bvc","bvd","bve","bvf","bvg","bvh","bvi","bvj","bvk","bvl","bvm","bvn","bvo","bvp","bvq","bvr","bvt","bvu","bvv","bvw","bvx","bvy","bvz","bwa","bwb","bwc","bwd","bwe","bwf","bwg","bwh","bwi","bwj","bwk","bwl","bwm","bwn","bwo","bwp","bwq","bwr","bws","bwt","bwu","bww","bwx","bwy","bwz","bxa","bxb","bxc","bxd","bxe","bxf","bxg","bxh","bxi","bxj","bxk","bxl","bxm","bxn","bxo","bxp","bxq","bxr","bxs","bxu","bxv","bxw","bxx","bxz","bya","byb","byc","byd","bye","byf","byg","byh","byi","byj","byk","byl","bym","byn","byo","byp","byq","byr","bys","byt","byv","byw","byx","byy","byz","bza","bzb","bzc","bzd","bze","bzf","bzg","bzh","bzi","bzj","bzk","bzl","bzm","bzn","bzo","bzp","bzq","bzr","bzs","bzt","bzu","bzv","bzw","bzx","bzy","bzz","caa","cab","cac","cad","cae","caf","cag","cah","cai","caj","cak","cal","cam","can","cao","cap","caq","car","cas","cau","cav","caw","cax","cay","caz","cba","cbb","cbc","cbd","cbe","cbg","cbh","cbi","cbj","cbk","cbl","cbn","cbo","cbq","cbr","cbs","cbt","cbu","cbv","cbw","cby","cca","ccc","ccd","cce","ccg","cch","ccj","ccl","ccm","ccn","cco","ccp","ccq","ccr","ccs","cda","cdc","cdd","cde","cdf","cdg","cdh","cdi","cdj","cdm","cdn","cdo","cdr","cds","cdy","cdz","cea","ceb","ceg","cek","cel","cen","cet","cfa","cfd","cfg","cfm","cga","cgc","cgg","cgk","chb","chc","chd","chf","chg","chh","chj","chk","chl","chm","chn","cho","chp","chq","chr","cht","chw","chx","chy","chz","cia","cib","cic","cid","cie","cih","cik","cim","cin","cip","cir","ciw","ciy","cja","cje","cjh","cji","cjk","cjm","cjn","cjo","cjp","cjr","cjs","cjv","cjy","cka","ckb","ckh","ckl","ckn","cko","ckq","ckr","cks","ckt","cku","ckv","ckx","cky","ckz","cla","clc","cld","cle","clh","cli","clj","clk","cll","clm","clo","clt","clu","clw","cly","cma","cmc","cme","cmg","cmi","cmk","cml","cmm","cmn","cmo","cmr","cms","cmt","cna","cnb","cnc","cng","cnh","cni","cnk","cnl","cno","cns","cnt","cnu","cnw","cnx","coa","cob","coc","cod","coe","cof","cog","coh","coj","cok","col","com","con","coo","cop","coq","cot","cou","cov","cow","cox","coy","coz","cpa","cpb","cpc","cpe","cpf","cpg","cpi","cpn","cpo","cpp","cps","cpu","cpx","cpy","cqd","cqu","cra","crb","crc","crd","crf","crg","crh","cri","crj","crk","crl","crm","crn","cro","crp","crq","crr","crs","crt","crv","crw","crx","cry","crz","csa","csb","csc","csd","cse","csf","csg","csh","csi","csj","csk","csl","csm","csn","cso","csq","csr","css","cst","csu","csv","csw","csy","csz","cta","ctc","ctd","cte","ctg","cth","ctl","ctm","ctn","cto","ctp","cts","ctt","ctu","ctz","cua","cub","cuc","cug","cuh","cui","cuj","cuk","cul","cum","cuo","cup","cuq","cur","cus","cut","cuu","cuv","cuw","cux","cvg","cvn","cwa","cwb","cwd","cwe","cwg","cwt","cya","cyb","cyo","czh","czk","czn","czo","czt","daa","dac","dad","dae","daf","dag","dah","dai","daj","dak","dal","dam","dao","dap","daq","dar","das","dau","dav","daw","dax","day","daz","dba","dbb","dbd","dbe","dbf","dbg","dbi","dbj","dbl","dbm","dbn","dbo","dbp","dbq","dbr","dbt","dbu","dbv","dbw","dby","dcc","dcr","dda","ddd","dde","ddg","ddi","ddj","ddn","ddo","ddr","dds","ddw","dec","ded","dee","def","deg","deh","dei","dek","del","dem","den","dep","deq","der","des","dev","dez","dga","dgb","dgc","dgd","dge","dgg","dgh","dgi","dgk","dgl","dgn","dgo","dgr","dgs","dgt","dgu","dgw","dgx","dgz","dha","dhd","dhg","dhi","dhl","dhm","dhn","dho","dhr","dhs","dhu","dhv","dhw","dhx","dia","dib","dic","did","dif","dig","dih","dii","dij","dik","dil","dim","din","dio","dip","diq","dir","dis","dit","diu","diw","dix","diy","diz","dja","djb","djc","djd","dje","djf","dji","djj","djk","djl","djm","djn","djo","djr","dju","djw","dka","dkk","dkl","dkr","dks","dkx","dlg","dlk","dlm","dln","dma","dmb","dmc","dmd","dme","dmg","dmk","dml","dmm","dmn","dmo","dmr","dms","dmu","dmv","dmw","dmx","dmy","dna","dnd","dne","dng","dni","dnj","dnk","dnn","dnr","dnt","dnu","dnv","dnw","dny","doa","dob","doc","doe","dof","doh","doi","dok","dol","don","doo","dop","doq","dor","dos","dot","dov","dow","dox","doy","doz","dpp","dra","drb","drc","drd","dre","drg","drh","dri","drl","drn","dro","drq","drr","drs","drt","dru","drw","dry","dsb","dse","dsh","dsi","dsl","dsn","dso","dsq","dta","dtb","dtd","dth","dti","dtk","dtm","dtn","dto","dtp","dtr","dts","dtt","dtu","dty","dua","dub","duc","dud","due","duf","dug","duh","dui","duj","duk","dul","dum","dun","duo","dup","duq","dur","dus","duu","duv","duw","dux","duy","duz","dva","dwa","dwl","dwr","dws","dwu","dww","dwy","dya","dyb","dyd","dyg","dyi","dym","dyn","dyo","dyu","dyy","dza","dzd","dze","dzg","dzl","dzn","eaa","ebg","ebk","ebo","ebr","ebu","ecr","ecs","ecy","eee","efa","efe","efi","ega","egl","ego","egx","egy","ehu","eip","eit","eiv","eja","eka","ekc","eke","ekg","eki","ekk","ekl","ekm","eko","ekp","ekr","eky","ele","elh","eli","elk","elm","elo","elp","elu","elx","ema","emb","eme","emg","emi","emk","emm","emn","emo","emp","ems","emu","emw","emx","emy","ena","enb","enc","end","enf","enh","enl","enm","enn","eno","enq","enr","enu","env","enw","enx","eot","epi","era","erg","erh","eri","erk","ero","err","ers","ert","erw","ese","esg","esh","esi","esk","esl","esm","esn","eso","esq","ess","esu","esx","esy","etb","etc","eth","etn","eto","etr","ets","ett","etu","etx","etz","euq","eve","evh","evn","ewo","ext","eya","eyo","eza","eze","faa","fab","fad","faf","fag","fah","fai","faj","fak","fal","fam","fan","fap","far","fat","fau","fax","fay","faz","fbl","fcs","fer","ffi","ffm","fgr","fia","fie","fil","fip","fir","fit","fiu","fiw","fkk","fkv","fla","flh","fli","fll","fln","flr","fly","fmp","fmu","fnb","fng","fni","fod","foi","fom","fon","for","fos","fox","fpe","fqs","frc","frd","frk","frm","fro","frp","frq","frr","frs","frt","fse","fsl","fss","fub","fuc","fud","fue","fuf","fuh","fui","fuj","fum","fun","fuq","fur","fut","fuu","fuv","fuy","fvr","fwa","fwe","gaa","gab","gac","gad","gae","gaf","gag","gah","gai","gaj","gak","gal","gam","gan","gao","gap","gaq","gar","gas","gat","gau","gav","gaw","gax","gay","gaz","gba","gbb","gbc","gbd","gbe","gbf","gbg","gbh","gbi","gbj","gbk","gbl","gbm","gbn","gbo","gbp","gbq","gbr","gbs","gbu","gbv","gbw","gbx","gby","gbz","gcc","gcd","gce","gcf","gcl","gcn","gcr","gct","gda","gdb","gdc","gdd","gde","gdf","gdg","gdh","gdi","gdj","gdk","gdl","gdm","gdn","gdo","gdq","gdr","gds","gdt","gdu","gdx","gea","geb","gec","ged","geg","geh","gei","gej","gek","gel","gem","geq","ges","gev","gew","gex","gey","gez","gfk","gft","gfx","gga","ggb","ggd","gge","ggg","ggk","ggl","ggn","ggo","ggr","ggt","ggu","ggw","gha","ghc","ghe","ghh","ghk","ghl","ghn","gho","ghr","ghs","ght","gia","gib","gic","gid","gie","gig","gih","gil","gim","gin","gio","gip","giq","gir","gis","git","giu","giw","gix","giy","giz","gji","gjk","gjm","gjn","gjr","gju","gka","gke","gkn","gko","gkp","gku","glc","gld","glh","gli","glj","glk","gll","glo","glr","glu","glw","gly","gma","gmb","gmd","gme","gmg","gmh","gml","gmm","gmn","gmq","gmu","gmv","gmw","gmx","gmy","gmz","gna","gnb","gnc","gnd","gne","gng","gnh","gni","gnk","gnl","gnm","gnn","gno","gnq","gnr","gnt","gnu","gnw","gnz","goa","gob","goc","god","goe","gof","gog","goh","goi","goj","gok","gol","gom","gon","goo","gop","goq","gor","gos","got","gou","gow","gox","goy","goz","gpa","gpe","gpn","gqa","gqi","gqn","gqr","gqu","gra","grb","grc","grd","grg","grh","gri","grj","grk","grm","gro","grq","grr","grs","grt","gru","grv","grw","grx","gry","grz","gse","gsg","gsl","gsm","gsn","gso","gsp","gss","gsw","gta","gti","gtu","gua","gub","guc","gud","gue","guf","gug","guh","gui","guk","gul","gum","gun","guo","gup","guq","gur","gus","gut","guu","guv","guw","gux","guz","gva","gvc","gve","gvf","gvj","gvl","gvm","gvn","gvo","gvp","gvr","gvs","gvy","gwa","gwb","gwc","gwd","gwe","gwf","gwg","gwi","gwj","gwm","gwn","gwr","gwt","gwu","gww","gwx","gxx","gya","gyb","gyd","gye","gyf","gyg","gyi","gyl","gym","gyn","gyr","gyy","gza","gzi","gzn","haa","hab","hac","had","hae","haf","hag","hah","hai","haj","hak","hal","ham","han","hao","hap","haq","har","has","hav","haw","hax","hay","haz","hba","hbb","hbn","hbo","hbu","hca","hch","hdn","hds","hdy","hea","hed","heg","heh","hei","hem","hgm","hgw","hhi","hhr","hhy","hia","hib","hid","hif","hig","hih","hii","hij","hik","hil","him","hio","hir","hit","hiw","hix","hji","hka","hke","hkk","hks","hla","hlb","hld","hle","hlt","hlu","hma","hmb","hmc","hmd","hme","hmf","hmg","hmh","hmi","hmj","hmk","hml","hmm","hmn","hmp","hmq","hmr","hms","hmt","hmu","hmv","hmw","hmx","hmy","hmz","hna","hnd","hne","hnh","hni","hnj","hnn","hno","hns","hnu","hoa","hob","hoc","hod","hoe","hoh","hoi","hoj","hok","hol","hom","hoo","hop","hor","hos","hot","hov","how","hoy","hoz","hpo","hps","hra","hrc","hre","hrk","hrm","hro","hrp","hrr","hrt","hru","hrw","hrx","hrz","hsb","hsh","hsl","hsn","hss","hti","hto","hts","htu","htx","hub","huc","hud","hue","huf","hug","huh","hui","huj","huk","hul","hum","huo","hup","huq","hur","hus","hut","huu","huv","huw","hux","huy","huz","hvc","hve","hvk","hvn","hvv","hwa","hwc","hwo","hya","hyx","iai","ian","iap","iar","iba","ibb","ibd","ibe","ibg","ibh","ibi","ibl","ibm","ibn","ibr","ibu","iby","ica","ich","icl","icr","ida","idb","idc","idd","ide","idi","idr","ids","idt","idu","ifa","ifb","ife","iff","ifk","ifm","ifu","ify","igb","ige","igg","igl","igm","ign","igo","igs","igw","ihb","ihi","ihp","ihw","iin","iir","ijc","ije","ijj","ijn","ijo","ijs","ike","iki","ikk","ikl","iko","ikp","ikr","iks","ikt","ikv","ikw","ikx","ikz","ila","ilb","ilg","ili","ilk","ill","ilm","ilo","ilp","ils","ilu","ilv","ilw","ima","ime","imi","iml","imn","imo","imr","ims","imy","inb","inc","ine","ing","inh","inj","inl","inm","inn","ino","inp","ins","int","inz","ior","iou","iow","ipi","ipo","iqu","iqw","ira","ire","irh","iri","irk","irn","iro","irr","iru","irx","iry","isa","isc","isd","ise","isg","ish","isi","isk","ism","isn","iso","isr","ist","isu","itb","itc","itd","ite","iti","itk","itl","itm","ito","itr","its","itt","itv","itw","itx","ity","itz","ium","ivb","ivv","iwk","iwm","iwo","iws","ixc","ixl","iya","iyo","iyx","izh","izi","izr","izz","jaa","jab","jac","jad","jae","jaf","jah","jaj","jak","jal","jam","jan","jao","jaq","jar","jas","jat","jau","jax","jay","jaz","jbe","jbi","jbj","jbk","jbn","jbo","jbr","jbt","jbu","jbw","jcs","jct","jda","jdg","jdt","jeb","jee","jeg","jeh","jei","jek","jel","jen","jer","jet","jeu","jgb","jge","jgk","jgo","jhi","jhs","jia","jib","jic","jid","jie","jig","jih","jii","jil","jim","jio","jiq","jit","jiu","jiv","jiy","jje","jjr","jka","jkm","jko","jkp","jkr","jku","jle","jls","jma","jmb","jmc","jmd","jmi","jml","jmn","jmr","jms","jmw","jmx","jna","jnd","jng","jni","jnj","jnl","jns","job","jod","jog","jor","jos","jow","jpa","jpr","jpx","jqr","jra","jrb","jrr","jrt","jru","jsl","jua","jub","juc","jud","juh","jui","juk","jul","jum","jun","juo","jup","jur","jus","jut","juu","juw","juy","jvd","jvn","jwi","jya","jye","jyy","kaa","kab","kac","kad","kae","kaf","kag","kah","kai","kaj","kak","kam","kao","kap","kaq","kar","kav","kaw","kax","kay","kba","kbb","kbc","kbd","kbe","kbf","kbg","kbh","kbi","kbj","kbk","kbl","kbm","kbn","kbo","kbp","kbq","kbr","kbs","kbt","kbu","kbv","kbw","kbx","kby","kbz","kca","kcb","kcc","kcd","kce","kcf","kcg","kch","kci","kcj","kck","kcl","kcm","kcn","kco","kcp","kcq","kcr","kcs","kct","kcu","kcv","kcw","kcx","kcy","kcz","kda","kdc","kdd","kde","kdf","kdg","kdh","kdi","kdj","kdk","kdl","kdm","kdn","kdo","kdp","kdq","kdr","kdt","kdu","kdv","kdw","kdx","kdy","kdz","kea","keb","kec","ked","kee","kef","keg","keh","kei","kej","kek","kel","kem","ken","keo","kep","keq","ker","kes","ket","keu","kev","kew","kex","key","kez","kfa","kfb","kfc","kfd","kfe","kff","kfg","kfh","kfi","kfj","kfk","kfl","kfm","kfn","kfo","kfp","kfq","kfr","kfs","kft","kfu","kfv","kfw","kfx","kfy","kfz","kga","kgb","kgc","kgd","kge","kgf","kgg","kgh","kgi","kgj","kgk","kgl","kgm","kgn","kgo","kgp","kgq","kgr","kgs","kgt","kgu","kgv","kgw","kgx","kgy","kha","khb","khc","khd","khe","khf","khg","khh","khi","khj","khk","khl","khn","kho","khp","khq","khr","khs","kht","khu","khv","khw","khx","khy","khz","kia","kib","kic","kid","kie","kif","kig","kih","kii","kij","kil","kim","kio","kip","kiq","kis","kit","kiu","kiv","kiw","kix","kiy","kiz","kja","kjb","kjc","kjd","kje","kjf","kjg","kjh","kji","kjj","kjk","kjl","kjm","kjn","kjo","kjp","kjq","kjr","kjs","kjt","kju","kjv","kjx","kjy","kjz","kka","kkb","kkc","kkd","kke","kkf","kkg","kkh","kki","kkj","kkk","kkl","kkm","kkn","kko","kkp","kkq","kkr","kks","kkt","kku","kkv","kkw","kkx","kky","kkz","kla","klb","klc","kld","kle","klf","klg","klh","kli","klj","klk","kll","klm","kln","klo","klp","klq","klr","kls","klt","klu","klv","klw","klx","kly","klz","kma","kmb","kmc","kmd","kme","kmf","kmg","kmh","kmi","kmj","kmk","kml","kmm","kmn","kmo","kmp","kmq","kmr","kms","kmt","kmu","kmv","kmw","kmx","kmy","kmz","kna","knb","knc","knd","kne","knf","kng","kni","knj","knk","knl","knm","knn","kno","knp","knq","knr","kns","knt","knu","knv","knw","knx","kny","knz","koa","koc","kod","koe","kof","kog","koh","koi","koj","kok","kol","koo","kop","koq","kos","kot","kou","kov","kow","kox","koy","koz","kpa","kpb","kpc","kpd","kpe","kpf","kpg","kph","kpi","kpj","kpk","kpl","kpm","kpn","kpo","kpp","kpq","kpr","kps","kpt","kpu","kpv","kpw","kpx","kpy","kpz","kqa","kqb","kqc","kqd","kqe","kqf","kqg","kqh","kqi","kqj","kqk","kql","kqm","kqn","kqo","kqp","kqq","kqr","kqs","kqt","kqu","kqv","kqw","kqx","kqy","kqz","kra","krb","krc","krd","kre","krf","krh","kri","krj","krk","krl","krm","krn","kro","krp","krr","krs","krt","kru","krv","krw","krx","kry","krz","ksa","ksb","ksc","ksd","kse","ksf","ksg","ksh","ksi","ksj","ksk","ksl","ksm","ksn","kso","ksp","ksq","ksr","kss","kst","ksu","ksv","ksw","ksx","ksy","ksz","kta","ktb","ktc","ktd","kte","ktf","ktg","kth","kti","ktj","ktk","ktl","ktm","ktn","kto","ktp","ktq","ktr","kts","ktt","ktu","ktv","ktw","ktx","kty","ktz","kub","kuc","kud","kue","kuf","kug","kuh","kui","kuj","kuk","kul","kum","kun","kuo","kup","kuq","kus","kut","kuu","kuv","kuw","kux","kuy","kuz","kva","kvb","kvc","kvd","kve","kvf","kvg","kvh","kvi","kvj","kvk","kvl","kvm","kvn","kvo","kvp","kvq","kvr","kvs","kvt","kvu","kvv","kvw","kvx","kvy","kvz","kwa","kwb","kwc","kwd","kwe","kwf","kwg","kwh","kwi","kwj","kwk","kwl","kwm","kwn","kwo","kwp","kwq","kwr","kws","kwt","kwu","kwv","kww","kwx","kwy","kwz","kxa","kxb","kxc","kxd","kxe","kxf","kxh","kxi","kxj","kxk","kxl","kxm","kxn","kxo","kxp","kxq","kxr","kxs","kxt","kxu","kxv","kxw","kxx","kxy","kxz","kya","kyb","kyc","kyd","kye","kyf","kyg","kyh","kyi","kyj","kyk","kyl","kym","kyn","kyo","kyp","kyq","kyr","kys","kyt","kyu","kyv","kyw","kyx","kyy","kyz","kza","kzb","kzc","kzd","kze","kzf","kzg","kzh","kzi","kzj","kzk","kzl","kzm","kzn","kzo","kzp","kzq","kzr","kzs","kzt","kzu","kzv","kzw","kzx","kzy","kzz","laa","lab","lac","lad","lae","laf","lag","lah","lai","laj","lak","lal","lam","lan","lap","laq","lar","las","lau","law","lax","lay","laz","lba","lbb","lbc","lbe","lbf","lbg","lbi","lbj","lbk","lbl","lbm","lbn","lbo","lbq","lbr","lbs","lbt","lbu","lbv","lbw","lbx","lby","lbz","lcc","lcd","lce","lcf","lch","lcl","lcm","lcp","lcq","lcs","lda","ldb","ldd","ldg","ldh","ldi","ldj","ldk","ldl","ldm","ldn","ldo","ldp","ldq","lea","leb","lec","led","lee","lef","leg","leh","lei","lej","lek","lel","lem","len","leo","lep","leq","ler","les","let","leu","lev","lew","lex","ley","lez","lfa","lfn","lga","lgb","lgg","lgh","lgi","lgk","lgl","lgm","lgn","lgq","lgr","lgt","lgu","lgz","lha","lhh","lhi","lhl","lhm","lhn","lhp","lhs","lht","lhu","lia","lib","lic","lid","lie","lif","lig","lih","lii","lij","lik","lil","lio","lip","liq","lir","lis","liu","liv","liw","lix","liy","liz","lja","lje","lji","ljl","ljp","ljw","ljx","lka","lkb","lkc","lkd","lke","lkh","lki","lkj","lkl","lkm","lkn","lko","lkr","lks","lkt","lku","lky","lla","llb","llc","lld","lle","llf","llg","llh","lli","llj","llk","lll","llm","lln","llo","llp","llq","lls","llu","llx","lma","lmb","lmc","lmd","lme","lmf","lmg","lmh","lmi","lmj","lmk","lml","lmm","lmn","lmo","lmp","lmq","lmr","lmu","lmv","lmw","lmx","lmy","lmz","lna","lnb","lnd","lng","lnh","lni","lnj","lnl","lnm","lnn","lno","lns","lnu","lnw","lnz","loa","lob","loc","loe","lof","log","loh","loi","loj","lok","lol","lom","lon","loo","lop","loq","lor","los","lot","lou","lov","low","lox","loy","loz","lpa","lpe","lpn","lpo","lpx","lra","lrc","lre","lrg","lri","lrk","lrl","lrm","lrn","lro","lrr","lrt","lrv","lrz","lsa","lsd","lse","lsg","lsh","lsi","lsl","lsm","lso","lsp","lsr","lss","lst","lsy","ltc","ltg","lth","lti","ltn","lto","lts","ltu","lua","luc","lud","lue","luf","lui","luj","luk","lul","lum","lun","luo","lup","luq","lur","lus","lut","luu","luv","luw","luy","luz","lva","lvk","lvs","lvu","lwa","lwe","lwg","lwh","lwl","lwm","lwo","lwt","lwu","lww","lya","lyg","lyn","lzh","lzl","lzn","lzz","maa","mab","mad","mae","maf","mag","mai","maj","mak","mam","man","map","maq","mas","mat","mau","mav","maw","max","maz","mba","mbb","mbc","mbd","mbe","mbf","mbh","mbi","mbj","mbk","mbl","mbm","mbn","mbo","mbp","mbq","mbr","mbs","mbt","mbu","mbv","mbw","mbx","mby","mbz","mca","mcb","mcc","mcd","mce","mcf","mcg","mch","mci","mcj","mck","mcl","mcm","mcn","mco","mcp","mcq","mcr","mcs","mct","mcu","mcv","mcw","mcx","mcy","mcz","mda","mdb","mdc","mdd","mde","mdf","mdg","mdh","mdi","mdj","mdk","mdl","mdm","mdn","mdp","mdq","mdr","mds","mdt","mdu","mdv","mdw","mdx","mdy","mdz","mea","meb","mec","med","mee","mef","meg","meh","mei","mej","mek","mel","mem","men","meo","mep","meq","mer","mes","met","meu","mev","mew","mey","mez","mfa","mfb","mfc","mfd","mfe","mff","mfg","mfh","mfi","mfj","mfk","mfl","mfm","mfn","mfo","mfp","mfq","mfr","mfs","mft","mfu","mfv","mfw","mfx","mfy","mfz","mga","mgb","mgc","mgd","mge","mgf","mgg","mgh","mgi","mgj","mgk","mgl","mgm","mgn","mgo","mgp","mgq","mgr","mgs","mgt","mgu","mgv","mgw","mgx","mgy","mgz","mha","mhb","mhc","mhd","mhe","mhf","mhg","mhh","mhi","mhj","mhk","mhl","mhm","mhn","mho","mhp","mhq","mhr","mhs","mht","mhu","mhw","mhx","mhy","mhz","mia","mib","mic","mid","mie","mif","mig","mih","mii","mij","mik","mil","mim","min","mio","mip","miq","mir","mis","mit","miu","miw","mix","miy","miz","mja","mjb","mjc","mjd","mje","mjg","mjh","mji","mjj","mjk","mjl","mjm","mjn","mjo","mjp","mjq","mjr","mjs","mjt","mju","mjv","mjw","mjx","mjy","mjz","mka","mkb","mkc","mke","mkf","mkg","mkh","mki","mkj","mkk","mkl","mkm","mkn","mko","mkp","mkq","mkr","mks","mkt","mku","mkv","mkw","mkx","mky","mkz","mla","mlb","mlc","mld","mle","mlf","mlh","mli","mlj","mlk","mll","mlm","mln","mlo","mlp","mlq","mlr","mls","mlu","mlv","mlw","mlx","mlz","mma","mmb","mmc","mmd","mme","mmf","mmg","mmh","mmi","mmj","mmk","mml","mmm","mmn","mmo","mmp","mmq","mmr","mmt","mmu","mmv","mmw","mmx","mmy","mmz","mna","mnb","mnc","mnd","mne","mnf","mng","mnh","mni","mnj","mnk","mnl","mnm","mnn","mno","mnp","mnq","mnr","mns","mnt","mnu","mnv","mnw","mnx","mny","mnz","moa","moc","mod","moe","mof","mog","moh","moi","moj","mok","mom","moo","mop","moq","mor","mos","mot","mou","mov","mow","mox","moy","moz","mpa","mpb","mpc","mpd","mpe","mpg","mph","mpi","mpj","mpk","mpl","mpm","mpn","mpo","mpp","mpq","mpr","mps","mpt","mpu","mpv","mpw","mpx","mpy","mpz","mqa","mqb","mqc","mqe","mqf","mqg","mqh","mqi","mqj","mqk","mql","mqm","mqn","mqo","mqp","mqq","mqr","mqs","mqt","mqu","mqv","mqw","mqx","mqy","mqz","mra","mrb","mrc","mrd","mre","mrf","mrg","mrh","mrj","mrk","mrl","mrm","mrn","mro","mrp","mrq","mrr","mrs","mrt","mru","mrv","mrw","mrx","mry","mrz","msb","msc","msd","mse","msf","msg","msh","msi","msj","msk","msl","msm","msn","mso","msp","msq","msr","mss","mst","msu","msv","msw","msx","msy","msz","mta","mtb","mtc","mtd","mte","mtf","mtg","mth","mti","mtj","mtk","mtl","mtm","mtn","mto","mtp","mtq","mtr","mts","mtt","mtu","mtv","mtw","mtx","mty","mua","mub","muc","mud","mue","mug","muh","mui","muj","muk","mul","mum","mun","muo","mup","muq","mur","mus","mut","muu","muv","mux","muy","muz","mva","mvb","mvd","mve","mvf","mvg","mvh","mvi","mvk","mvl","mvm","mvn","mvo","mvp","mvq","mvr","mvs","mvt","mvu","mvv","mvw","mvx","mvy","mvz","mwa","mwb","mwc","mwd","mwe","mwf","mwg","mwh","mwi","mwj","mwk","mwl","mwm","mwn","mwo","mwp","mwq","mwr","mws","mwt","mwu","mwv","mww","mwx","mwy","mwz","mxa","mxb","mxc","mxd","mxe","mxf","mxg","mxh","mxi","mxj","mxk","mxl","mxm","mxn","mxo","mxp","mxq","mxr","mxs","mxt","mxu","mxv","mxw","mxx","mxy","mxz","myb","myc","myd","mye","myf","myg","myh","myi","myj","myk","myl","mym","myn","myo","myp","myq","myr","mys","myt","myu","myv","myw","myx","myy","myz","mza","mzb","mzc","mzd","mze","mzg","mzh","mzi","mzj","mzk","mzl","mzm","mzn","mzo","mzp","mzq","mzr","mzs","mzt","mzu","mzv","mzw","mzx","mzy","mzz","naa","nab","nac","nad","nae","naf","nag","nah","nai","naj","nak","nal","nam","nan","nao","nap","naq","nar","nas","nat","naw","nax","nay","naz","nba","nbb","nbc","nbd","nbe","nbf","nbg","nbh","nbi","nbj","nbk","nbm","nbn","nbo","nbp","nbq","nbr","nbs","nbt","nbu","nbv","nbw","nbx","nby","nca","ncb","ncc","ncd","nce","ncf","ncg","nch","nci","ncj","nck","ncl","ncm","ncn","nco","ncp","ncq","ncr","ncs","nct","ncu","ncx","ncz","nda","ndb","ndc","ndd","ndf","ndg","ndh","ndi","ndj","ndk","ndl","ndm","ndn","ndp","ndq","ndr","nds","ndt","ndu","ndv","ndw","ndx","ndy","ndz","nea","neb","nec","ned","nee","nef","neg","neh","nei","nej","nek","nem","nen","neo","neq","ner","nes","net","neu","nev","new","nex","ney","nez","nfa","nfd","nfl","nfr","nfu","nga","ngb","ngc","ngd","nge","ngf","ngg","ngh","ngi","ngj","ngk","ngl","ngm","ngn","ngo","ngp","ngq","ngr","ngs","ngt","ngu","ngv","ngw","ngx","ngy","ngz","nha","nhb","nhc","nhd","nhe","nhf","nhg","nhh","nhi","nhk","nhm","nhn","nho","nhp","nhq","nhr","nht","nhu","nhv","nhw","nhx","nhy","nhz","nia","nib","nic","nid","nie","nif","nig","nih","nii","nij","nik","nil","nim","nin","nio","niq","nir","nis","nit","niu","niv","niw","nix","niy","niz","nja","njb","njd","njh","nji","njj","njl","njm","njn","njo","njr","njs","njt","nju","njx","njy","njz","nka","nkb","nkc","nkd","nke","nkf","nkg","nkh","nki","nkj","nkk","nkm","nkn","nko","nkp","nkq","nkr","nks","nkt","nku","nkv","nkw","nkx","nkz","nla","nlc","nle","nlg","nli","nlj","nlk","nll","nln","nlo","nlq","nlr","nlu","nlv","nlw","nlx","nly","nlz","nma","nmb","nmc","nmd","nme","nmf","nmg","nmh","nmi","nmj","nmk","nml","nmm","nmn","nmo","nmp","nmq","nmr","nms","nmt","nmu","nmv","nmw","nmx","nmy","nmz","nna","nnb","nnc","nnd","nne","nnf","nng","nnh","nni","nnj","nnk","nnl","nnm","nnn","nnp","nnq","nnr","nns","nnt","nnu","nnv","nnw","nnx","nny","nnz","noa","noc","nod","noe","nof","nog","noh","noi","noj","nok","nol","nom","non","noo","nop","noq","nos","not","nou","nov","now","noy","noz","npa","npb","npg","nph","npi","npl","npn","npo","nps","npu","npx","npy","nqg","nqk","nql","nqm","nqn","nqo","nqq","nqy","nra","nrb","nrc","nre","nrf","nrg","nri","nrk","nrl","nrm","nrn","nrp","nrr","nrt","nru","nrx","nrz","nsa","nsc","nsd","nse","nsf","nsg","nsh","nsi","nsk","nsl","nsm","nsn","nso","nsp","nsq","nsr","nss","nst","nsu","nsv","nsw","nsx","nsy","nsz","ntd","nte","ntg","nti","ntj","ntk","ntm","nto","ntp","ntr","nts","ntu","ntw","ntx","nty","ntz","nua","nub","nuc","nud","nue","nuf","nug","nuh","nui","nuj","nuk","nul","num","nun","nuo","nup","nuq","nur","nus","nut","nuu","nuv","nuw","nux","nuy","nuz","nvh","nvm","nvo","nwa","nwb","nwc","nwe","nwg","nwi","nwm","nwo","nwr","nwx","nwy","nxa","nxd","nxe","nxg","nxi","nxk","nxl","nxm","nxn","nxo","nxq","nxr","nxu","nxx","nyb","nyc","nyd","nye","nyf","nyg","nyh","nyi","nyj","nyk","nyl","nym","nyn","nyo","nyp","nyq","nyr","nys","nyt","nyu","nyv","nyw","nyx","nyy","nza","nzb","nzi","nzk","nzm","nzs","nzu","nzy","nzz","oaa","oac","oar","oav","obi","obk","obl","obm","obo","obr","obt","obu","oca","och","oco","ocu","oda","odk","odt","odu","ofo","ofs","ofu","ogb","ogc","oge","ogg","ogo","ogu","oht","ohu","oia","oin","ojb","ojc","ojg","ojp","ojs","ojv","ojw","oka","okb","okd","oke","okg","okh","oki","okj","okk","okl","okm","okn","oko","okr","oks","oku","okv","okx","ola","old","ole","olk","olm","olo","olr","olt","olu","oma","omb","omc","ome","omg","omi","omk","oml","omn","omo","omp","omq","omr","omt","omu","omv","omw","omx","ona","onb","one","ong","oni","onj","onk","onn","ono","onp","onr","ons","ont","onu","onw","onx","ood","oog","oon","oor","oos","opa","opk","opm","opo","opt","opy","ora","orc","ore","org","orh","orn","oro","orr","ors","ort","oru","orv","orw","orx","ory","orz","osa","osc","osi","oso","osp","ost","osu","osx","ota","otb","otd","ote","oti","otk","otl","otm","otn","oto","otq","otr","ots","ott","otu","otw","otx","oty","otz","oua","oub","oue","oui","oum","oun","ovd","owi","owl","oyb","oyd","oym","oyy","ozm","paa","pab","pac","pad","pae","paf","pag","pah","pai","pak","pal","pam","pao","pap","paq","par","pas","pat","pau","pav","paw","pax","pay","paz","pbb","pbc","pbe","pbf","pbg","pbh","pbi","pbl","pbn","pbo","pbp","pbr","pbs","pbt","pbu","pbv","pby","pbz","pca","pcb","pcc","pcd","pce","pcf","pcg","pch","pci","pcj","pck","pcl","pcm","pcn","pcp","pcr","pcw","pda","pdc","pdi","pdn","pdo","pdt","pdu","pea","peb","ped","pee","pef","peg","peh","pei","pej","pek","pel","pem","peo","pep","peq","pes","pev","pex","pey","pez","pfa","pfe","pfl","pga","pgd","pgg","pgi","pgk","pgl","pgn","pgs","pgu","pgy","pgz","pha","phd","phg","phh","phi","phk","phl","phm","phn","pho","phq","phr","pht","phu","phv","phw","pia","pib","pic","pid","pie","pif","pig","pih","pii","pij","pil","pim","pin","pio","pip","pir","pis","pit","piu","piv","piw","pix","piy","piz","pjt","pka","pkb","pkc","pkg","pkh","pkn","pko","pkp","pkr","pks","pkt","pku","pla","plb","plc","pld","ple","plf","plg","plh","plj","plk","pll","pln","plo","plp","plq","plr","pls","plt","plu","plv","plw","ply","plz","pma","pmb","pmc","pmd","pme","pmf","pmh","pmi","pmj","pmk","pml","pmm","pmn","pmo","pmq","pmr","pms","pmt","pmu","pmw","pmx","pmy","pmz","pna","pnb","pnc","pne","png","pnh","pni","pnj","pnk","pnl","pnm","pnn","pno","pnp","pnq","pnr","pns","pnt","pnu","pnv","pnw","pnx","pny","pnz","poc","pod","poe","pof","pog","poh","poi","pok","pom","pon","poo","pop","poq","pos","pot","pov","pow","pox","poy","poz","ppa","ppe","ppi","ppk","ppl","ppm","ppn","ppo","ppp","ppq","ppr","pps","ppt","ppu","pqa","pqe","pqm","pqw","pra","prb","prc","prd","pre","prf","prg","prh","pri","prk","prl","prm","prn","pro","prp","prq","prr","prs","prt","pru","prw","prx","pry","prz","psa","psc","psd","pse","psg","psh","psi","psl","psm","psn","pso","psp","psq","psr","pss","pst","psu","psw","psy","pta","pth","pti","ptn","pto","ptp","ptq","ptr","ptt","ptu","ptv","ptw","pty","pua","pub","puc","pud","pue","puf","pug","pui","puj","puk","pum","puo","pup","puq","pur","put","puu","puw","pux","puy","puz","pwa","pwb","pwg","pwi","pwm","pwn","pwo","pwr","pww","pxm","pye","pym","pyn","pys","pyu","pyx","pyy","pzn","qaa..qtz","qua","qub","quc","qud","quf","qug","quh","qui","quk","qul","qum","qun","qup","quq","qur","qus","quv","quw","qux","quy","quz","qva","qvc","qve","qvh","qvi","qvj","qvl","qvm","qvn","qvo","qvp","qvs","qvw","qvy","qvz","qwa","qwc","qwe","qwh","qwm","qws","qwt","qxa","qxc","qxh","qxl","qxn","qxo","qxp","qxq","qxr","qxs","qxt","qxu","qxw","qya","qyp","raa","rab","rac","rad","raf","rag","rah","rai","raj","rak","ral","ram","ran","rao","rap","raq","rar","ras","rat","rau","rav","raw","rax","ray","raz","rbb","rbk","rbl","rbp","rcf","rdb","rea","reb","ree","reg","rei","rej","rel","rem","ren","rer","res","ret","rey","rga","rge","rgk","rgn","rgr","rgs","rgu","rhg","rhp","ria","rie","rif","ril","rim","rin","rir","rit","riu","rjg","rji","rjs","rka","rkb","rkh","rki","rkm","rkt","rkw","rma","rmb","rmc","rmd","rme","rmf","rmg","rmh","rmi","rmk","rml","rmm","rmn","rmo","rmp","rmq","rmr","rms","rmt","rmu","rmv","rmw","rmx","rmy","rmz","rna","rnd","rng","rnl","rnn","rnp","rnr","rnw","roa","rob","roc","rod","roe","rof","rog","rol","rom","roo","rop","ror","rou","row","rpn","rpt","rri","rro","rrt","rsb","rsi","rsl","rsm","rtc","rth","rtm","rts","rtw","rub","ruc","rue","ruf","rug","ruh","rui","ruk","ruo","rup","ruq","rut","ruu","ruy","ruz","rwa","rwk","rwm","rwo","rwr","rxd","rxw","ryn","rys","ryu","rzh","saa","sab","sac","sad","sae","saf","sah","sai","saj","sak","sal","sam","sao","sap","saq","sar","sas","sat","sau","sav","saw","sax","say","saz","sba","sbb","sbc","sbd","sbe","sbf","sbg","sbh","sbi","sbj","sbk","sbl","sbm","sbn","sbo","sbp","sbq","sbr","sbs","sbt","sbu","sbv","sbw","sbx","sby","sbz","sca","scb","sce","scf","scg","sch","sci","sck","scl","scn","sco","scp","scq","scs","sct","scu","scv","scw","scx","sda","sdb","sdc","sde","sdf","sdg","sdh","sdj","sdk","sdl","sdm","sdn","sdo","sdp","sdr","sds","sdt","sdu","sdv","sdx","sdz","sea","seb","sec","sed","see","sef","seg","seh","sei","sej","sek","sel","sem","sen","seo","sep","seq","ser","ses","set","seu","sev","sew","sey","sez","sfb","sfe","sfm","sfs","sfw","sga","sgb","sgc","sgd","sge","sgg","sgh","sgi","sgj","sgk","sgl","sgm","sgn","sgo","sgp","sgr","sgs","sgt","sgu","sgw","sgx","sgy","sgz","sha","shb","shc","shd","she","shg","shh","shi","shj","shk","shl","shm","shn","sho","shp","shq","shr","shs","sht","shu","shv","shw","shx","shy","shz","sia","sib","sid","sie","sif","sig","sih","sii","sij","sik","sil","sim","sio","sip","siq","sir","sis","sit","siu","siv","siw","six","siy","siz","sja","sjb","sjd","sje","sjg","sjk","sjl","sjm","sjn","sjo","sjp","sjr","sjs","sjt","sju","sjw","ska","skb","skc","skd","ske","skf","skg","skh","ski","skj","skk","skm","skn","sko","skp","skq","skr","sks","skt","sku","skv","skw","skx","sky","skz","sla","slc","sld","sle","slf","slg","slh","sli","slj","sll","slm","sln","slp","slq","slr","sls","slt","slu","slw","slx","sly","slz","sma","smb","smc","smd","smf","smg","smh","smi","smj","smk","sml","smm","smn","smp","smq","smr","sms","smt","smu","smv","smw","smx","smy","smz","snb","snc","sne","snf","sng","snh","sni","snj","snk","snl","snm","snn","sno","snp","snq","snr","sns","snu","snv","snw","snx","sny","snz","soa","sob","soc","sod","soe","sog","soh","soi","soj","sok","sol","son","soo","sop","soq","sor","sos","sou","sov","sow","sox","soy","soz","spb","spc","spd","spe","spg","spi","spk","spl","spm","spn","spo","spp","spq","spr","sps","spt","spu","spv","spx","spy","sqa","sqh","sqj","sqk","sqm","sqn","sqo","sqq","sqr","sqs","sqt","squ","sra","srb","src","sre","srf","srg","srh","sri","srk","srl","srm","srn","sro","srq","srr","srs","srt","sru","srv","srw","srx","sry","srz","ssa","ssb","ssc","ssd","sse","ssf","ssg","ssh","ssi","ssj","ssk","ssl","ssm","ssn","sso","ssp","ssq","ssr","sss","sst","ssu","ssv","ssx","ssy","ssz","sta","stb","std","ste","stf","stg","sth","sti","stj","stk","stl","stm","stn","sto","stp","stq","str","sts","stt","stu","stv","stw","sty","sua","sub","suc","sue","sug","sui","suj","suk","sul","sum","suq","sur","sus","sut","suv","suw","sux","suy","suz","sva","svb","svc","sve","svk","svm","svr","svs","svx","swb","swc","swf","swg","swh","swi","swj","swk","swl","swm","swn","swo","swp","swq","swr","sws","swt","swu","swv","sww","swx","swy","sxb","sxc","sxe","sxg","sxk","sxl","sxm","sxn","sxo","sxr","sxs","sxu","sxw","sya","syb","syc","syd","syi","syk","syl","sym","syn","syo","syr","sys","syw","syx","syy","sza","szb","szc","szd","sze","szg","szl","szn","szp","szs","szv","szw","taa","tab","tac","tad","tae","taf","tag","tai","taj","tak","tal","tan","tao","tap","taq","tar","tas","tau","tav","taw","tax","tay","taz","tba","tbb","tbc","tbd","tbe","tbf","tbg","tbh","tbi","tbj","tbk","tbl","tbm","tbn","tbo","tbp","tbq","tbr","tbs","tbt","tbu","tbv","tbw","tbx","tby","tbz","tca","tcb","tcc","tcd","tce","tcf","tcg","tch","tci","tck","tcl","tcm","tcn","tco","tcp","tcq","tcs","tct","tcu","tcw","tcx","tcy","tcz","tda","tdb","tdc","tdd","tde","tdf","tdg","tdh","tdi","tdj","tdk","tdl","tdm","tdn","tdo","tdq","tdr","tds","tdt","tdu","tdv","tdx","tdy","tea","teb","tec","ted","tee","tef","teg","teh","tei","tek","tem","ten","teo","tep","teq","ter","tes","tet","teu","tev","tew","tex","tey","tfi","tfn","tfo","tfr","tft","tga","tgb","tgc","tgd","tge","tgf","tgg","tgh","tgi","tgj","tgn","tgo","tgp","tgq","tgr","tgs","tgt","tgu","tgv","tgw","tgx","tgy","tgz","thc","thd","the","thf","thh","thi","thk","thl","thm","thn","thp","thq","thr","ths","tht","thu","thv","thw","thx","thy","thz","tia","tic","tid","tie","tif","tig","tih","tii","tij","tik","til","tim","tin","tio","tip","tiq","tis","tit","tiu","tiv","tiw","tix","tiy","tiz","tja","tjg","tji","tjl","tjm","tjn","tjo","tjs","tju","tjw","tka","tkb","tkd","tke","tkf","tkg","tkk","tkl","tkm","tkn","tkp","tkq","tkr","tks","tkt","tku","tkv","tkw","tkx","tkz","tla","tlb","tlc","tld","tlf","tlg","tlh","tli","tlj","tlk","tll","tlm","tln","tlo","tlp","tlq","tlr","tls","tlt","tlu","tlv","tlw","tlx","tly","tma","tmb","tmc","tmd","tme","tmf","tmg","tmh","tmi","tmj","tmk","tml","tmm","tmn","tmo","tmp","tmq","tmr","tms","tmt","tmu","tmv","tmw","tmy","tmz","tna","tnb","tnc","tnd","tne","tnf","tng","tnh","tni","tnk","tnl","tnm","tnn","tno","tnp","tnq","tnr","tns","tnt","tnu","tnv","tnw","tnx","tny","tnz","tob","toc","tod","toe","tof","tog","toh","toi","toj","tol","tom","too","top","toq","tor","tos","tou","tov","tow","tox","toy","toz","tpa","tpc","tpe","tpf","tpg","tpi","tpj","tpk","tpl","tpm","tpn","tpo","tpp","tpq","tpr","tpt","tpu","tpv","tpw","tpx","tpy","tpz","tqb","tql","tqm","tqn","tqo","tqp","tqq","tqr","tqt","tqu","tqw","tra","trb","trc","trd","tre","trf","trg","trh","tri","trj","trk","trl","trm","trn","tro","trp","trq","trr","trs","trt","tru","trv","trw","trx","try","trz","tsa","tsb","tsc","tsd","tse","tsf","tsg","tsh","tsi","tsj","tsk","tsl","tsm","tsp","tsq","tsr","tss","tst","tsu","tsv","tsw","tsx","tsy","tsz","tta","ttb","ttc","ttd","tte","ttf","ttg","tth","tti","ttj","ttk","ttl","ttm","ttn","tto","ttp","ttq","ttr","tts","ttt","ttu","ttv","ttw","tty","ttz","tua","tub","tuc","tud","tue","tuf","tug","tuh","tui","tuj","tul","tum","tun","tuo","tup","tuq","tus","tut","tuu","tuv","tuw","tux","tuy","tuz","tva","tvd","tve","tvk","tvl","tvm","tvn","tvo","tvs","tvt","tvu","tvw","tvy","twa","twb","twc","twd","twe","twf","twg","twh","twl","twm","twn","two","twp","twq","twr","twt","twu","tww","twx","twy","txa","txb","txc","txe","txg","txh","txi","txj","txm","txn","txo","txq","txr","txs","txt","txu","txx","txy","tya","tye","tyh","tyi","tyj","tyl","tyn","typ","tyr","tys","tyt","tyu","tyv","tyx","tyz","tza","tzh","tzj","tzl","tzm","tzn","tzo","tzx","uam","uan","uar","uba","ubi","ubl","ubr","ubu","uby","uda","ude","udg","udi","udj","udl","udm","udu","ues","ufi","uga","ugb","uge","ugn","ugo","ugy","uha","uhn","uis","uiv","uji","uka","ukg","ukh","ukk","ukl","ukp","ukq","uks","uku","ukw","uky","ula","ulb","ulc","ule","ulf","uli","ulk","ull","ulm","uln","ulu","ulw","uma","umb","umc","umd","umg","umi","umm","umn","umo","ump","umr","ums","umu","una","und","une","ung","unk","unm","unn","unp","unr","unu","unx","unz","uok","upi","upv","ura","urb","urc","ure","urf","urg","urh","uri","urj","urk","url","urm","urn","uro","urp","urr","urt","uru","urv","urw","urx","ury","urz","usa","ush","usi","usk","usp","usu","uta","ute","utp","utr","utu","uum","uun","uur","uuu","uve","uvh","uvl","uwa","uya","uzn","uzs","vaa","vae","vaf","vag","vah","vai","vaj","val","vam","van","vao","vap","var","vas","vau","vav","vay","vbb","vbk","vec","ved","vel","vem","veo","vep","ver","vgr","vgt","vic","vid","vif","vig","vil","vin","vis","vit","viv","vka","vki","vkj","vkk","vkl","vkm","vko","vkp","vkt","vku","vlp","vls","vma","vmb","vmc","vmd","vme","vmf","vmg","vmh","vmi","vmj","vmk","vml","vmm","vmp","vmq","vmr","vms","vmu","vmv","vmw","vmx","vmy","vmz","vnk","vnm","vnp","vor","vot","vra","vro","vrs","vrt","vsi","vsl","vsv","vto","vum","vun","vut","vwa","waa","wab","wac","wad","wae","waf","wag","wah","wai","waj","wak","wal","wam","wan","wao","wap","waq","war","was","wat","wau","wav","waw","wax","way","waz","wba","wbb","wbe","wbf","wbh","wbi","wbj","wbk","wbl","wbm","wbp","wbq","wbr","wbs","wbt","wbv","wbw","wca","wci","wdd","wdg","wdj","wdk","wdu","wdy","wea","wec","wed","weg","weh","wei","wem","wen","weo","wep","wer","wes","wet","weu","wew","wfg","wga","wgb","wgg","wgi","wgo","wgu","wgw","wgy","wha","whg","whk","whu","wib","wic","wie","wif","wig","wih","wii","wij","wik","wil","wim","win","wir","wit","wiu","wiv","wiw","wiy","wja","wji","wka","wkb","wkd","wkl","wku","wkw","wky","wla","wlc","wle","wlg","wli","wlk","wll","wlm","wlo","wlr","wls","wlu","wlv","wlw","wlx","wly","wma","wmb","wmc","wmd","wme","wmh","wmi","wmm","wmn","wmo","wms","wmt","wmw","wmx","wnb","wnc","wnd","wne","wng","wni","wnk","wnm","wnn","wno","wnp","wnu","wnw","wny","woa","wob","woc","wod","woe","wof","wog","woi","wok","wom","won","woo","wor","wos","wow","woy","wpc","wra","wrb","wrd","wrg","wrh","wri","wrk","wrl","wrm","wrn","wro","wrp","wrr","wrs","wru","wrv","wrw","wrx","wry","wrz","wsa","wsg","wsi","wsk","wsr","wss","wsu","wsv","wtf","wth","wti","wtk","wtm","wtw","wua","wub","wud","wuh","wul","wum","wun","wur","wut","wuu","wuv","wux","wuy","wwa","wwb","wwo","wwr","www","wxa","wxw","wya","wyb","wyi","wym","wyr","wyy","xaa","xab","xac","xad","xae","xag","xai","xaj","xak","xal","xam","xan","xao","xap","xaq","xar","xas","xat","xau","xav","xaw","xay","xba","xbb","xbc","xbd","xbe","xbg","xbi","xbj","xbm","xbn","xbo","xbp","xbr","xbw","xbx","xby","xcb","xcc","xce","xcg","xch","xcl","xcm","xcn","xco","xcr","xct","xcu","xcv","xcw","xcy","xda","xdc","xdk","xdm","xdo","xdy","xeb","xed","xeg","xel","xem","xep","xer","xes","xet","xeu","xfa","xga","xgb","xgd","xgf","xgg","xgi","xgl","xgm","xgn","xgr","xgu","xgw","xha","xhc","xhd","xhe","xhr","xht","xhu","xhv","xia","xib","xii","xil","xin","xip","xir","xis","xiv","xiy","xjb","xjt","xka","xkb","xkc","xkd","xke","xkf","xkg","xkh","xki","xkj","xkk","xkl","xkn","xko","xkp","xkq","xkr","xks","xkt","xku","xkv","xkw","xkx","xky","xkz","xla","xlb","xlc","xld","xle","xlg","xli","xln","xlo","xlp","xls","xlu","xly","xma","xmb","xmc","xmd","xme","xmf","xmg","xmh","xmj","xmk","xml","xmm","xmn","xmo","xmp","xmq","xmr","xms","xmt","xmu","xmv","xmw","xmx","xmy","xmz","xna","xnb","xnd","xng","xnh","xni","xnk","xnn","xno","xnr","xns","xnt","xnu","xny","xnz","xoc","xod","xog","xoi","xok","xom","xon","xoo","xop","xor","xow","xpa","xpc","xpe","xpg","xpi","xpj","xpk","xpm","xpn","xpo","xpp","xpq","xpr","xps","xpt","xpu","xpy","xqa","xqt","xra","xrb","xrd","xre","xrg","xri","xrm","xrn","xrq","xrr","xrt","xru","xrw","xsa","xsb","xsc","xsd","xse","xsh","xsi","xsj","xsl","xsm","xsn","xso","xsp","xsq","xsr","xss","xsu","xsv","xsy","xta","xtb","xtc","xtd","xte","xtg","xth","xti","xtj","xtl","xtm","xtn","xto","xtp","xtq","xtr","xts","xtt","xtu","xtv","xtw","xty","xtz","xua","xub","xud","xug","xuj","xul","xum","xun","xuo","xup","xur","xut","xuu","xve","xvi","xvn","xvo","xvs","xwa","xwc","xwd","xwe","xwg","xwj","xwk","xwl","xwo","xwr","xwt","xww","xxb","xxk","xxm","xxr","xxt","xya","xyb","xyj","xyk","xyl","xyt","xyy","xzh","xzm","xzp","yaa","yab","yac","yad","yae","yaf","yag","yah","yai","yaj","yak","yal","yam","yan","yao","yap","yaq","yar","yas","yat","yau","yav","yaw","yax","yay","yaz","yba","ybb","ybd","ybe","ybh","ybi","ybj","ybk","ybl","ybm","ybn","ybo","ybx","yby","ych","ycl","ycn","ycp","yda","ydd","yde","ydg","ydk","yds","yea","yec","yee","yei","yej","yel","yen","yer","yes","yet","yeu","yev","yey","yga","ygi","ygl","ygm","ygp","ygr","ygs","ygu","ygw","yha","yhd","yhl","yhs","yia","yif","yig","yih","yii","yij","yik","yil","yim","yin","yip","yiq","yir","yis","yit","yiu","yiv","yix","yiy","yiz","yka","ykg","yki","ykk","ykl","ykm","ykn","yko","ykr","ykt","yku","yky","yla","ylb","yle","ylg","yli","yll","ylm","yln","ylo","ylr","ylu","yly","yma","ymb","ymc","ymd","yme","ymg","ymh","ymi","ymk","yml","ymm","ymn","ymo","ymp","ymq","ymr","yms","ymt","ymx","ymz","yna","ynd","yne","yng","ynh","ynk","ynl","ynn","yno","ynq","yns","ynu","yob","yog","yoi","yok","yol","yom","yon","yos","yot","yox","yoy","ypa","ypb","ypg","yph","ypk","ypm","ypn","ypo","ypp","ypz","yra","yrb","yre","yri","yrk","yrl","yrm","yrn","yro","yrs","yrw","yry","ysc","ysd","ysg","ysl","ysn","yso","ysp","ysr","yss","ysy","yta","ytl","ytp","ytw","yty","yua","yub","yuc","yud","yue","yuf","yug","yui","yuj","yuk","yul","yum","yun","yup","yuq","yur","yut","yuu","yuw","yux","yuy","yuz","yva","yvt","ywa","ywg","ywl","ywn","ywq","ywr","ywt","ywu","yww","yxa","yxg","yxl","yxm","yxu","yxy","yyr","yyu","yyz","yzg","yzk","zaa","zab","zac","zad","zae","zaf","zag","zah","zai","zaj","zak","zal","zam","zao","zap","zaq","zar","zas","zat","zau","zav","zaw","zax","zay","zaz","zbc","zbe","zbl","zbt","zbw","zca","zch","zdj","zea","zeg","zeh","zen","zga","zgb","zgh","zgm","zgn","zgr","zhb","zhd","zhi","zhn","zhw","zhx","zia","zib","zik","zil","zim","zin","zir","ziw","ziz","zka","zkb","zkd","zkg","zkh","zkk","zkn","zko","zkp","zkr","zkt","zku","zkv","zkz","zle","zlj","zlm","zln","zlq","zls","zlw","zma","zmb","zmc","zmd","zme","zmf","zmg","zmh","zmi","zmj","zmk","zml","zmm","zmn","zmo","zmp","zmq","zmr","zms","zmt","zmu","zmv","zmw","zmx","zmy","zmz","zna","znd","zne","zng","znk","zns","zoc","zoh","zom","zoo","zoq","zor","zos","zpa","zpb","zpc","zpd","zpe","zpf","zpg","zph","zpi","zpj","zpk","zpl","zpm","zpn","zpo","zpp","zpq","zpr","zps","zpt","zpu","zpv","zpw","zpx","zpy","zpz","zqe","zra","zrg","zrn","zro","zrp","zrs","zsa","zsk","zsl","zsm","zsr","zsu","zte","ztg","ztl","ztm","ztn","ztp","ztq","zts","ztt","ztu","ztx","zty","zua","zuh","zum","zun","zuy","zwa","zxx","zyb","zyg","zyj","zyn","zyp","zza","zzj"] +;return axe.utils.validLangs=function(){"use strict";return I},commons}()})}("object"==typeof window?window:this); \ No newline at end of file
diff --git a/tools/mb/mb_config.pyl b/tools/mb/mb_config.pyl index 89cb5203..fc2f227 100644 --- a/tools/mb/mb_config.pyl +++ b/tools/mb/mb_config.pyl
@@ -114,12 +114,13 @@ 'Chromium Linux32 Goma Canary (clobber)': 'release_bot_x86', 'Chromium Mac 10.10 MacViews': 'mac_views_browser_release_bot', 'Chromium Mac 10.11': 'release_bot', - 'Chromium Mac 10.11 Force Mac Toolchain': 'release_bot_mac_hermetic', + 'Chromium Mac 10.11 Force Mac Toolchain': 'release_bot_mac_new_sdk', 'Chromium Mac 10.9 Goma Canary': 'release_bot', 'Chromium Mac 10.9 Goma Canary (clobber)': 'release_bot', 'Chromium Mac 10.9 Goma Canary (dbg)': 'debug_bot', 'Chromium Mac 10.9 Goma Canary (dbg)(clobber)': 'debug_bot', 'Chromium Mac Goma Canary LocalOutputCache': 'release_bot', + 'Chromium Win 10 GCE Tests': 'release_bot_x86_minimal_symbols', 'Chromium Win PGO Builder': { '1': 'official_optimize_chrome_pgo_phase_1_x86', '2': 'official_optimize_chrome_pgo_phase_2_x86', @@ -1432,8 +1433,8 @@ 'release_bot', 'chrome_with_codecs', ], - 'release_bot_mac_hermetic': [ - 'release_bot', 'mac_hermetic_toolchain', + 'release_bot_mac_new_sdk': [ + 'release_bot', 'mac_new_sdk', ], 'release_bot_mac_strip': [ @@ -1775,8 +1776,8 @@ 'mixins': ['chrome_with_codecs'], }, - 'mac_hermetic_toolchain': { - 'gn_args': 'use_system_xcode=false', + 'mac_new_sdk': { + 'gn_args': 'mac_sdk_min=10.12', }, 'headless': {
diff --git a/tools/metrics/histograms/enums.xml b/tools/metrics/histograms/enums.xml index b732eff..692bb60 100644 --- a/tools/metrics/histograms/enums.xml +++ b/tools/metrics/histograms/enums.xml
@@ -18061,6 +18061,15 @@ <int value="1" label="Google CAPTCHA solved"/> </enum> +<enum name="GoogleFaviconServerRequestStatus"> + <int value="0" label="Success"/> + <int value="1" label="Failure (connection error, no HTTP response)"/> + <int value="2" label="Failure (HTTP error)"/> + <int value="3" label="Failure (previous HTTP error cached)"/> + <int value="4" label="Failure (on write to database)"/> + <int value="5" label="Failure (invalid request)"/> +</enum> + <enum name="GoogleNowCardTypeId"> <summary> Represents a card type ID. See cardTypeId in @@ -22721,6 +22730,7 @@ <int value="-867087281" label="enable-virtual-keyboard"/> <int value="-866993841" label="OfflinePagesCTV2:disabled"/> <int value="-864266073" label="cros-regions-mode"/> + <int value="-864234985" label="UseDdljsonApi:enabled"/> <int value="-864205629" label="enable-offline-load-stale-cache"/> <int value="-861678473" label="disable-offer-upload-credit-cards"/> <int value="-861343291" label="ChromeHome:disabled"/> @@ -22858,6 +22868,7 @@ <int value="-353182790" label="ConsistentOmniboxGeolocation:disabled"/> <int value="-351552989" label="disable-hosted-apps-in-windows"/> <int value="-351127770" label="enable-offline-pages-as-bookmarks"/> + <int value="-349437334" label="UseDdljsonApi:disabled"/> <int value="-349057743" label="extensions-on-chrome-urls"/> <int value="-345838366" label="enable-hosted-apps-in-windows"/> <int value="-345324571" label="enable-quirks-client"/>
diff --git a/tools/metrics/histograms/histograms.xml b/tools/metrics/histograms/histograms.xml index 40eaa90..b29ad08 100644 --- a/tools/metrics/histograms/histograms.xml +++ b/tools/metrics/histograms/histograms.xml
@@ -22761,6 +22761,9 @@ <histogram name="GCM.DataMessageReceivedHasRegisteredApp" enum="BooleanRegistered"> + <obsolete> + No longer used starting with Chrome 61 as the check was removed. + </obsolete> <owner>peter@chromium.org</owner> <summary> Records whether a matching registration was found for each received @@ -45257,15 +45260,49 @@ </histogram> <histogram base="true" + name="NewTabPage.ContentSuggestions.TimeUntilFirstShownTrigger" units="ms"> + <owner>jkrcal@chromium.org</owner> + <summary> + Android: The time since the last fetch, recorded upon the first on-shown + fetch trigger. The first on-shown trigger does not necessarily cause a fetch + (if it comes before the end of the respective scheduling interval). This + metric is recorded at most once after each fetch (and additionaly at most + once after each startup of Chrome before the next fetch). This is used to + understand how changing scheduling intervals will impact traffic of + background fetches. + </summary> +</histogram> + +<histogram base="true" name="NewTabPage.ContentSuggestions.TimeUntilFirstSoftTrigger" units="ms"> + <obsolete> + Deprecated as of July 2017, in favor of + NewTabPage.ContentSuggestions.TimeUntilFirstShownTrigger and + NewTabPage.ContentSuggestions.TimeUntilFirstStartupTrigger. + </obsolete> <owner>jkrcal@chromium.org</owner> <summary> Android: The time since the last fetch, recorded upon the first soft fetch trigger. The first soft trigger does not necessarily cause a fetch (if it comes before the end of the respective scheduling interval). This metric is - recorded at most once (per lifetime of a Chrome instance) after each fetch. - This is used to understand how changing scheduling intervals will impact - traffic of background fetches. + recorded at most once after each fetch (and additionaly at most once after + each startup of Chrome before the next fetch). This is used to understand + how changing scheduling intervals will impact traffic of background fetches. + </summary> +</histogram> + +<histogram base="true" + name="NewTabPage.ContentSuggestions.TimeUntilFirstStartupTrigger" + units="ms"> + <owner>jkrcal@chromium.org</owner> + <summary> + Android: The time since the last fetch, recorded upon the first startup + fetch trigger. The first startup trigger does not necessarily cause a fetch + (if it comes before the end of the respective scheduling interval). This + metric is recorded at most once after each fetch (and additionaly at most + once after each startup of Chrome before the next fetch). This is used to + understand how changing scheduling intervals will impact traffic of + background fetches. </summary> </histogram> @@ -46372,6 +46409,16 @@ </summary> </histogram> +<histogram name="NewTabPage.TileFaviconFetchStatus.Server" + enum="GoogleFaviconServerRequestStatus"> + <owner>jkrcal@chromium.org</owner> + <summary> + Mobile only. The result of fetching a favicon for a tile on the New Tab + Page. This is recorded for each gray MostVisited tile on the New Tab Page + once per impression of the tile. + </summary> +</histogram> + <histogram name="NewTabPage.TileFaviconFetchSuccess.Popular" enum="BooleanSuccess"> <owner>jkrcal@chromium.org</owner> @@ -46384,6 +46431,9 @@ <histogram name="NewTabPage.TileFaviconFetchSuccess.Server" enum="BooleanSuccess"> + <obsolete> + Deprecated 06/2017. Replaced by NewTabPage.TileFaviconFetchStatus.Server. + </obsolete> <owner>jkrcal@chromium.org</owner> <summary> Mobile only. The result of fetching a favicon for a tile on the New Tab @@ -80489,6 +80539,10 @@ <histogram name="UMA.FileMetricsProvider.EmbeddedProfile.DroppedFileAge" units="minutes"> + <obsolete> + Deprecated 07/2017. Was only for short-term analysis. About 95% of dropped + files were less than 1 day old. + </obsolete> <owner>asvitkine@chromium.org</owner> <owner>bcwhite@chromium.org</owner> <summary> @@ -97560,11 +97614,21 @@ </histogram_suffixes> <histogram_suffixes name="UserClasses" separator="."> + <affected-histogram + name="NewTabPage.ContentSuggestions.TimeUntilFirstShownTrigger"/> <suffix name="RareNTPUser" label="Rare NTP user"/> <suffix name="ActiveNTPUser" label="Active NTP user"/> <suffix name="ActiveSuggestionsConsumer" label="Active suggestions consumer"/> <affected-histogram - name="NewTabPage.ContentSuggestions.TimeUntilFirstSoftTrigger"/> + name="NewTabPage.ContentSuggestions.TimeUntilFirstSoftTrigger"> + <obsolete> + Deprecated as of July 2017, in favor of + NewTabPage.ContentSuggestions.TimeUntilFirstShownTrigger and + NewTabPage.ContentSuggestions.TimeUntilFirstStartupTrigger. + </obsolete> + </affected-histogram> + <affected-histogram + name="NewTabPage.ContentSuggestions.TimeUntilFirstStartupTrigger"/> <affected-histogram name="NewTabPage.ContentSuggestions.TimeUntilPersistentFetch"/> <affected-histogram name="NewTabPage.ContentSuggestions.TimeUntilSoftFetch"/>
diff --git a/tools/metrics/ukm/ukm.xml b/tools/metrics/ukm/ukm.xml index d9cb199..3994165 100644 --- a/tools/metrics/ukm/ukm.xml +++ b/tools/metrics/ukm/ukm.xml
@@ -489,6 +489,55 @@ <metric name="AudioVideo.SRC"/> </event> +<event name="Memory.Experimental"> + <owner>erikchen@chromium.org</owner> + <summary> + Metrics associated with memory consumption, in MB. + </summary> + <metric name="BlinkGC"> + <summary> + Measure of memory consumed by Oilpan. + </summary> + </metric> + <metric name="CommandBuffer"> + <summary> + Measure of memory consumed by GL command buffer. + </summary> + </metric> + <metric name="Malloc"> + <summary> + Measure of memory allocated by malloc. + </summary> + </metric> + <metric name="PartitionAlloc"> + <summary> + Measure of memory allocated by PartitionAlloc. + </summary> + </metric> + <metric name="PrivateMemoryFootprint"> + <summary> + Measure of total memory consumed by process. + </summary> + </metric> + <metric name="ProcessType"> + <summary> + Type of process (e.g. browser, renderer, GPU --- see + services/resource_coordinator/public/interfaces/memory_instrumentation/memory_instrumentation.mojom) + of associated metrics. + </summary> + </metric> + <metric name="Resident"> + <summary> + Size of process' working set. + </summary> + </metric> + <metric name="V8"> + <summary> + Measure of memory consumed by V8. + </summary> + </metric> +</event> + <event name="PageDomainInfo"> <owner>uthakore@chromium.org</owner> <summary>
diff --git a/tools/perf/page_sets/system_health/expectations.py b/tools/perf/page_sets/system_health/expectations.py index 93b3b4c..3a4248d 100644 --- a/tools/perf/page_sets/system_health/expectations.py +++ b/tools/perf/page_sets/system_health/expectations.py
@@ -28,9 +28,6 @@ [expectations.ALL_WIN], 'crbug.com/728152') self.DisableStory('browse:news:cnn', [expectations.ALL_MAC], 'crbug.com/728576') - self.DisableStory('browse:media:flickr_infinite_scroll', - [expectations.ALL], - 'crbug.com/728785') class SystemHealthDesktopMemoryExpectations(expectations.StoryExpectations): @@ -59,9 +56,8 @@ [expectations.ALL_WIN], 'crbug.com/728152') self.DisableStory('browse:news:cnn', [expectations.ALL_MAC], 'crbug.com/728576') - self.DisableStory('browse:media:flickr_infinite_scroll', - [expectations.ALL], - 'crbug.com/728785') + self.DisableStory('browse:social:twitter_infinite_scroll', + [expectations.ALL_WIN], 'crbug.com/728464') class SystemHealthMobileCommonExpectations(expectations.StoryExpectations): @@ -82,8 +78,6 @@ 'crbug.com/728081') self.DisableStory('browse:social:facebook_infinite_scroll', [expectations.ALL], 'crbug.com/728152') - self.DisableStory('browse:media:flickr_infinite_scroll', - [expectations.ALL], 'crbug.com/728785') self.DisableStory( 'load:tools:drive', [expectations.ANDROID_NEXUS5X, expectations.ANDROID_WEBVIEW], @@ -122,8 +116,6 @@ 'crbug.com/728081') self.DisableStory('browse:social:facebook_infinite_scroll', [expectations.ALL], 'crbug.com/728152') - self.DisableStory('browse:media:flickr_infinite_scroll', - [expectations.ALL], 'crbug.com/728785') self.DisableStory( 'load:tools:drive', [expectations.ANDROID_NEXUS5X, expectations.ANDROID_WEBVIEW], @@ -163,9 +155,6 @@ [expectations.ALL_MAC], 'crbug.com/728576') self.DisableStory('browse:social:twitter_infinite_scroll', [expectations.ALL], 'crbug.com/728464') - self.DisableStory('browse:media:flickr_infinite_scroll', - [expectations.ALL, expectations.ALL_WIN], - 'crbug.com/728785') # Should only include browse:*:* stories. class V8BrowsingMobileExpecations(expectations.StoryExpectations): @@ -178,8 +167,6 @@ 'crbug.com/728081') self.DisableStory('browse:social:facebook_infinite_scroll', [expectations.ALL], 'crbug.com/728152') - self.DisableStory('browse:media:flickr_infinite_scroll', - [expectations.ALL], 'crbug.com/728785') # TODO(rnephew): This disabling should move to CanRunOnBrowser. self.DisableStory('browse:chrome:omnibox', [expectations.ANDROID_WEBVIEW],
diff --git a/tools/win/pe_summarize.py b/tools/win/pe_summarize.py index 3fbb9207..13e4a4b2 100644 --- a/tools/win/pe_summarize.py +++ b/tools/win/pe_summarize.py
@@ -57,6 +57,13 @@ import sys +def _FindSection(section_list, section_name): + for i in range(len(section_list)): + if section_name == section_list[i][0]: + return i + return -1 + + def main(): if len(sys.argv) < 2: print r'Usage: %s PEFileName [OtherPeFileNames...]' % sys.argv[0] @@ -119,16 +126,25 @@ print 'Memory size change from %s to %s' % (last_pe_path, pe_path) total_delta = 0 for i in range(len(results)): - # Make sure the current/last section names match or else the deltas - # will be meaningless. Mismatches can occur when comparing 32-bit and - # 64-bit binaries. - if results[i][0] != last_results[i][0]: - print "Names for section[%d] don't match. Aborting." % i - return 0 - delta = results[i][1] - last_results[i][1] + section_name = results[i][0] + # Find a matching section name. Mismatches can occur when comparing + # 32-bit and 64-bit binaries. They can also occur when one of the + # binaries pulls in code that defines custom sections such as .rodata. + last_i = _FindSection(last_results, section_name) + delta = results[i][1] + if last_i >= 0: + delta -= last_results[last_i][1] total_delta += delta if delta: - print '%12s: %7d bytes change' % (results[i][0], delta) + print '%12s: %7d bytes change' % (section_name, delta) + for last_i in range(len(last_results)): + section_name = last_results[last_i][0] + # Find sections that exist only in last_results. + i = _FindSection(results, section_name) + if i < 0: + delta = -last_results[last_i][1] + total_delta += delta + print '%12s: %7d bytes change' % (section_name, delta) print 'Total change: %7d bytes' % total_delta last_pe_filepart = pe_filepart last_pe_path = pe_path
diff --git a/ui/app_list/views/apps_grid_view.cc b/ui/app_list/views/apps_grid_view.cc index ae1bb11..00c3387 100644 --- a/ui/app_list/views/apps_grid_view.cc +++ b/ui/app_list/views/apps_grid_view.cc
@@ -962,14 +962,10 @@ SetSelectedItemByIndex(Index(target_page, target_slot)); } -void AppsGridView::CalculateIdealBounds() { +const gfx::Vector2d AppsGridView::CalculateTransitionOffset( + int page_of_view) const { gfx::Size grid_size = GetTileGridSize(); - // Page size including padding pixels. A tile.x + page_width means the same - // tile slot in the next page; similarly for tile.y + page_height. - const int page_width = grid_size.width() + kPagePadding; - const int page_height = grid_size.height() + kPagePadding; - // If there is a transition, calculates offset for current and target page. const int current_page = pagination_model_.selected_page(); const PaginationModel::Transition& transition = @@ -979,6 +975,44 @@ // Transition to previous page means negative offset. const int dir = transition.target_page > current_page ? -1 : 1; + int x_offset = 0; + int y_offset = 0; + + if (pagination_controller_->scroll_axis() == + PaginationController::SCROLL_AXIS_HORIZONTAL) { + // Page size including padding pixels. A tile.x + page_width means the same + // tile slot in the next page. + const int page_width = grid_size.width() + kPagePadding; + if (page_of_view < current_page) + x_offset = -page_width; + else if (page_of_view > current_page) + x_offset = page_width; + + if (is_valid) { + if (page_of_view == current_page || + page_of_view == transition.target_page) { + x_offset += transition.progress * page_width * dir; + } + } + } else { + const int page_height = grid_size.height() + kPagePadding; + if (page_of_view < current_page) + y_offset = -page_height; + else if (page_of_view > current_page) + y_offset = page_height; + + if (is_valid) { + if (page_of_view == current_page || + page_of_view == transition.target_page) { + y_offset += transition.progress * page_height * dir; + } + } + } + + return gfx::Vector2d(x_offset, y_offset); +} + +void AppsGridView::CalculateIdealBounds() { const int total_views = view_model_.view_size() + pulsing_blocks_model_.view_size(); int slot_index = 0; @@ -994,41 +1028,11 @@ view_index = GetIndexFromModelIndex(slot_index); } - // Decide the x or y offset for current item. - int x_offset = 0; - int y_offset = 0; - - if (pagination_controller_->scroll_axis() == - PaginationController::SCROLL_AXIS_HORIZONTAL) { - if (view_index.page < current_page) - x_offset = -page_width; - else if (view_index.page > current_page) - x_offset = page_width; - - if (is_valid) { - if (view_index.page == current_page || - view_index.page == transition.target_page) { - x_offset += transition.progress * page_width * dir; - } - } - } else { - if (view_index.page < current_page) - y_offset = -page_height; - else if (view_index.page > current_page) - y_offset = page_height; - - if (is_valid) { - if (view_index.page == current_page || - view_index.page == transition.target_page) { - y_offset += transition.progress * page_height * dir; - } - } - } - const int row = view_index.slot / cols_; const int col = view_index.slot % cols_; gfx::Rect tile_slot = GetExpectedTileBounds(row, col); - tile_slot.Offset(x_offset, y_offset); + const gfx::Vector2d offset = CalculateTransitionOffset(view_index.page); + tile_slot.Offset(offset.x(), offset.y()); if (i < view_model_.view_size()) { view_model_.set_ideal_bounds(i, tile_slot); } else {
diff --git a/ui/app_list/views/apps_grid_view.h b/ui/app_list/views/apps_grid_view.h index 932f3c9..0c8512c 100644 --- a/ui/app_list/views/apps_grid_view.h +++ b/ui/app_list/views/apps_grid_view.h
@@ -276,6 +276,10 @@ void MoveSelected(int page_delta, int slot_x_delta, int slot_y_delta); + // Calculates the offset for |page_of_view| based on current page and + // transition target page. + const gfx::Vector2d CalculateTransitionOffset(int page_of_view) const; + void CalculateIdealBounds(); void AnimateToIdealBounds();
diff --git a/ui/base/accelerators/accelerator.cc b/ui/base/accelerators/accelerator.cc index 8b8d14e..7bbddf42 100644 --- a/ui/base/accelerators/accelerator.cc +++ b/ui/base/accelerators/accelerator.cc
@@ -42,19 +42,22 @@ KeyState key_state) : key_code_(key_code), key_state_(key_state), - modifiers_(modifiers & kInterestingFlagsMask) {} + modifiers_(modifiers & kInterestingFlagsMask), + interrupted_by_mouse_event_(false) {} Accelerator::Accelerator(const KeyEvent& key_event) : key_code_(key_event.key_code()), key_state_(key_event.type() == ET_KEY_PRESSED ? KeyState::PRESSED : KeyState::RELEASED), // |modifiers_| may include the repeat flag. - modifiers_(key_event.flags() & kInterestingFlagsMask) {} + modifiers_(key_event.flags() & kInterestingFlagsMask), + interrupted_by_mouse_event_(false) {} Accelerator::Accelerator(const Accelerator& accelerator) { key_code_ = accelerator.key_code_; key_state_ = accelerator.key_state_; modifiers_ = accelerator.modifiers_; + interrupted_by_mouse_event_ = accelerator.interrupted_by_mouse_event_; if (accelerator.platform_accelerator_) platform_accelerator_ = accelerator.platform_accelerator_->CreateCopy(); } @@ -72,6 +75,7 @@ key_code_ = accelerator.key_code_; key_state_ = accelerator.key_state_; modifiers_ = accelerator.modifiers_; + interrupted_by_mouse_event_ = accelerator.interrupted_by_mouse_event_; if (accelerator.platform_accelerator_) platform_accelerator_ = accelerator.platform_accelerator_->CreateCopy(); else @@ -94,7 +98,8 @@ bool Accelerator::operator ==(const Accelerator& rhs) const { return (key_code_ == rhs.key_code_) && (key_state_ == rhs.key_state_) && (MaskOutKeyEventFlags(modifiers_) == - MaskOutKeyEventFlags(rhs.modifiers_)); + MaskOutKeyEventFlags(rhs.modifiers_)) && + interrupted_by_mouse_event_ == rhs.interrupted_by_mouse_event_; } bool Accelerator::operator !=(const Accelerator& rhs) const {
diff --git a/ui/base/accelerators/accelerator.h b/ui/base/accelerators/accelerator.h index f5ee417..3d6b422 100644 --- a/ui/base/accelerators/accelerator.h +++ b/ui/base/accelerators/accelerator.h
@@ -89,6 +89,14 @@ return platform_accelerator_.get(); } + void set_interrupted_by_mouse_event(bool interrupted_by_mouse_event) { + interrupted_by_mouse_event_ = interrupted_by_mouse_event; + } + + bool interrupted_by_mouse_event() const { + return interrupted_by_mouse_event_; + } + private: // The keycode (VK_...). KeyboardCode key_code_; @@ -102,6 +110,13 @@ // TODO: this is only used in Mac code and should be removed from here. // http://crbug.com/702823. std::unique_ptr<PlatformAccelerator> platform_accelerator_; + + // Whether the accelerator is interrupted by a mouse press/release. This is + // optionally used by AcceleratorController. Even this is set to true, the + // accelerator may still be handled successfully. (Currently only + // TOGGLE_APP_LIST is disabled when mouse press/release occurs between + // search key down and up. See crbug.com/665897) + bool interrupted_by_mouse_event_; }; // An interface that classes that want to register for keyboard accelerators
diff --git a/ui/base/accelerators/accelerator_history.cc b/ui/base/accelerators/accelerator_history.cc index 94e78da2..e4fbc81 100644 --- a/ui/base/accelerators/accelerator_history.cc +++ b/ui/base/accelerators/accelerator_history.cc
@@ -31,4 +31,11 @@ } } +void AcceleratorHistory::InterruptCurrentAccelerator() { + if (current_accelerator_.key_state() == Accelerator::KeyState::PRESSED) { + // Only interrupts pressed keys. + current_accelerator_.set_interrupted_by_mouse_event(true); + } +} + } // namespace ui
diff --git a/ui/base/accelerators/accelerator_history.h b/ui/base/accelerators/accelerator_history.h index ee63a572..bc944cc 100644 --- a/ui/base/accelerators/accelerator_history.h +++ b/ui/base/accelerators/accelerator_history.h
@@ -35,6 +35,8 @@ // stored one. void StoreCurrentAccelerator(const Accelerator& accelerator); + void InterruptCurrentAccelerator(); + private: Accelerator current_accelerator_; Accelerator previous_accelerator_;
diff --git a/ui/compositor/DEPS b/ui/compositor/DEPS index 567f270..1db43fd 100644 --- a/ui/compositor/DEPS +++ b/ui/compositor/DEPS
@@ -1,6 +1,7 @@ include_rules = [ "+cc", "-cc/blink", + "+components/viz/common/quads", "+components/viz/host", "+gpu/command_buffer/client/gles2_interface.h", "+services/ui/public/cpp",
diff --git a/ui/compositor/compositor.cc b/ui/compositor/compositor.cc index d851a9b..513fba2 100644 --- a/ui/compositor/compositor.cc +++ b/ui/compositor/compositor.cc
@@ -15,6 +15,7 @@ #include "base/message_loop/message_loop.h" #include "base/metrics/histogram_macros.h" #include "base/stl_util.h" +#include "base/strings/string_number_conversions.h" #include "base/strings/string_split.h" #include "base/strings/string_util.h" #include "base/sys_info.h" @@ -34,6 +35,7 @@ #include "cc/surfaces/local_surface_id_allocator.h" #include "cc/trees/layer_tree_host.h" #include "cc/trees/layer_tree_settings.h" +#include "components/viz/common/quads/resource_format.h" #include "third_party/skia/include/core/SkBitmap.h" #include "ui/compositor/compositor_observer.h" #include "ui/compositor/compositor_switches.h" @@ -84,6 +86,15 @@ refresh_rate_ = context_factory_->GetRefreshRate(); settings.main_frame_before_activation_enabled = false; + if (command_line->HasSwitch(switches::kLimitFps)) { + std::string fps_str = + command_line->GetSwitchValueASCII(switches::kLimitFps); + double fps; + if (base::StringToDouble(fps_str, &fps) && fps > 0) { + forced_refresh_rate_ = fps; + } + } + if (command_line->HasSwitch(cc::switches::kUIShowCompositedLayerBorders)) { std::string layer_borders_string = command_line->GetSwitchValueASCII( cc::switches::kUIShowCompositedLayerBorders); @@ -141,7 +152,7 @@ settings.use_partial_raster = !settings.use_zero_copy; if (command_line->HasSwitch(switches::kUIEnableRGBA4444Textures)) - settings.preferred_tile_format = cc::RGBA_4444; + settings.preferred_tile_format = viz::RGBA_4444; settings.resource_settings = context_factory_->GetResourceSettings(); settings.gpu_memory_policy.bytes_limit_when_visible = 512 * 1024 * 1024; @@ -372,6 +383,10 @@ void Compositor::SetDisplayVSyncParameters(base::TimeTicks timebase, base::TimeDelta interval) { + if (forced_refresh_rate_) { + timebase = base::TimeTicks(); + interval = base::TimeDelta::FromSeconds(1) / forced_refresh_rate_; + } if (interval.is_zero()) { // TODO(brianderson): We should not be receiving 0 intervals. interval = cc::BeginFrameArgs::DefaultInterval();
diff --git a/ui/compositor/compositor.h b/ui/compositor/compositor.h index 292d734..7a1b0a9 100644 --- a/ui/compositor/compositor.h +++ b/ui/compositor/compositor.h
@@ -404,6 +404,9 @@ // Current vsync refresh rate per second. float refresh_rate_ = 0.f; + // If nonzero, this is the refresh rate forced from the command-line. + double forced_refresh_rate_ = 0.f; + // A map from child id to parent id. std::unordered_set<cc::FrameSinkId, cc::FrameSinkIdHash> child_frame_sinks_; bool widget_valid_ = false;
diff --git a/ui/compositor/compositor_switches.cc b/ui/compositor/compositor_switches.cc index 2a999a8..991aba5 100644 --- a/ui/compositor/compositor_switches.cc +++ b/ui/compositor/compositor_switches.cc
@@ -17,6 +17,10 @@ // Forces tests to produce pixel output when they normally wouldn't. const char kEnablePixelOutputInTests[] = "enable-pixel-output-in-tests"; +// Limits the compositor to output a certain number of frames per second, +// maximum. +const char kLimitFps[] = "limit-fps"; + // Disable partial swap which is needed for some OpenGL drivers / emulators. const char kUIDisablePartialSwap[] = "ui-disable-partial-swap";
diff --git a/ui/compositor/compositor_switches.h b/ui/compositor/compositor_switches.h index 0cc31be97..54fc33542 100644 --- a/ui/compositor/compositor_switches.h +++ b/ui/compositor/compositor_switches.h
@@ -11,6 +11,7 @@ COMPOSITOR_EXPORT extern const char kEnableHardwareOverlays[]; COMPOSITOR_EXPORT extern const char kEnablePixelOutputInTests[]; +COMPOSITOR_EXPORT extern const char kLimitFps[]; COMPOSITOR_EXPORT extern const char kUIDisablePartialSwap[]; COMPOSITOR_EXPORT extern const char kUIEnableRGBA4444Textures[]; COMPOSITOR_EXPORT extern const char kUIEnableZeroCopy[];
diff --git a/ui/gfx/render_text.cc b/ui/gfx/render_text.cc index ebae2fb..041c9f2 100644 --- a/ui/gfx/render_text.cc +++ b/ui/gfx/render_text.cc
@@ -105,11 +105,11 @@ // Creates a SkShader to fade the text, with |left_part| specifying the left // fade effect, if any, and |right_part| specifying the right fade effect. -std::unique_ptr<cc::PaintShader> CreateFadeShader(const FontList& font_list, - const Rect& text_rect, - const Rect& left_part, - const Rect& right_part, - SkColor color) { +sk_sp<cc::PaintShader> CreateFadeShader(const FontList& font_list, + const Rect& text_rect, + const Rect& left_part, + const Rect& right_part, + SkColor color) { // The shader should only specify transparency of the fade itself, not the // original transparency, which will be applied by the actual renderer. DCHECK_EQ(SkColorGetA(color), static_cast<uint8_t>(0xff)); @@ -224,7 +224,7 @@ flags_.setColor(foreground); } -void SkiaTextRenderer::SetShader(std::unique_ptr<cc::PaintShader> shader) { +void SkiaTextRenderer::SetShader(sk_sp<cc::PaintShader> shader) { flags_.setShader(std::move(shader)); }
diff --git a/ui/gfx/render_text.h b/ui/gfx/render_text.h index d912882..24ea3d4 100644 --- a/ui/gfx/render_text.h +++ b/ui/gfx/render_text.h
@@ -62,7 +62,7 @@ void SetTypeface(sk_sp<SkTypeface> typeface); void SetTextSize(SkScalar size); void SetForegroundColor(SkColor foreground); - void SetShader(std::unique_ptr<cc::PaintShader> shader); + void SetShader(sk_sp<cc::PaintShader> shader); void DrawSelection(const std::vector<Rect>& selection, SkColor color); virtual void DrawPosText(const SkPoint* pos, const uint16_t* glyphs,
diff --git a/ui/gfx/skia_paint_util.cc b/ui/gfx/skia_paint_util.cc index 6bbe1ca..c18fbd1 100644 --- a/ui/gfx/skia_paint_util.cc +++ b/ui/gfx/skia_paint_util.cc
@@ -13,15 +13,14 @@ namespace gfx { -std::unique_ptr<cc::PaintShader> CreateImageRepShader( - const gfx::ImageSkiaRep& image_rep, - SkShader::TileMode tile_mode, - const SkMatrix& local_matrix) { +sk_sp<cc::PaintShader> CreateImageRepShader(const gfx::ImageSkiaRep& image_rep, + SkShader::TileMode tile_mode, + const SkMatrix& local_matrix) { return CreateImageRepShaderForScale(image_rep, tile_mode, local_matrix, image_rep.scale()); } -std::unique_ptr<cc::PaintShader> CreateImageRepShaderForScale( +sk_sp<cc::PaintShader> CreateImageRepShaderForScale( const gfx::ImageSkiaRep& image_rep, SkShader::TileMode tile_mode, const SkMatrix& local_matrix, @@ -43,10 +42,10 @@ &shader_scale); } -std::unique_ptr<cc::PaintShader> CreateGradientShader(int start_point, - int end_point, - SkColor start_color, - SkColor end_color) { +sk_sp<cc::PaintShader> CreateGradientShader(int start_point, + int end_point, + SkColor start_color, + SkColor end_color) { SkColor grad_colors[2] = {start_color, end_color}; SkPoint grad_points[2]; grad_points[0].iset(0, start_point);
diff --git a/ui/gfx/skia_paint_util.h b/ui/gfx/skia_paint_util.h index 1d163437..f76fc23 100644 --- a/ui/gfx/skia_paint_util.h +++ b/ui/gfx/skia_paint_util.h
@@ -26,13 +26,13 @@ // TODO(pkotwicz): Allow shader's local matrix to be changed after the shader // is created. // -GFX_EXPORT std::unique_ptr<cc::PaintShader> CreateImageRepShader( +GFX_EXPORT sk_sp<cc::PaintShader> CreateImageRepShader( const gfx::ImageSkiaRep& image_rep, SkShader::TileMode tile_mode, const SkMatrix& local_matrix); // Creates a bitmap shader for the image rep with the passed in scale factor. -GFX_EXPORT std::unique_ptr<cc::PaintShader> CreateImageRepShaderForScale( +GFX_EXPORT sk_sp<cc::PaintShader> CreateImageRepShaderForScale( const gfx::ImageSkiaRep& image_rep, SkShader::TileMode tile_mode, const SkMatrix& local_matrix, @@ -40,11 +40,10 @@ // Creates a vertical gradient shader. The caller owns the shader. // Example usage to avoid leaks: -GFX_EXPORT std::unique_ptr<cc::PaintShader> CreateGradientShader( - int start_point, - int end_point, - SkColor start_color, - SkColor end_color); +GFX_EXPORT sk_sp<cc::PaintShader> CreateGradientShader(int start_point, + int end_point, + SkColor start_color, + SkColor end_color); // Creates a draw looper to generate |shadows|. The caller owns the draw looper. // NULL is returned if |shadows| is empty since no draw looper is needed in
diff --git a/ui/keyboard/keyboard_controller.cc b/ui/keyboard/keyboard_controller.cc index 8bd0a54..05bb656 100644 --- a/ui/keyboard/keyboard_controller.cc +++ b/ui/keyboard/keyboard_controller.cc
@@ -8,12 +8,9 @@ #include "base/bind.h" #include "base/command_line.h" -#include "base/location.h" #include "base/macros.h" #include "base/metrics/histogram_macros.h" -#include "base/single_thread_task_runner.h" #include "base/threading/thread_task_runner_handle.h" -#include "build/build_config.h" #include "ui/aura/env.h" #include "ui/aura/window.h" #include "ui/aura/window_delegate.h" @@ -27,7 +24,6 @@ #include "ui/display/types/display_constants.h" #include "ui/gfx/geometry/rect.h" #include "ui/gfx/path.h" -#include "ui/gfx/skia_util.h" #include "ui/keyboard/keyboard_controller_observer.h" #include "ui/keyboard/keyboard_layout_manager.h" #include "ui/keyboard/keyboard_ui.h"
diff --git a/ui/keyboard/keyboard_controller.h b/ui/keyboard/keyboard_controller.h index a62890e3..5fd0028 100644 --- a/ui/keyboard/keyboard_controller.h +++ b/ui/keyboard/keyboard_controller.h
@@ -7,7 +7,6 @@ #include <memory> -#include "base/event_types.h" #include "base/macros.h" #include "base/observer_list.h" #include "ui/aura/window_observer.h"
diff --git a/ui/keyboard/keyboard_controller_unittest.cc b/ui/keyboard/keyboard_controller_unittest.cc index 8a3c096..b3f2dea 100644 --- a/ui/keyboard/keyboard_controller_unittest.cc +++ b/ui/keyboard/keyboard_controller_unittest.cc
@@ -6,18 +6,15 @@ #include <memory> -#include "base/bind.h" #include "base/command_line.h" #include "base/macros.h" #include "base/run_loop.h" #include "base/test/scoped_task_environment.h" #include "testing/gtest/include/gtest/gtest.h" #include "ui/aura/client/focus_client.h" -#include "ui/aura/layout_manager.h" #include "ui/aura/test/aura_test_helper.h" #include "ui/aura/test/test_window_delegate.h" #include "ui/aura/window.h" -#include "ui/aura/window_event_dispatcher.h" #include "ui/base/ime/dummy_text_input_client.h" #include "ui/base/ime/input_method.h" #include "ui/base/ime/input_method_factory.h" @@ -28,7 +25,6 @@ #include "ui/compositor/scoped_animation_duration_scale_mode.h" #include "ui/compositor/test/context_factories_for_test.h" #include "ui/compositor/test/layer_animator_test_controller.h" -#include "ui/events/event_utils.h" #include "ui/events/test/event_generator.h" #include "ui/gfx/geometry/rect.h" #include "ui/keyboard/keyboard_controller_observer.h"
diff --git a/ui/keyboard/keyboard_util.h b/ui/keyboard/keyboard_util.h index f0089a4..1caa1b3a 100644 --- a/ui/keyboard/keyboard_util.h +++ b/ui/keyboard/keyboard_util.h
@@ -7,14 +7,17 @@ #include <string> -// TODO(beng): replace with forward decl once RootWindow is renamed. -#include "ui/aura/window.h" +#include "base/strings/string16.h" #include "ui/keyboard/keyboard_export.h" namespace aura { class WindowTreeHost; } +namespace gfx { +class Rect; +}; + class GURL; namespace keyboard {
diff --git a/ui/views/win/fullscreen_handler.cc b/ui/views/win/fullscreen_handler.cc index c35bad52..6cbe30a 100644 --- a/ui/views/win/fullscreen_handler.cc +++ b/ui/views/win/fullscreen_handler.cc
@@ -90,7 +90,8 @@ HRESULT hr = ::CoCreateInstance(CLSID_TaskbarList, NULL, CLSCTX_INPROC_SERVER, IID_PPV_ARGS(&task_bar_list_)); - CHECK(SUCCEEDED(hr)); + if (SUCCEEDED(hr) && FAILED(task_bar_list_->HrInit())) + task_bar_list_ = nullptr; } // As per MSDN marking the window as fullscreen should ensure that the @@ -98,7 +99,8 @@ // is activated. If the window is not fullscreen, the Shell falls back to // heuristics to determine how the window should be treated, which means // that it could still consider the window as fullscreen. :( - task_bar_list_->MarkFullscreenWindow(hwnd_, !!fullscreen); + if (task_bar_list_) + task_bar_list_->MarkFullscreenWindow(hwnd_, !!fullscreen); } } // namespace views
diff --git a/ui/wm/core/accelerator_filter.cc b/ui/wm/core/accelerator_filter.cc index 03ea898..21f10d5 100644 --- a/ui/wm/core/accelerator_filter.cc +++ b/ui/wm/core/accelerator_filter.cc
@@ -46,4 +46,11 @@ event->StopPropagation(); } +void AcceleratorFilter::OnMouseEvent(ui::MouseEvent* event) { + if (event->type() == ui::ET_MOUSE_PRESSED || + event->type() == ui::ET_MOUSE_RELEASED) { + accelerator_history_->InterruptCurrentAccelerator(); + } +} + } // namespace wm
diff --git a/ui/wm/core/accelerator_filter.h b/ui/wm/core/accelerator_filter.h index 492ab6c..86bdf77e2 100644 --- a/ui/wm/core/accelerator_filter.h +++ b/ui/wm/core/accelerator_filter.h
@@ -30,6 +30,7 @@ // Overridden from ui::EventHandler: void OnKeyEvent(ui::KeyEvent* event) override; + void OnMouseEvent(ui::MouseEvent* event) override; private: std::unique_ptr<AcceleratorDelegate> delegate_;