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

Unified Diff: chrome/test/ppapi/ppapi_test.cc

Issue 22694006: Infobar system refactor. (Closed) Base URL: svn://chrome-svn/chrome/trunk/src/
Patch Set: Created 7 years, 2 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/test/ppapi/ppapi_test.cc
===================================================================
--- chrome/test/ppapi/ppapi_test.cc (revision 226624)
+++ chrome/test/ppapi/ppapi_test.cc (working copy)
@@ -6,12 +6,9 @@
#include "base/command_line.h"
#include "base/file_util.h"
-#include "base/logging.h"
#include "base/path_service.h"
#include "base/strings/string_util.h"
#include "base/strings/stringprintf.h"
-#include "base/test/test_timeouts.h"
-#include "build/build_config.h"
#include "chrome/browser/chrome_notification_types.h"
#include "chrome/browser/content_settings/host_content_settings_map.h"
#include "chrome/browser/infobars/confirm_infobar_delegate.h"
@@ -18,7 +15,6 @@
#include "chrome/browser/infobars/infobar.h"
#include "chrome/browser/profiles/profile.h"
#include "chrome/browser/ui/browser.h"
-#include "chrome/browser/ui/browser_tabstrip.h"
#include "chrome/browser/ui/tabs/tab_strip_model.h"
#include "chrome/common/chrome_paths.h"
#include "chrome/common/chrome_switches.h"
@@ -26,12 +22,7 @@
#include "chrome/test/base/ui_test_utils.h"
#include "content/public/browser/dom_operation_notification_details.h"
#include "content/public/browser/notification_service.h"
-#include "content/public/browser/notification_types.h"
#include "content/public/browser/web_contents.h"
-#include "content/public/common/content_paths.h"
-#include "content/public/common/content_switches.h"
-#include "content/public/test/browser_test_utils.h"
-#include "content/public/test/test_renderer_host.h"
#include "net/base/net_util.h"
#include "net/base/test_data_directory.h"
#include "ppapi/shared_impl/ppapi_switches.h"
@@ -73,41 +64,63 @@
message_.clear();
}
-PPAPITestBase::InfoBarObserver::InfoBarObserver() {
+PPAPITestBase::InfoBarObserver::InfoBarObserver(PPAPITestBase* test_base)
+ : test_base_(test_base),
+ expecting_infobar_(false),
+ should_accept_(false) {
registrar_.Add(this, chrome::NOTIFICATION_TAB_CONTENTS_INFOBAR_ADDED,
content::NotificationService::AllSources());
}
PPAPITestBase::InfoBarObserver::~InfoBarObserver() {
- EXPECT_EQ(0u, expected_infobars_.size()) << "Missing an expected infobar";
+ EXPECT_FALSE(expecting_infobar_) << "Missing an expected infobar";
}
+void PPAPITestBase::InfoBarObserver::ExpectInfoBarAndAccept(
+ bool should_accept) {
+ ASSERT_FALSE(expecting_infobar_);
+ expecting_infobar_ = true;
+ should_accept_ = should_accept;
+}
+
void PPAPITestBase::InfoBarObserver::Observe(
int type,
const content::NotificationSource& source,
const content::NotificationDetails& details) {
ASSERT_EQ(chrome::NOTIFICATION_TAB_CONTENTS_INFOBAR_ADDED, type);
- InfoBarDelegate* infobar =
- content::Details<InfoBarAddedDetails>(details).ptr();
- ConfirmInfoBarDelegate* confirm_infobar_delegate =
- infobar->AsConfirmInfoBarDelegate();
- ASSERT_TRUE(confirm_infobar_delegate);
+ // It's not safe to remove the infobar here, since other observers (e.g. the
+ // InfoBarContainer) may still need to access it. Instead, post a task to
+ // do all necessary infobar manipulation as soon as this call stack returns.
+ base::MessageLoop::current()->PostTask(
+ FROM_HERE, base::Bind(&InfoBarObserver::VerifyInfoBarState,
+ base::Unretained(this)));
+}
- ASSERT_FALSE(expected_infobars_.empty()) << "Unexpected infobar";
- if (expected_infobars_.front())
- confirm_infobar_delegate->Accept();
+void PPAPITestBase::InfoBarObserver::VerifyInfoBarState() {
+ content::WebContents* web_contents =
+ test_base_->browser()->tab_strip_model()->GetActiveWebContents();
+ ASSERT_TRUE(web_contents != NULL);
+ InfoBarService* infobar_service =
+ InfoBarService::FromWebContents(web_contents);
+ ASSERT_TRUE(infobar_service != NULL);
+
+ EXPECT_EQ(expecting_infobar_ ? 1U : 0U, infobar_service->infobar_count());
+ if (!expecting_infobar_)
+ return;
+ expecting_infobar_ = false;
+
+ InfoBar* infobar = infobar_service->infobar_at(0);
+ ConfirmInfoBarDelegate* delegate =
+ infobar->delegate()->AsConfirmInfoBarDelegate();
+ ASSERT_TRUE(delegate != NULL);
+ if (should_accept_)
+ delegate->Accept();
else
- confirm_infobar_delegate->Cancel();
- expected_infobars_.pop_front();
+ delegate->Cancel();
- // TODO(bauerb): We should close the infobar.
+ infobar_service->RemoveInfoBar(infobar);
}
-void PPAPITestBase::InfoBarObserver::ExpectInfoBarAndAccept(
- bool should_accept) {
- expected_infobars_.push_back(should_accept);
-}
-
PPAPITestBase::PPAPITestBase() {
}

Powered by Google App Engine
This is Rietveld 408576698