OLD | NEW |
1 // Copyright 2012 The Chromium Authors. All rights reserved. | 1 // Copyright 2012 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 "base/command_line.h" | 5 #include "base/command_line.h" |
6 #include "base/memory/singleton.h" | 6 #include "base/memory/singleton.h" |
7 #include "base/run_loop.h" | 7 #include "base/run_loop.h" |
8 #include "base/strings/string_split.h" | 8 #include "base/strings/string_split.h" |
9 #include "base/strings/string_util.h" | 9 #include "base/strings/string_util.h" |
10 #include "base/strings/utf_string_conversions.h" | 10 #include "base/strings/utf_string_conversions.h" |
(...skipping 207 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
218 test_guest_manager_(NULL) {} | 218 test_guest_manager_(NULL) {} |
219 | 219 |
220 virtual void SetUp() OVERRIDE { | 220 virtual void SetUp() OVERRIDE { |
221 // Override factory to create tests instances of BrowserPlugin*. | 221 // Override factory to create tests instances of BrowserPlugin*. |
222 content::BrowserPluginEmbedder::set_factory_for_testing( | 222 content::BrowserPluginEmbedder::set_factory_for_testing( |
223 TestBrowserPluginHostFactory::GetInstance()); | 223 TestBrowserPluginHostFactory::GetInstance()); |
224 content::BrowserPluginGuest::set_factory_for_testing( | 224 content::BrowserPluginGuest::set_factory_for_testing( |
225 TestBrowserPluginHostFactory::GetInstance()); | 225 TestBrowserPluginHostFactory::GetInstance()); |
226 content::BrowserPluginGuestManager::set_factory_for_testing( | 226 content::BrowserPluginGuestManager::set_factory_for_testing( |
227 TestBrowserPluginHostFactory::GetInstance()); | 227 TestBrowserPluginHostFactory::GetInstance()); |
228 | |
229 // We need real contexts, otherwise the embedder doesn't composite, but the | |
230 // guest does, and that isn't an expected configuration. | |
231 UseRealGLContexts(); | |
232 | |
233 ContentBrowserTest::SetUp(); | 228 ContentBrowserTest::SetUp(); |
234 } | 229 } |
235 virtual void TearDown() OVERRIDE { | 230 virtual void TearDown() OVERRIDE { |
236 content::BrowserPluginEmbedder::set_factory_for_testing(NULL); | 231 content::BrowserPluginEmbedder::set_factory_for_testing(NULL); |
237 content::BrowserPluginGuest::set_factory_for_testing(NULL); | 232 content::BrowserPluginGuest::set_factory_for_testing(NULL); |
238 | 233 |
239 ContentBrowserTest::TearDown(); | 234 ContentBrowserTest::TearDown(); |
240 } | 235 } |
241 | 236 |
242 virtual void SetUpCommandLine(CommandLine* command_line) OVERRIDE { | 237 virtual void SetUpCommandLine(CommandLine* command_line) OVERRIDE { |
(...skipping 568 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
811 // Tests involving the threaded compositor. | 806 // Tests involving the threaded compositor. |
812 class BrowserPluginThreadedCompositorTest : public BrowserPluginHostTest { | 807 class BrowserPluginThreadedCompositorTest : public BrowserPluginHostTest { |
813 public: | 808 public: |
814 BrowserPluginThreadedCompositorTest() {} | 809 BrowserPluginThreadedCompositorTest() {} |
815 virtual ~BrowserPluginThreadedCompositorTest() {} | 810 virtual ~BrowserPluginThreadedCompositorTest() {} |
816 | 811 |
817 protected: | 812 protected: |
818 virtual void SetUpCommandLine(CommandLine* cmd) OVERRIDE { | 813 virtual void SetUpCommandLine(CommandLine* cmd) OVERRIDE { |
819 BrowserPluginHostTest::SetUpCommandLine(cmd); | 814 BrowserPluginHostTest::SetUpCommandLine(cmd); |
820 cmd->AppendSwitch(switches::kEnableThreadedCompositing); | 815 cmd->AppendSwitch(switches::kEnableThreadedCompositing); |
| 816 } |
| 817 }; |
821 | 818 |
| 819 class BrowserPluginThreadedCompositorPixelTest |
| 820 : public BrowserPluginThreadedCompositorTest { |
| 821 protected: |
| 822 virtual void SetUp() OVERRIDE { |
| 823 UseRealGLContexts(); |
| 824 BrowserPluginThreadedCompositorTest::SetUp(); |
| 825 } |
| 826 |
| 827 virtual void SetUpCommandLine(CommandLine* cmd) OVERRIDE { |
| 828 BrowserPluginThreadedCompositorTest::SetUpCommandLine(cmd); |
822 // http://crbug.com/327035 | 829 // http://crbug.com/327035 |
823 cmd->AppendSwitch(switches::kDisableDelegatedRenderer); | 830 cmd->AppendSwitch(switches::kDisableDelegatedRenderer); |
824 } | 831 } |
825 }; | 832 }; |
826 | 833 |
827 static void CompareSkBitmaps(const SkBitmap& expected_bitmap, | 834 static void CompareSkBitmaps(const SkBitmap& expected_bitmap, |
828 const SkBitmap& bitmap) { | 835 const SkBitmap& bitmap) { |
829 EXPECT_EQ(expected_bitmap.width(), bitmap.width()); | 836 EXPECT_EQ(expected_bitmap.width(), bitmap.width()); |
830 if (expected_bitmap.width() != bitmap.width()) | 837 if (expected_bitmap.width() != bitmap.width()) |
831 return; | 838 return; |
(...skipping 55 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
887 CompareSkBitmaps(expected_bitmap, bitmap); | 894 CompareSkBitmaps(expected_bitmap, bitmap); |
888 callback.Run(); | 895 callback.Run(); |
889 } | 896 } |
890 | 897 |
891 // http://crbug.com/171744 | 898 // http://crbug.com/171744 |
892 #if defined(OS_MACOSX) | 899 #if defined(OS_MACOSX) |
893 #define MAYBE_GetBackingStore DISABLED_GetBackingStore | 900 #define MAYBE_GetBackingStore DISABLED_GetBackingStore |
894 #else | 901 #else |
895 #define MAYBE_GetBackingStore GetBackingStore | 902 #define MAYBE_GetBackingStore GetBackingStore |
896 #endif | 903 #endif |
897 IN_PROC_BROWSER_TEST_F(BrowserPluginThreadedCompositorTest, | 904 IN_PROC_BROWSER_TEST_F(BrowserPluginThreadedCompositorPixelTest, |
898 MAYBE_GetBackingStore) { | 905 MAYBE_GetBackingStore) { |
899 const char kEmbedderURL[] = "/browser_plugin_embedder.html"; | 906 const char kEmbedderURL[] = "/browser_plugin_embedder.html"; |
900 const char kHTMLForGuest[] = | 907 const char kHTMLForGuest[] = |
901 "data:text/html,<html><style>body { background-color: red; }</style>" | 908 "data:text/html,<html><style>body { background-color: red; }</style>" |
902 "<body></body></html>"; | 909 "<body></body></html>"; |
903 StartBrowserPluginTest(kEmbedderURL, kHTMLForGuest, true, | 910 StartBrowserPluginTest(kEmbedderURL, kHTMLForGuest, true, |
904 std::string("SetSize(50, 60);")); | 911 std::string("SetSize(50, 60);")); |
905 | 912 |
906 WebContentsImpl* guest_contents = test_guest()->web_contents(); | 913 WebContentsImpl* guest_contents = test_guest()->web_contents(); |
907 RenderWidgetHostImpl* guest_widget_host = | 914 RenderWidgetHostImpl* guest_widget_host = |
(...skipping 119 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
1027 scoped_ptr<base::Value> value = | 1034 scoped_ptr<base::Value> value = |
1028 content::ExecuteScriptAndGetValue( | 1035 content::ExecuteScriptAndGetValue( |
1029 guest_rvh, "document.getElementById('input1').value"); | 1036 guest_rvh, "document.getElementById('input1').value"); |
1030 std::string actual_value; | 1037 std::string actual_value; |
1031 ASSERT_TRUE(value->GetAsString(&actual_value)); | 1038 ASSERT_TRUE(value->GetAsString(&actual_value)); |
1032 EXPECT_EQ(base::UTF16ToUTF8(expected_value), actual_value); | 1039 EXPECT_EQ(base::UTF16ToUTF8(expected_value), actual_value); |
1033 } | 1040 } |
1034 } | 1041 } |
1035 | 1042 |
1036 } // namespace content | 1043 } // namespace content |
OLD | NEW |