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

Side by Side Diff: chrome/browser/chromeos/printing/synced_printers_manager_unittest.cc

Issue 2975013002: Make chromeos CUPS printing code namespaces consistent. (Closed)
Patch Set: Rebase Created 3 years, 5 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 unified diff | Download patch
OLDNEW
1 // Copyright 2016 The Chromium Authors. All rights reserved. 1 // Copyright 2016 The Chromium Authors. All rights reserved.
2 // Use of this source code is governed by a BSD-style license that can be 2 // Use of this source code is governed by a BSD-style license that can be
3 // found in the LICENSE file. 3 // found in the LICENSE file.
4 4
5 #include "chrome/browser/chromeos/printing/synced_printers_manager.h" 5 #include "chrome/browser/chromeos/printing/synced_printers_manager.h"
6 6
7 #include <memory> 7 #include <memory>
8 #include <utility> 8 #include <utility>
9 9
10 #include "base/bind.h" 10 #include "base/bind.h"
11 #include "base/debug/dump_without_crashing.h" 11 #include "base/debug/dump_without_crashing.h"
12 #include "base/memory/ptr_util.h" 12 #include "base/memory/ptr_util.h"
13 #include "base/optional.h" 13 #include "base/optional.h"
14 #include "base/run_loop.h" 14 #include "base/run_loop.h"
15 #include "base/time/time.h" 15 #include "base/time/time.h"
16 #include "chrome/browser/chromeos/printing/printers_sync_bridge.h" 16 #include "chrome/browser/chromeos/printing/printers_sync_bridge.h"
17 #include "chrome/browser/chromeos/printing/synced_printers_manager_factory.h" 17 #include "chrome/browser/chromeos/printing/synced_printers_manager_factory.h"
18 #include "chrome/common/pref_names.h" 18 #include "chrome/common/pref_names.h"
19 #include "chrome/test/base/testing_profile.h" 19 #include "chrome/test/base/testing_profile.h"
20 #include "components/sync/model/fake_model_type_change_processor.h" 20 #include "components/sync/model/fake_model_type_change_processor.h"
21 #include "components/sync/model/model_type_store.h" 21 #include "components/sync/model/model_type_store.h"
22 #include "components/sync_preferences/testing_pref_service_syncable.h" 22 #include "components/sync_preferences/testing_pref_service_syncable.h"
23 #include "content/public/test/test_browser_thread_bundle.h" 23 #include "content/public/test/test_browser_thread_bundle.h"
24 #include "testing/gtest/include/gtest/gtest.h" 24 #include "testing/gtest/include/gtest/gtest.h"
25 25
26 namespace chromeos { 26 namespace chromeos {
27 27
28 namespace { 28 namespace {
29 29
30 const char kPrinterId[] = "UUID-UUID-UUID-PRINTER"; 30 const char kTestPrinterId[] = "UUID-UUID-UUID-PRINTER";
31 const char kUri[] = "ipps://printer.chromium.org/ipp/print"; 31 const char kTestUri[] = "ipps://printer.chromium.org/ipp/print";
32 32
33 const char kLexJson[] = R"json({ 33 const char kLexJson[] = R"json({
34 "display_name": "LexaPrint", 34 "display_name": "LexaPrint",
35 "description": "Laser on the test shelf", 35 "description": "Laser on the test shelf",
36 "manufacturer": "LexaPrint, Inc.", 36 "manufacturer": "LexaPrint, Inc.",
37 "model": "MS610de", 37 "model": "MS610de",
38 "uri": "ipp://192.168.1.5", 38 "uri": "ipp://192.168.1.5",
39 "ppd_resource": { 39 "ppd_resource": {
40 "effective_manufacturer": "LexaPrint", 40 "effective_manufacturer": "LexaPrint",
41 "effective_model": "MS610de", 41 "effective_model": "MS610de",
(...skipping 60 matching lines...) Expand 10 before | Expand all | Expand 10 after
102 102
103 // Must outlive |manager_|. 103 // Must outlive |manager_|.
104 TestingProfile profile_; 104 TestingProfile profile_;
105 105
106 SyncedPrintersManager manager_; 106 SyncedPrintersManager manager_;
107 }; 107 };
108 108
109 TEST_F(SyncedPrintersManagerTest, AddPrinter) { 109 TEST_F(SyncedPrintersManagerTest, AddPrinter) {
110 LoggingObserver observer; 110 LoggingObserver observer;
111 manager_.AddObserver(&observer); 111 manager_.AddObserver(&observer);
112 manager_.RegisterPrinter(base::MakeUnique<Printer>(kPrinterId)); 112 manager_.RegisterPrinter(base::MakeUnique<Printer>(kTestPrinterId));
113 113
114 auto printers = manager_.GetPrinters(); 114 auto printers = manager_.GetPrinters();
115 ASSERT_EQ(1U, printers.size()); 115 ASSERT_EQ(1U, printers.size());
116 EXPECT_EQ(kPrinterId, printers[0]->id()); 116 EXPECT_EQ(kTestPrinterId, printers[0]->id());
117 EXPECT_EQ(Printer::Source::SRC_USER_PREFS, printers[0]->source()); 117 EXPECT_EQ(Printer::Source::SRC_USER_PREFS, printers[0]->source());
118 118
119 EXPECT_TRUE(observer.AddCalled()); 119 EXPECT_TRUE(observer.AddCalled());
120 EXPECT_FALSE(observer.UpdateCalled()); 120 EXPECT_FALSE(observer.UpdateCalled());
121 } 121 }
122 122
123 TEST_F(SyncedPrintersManagerTest, UpdatePrinterAssignsId) { 123 TEST_F(SyncedPrintersManagerTest, UpdatePrinterAssignsId) {
124 manager_.RegisterPrinter(base::MakeUnique<Printer>()); 124 manager_.RegisterPrinter(base::MakeUnique<Printer>());
125 125
126 auto printers = manager_.GetPrinters(); 126 auto printers = manager_.GetPrinters();
127 ASSERT_EQ(1U, printers.size()); 127 ASSERT_EQ(1U, printers.size());
128 EXPECT_FALSE(printers[0]->id().empty()); 128 EXPECT_FALSE(printers[0]->id().empty());
129 } 129 }
130 130
131 TEST_F(SyncedPrintersManagerTest, UpdatePrinter) { 131 TEST_F(SyncedPrintersManagerTest, UpdatePrinter) {
132 manager_.RegisterPrinter(base::MakeUnique<Printer>(kPrinterId)); 132 manager_.RegisterPrinter(base::MakeUnique<Printer>(kTestPrinterId));
133 auto updated_printer = base::MakeUnique<Printer>(kPrinterId); 133 auto updated_printer = base::MakeUnique<Printer>(kTestPrinterId);
134 updated_printer->set_uri(kUri); 134 updated_printer->set_uri(kTestUri);
135 135
136 // Register observer so it only receives the update event. 136 // Register observer so it only receives the update event.
137 LoggingObserver observer; 137 LoggingObserver observer;
138 manager_.AddObserver(&observer); 138 manager_.AddObserver(&observer);
139 139
140 manager_.RegisterPrinter(std::move(updated_printer)); 140 manager_.RegisterPrinter(std::move(updated_printer));
141 141
142 auto printers = manager_.GetPrinters(); 142 auto printers = manager_.GetPrinters();
143 ASSERT_EQ(1U, printers.size()); 143 ASSERT_EQ(1U, printers.size());
144 EXPECT_EQ(kUri, printers[0]->uri()); 144 EXPECT_EQ(kTestUri, printers[0]->uri());
145 145
146 EXPECT_TRUE(observer.UpdateCalled()); 146 EXPECT_TRUE(observer.UpdateCalled());
147 EXPECT_FALSE(observer.AddCalled()); 147 EXPECT_FALSE(observer.AddCalled());
148 } 148 }
149 149
150 TEST_F(SyncedPrintersManagerTest, RemovePrinter) { 150 TEST_F(SyncedPrintersManagerTest, RemovePrinter) {
151 manager_.RegisterPrinter(base::MakeUnique<Printer>("OtherUUID")); 151 manager_.RegisterPrinter(base::MakeUnique<Printer>("OtherUUID"));
152 manager_.RegisterPrinter(base::MakeUnique<Printer>(kPrinterId)); 152 manager_.RegisterPrinter(base::MakeUnique<Printer>(kTestPrinterId));
153 manager_.RegisterPrinter(base::MakeUnique<Printer>()); 153 manager_.RegisterPrinter(base::MakeUnique<Printer>());
154 154
155 manager_.RemovePrinter(kPrinterId); 155 manager_.RemovePrinter(kTestPrinterId);
156 156
157 auto printers = manager_.GetPrinters(); 157 auto printers = manager_.GetPrinters();
158 ASSERT_EQ(2U, printers.size()); 158 ASSERT_EQ(2U, printers.size());
159 EXPECT_NE(kPrinterId, printers.at(0)->id()); 159 EXPECT_NE(kTestPrinterId, printers.at(0)->id());
160 EXPECT_NE(kPrinterId, printers.at(1)->id()); 160 EXPECT_NE(kTestPrinterId, printers.at(1)->id());
161 } 161 }
162 162
163 // Tests for policy printers 163 // Tests for policy printers
164 164
165 TEST_F(SyncedPrintersManagerTest, RecommendedPrinters) { 165 TEST_F(SyncedPrintersManagerTest, RecommendedPrinters) {
166 std::string first_printer = 166 std::string first_printer =
167 R"json({ 167 R"json({
168 "display_name": "Color Laser", 168 "display_name": "Color Laser",
169 "description": "The printer next to the water cooler.", 169 "description": "The printer next to the water cooler.",
170 "manufacturer": "Printer Manufacturer", 170 "manufacturer": "Printer Manufacturer",
(...skipping 38 matching lines...) Expand 10 before | Expand all | Expand 10 after
209 209
210 const Printer& from_list = *(printers.front()); 210 const Printer& from_list = *(printers.front());
211 std::unique_ptr<Printer> retrieved = manager_.GetPrinter(from_list.id()); 211 std::unique_ptr<Printer> retrieved = manager_.GetPrinter(from_list.id());
212 212
213 EXPECT_EQ(from_list.id(), retrieved->id()); 213 EXPECT_EQ(from_list.id(), retrieved->id());
214 EXPECT_EQ("LexaPrint", from_list.display_name()); 214 EXPECT_EQ("LexaPrint", from_list.display_name());
215 EXPECT_EQ(Printer::Source::SRC_POLICY, from_list.source()); 215 EXPECT_EQ(Printer::Source::SRC_POLICY, from_list.source());
216 } 216 }
217 217
218 TEST_F(SyncedPrintersManagerTest, PrinterNotInstalled) { 218 TEST_F(SyncedPrintersManagerTest, PrinterNotInstalled) {
219 Printer printer(kPrinterId, base::Time::FromInternalValue(1000)); 219 Printer printer(kTestPrinterId, base::Time::FromInternalValue(1000));
220 EXPECT_FALSE(manager_.IsConfigurationCurrent(printer)); 220 EXPECT_FALSE(manager_.IsConfigurationCurrent(printer));
221 } 221 }
222 222
223 TEST_F(SyncedPrintersManagerTest, PrinterIsInstalled) { 223 TEST_F(SyncedPrintersManagerTest, PrinterIsInstalled) {
224 Printer printer(kPrinterId, base::Time::FromInternalValue(1000)); 224 Printer printer(kTestPrinterId, base::Time::FromInternalValue(1000));
225 manager_.PrinterInstalled(printer); 225 manager_.PrinterInstalled(printer);
226 EXPECT_TRUE(manager_.IsConfigurationCurrent(printer)); 226 EXPECT_TRUE(manager_.IsConfigurationCurrent(printer));
227 } 227 }
228 228
229 TEST_F(SyncedPrintersManagerTest, UpdatedPrinterConfiguration) { 229 TEST_F(SyncedPrintersManagerTest, UpdatedPrinterConfiguration) {
230 Printer printer(kPrinterId, base::Time::FromInternalValue(1000)); 230 Printer printer(kTestPrinterId, base::Time::FromInternalValue(1000));
231 manager_.PrinterInstalled(printer); 231 manager_.PrinterInstalled(printer);
232 232
233 Printer updated_printer(kPrinterId, base::Time::FromInternalValue(2000)); 233 Printer updated_printer(kTestPrinterId, base::Time::FromInternalValue(2000));
234 EXPECT_FALSE(manager_.IsConfigurationCurrent(updated_printer)); 234 EXPECT_FALSE(manager_.IsConfigurationCurrent(updated_printer));
235 } 235 }
236 236
237 } // namespace chromeos 237 } // namespace chromeos
OLDNEW
« no previous file with comments | « chrome/browser/chromeos/printing/synced_printers_manager.cc ('k') | chrome/browser/chromeos/printing/usb_printer_detector.cc » ('j') | no next file with comments »

Powered by Google App Engine
This is Rietveld 408576698