Chromium Code Reviews
chromiumcodereview-hr@appspot.gserviceaccount.com (chromiumcodereview-hr) | Please choose your nickname with Settings | Help | Chromium Project | Gerrit Changes | Sign out
(1588)

Unified Diff: chrome/browser/extensions/extension_install_prompt_browsertest.cc

Issue 1534123002: [Extensions] Migrate ExtensionInstallPrompt::Delegate to be a callback (Closed) Base URL: https://chromium.googlesource.com/chromium/src.git@master
Patch Set: Created 4 years, 11 months ago
Use n/p to move between diff chunks; N/P to move between comments. Draft comments are only viewable by you.
Jump to:
View side-by-side diff with in-line comments
Download patch
Index: chrome/browser/extensions/extension_install_prompt_browsertest.cc
diff --git a/chrome/browser/extensions/extension_install_prompt_browsertest.cc b/chrome/browser/extensions/extension_install_prompt_browsertest.cc
index fe3dd93d1050221bea8a698519835190b22f5a8d..9bdb94e131d91c8272b5a4ee09544069824346b3 100644
--- a/chrome/browser/extensions/extension_install_prompt_browsertest.cc
+++ b/chrome/browser/extensions/extension_install_prompt_browsertest.cc
@@ -7,15 +7,19 @@
#include "base/macros.h"
#include "base/run_loop.h"
#include "chrome/browser/extensions/extension_install_prompt_show_params.h"
+#include "chrome/browser/extensions/extension_install_prompt_test_helper.h"
#include "chrome/browser/ui/browser.h"
#include "chrome/browser/ui/browser_window.h"
#include "chrome/browser/ui/tabs/tab_strip_model.h"
#include "chrome/test/base/in_process_browser_test.h"
#include "content/public/test/test_utils.h"
+#include "extensions/browser/extension_dialog_auto_confirm.h"
#include "extensions/common/extension.h"
#include "extensions/common/extension_builder.h"
#include "extensions/common/value_builder.h"
+using extensions::ScopedTestDialogAutoConfirm;
+
namespace {
scoped_refptr<extensions::Extension> BuildTestExtension() {
@@ -26,49 +30,6 @@ scoped_refptr<extensions::Extension> BuildTestExtension() {
.Build();
}
-// ExtensionInstallPrompt::ShowDialogCallback which proceeds without showing the
-// prompt.
-void TestShowDialogCallback(ExtensionInstallPromptShowParams* params,
- ExtensionInstallPrompt::Delegate* delegate,
- scoped_ptr<ExtensionInstallPrompt::Prompt> prompt) {
- delegate->InstallUIProceed();
-}
-
-class TestExtensionInstallPromptDelegate
- : public ExtensionInstallPrompt::Delegate {
- public:
- explicit TestExtensionInstallPromptDelegate(const base::Closure& quit_closure)
- : quit_closure_(quit_closure), proceeded_(false), aborted_(false) {}
-
- ~TestExtensionInstallPromptDelegate() override {
- }
-
- bool DidProceed() {
- return proceeded_;
- }
-
- bool DidAbort() {
- return aborted_;
- }
-
- private:
- void InstallUIProceed() override {
- proceeded_ = true;
- quit_closure_.Run();
- }
-
- void InstallUIAbort(bool user_initiated) override {
- aborted_ = true;
- quit_closure_.Run();
- }
-
- base::Closure quit_closure_;
- bool proceeded_;
- bool aborted_;
-
- DISALLOW_COPY_AND_ASSIGN(TestExtensionInstallPromptDelegate);
-};
-
} // namespace
typedef InProcessBrowserTest ExtensionInstallPromptBrowserTest;
@@ -86,17 +47,21 @@ IN_PROC_BROWSER_TEST_F(ExtensionInstallPromptBrowserTest,
int web_contents_index = tab_strip_model->GetIndexOfWebContents(web_contents);
scoped_refptr<extensions::Extension> extension(BuildTestExtension());
+ ScopedTestDialogAutoConfirm auto_confirm(ScopedTestDialogAutoConfirm::ACCEPT);
+
ExtensionInstallPrompt prompt(web_contents);
tab_strip_model->CloseWebContentsAt(web_contents_index,
TabStripModel::CLOSE_NONE);
content::RunAllPendingInMessageLoop();
base::RunLoop run_loop;
- TestExtensionInstallPromptDelegate delegate(run_loop.QuitClosure());
- prompt.ShowDialog(&delegate, extension.get(), nullptr,
- base::Bind(&TestShowDialogCallback));
+ ExtensionInstallPromptTestHelper helper(run_loop.QuitClosure());
+ prompt.ShowDialog(
+ helper.GetCallback(),
+ extension.get(), nullptr,
+ ExtensionInstallPrompt::GetDefaultShowDialogCallback());
run_loop.Run();
- EXPECT_TRUE(delegate.DidAbort());
+ EXPECT_EQ(ExtensionInstallPrompt::Result::ABORTED, helper.result());
}
// Test that ExtensionInstallPrompt aborts the install if the gfx::NativeWindow
@@ -109,17 +74,21 @@ IN_PROC_BROWSER_TEST_F(ExtensionInstallPromptBrowserTest,
scoped_refptr<extensions::Extension> extension(BuildTestExtension());
+ ScopedTestDialogAutoConfirm auto_confirm(ScopedTestDialogAutoConfirm::ACCEPT);
+
ExtensionInstallPrompt prompt(browser()->profile(),
browser()->window()->GetNativeWindow());
browser()->window()->Close();
content::RunAllPendingInMessageLoop();
base::RunLoop run_loop;
- TestExtensionInstallPromptDelegate delegate(run_loop.QuitClosure());
- prompt.ShowDialog(&delegate, extension.get(), nullptr,
- base::Bind(&TestShowDialogCallback));
+ ExtensionInstallPromptTestHelper helper(run_loop.QuitClosure());
+ prompt.ShowDialog(
+ helper.GetCallback(),
+ extension.get(), nullptr,
+ ExtensionInstallPrompt::GetDefaultShowDialogCallback());
run_loop.Run();
- EXPECT_TRUE(delegate.DidAbort());
+ EXPECT_EQ(ExtensionInstallPrompt::Result::ABORTED, helper.result());
}
// Test that ExtensionInstallPrompt shows the dialog normally if no parent
@@ -128,13 +97,15 @@ IN_PROC_BROWSER_TEST_F(ExtensionInstallPromptBrowserTest,
IN_PROC_BROWSER_TEST_F(ExtensionInstallPromptBrowserTest, NoParent) {
scoped_refptr<extensions::Extension> extension(BuildTestExtension());
+ ScopedTestDialogAutoConfirm auto_confirm(ScopedTestDialogAutoConfirm::ACCEPT);
+
ExtensionInstallPrompt prompt(browser()->profile(), NULL);
base::RunLoop run_loop;
- TestExtensionInstallPromptDelegate delegate(run_loop.QuitClosure());
- prompt.ShowDialog(&delegate, extension.get(), nullptr,
- base::Bind(&TestShowDialogCallback));
+ ExtensionInstallPromptTestHelper helper(run_loop.QuitClosure());
+ prompt.ShowDialog(
+ helper.GetCallback(),
+ extension.get(), nullptr,
+ ExtensionInstallPrompt::GetDefaultShowDialogCallback());
run_loop.Run();
-
- // TestShowDialogCallback() should have signaled the install to proceed.
- EXPECT_TRUE(delegate.DidProceed());
+ EXPECT_EQ(ExtensionInstallPrompt::Result::ACCEPTED, helper.result());
}

Powered by Google App Engine
This is Rietveld 408576698