OLD | NEW |
1 // Copyright 2013 The Chromium Authors. All rights reserved. | 1 // Copyright 2013 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/app_mode/kiosk_app_manager.h" | 5 #include "chrome/browser/chromeos/app_mode/kiosk_app_manager.h" |
6 | 6 |
7 #include "base/command_line.h" | 7 #include "base/command_line.h" |
8 #include "base/file_util.h" | 8 #include "base/file_util.h" |
9 #include "base/files/scoped_temp_dir.h" | 9 #include "base/files/scoped_temp_dir.h" |
10 #include "base/message_loop/message_loop.h" | 10 #include "base/message_loop/message_loop.h" |
(...skipping 83 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
94 base::FilePath(), | 94 base::FilePath(), |
95 extensions::Manifest::INTERNAL, | 95 extensions::Manifest::INTERNAL, |
96 value, | 96 value, |
97 extensions::Extension::WAS_INSTALLED_BY_DEFAULT, | 97 extensions::Extension::WAS_INSTALLED_BY_DEFAULT, |
98 id, | 98 id, |
99 &err); | 99 &err); |
100 EXPECT_EQ(err, ""); | 100 EXPECT_EQ(err, ""); |
101 return app; | 101 return app; |
102 } | 102 } |
103 | 103 |
104 class TestKioskAppManagerObserver : public KioskAppManagerObserver { | |
105 public: | |
106 explicit TestKioskAppManagerObserver(KioskAppManager* manager) | |
107 : manager_(manager), | |
108 data_changed_count_(0), | |
109 load_failure_count_(0) { | |
110 manager_->AddObserver(this); | |
111 } | |
112 virtual ~TestKioskAppManagerObserver() { | |
113 manager_->RemoveObserver(this); | |
114 } | |
115 | |
116 void Reset() { | |
117 data_changed_count_ = 0; | |
118 load_failure_count_ = 0; | |
119 } | |
120 | |
121 int data_changed_count() const { return data_changed_count_; } | |
122 int load_failure_count() const { return load_failure_count_; } | |
123 | |
124 private: | |
125 // KioskAppManagerObserver overrides: | |
126 virtual void OnKioskAppDataChanged(const std::string& app_id) OVERRIDE { | |
127 ++data_changed_count_; | |
128 } | |
129 virtual void OnKioskAppDataLoadFailure(const std::string& app_id) OVERRIDE { | |
130 ++load_failure_count_; | |
131 } | |
132 | |
133 KioskAppManager* manager_; | |
134 int data_changed_count_; | |
135 int load_failure_count_; | |
136 | |
137 DISALLOW_COPY_AND_ASSIGN(TestKioskAppManagerObserver); | |
138 }; | |
139 | |
140 class AppDataLoadWaiter : public KioskAppManagerObserver { | 104 class AppDataLoadWaiter : public KioskAppManagerObserver { |
141 public: | 105 public: |
142 AppDataLoadWaiter(KioskAppManager* manager, int data_loaded_threshold) | 106 AppDataLoadWaiter(KioskAppManager* manager, int data_loaded_threshold) |
143 : runner_(NULL), | 107 : runner_(NULL), |
144 manager_(manager), | 108 manager_(manager), |
145 loaded_(false), | 109 loaded_(false), |
146 quit_(false), | 110 quit_(false), |
147 data_change_count_(0), | 111 data_change_count_(0), |
148 data_loaded_threshold_(data_loaded_threshold) { | 112 data_loaded_threshold_(data_loaded_threshold) { |
149 manager_->AddObserver(this); | 113 manager_->AddObserver(this); |
(...skipping 327 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
477 | 441 |
478 waiter.Wait(); | 442 waiter.Wait(); |
479 EXPECT_TRUE(waiter.loaded()); | 443 EXPECT_TRUE(waiter.loaded()); |
480 | 444 |
481 manager()->GetApps(&apps); | 445 manager()->GetApps(&apps); |
482 EXPECT_EQ(1u, apps.size()); | 446 EXPECT_EQ(1u, apps.size()); |
483 EXPECT_EQ("app_1", apps[0].app_id); | 447 EXPECT_EQ("app_1", apps[0].app_id); |
484 EXPECT_EQ("Updated App1 Name", apps[0].name); | 448 EXPECT_EQ("Updated App1 Name", apps[0].name); |
485 } | 449 } |
486 | 450 |
487 // Test is flaky. See http://crbug.com/379769 for details. | 451 IN_PROC_BROWSER_TEST_F(KioskAppManagerTest, BadApp) { |
488 IN_PROC_BROWSER_TEST_F(KioskAppManagerTest, DISABLED_BadApp) { | |
489 AppDataLoadWaiter waiter(manager(), 2); | 452 AppDataLoadWaiter waiter(manager(), 2); |
490 manager()->AddApp("unknown_app"); | 453 manager()->AddApp("unknown_app"); |
491 TestKioskAppManagerObserver observer(manager()); | |
492 waiter.Wait(); | 454 waiter.Wait(); |
493 EXPECT_FALSE(waiter.loaded()); | 455 EXPECT_FALSE(waiter.loaded()); |
494 | |
495 EXPECT_EQ("", GetAppIds()); | 456 EXPECT_EQ("", GetAppIds()); |
496 EXPECT_EQ(1, observer.load_failure_count()); | |
497 } | 457 } |
498 | 458 |
499 IN_PROC_BROWSER_TEST_F(KioskAppManagerTest, GoodApp) { | 459 IN_PROC_BROWSER_TEST_F(KioskAppManagerTest, GoodApp) { |
500 // Webstore data json is in | 460 // Webstore data json is in |
501 // chrome/test/data/chromeos/app_mode/webstore/inlineinstall/detail/app_1 | 461 // chrome/test/data/chromeos/app_mode/webstore/inlineinstall/detail/app_1 |
502 fake_cws()->SetNoUpdate("app_1"); | 462 fake_cws()->SetNoUpdate("app_1"); |
503 AppDataLoadWaiter waiter(manager(), 2); | 463 AppDataLoadWaiter waiter(manager(), 2); |
504 manager()->AddApp("app_1"); | 464 manager()->AddApp("app_1"); |
505 waiter.Wait(); | 465 waiter.Wait(); |
506 EXPECT_TRUE(waiter.loaded()); | 466 EXPECT_TRUE(waiter.loaded()); |
(...skipping 20 matching lines...) Expand all Loading... |
527 | 487 |
528 base::FilePath expected_icon_path; | 488 base::FilePath expected_icon_path; |
529 ASSERT_TRUE(PathService::Get(chrome::DIR_USER_DATA, &expected_icon_path)); | 489 ASSERT_TRUE(PathService::Get(chrome::DIR_USER_DATA, &expected_icon_path)); |
530 expected_icon_path = expected_icon_path. | 490 expected_icon_path = expected_icon_path. |
531 AppendASCII(KioskAppManager::kIconCacheDir). | 491 AppendASCII(KioskAppManager::kIconCacheDir). |
532 AppendASCII(apps[0].app_id).AddExtension(".png"); | 492 AppendASCII(apps[0].app_id).AddExtension(".png"); |
533 EXPECT_EQ(expected_icon_path.value(), icon_path_string); | 493 EXPECT_EQ(expected_icon_path.value(), icon_path_string); |
534 } | 494 } |
535 | 495 |
536 IN_PROC_BROWSER_TEST_F(KioskAppManagerTest, DownloadNewApp) { | 496 IN_PROC_BROWSER_TEST_F(KioskAppManagerTest, DownloadNewApp) { |
537 base::FilePath crx_path; | |
538 RunAddNewAppTest(kTestLocalFsKioskApp, "1.0.0", kTestLocalFsKioskAppName); | 497 RunAddNewAppTest(kTestLocalFsKioskApp, "1.0.0", kTestLocalFsKioskAppName); |
539 } | 498 } |
540 | 499 |
541 IN_PROC_BROWSER_TEST_F(KioskAppManagerTest, RemoveApp) { | 500 IN_PROC_BROWSER_TEST_F(KioskAppManagerTest, RemoveApp) { |
542 // Add a new app. | 501 // Add a new app. |
543 RunAddNewAppTest(kTestLocalFsKioskApp, "1.0.0", kTestLocalFsKioskAppName); | 502 RunAddNewAppTest(kTestLocalFsKioskApp, "1.0.0", kTestLocalFsKioskAppName); |
544 KioskAppManager::Apps apps; | 503 KioskAppManager::Apps apps; |
545 manager()->GetApps(&apps); | 504 manager()->GetApps(&apps); |
546 ASSERT_EQ(1u, apps.size()); | 505 ASSERT_EQ(1u, apps.size()); |
547 base::FilePath crx_path; | 506 base::FilePath crx_path; |
(...skipping 166 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
714 manager()->GetConsumerKioskAutoLaunchStatus( | 673 manager()->GetConsumerKioskAutoLaunchStatus( |
715 base::Bind(&ConsumerKioskAutoLaunchStatusCheck, | 674 base::Bind(&ConsumerKioskAutoLaunchStatusCheck, |
716 status.get(), | 675 status.get(), |
717 runner3->QuitClosure())); | 676 runner3->QuitClosure())); |
718 runner3->Run(); | 677 runner3->Run(); |
719 EXPECT_EQ(*status.get(), | 678 EXPECT_EQ(*status.get(), |
720 KioskAppManager::CONSUMER_KIOSK_AUTO_LAUNCH_DISABLED); | 679 KioskAppManager::CONSUMER_KIOSK_AUTO_LAUNCH_DISABLED); |
721 } | 680 } |
722 | 681 |
723 } // namespace chromeos | 682 } // namespace chromeos |
OLD | NEW |