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

Unified Diff: ash/shelf/shelf_controller_unittest.cc

Issue 2833173002: mash: Support ShelfModel access in Chrome. (Closed)
Patch Set: Address comments; fix test failures. Created 3 years, 7 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: ash/shelf/shelf_controller_unittest.cc
diff --git a/ash/shelf/shelf_controller_unittest.cc b/ash/shelf/shelf_controller_unittest.cc
new file mode 100644
index 0000000000000000000000000000000000000000..4926ab057229af82a0638891d59d7dd7cc620609
--- /dev/null
+++ b/ash/shelf/shelf_controller_unittest.cc
@@ -0,0 +1,192 @@
+// Copyright 2017 The Chromium Authors. All rights reserved.
+// Use of this source code is governed by a BSD-style license that can be
+// found in the LICENSE file.
+
+#include "ash/shelf/shelf_controller.h"
+
+#include <set>
+#include <string>
+
+#include "ash/public/cpp/config.h"
+#include "ash/public/interfaces/shelf.mojom.h"
+#include "ash/shelf/shelf.h"
+#include "ash/shelf/shelf_model.h"
+#include "ash/shelf/shelf_model_observer.h"
+#include "ash/shell.h"
+#include "ash/test/ash_test_base.h"
+#include "mojo/public/cpp/bindings/associated_binding.h"
+#include "ui/display/types/display_constants.h"
+
+namespace ash {
+namespace {
+
+// A test implementation of the ShelfObserver mojo interface.
+class TestShelfObserver : public mojom::ShelfObserver {
+ public:
+ TestShelfObserver() = default;
+ ~TestShelfObserver() override = default;
+
+ // mojom::ShelfObserver:
+ void OnShelfInitialized(int64_t display_id) override {
+ display_id_ = display_id;
+ }
+ void OnAlignmentChanged(ShelfAlignment alignment,
+ int64_t display_id) override {
+ alignment_ = alignment;
+ display_id_ = display_id;
+ }
+ void OnAutoHideBehaviorChanged(ShelfAutoHideBehavior auto_hide,
+ int64_t display_id) override {
+ auto_hide_ = auto_hide;
+ display_id_ = display_id;
+ }
+ void OnShelfItemAdded(int32_t, const ShelfItem&) override { added_count_++; }
+ void OnShelfItemRemoved(const ShelfID&) override { removed_count_++; }
+ void OnShelfItemMoved(const ShelfID&, int32_t) override {}
+ void OnShelfItemUpdated(const ShelfItem&) override {}
+ void OnShelfItemDelegateChanged(const ShelfID&,
+ mojom::ShelfItemDelegatePtr) override {}
+
+ int64_t display_id() const { return display_id_; }
+ ShelfAlignment alignment() const { return alignment_; }
+ ShelfAutoHideBehavior auto_hide() const { return auto_hide_; }
+ size_t added_count() const { return added_count_; }
+ size_t removed_count() const { return removed_count_; }
+
+ private:
+ int64_t display_id_ = display::kInvalidDisplayId;
+ ShelfAlignment alignment_ = SHELF_ALIGNMENT_BOTTOM_LOCKED;
+ ShelfAutoHideBehavior auto_hide_ = SHELF_AUTO_HIDE_ALWAYS_HIDDEN;
+ size_t added_count_ = 0;
+ size_t removed_count_ = 0;
+
+ DISALLOW_COPY_AND_ASSIGN(TestShelfObserver);
+};
+
+using ShelfControllerTest = test::AshTestBase;
+using NoSessionShelfControllerTest = test::NoSessionAshTestBase;
+
+TEST_F(ShelfControllerTest, IntializesAppListItemDelegate) {
+ ShelfModel* model = Shell::Get()->shelf_controller()->model();
+ EXPECT_EQ(1, model->item_count());
+ EXPECT_EQ(kAppListId, model->items()[0].id.app_id);
+ EXPECT_TRUE(model->GetShelfItemDelegate(ShelfID(kAppListId)));
+}
+
+TEST_F(NoSessionShelfControllerTest, AlignmentAndAutoHide) {
+ ShelfController* controller = Shell::Get()->shelf_controller();
+ TestShelfObserver observer;
+ mojom::ShelfObserverAssociatedPtr observer_ptr;
+ mojo::AssociatedBinding<mojom::ShelfObserver> binding(
+ &observer, mojo::MakeIsolatedRequest(&observer_ptr));
+ controller->AddObserver(observer_ptr.PassInterface());
+
+ // Simulated login should initialize the primary shelf and notify |observer|.
+ EXPECT_EQ(display::kInvalidDisplayId, observer.display_id());
+ EXPECT_EQ(SHELF_ALIGNMENT_BOTTOM_LOCKED, observer.alignment());
+ EXPECT_EQ(SHELF_AUTO_HIDE_ALWAYS_HIDDEN, observer.auto_hide());
+ SetUserLoggedIn(true);
+ SetSessionStarted(true);
+ base::RunLoop().RunUntilIdle();
+ EXPECT_EQ(GetPrimaryDisplay().id(), observer.display_id());
+ EXPECT_EQ(SHELF_ALIGNMENT_BOTTOM, observer.alignment());
+ EXPECT_EQ(SHELF_AUTO_HIDE_BEHAVIOR_NEVER, observer.auto_hide());
+
+ // Changing shelf properties should notify |observer|.
+ GetPrimaryShelf()->SetAlignment(SHELF_ALIGNMENT_LEFT);
+ base::RunLoop().RunUntilIdle();
+ EXPECT_EQ(SHELF_ALIGNMENT_LEFT, observer.alignment());
+ GetPrimaryShelf()->SetAutoHideBehavior(SHELF_AUTO_HIDE_BEHAVIOR_ALWAYS);
+ base::RunLoop().RunUntilIdle();
+ EXPECT_EQ(SHELF_AUTO_HIDE_BEHAVIOR_ALWAYS, observer.auto_hide());
+}
+
+TEST_F(ShelfControllerTest, ShelfModelChangesInClassicAsh) {
+ if (Shell::GetAshConfig() == Config::MASH)
+ return;
+
+ ShelfController* controller = Shell::Get()->shelf_controller();
+ TestShelfObserver observer;
+ mojom::ShelfObserverAssociatedPtr observer_ptr;
+ mojo::AssociatedBinding<mojom::ShelfObserver> binding(
+ &observer, mojo::MakeIsolatedRequest(&observer_ptr));
+ controller->AddObserver(observer_ptr.PassInterface());
+
+ // The ShelfModel should be initialized with a single item for the AppList.
+ // In classic ash, the observer should not be notified of ShelfModel changes.
+ EXPECT_EQ(1, controller->model()->item_count());
+ EXPECT_EQ(0u, observer.added_count());
+ EXPECT_EQ(0u, observer.removed_count());
+
+ // Add a ShelfModel item; |observer| should not be notified in classic ash.
+ ShelfItem item;
+ item.type = TYPE_PINNED_APP;
+ item.id = ShelfID("foo");
+ int index = controller->model()->Add(item);
+ base::RunLoop().RunUntilIdle();
+ EXPECT_EQ(2, controller->model()->item_count());
+ EXPECT_EQ(0u, observer.added_count());
+ EXPECT_EQ(0u, observer.removed_count());
+
+ // Remove a ShelfModel item; |observer| should not be notified in classic ash.
+ controller->model()->RemoveItemAt(index);
+ base::RunLoop().RunUntilIdle();
+ EXPECT_EQ(1, controller->model()->item_count());
+ EXPECT_EQ(0u, observer.added_count());
+ EXPECT_EQ(0u, observer.removed_count());
+}
+
+TEST_F(ShelfControllerTest, ShelfModelChangesInMash) {
+ if (Shell::GetAshConfig() != Config::MASH)
+ return;
+
+ ShelfController* controller = Shell::Get()->shelf_controller();
+ TestShelfObserver observer;
+ mojom::ShelfObserverAssociatedPtr observer_ptr;
+ mojo::AssociatedBinding<mojom::ShelfObserver> binding(
+ &observer, mojo::MakeIsolatedRequest(&observer_ptr));
+ controller->AddObserver(observer_ptr.PassInterface());
+ base::RunLoop().RunUntilIdle();
+
+ // The ShelfModel should be initialized with a single item for the AppList.
+ // In mash, the observer is immediately notified of existing shelf items.
+ EXPECT_EQ(1, controller->model()->item_count());
+ EXPECT_EQ(1u, observer.added_count());
+ EXPECT_EQ(0u, observer.removed_count());
+
+ // Add a ShelfModel item; |observer| should be notified in mash.
+ ShelfItem item;
+ item.type = TYPE_PINNED_APP;
+ item.id = ShelfID("foo");
+ int index = controller->model()->Add(item);
+ base::RunLoop().RunUntilIdle();
+ EXPECT_EQ(2, controller->model()->item_count());
+ EXPECT_EQ(2u, observer.added_count());
+ EXPECT_EQ(0u, observer.removed_count());
+
+ // Remove a ShelfModel item; |observer| should be notified in mash.
+ controller->model()->RemoveItemAt(index);
+ base::RunLoop().RunUntilIdle();
+ EXPECT_EQ(1, controller->model()->item_count());
+ EXPECT_EQ(2u, observer.added_count());
+ EXPECT_EQ(1u, observer.removed_count());
+
+ // Simulate adding an item remotely; Ash should apply the change.
+ // |observer| is not notified; see mojom::ShelfController for rationale.
+ controller->AddShelfItem(index, item);
+ base::RunLoop().RunUntilIdle();
+ EXPECT_EQ(2, controller->model()->item_count());
+ EXPECT_EQ(2u, observer.added_count());
+ EXPECT_EQ(1u, observer.removed_count());
+
+ // Simulate removing an item remotely; Ash should apply the change.
+ // |observer| is not notified; see mojom::ShelfController for rationale.
+ controller->RemoveShelfItem(item.id);
+ base::RunLoop().RunUntilIdle();
+ EXPECT_EQ(1, controller->model()->item_count());
+ EXPECT_EQ(2u, observer.added_count());
+ EXPECT_EQ(1u, observer.removed_count());
+}
+
+} // namespace
+} // namespace ash

Powered by Google App Engine
This is Rietveld 408576698