Chromium Code Reviews| Index: extensions/shell/browser/shell_native_app_window_aura_unittest.cc |
| diff --git a/extensions/shell/browser/shell_native_app_window_aura_unittest.cc b/extensions/shell/browser/shell_native_app_window_aura_unittest.cc |
| new file mode 100644 |
| index 0000000000000000000000000000000000000000..81abe427e55ec1ee71de1ceb3c764552ea22b6b0 |
| --- /dev/null |
| +++ b/extensions/shell/browser/shell_native_app_window_aura_unittest.cc |
| @@ -0,0 +1,76 @@ |
| +// Copyright 2014 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 "extensions/shell/browser/shell_native_app_window_aura.h" |
| + |
| +#include "base/memory/scoped_ptr.h" |
| +#include "content/public/browser/browser_context.h" |
| +#include "content/public/browser/notification_service.h" |
| +#include "content/public/browser/web_contents.h" |
| +#include "content/public/test/test_browser_context.h" |
| +#include "content/public/test/test_browser_thread_bundle.h" |
| +#include "extensions/browser/app_window/app_window.h" |
| +#include "extensions/browser/app_window/test_app_window_contents.h" |
| +#include "extensions/browser/extensions_test.h" |
| +#include "extensions/common/extension.h" |
| +#include "extensions/common/extension_builder.h" |
| +#include "extensions/shell/browser/desktop_controller.h" |
| +#include "extensions/shell/browser/shell_app_delegate.h" |
| +#include "extensions/shell/browser/shell_app_window_client.h" |
| +#include "ui/gfx/geometry/rect.h" |
| + |
| +namespace extensions { |
| + |
| +class ShellNativeAppWindowAuraTest : public ExtensionsTest { |
| + public: |
| + ShellNativeAppWindowAuraTest() |
| + : notification_service_(content::NotificationService::Create()) { |
|
James Cook
2014/11/17 20:54:22
Not necessarily for this CL: I think we should cre
Yoyo Zhou
2014/11/17 23:55:26
I agree. Added a TODO.
|
| + AppWindowClient::Set(&app_window_client_); |
| + } |
| + |
| + ~ShellNativeAppWindowAuraTest() override {} |
| + |
| + void TearDown() override { ExtensionsTest::TearDown(); } |
|
James Cook
2014/11/17 20:54:22
not needed
Yoyo Zhou
2014/11/17 23:55:26
Done.
|
| + |
| + protected: |
| + content::TestBrowserThreadBundle thread_bundle_; |
| + scoped_ptr<content::NotificationService> notification_service_; |
| + ShellAppWindowClient app_window_client_; |
| +}; |
| + |
| +TEST_F(ShellNativeAppWindowAuraTest, Bounds) { |
| + // The BrowserContext used here must be destroyed before the thread bundle, |
| + // because of destructors of things spawned from creating a WebContents. |
| + scoped_ptr<content::BrowserContext> browser_context( |
| + new content::TestBrowserContext); |
| + scoped_refptr<Extension> extension = |
| + ExtensionBuilder() |
| + .SetManifest(DictionaryBuilder() |
| + .Set("name", "test extension") |
| + .Set("version", "1") |
| + .Set("manifest_version", 2)) |
| + .Build(); |
| + |
| + AppWindow* app_window = new AppWindow( |
| + browser_context.get(), new ShellAppDelegate, extension.get()); |
| + content::WebContents* web_contents = content::WebContents::Create( |
| + content::WebContents::CreateParams(browser_context.get())); |
| + app_window->SetAppWindowContentsForTesting( |
| + make_scoped_ptr(new TestAppWindowContents(web_contents))); |
| + |
| + AppWindow::BoundsSpecification window_spec; |
| + window_spec.bounds = gfx::Rect(100, 200, 300, 400); |
|
James Cook
2014/11/17 20:54:22
+1 for varying the data!
|
| + AppWindow::CreateParams params; |
| + params.window_spec = window_spec; |
| + |
| + ShellNativeAppWindowAura window(app_window, params); |
| + |
| + gfx::Rect bounds = window.GetBounds(); |
| + ASSERT_EQ(window_spec.bounds, bounds); |
|
James Cook
2014/11/17 20:54:22
EXPECT_EQ? Do you want the test to crash if this d
Yoyo Zhou
2014/11/17 23:55:26
Done.
|
| + |
| + // Delete the AppWindow. |
| + app_window->OnNativeClose(); |
| +} |
| + |
| +} // namespace extensions |
|
James Cook
2014/11/17 20:54:22
Thanks for writing this test. I know it was a pain
|