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

Side by Side Diff: chrome/browser/extensions/extension_warning_badge_service_unittest.cc

Issue 10407105: Improve error messaging of webRequest API in case of conflicts (Closed) Base URL: svn://svn.chromium.org/chrome/trunk/src
Patch Set: Addressed Evan's comments Created 8 years, 1 month 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 unified diff | Download patch | Annotate | Revision Log
OLDNEW
(Empty)
1 // Copyright (c) 2012 The Chromium Authors. All rights reserved.
2 // Use of this source code is governed by a BSD-style license that can be
3 // found in the LICENSE file.
4
5 #include "chrome/browser/extensions/extension_warning_badge_service.h"
6
7 #include "chrome/app/chrome_command_ids.h"
8 #include "chrome/browser/extensions/extension_warning_set.h"
9 #include "chrome/browser/profiles/profile.h"
10 #include "chrome/browser/ui/global_error/global_error_service.h"
11 #include "chrome/browser/ui/global_error/global_error_service_factory.h"
12 #include "chrome/test/base/testing_profile.h"
13 #include "testing/gtest/include/gtest/gtest.h"
14
15 namespace extensions {
16
17 namespace {
18
19 class TestExtensionWarningSet : public ExtensionWarningService {
20 public:
21 explicit TestExtensionWarningSet(Profile* profile)
22 : ExtensionWarningService(profile) {
23 }
24 virtual ~TestExtensionWarningSet() {}
25
26 void AddWarning(const ExtensionWarning& warning) {
27 ExtensionWarningSet warnings;
28 warnings.insert(warning);
29 AddWarnings(warnings);
30 }
31 };
32
33 class TestExtensionWarningBadgeService : public ExtensionWarningBadgeService {
34 public:
35 TestExtensionWarningBadgeService(Profile* profile,
36 ExtensionWarningService* warning_service)
37 : ExtensionWarningBadgeService(profile),
38 warning_service_(warning_service) {}
39 virtual ~TestExtensionWarningBadgeService() {}
40
41 virtual const std::set<ExtensionWarning>& GetCurrentWarnings() const {
42 return warning_service_->warnings();
43 }
44
45 private:
46 ExtensionWarningService* warning_service_;
47 };
48
49 bool HasBadge(Profile* profile) {
50 GlobalErrorService* service =
51 GlobalErrorServiceFactory::GetForProfile(profile);
52 return service->GetGlobalErrorByMenuItemCommandID(IDC_EXTENSION_ERRORS) !=
53 NULL;
54 }
55
56 const char* ext1_id = "extension1";
57 const char* ext2_id = "extension2";
58 const ExtensionWarning::WarningType warning_1 =
59 ExtensionWarning::kNetworkDelay;
60 const ExtensionWarning::WarningType warning_2 =
61 ExtensionWarning::kNetworkConflict;
62
63 } // namespace
64
65 // Check that no badge appears if it has been suppressed for a specific
66 // warning.
67 TEST(ExtensionWarningBadgeServiceTest, SuppressBadgeForCurrentWarnings) {
68 TestingProfile profile;
69 TestExtensionWarningSet warnings(&profile);
70 TestExtensionWarningBadgeService badge_service(&profile, &warnings);
71 warnings.AddObserver(&badge_service);
72
73 // Insert first warning.
74 warnings.AddWarning(ExtensionWarning::CreateNetworkDelayWarning(ext1_id));
75 EXPECT_TRUE(HasBadge(&profile));
76
77 // Suppress first warning.
78 badge_service.SuppressCurrentWarnings();
79 EXPECT_FALSE(HasBadge(&profile));
80
81 // Simulate deinstallation of extension.
82 std::set<ExtensionWarning::WarningType> to_clear =
83 warnings.GetWarningTypesAffectingExtension(ext1_id);
84 warnings.ClearWarnings(to_clear);
85 EXPECT_FALSE(HasBadge(&profile));
86
87 // Set first warning again and verify that not badge is shown this time.
88 warnings.AddWarning(ExtensionWarning::CreateNetworkDelayWarning(ext1_id));
89 EXPECT_FALSE(HasBadge(&profile));
90
91 // Set second warning and verify that it shows a badge.
92 warnings.AddWarning(ExtensionWarning::CreateNetworkConflictWarning(ext2_id));
93 EXPECT_TRUE(HasBadge(&profile));
94
95 warnings.RemoveObserver(&badge_service);
96 }
97
98 } // namespace extensions
OLDNEW

Powered by Google App Engine
This is Rietveld 408576698