| Index: mojo/services/window_manager/window_manager_api_unittest.cc
|
| diff --git a/mojo/services/window_manager/window_manager_api_unittest.cc b/mojo/services/window_manager/window_manager_api_unittest.cc
|
| index b58d994994cefc59d1dba17d2d194d1873c27f9c..d229d84227052955f192116b968d6442777ee942 100644
|
| --- a/mojo/services/window_manager/window_manager_api_unittest.cc
|
| +++ b/mojo/services/window_manager/window_manager_api_unittest.cc
|
| @@ -3,8 +3,14 @@
|
| // found in the LICENSE file.
|
|
|
| #include "base/bind.h"
|
| +#include "base/memory/scoped_vector.h"
|
| +#include "mojo/public/cpp/application/application_delegate.h"
|
| +#include "mojo/public/cpp/application/application_impl.h"
|
| #include "mojo/service_manager/service_manager.h"
|
| +#include "mojo/services/public/cpp/view_manager/node.h"
|
| #include "mojo/services/public/cpp/view_manager/types.h"
|
| +#include "mojo/services/public/cpp/view_manager/view_manager.h"
|
| +#include "mojo/services/public/cpp/view_manager/view_manager_delegate.h"
|
| #include "mojo/services/public/interfaces/view_manager/view_manager.mojom.h"
|
| #include "mojo/services/public/interfaces/window_manager/window_manager.mojom.h"
|
| #include "mojo/shell/shell_test_helper.h"
|
| @@ -13,6 +19,10 @@
|
| namespace mojo {
|
| namespace {
|
|
|
| +const char kTestServiceURL[] = "mojo:test_url";
|
| +
|
| +void EmptyResultCallback(bool result) {}
|
| +
|
| // Callback from EmbedRoot(). |result| is the result of the
|
| // Embed() call and |run_loop| the nested RunLoop.
|
| void ResultCallback(bool* result_cache, base::RunLoop* run_loop, bool result) {
|
| @@ -48,12 +58,33 @@ view_manager::Id OpenWindow(WindowManagerService* window_manager) {
|
| return id;
|
| }
|
|
|
| +view_manager::Id OpenWindowWithURL(WindowManagerService* window_manager,
|
| + const std::string& url) {
|
| + base::RunLoop run_loop;
|
| + view_manager::Id id;
|
| + window_manager->OpenWindowWithURL(
|
| + url,
|
| + base::Bind(&OpenWindowCallback, &id, &run_loop));
|
| + run_loop.Run();
|
| + return id;
|
| +}
|
| +
|
| class TestWindowManagerClient : public WindowManagerClient {
|
| public:
|
| + typedef base::Callback<void(view_manager::Id, view_manager::Id)>
|
| + TwoNodeCallback;
|
| +
|
| explicit TestWindowManagerClient(base::RunLoop* run_loop)
|
| : run_loop_(run_loop) {}
|
| virtual ~TestWindowManagerClient() {}
|
|
|
| + void set_focus_changed_callback(const TwoNodeCallback& callback) {
|
| + focus_changed_callback_ = callback;
|
| + }
|
| + void set_active_window_changed_callback(const TwoNodeCallback& callback) {
|
| + active_window_changed_callback_ = callback;
|
| + }
|
| +
|
| private:
|
| // Overridden from WindowManagerClient:
|
| virtual void OnWindowManagerReady() MOJO_OVERRIDE {
|
| @@ -61,13 +92,74 @@ class TestWindowManagerClient : public WindowManagerClient {
|
| }
|
| virtual void OnCaptureChanged(
|
| view_manager::Id old_capture_node_id,
|
| - view_manager::Id new_capture_node_id) MOJO_OVERRIDE {}
|
| + view_manager::Id new_capture_node_id) MOJO_OVERRIDE {
|
| + }
|
| + virtual void OnFocusChanged(
|
| + view_manager::Id old_focused_node_id,
|
| + view_manager::Id new_focused_node_id) MOJO_OVERRIDE {
|
| + if (!focus_changed_callback_.is_null())
|
| + focus_changed_callback_.Run(old_focused_node_id, new_focused_node_id);
|
| + }
|
| + virtual void OnActiveWindowChanged(
|
| + view_manager::Id old_active_window,
|
| + view_manager::Id new_active_window) MOJO_OVERRIDE {
|
| + if (!active_window_changed_callback_.is_null())
|
| + active_window_changed_callback_.Run(old_active_window, new_active_window);
|
| + }
|
|
|
| base::RunLoop* run_loop_;
|
| + TwoNodeCallback focus_changed_callback_;
|
| + TwoNodeCallback active_window_changed_callback_;
|
|
|
| DISALLOW_COPY_AND_ASSIGN(TestWindowManagerClient);
|
| };
|
|
|
| +class TestServiceLoader : public ServiceLoader,
|
| + public ApplicationDelegate,
|
| + public view_manager::ViewManagerDelegate {
|
| + public:
|
| + typedef base::Callback<void(view_manager::Node*)> RootAddedCallback;
|
| +
|
| + explicit TestServiceLoader(const RootAddedCallback& root_added_callback)
|
| + : root_added_callback_(root_added_callback) {}
|
| + virtual ~TestServiceLoader() {}
|
| +
|
| + private:
|
| + // Overridden from ServiceLoader:
|
| + virtual void LoadService(ServiceManager* service_manager,
|
| + const GURL& url,
|
| + ScopedMessagePipeHandle shell_handle) MOJO_OVERRIDE {
|
| + scoped_ptr<ApplicationImpl> app(
|
| + new ApplicationImpl(this, shell_handle.Pass()));
|
| + apps_.push_back(app.release());
|
| + }
|
| + virtual void OnServiceError(ServiceManager* service_manager,
|
| + const GURL& url) MOJO_OVERRIDE {
|
| + }
|
| +
|
| + // Overridden from ApplicationDelegate:
|
| + virtual bool ConfigureIncomingConnection(
|
| + ApplicationConnection* connection) MOJO_OVERRIDE {
|
| + view_manager::ViewManager::ConfigureIncomingConnection(connection, this);
|
| + return true;
|
| + }
|
| +
|
| + // Overridden from ViewManagerDelegate:
|
| + virtual void OnRootAdded(view_manager::ViewManager* view_manager,
|
| + view_manager::Node* root) MOJO_OVERRIDE {
|
| + root_added_callback_.Run(root);
|
| + }
|
| + virtual void OnViewManagerDisconnected(
|
| + view_manager::ViewManager* view_manager) MOJO_OVERRIDE {
|
| + }
|
| +
|
| + RootAddedCallback root_added_callback_;
|
| +
|
| + ScopedVector<ApplicationImpl> apps_;
|
| +
|
| + DISALLOW_COPY_AND_ASSIGN(TestServiceLoader);
|
| +};
|
| +
|
| } // namespace
|
|
|
| class WindowManagerApiTest : public testing::Test {
|
| @@ -76,12 +168,52 @@ class WindowManagerApiTest : public testing::Test {
|
| virtual ~WindowManagerApiTest() {}
|
|
|
| protected:
|
| + typedef std::pair<view_manager::Id, view_manager::Id> TwoIds;
|
| +
|
| + view_manager::Id WaitForEmbed() {
|
| + view_manager::Id id;
|
| + base::RunLoop run_loop;
|
| + root_added_callback_ = base::Bind(&WindowManagerApiTest::OnEmbed,
|
| + base::Unretained(this), &id, &run_loop);
|
| + run_loop.Run();
|
| + return id;
|
| + }
|
| +
|
| + TwoIds WaitForFocusChange() {
|
| + TwoIds old_and_new;
|
| + base::RunLoop run_loop;
|
| + window_manager_client()->set_focus_changed_callback(
|
| + base::Bind(&WindowManagerApiTest::OnFocusChanged,
|
| + base::Unretained(this), &old_and_new, &run_loop));
|
| + run_loop.Run();
|
| + return old_and_new;
|
| + }
|
| +
|
| + TwoIds WaitForActiveWindowChange() {
|
| + TwoIds old_and_new;
|
| + base::RunLoop run_loop;
|
| + window_manager_client()->set_active_window_changed_callback(
|
| + base::Bind(&WindowManagerApiTest::OnActiveWindowChanged,
|
| + base::Unretained(this), &old_and_new, &run_loop));
|
| + run_loop.Run();
|
| + return old_and_new;
|
| + }
|
| +
|
| + TestWindowManagerClient* window_manager_client() {
|
| + return window_manager_client_.get();
|
| + }
|
| +
|
| WindowManagerServicePtr window_manager_;
|
|
|
| private:
|
| // Overridden from testing::Test:
|
| virtual void SetUp() MOJO_OVERRIDE {
|
| test_helper_.Init();
|
| + test_helper_.SetLoaderForURL(
|
| + scoped_ptr<ServiceLoader>(new TestServiceLoader(
|
| + base::Bind(&WindowManagerApiTest::OnRootAdded,
|
| + base::Unretained(this)))),
|
| + GURL(kTestServiceURL));
|
| test_helper_.service_manager()->ConnectToService(
|
| GURL("mojo:mojo_view_manager"),
|
| &view_manager_init_);
|
| @@ -96,21 +228,74 @@ class WindowManagerApiTest : public testing::Test {
|
| GURL("mojo:mojo_core_window_manager"),
|
| &window_manager_);
|
| base::RunLoop connect_loop;
|
| - window_manager_client_ = new TestWindowManagerClient(&connect_loop);
|
| - window_manager_.set_client(window_manager_client_);
|
| + window_manager_client_.reset(new TestWindowManagerClient(&connect_loop));
|
| + window_manager_.set_client(window_manager_client());
|
| connect_loop.Run();
|
| }
|
|
|
| + void OnRootAdded(view_manager::Node* root) {
|
| + if (!root_added_callback_.is_null())
|
| + root_added_callback_.Run(root);
|
| + }
|
| +
|
| + void OnEmbed(view_manager::Id* root_id,
|
| + base::RunLoop* loop,
|
| + view_manager::Node* root) {
|
| + *root_id = root->id();
|
| + loop->Quit();
|
| + }
|
| +
|
| + void OnFocusChanged(TwoIds* old_and_new,
|
| + base::RunLoop* run_loop,
|
| + view_manager::Id old_focused_node_id,
|
| + view_manager::Id new_focused_node_id) {
|
| + DCHECK(old_and_new);
|
| + old_and_new->first = old_focused_node_id;
|
| + old_and_new->second = new_focused_node_id;
|
| + run_loop->Quit();
|
| + }
|
| +
|
| + void OnActiveWindowChanged(TwoIds* old_and_new,
|
| + base::RunLoop* run_loop,
|
| + view_manager::Id old_focused_node_id,
|
| + view_manager::Id new_focused_node_id) {
|
| + DCHECK(old_and_new);
|
| + old_and_new->first = old_focused_node_id;
|
| + old_and_new->second = new_focused_node_id;
|
| + run_loop->Quit();
|
| + }
|
| +
|
| base::MessageLoop loop_;
|
| shell::ShellTestHelper test_helper_;
|
| view_manager::ViewManagerInitServicePtr view_manager_init_;
|
| - TestWindowManagerClient* window_manager_client_;
|
| + scoped_ptr<TestWindowManagerClient> window_manager_client_;
|
| + TestServiceLoader::RootAddedCallback root_added_callback_;
|
|
|
| DISALLOW_COPY_AND_ASSIGN(WindowManagerApiTest);
|
| };
|
|
|
| TEST_F(WindowManagerApiTest, OpenWindow) {
|
| OpenWindow(window_manager_.get());
|
| + view_manager::Id created_node =
|
| + OpenWindowWithURL(window_manager_.get(), kTestServiceURL);
|
| + view_manager::Id embed_node = WaitForEmbed();
|
| + EXPECT_EQ(created_node, embed_node);
|
| +}
|
| +
|
| +TEST_F(WindowManagerApiTest, FocusAndActivateWindow) {
|
| + view_manager::Id first_window = OpenWindow(window_manager_.get());
|
| + window_manager_->FocusWindow(first_window,
|
| + base::Bind(&EmptyResultCallback));
|
| + TwoIds ids = WaitForFocusChange();
|
| + EXPECT_EQ(ids.first, 0);
|
| + EXPECT_EQ(ids.second, first_window);
|
| +
|
| + view_manager::Id second_window = OpenWindow(window_manager_.get());
|
| + window_manager_->ActivateWindow(second_window,
|
| + base::Bind(&EmptyResultCallback));
|
| + ids = WaitForActiveWindowChange();
|
| + EXPECT_EQ(ids.first, first_window);
|
| + EXPECT_EQ(ids.second, second_window);
|
| }
|
|
|
| } // namespace mojo
|
|
|