0
Files
src/chrome/browser/extensions/renderer_initialization_browsertest.cc
HuanPo Lin 0d795c6e8b preloading: Add NewTabPagePageLoadMetricsObserver
This CL adds NewTabPagePageLoadMetricsObserver and adds base::OnceCallback<void(content::NavigationHandle&)>
navigation_handle_callback to PageNavigator::OpenURL and
WebContentsDelegate::OpenURLFromTab to attach NavigationHandleUserData for identifying whether a navigation is initiated by NewTabPage.
Please refer to
https://docs.google.com/document/d/11VtFdLTjOOQoUi_MnycnNgwtI1liYd_4u7zWzb6OcEY/edit?usp=sharing for more details.

Bug: 1462832
Change-Id: I54e90bc4aafc3bd8c40427d35555acf026d70df3
Reviewed-on: https://chromium-review.googlesource.com/c/chromium/src/+/4918014
Reviewed-by: Devlin Cronin <rdevlin.cronin@chromium.org>
Reviewed-by: Arthur Sonzogni <arthursonzogni@chromium.org>
Reviewed-by: Takashi Toyoshima <toyoshim@chromium.org>
Commit-Queue: Huanpo Lin <robertlin@chromium.org>
Reviewed-by: Andrey Kosyakov <caseq@chromium.org>
Reviewed-by: Daniel Nicoara <dnicoara@chromium.org>
Reviewed-by: Scott Violet <sky@chromium.org>
Cr-Commit-Position: refs/heads/main@{#1279451}
2024-03-28 03:54:05 +00:00

68 lines
3.0 KiB
C++

// Copyright 2016 The Chromium Authors
// Use of this source code is governed by a BSD-style license that can be
// found in the LICENSE file.
#include "chrome/browser/extensions/extension_browsertest.h"
#include "chrome/browser/extensions/extension_service.h"
#include "chrome/browser/themes/theme_service.h"
#include "chrome/browser/ui/browser.h"
#include "chrome/browser/ui/tabs/tab_strip_model.h"
#include "chrome/test/base/ui_test_utils.h"
#include "content/public/test/browser_test.h"
#include "content/public/test/browser_test_utils.h"
namespace extensions {
// Test that opening a window with an extension recorded as active, then
// unloading the extension, all before the renderer is fully initialized,
// doesn't crash. This addresses crbug.com/528026, where messages could be sent
// out of order if an extension unloaded before the activation message was sent.
IN_PROC_BROWSER_TEST_F(ExtensionBrowserTest,
TestRendererStartupWithConflictingMessages) {
// Load up an extension an begin opening an URL to a page within it. Since
// this will be an extension tab, the extension will be active within that
// process.
const Extension* extension =
LoadExtension(test_data_dir_.AppendASCII("simple_with_file"));
ASSERT_TRUE(extension);
GURL url = extension->GetResourceURL("file.html");
browser()->OpenURL(
content::OpenURLParams(url, content::Referrer(),
WindowOpenDisposition::NEW_FOREGROUND_TAB,
ui::PAGE_TRANSITION_TYPED, false),
/*navigation_handle_callback=*/{});
// Without waiting for the tab to finish, unload the extension.
extension_service()->UnloadExtension(extension->id(),
UnloadedExtensionReason::TERMINATE);
content::WebContents* web_contents =
browser()->tab_strip_model()->GetActiveWebContents();
// Wait for the web contents to stop loading.
content::WaitForLoadStop(web_contents);
EXPECT_EQ(url, web_contents->GetLastCommittedURL());
ASSERT_FALSE(web_contents->IsCrashed());
}
// Tests that loading a file from a theme in a tab doesn't crash anything.
// Another part of crbug.com/528026 and related.
IN_PROC_BROWSER_TEST_F(ExtensionBrowserTest,
TestRendererInitializationWithThemesTab) {
// Don't create "Cached Theme.pak" in the extension directory, so as not to
// modify the source tree.
ThemeService::DisableThemePackForTesting();
const Extension* extension =
LoadExtension(test_data_dir_.AppendASCII("theme"));
ASSERT_TRUE(extension);
ASSERT_TRUE(extension->is_theme());
GURL url = extension->GetResourceURL("manifest.json");
ASSERT_TRUE(ui_test_utils::NavigateToURL(browser(), url));
content::WebContents* web_contents =
browser()->tab_strip_model()->GetActiveWebContents();
// Wait for the web contents to stop loading.
EXPECT_TRUE(content::WaitForLoadStop(web_contents));
EXPECT_EQ(url, web_contents->GetLastCommittedURL());
ASSERT_FALSE(web_contents->IsCrashed());
}
} // namespace extensions