OLD | NEW |
1 // Copyright (c) 2012 The Chromium Authors. All rights reserved. | 1 // Copyright (c) 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/base_paths.h" | 5 #include "base/base_paths.h" |
| 6 #include "base/callback.h" |
6 #include "base/command_line.h" | 7 #include "base/command_line.h" |
7 #include "base/path_service.h" | 8 #include "base/path_service.h" |
8 #include "base/synchronization/waitable_event_watcher.h" | 9 #include "base/synchronization/waitable_event_watcher.h" |
9 #include "content/browser/plugin_data_remover_impl.h" | 10 #include "content/browser/plugin_data_remover_impl.h" |
10 #include "content/public/browser/web_contents.h" | 11 #include "content/public/browser/web_contents.h" |
11 #include "content/public/common/content_switches.h" | 12 #include "content/public/common/content_switches.h" |
12 #include "content/public/test/test_utils.h" | 13 #include "content/public/test/test_utils.h" |
13 #include "content/shell/shell.h" | 14 #include "content/shell/shell.h" |
14 #include "content/test/content_browser_test.h" | 15 #include "content/test/content_browser_test.h" |
15 | 16 |
16 namespace content { | 17 namespace content { |
17 | 18 |
18 namespace { | 19 namespace { |
19 const char* kNPAPITestPluginMimeType = "application/vnd.npapi-test"; | 20 const char* kNPAPITestPluginMimeType = "application/vnd.npapi-test"; |
20 } | 21 } |
21 | 22 |
22 class PluginDataRemoverTest : public ContentBrowserTest, | 23 class PluginDataRemoverTest : public ContentBrowserTest { |
23 public base::WaitableEventWatcher::Delegate { | |
24 public: | 24 public: |
25 PluginDataRemoverTest() {} | 25 PluginDataRemoverTest() {} |
26 | 26 |
27 virtual void OnWaitableEventSignaled(base::WaitableEvent* waitable_event) { | 27 void OnWaitableEventSignaled(base::WaitableEvent* waitable_event) { |
28 MessageLoop::current()->Quit(); | 28 MessageLoop::current()->Quit(); |
29 } | 29 } |
30 | 30 |
31 virtual void SetUpCommandLine(CommandLine* command_line) { | 31 virtual void SetUpCommandLine(CommandLine* command_line) { |
32 #ifdef OS_MACOSX | 32 #ifdef OS_MACOSX |
33 FilePath browser_directory; | 33 FilePath browser_directory; |
34 PathService::Get(base::DIR_MODULE, &browser_directory); | 34 PathService::Get(base::DIR_MODULE, &browser_directory); |
35 command_line->AppendSwitchPath(switches::kExtraPluginDir, | 35 command_line->AppendSwitchPath(switches::kExtraPluginDir, |
36 browser_directory.AppendASCII("plugins")); | 36 browser_directory.AppendASCII("plugins")); |
37 #endif | 37 #endif |
38 // TODO(jam): since these plugin tests are running under Chrome, we need to | 38 // TODO(jam): since these plugin tests are running under Chrome, we need to |
39 // tell it to disable its security features for old plugins. Once this is | 39 // tell it to disable its security features for old plugins. Once this is |
40 // running under content_browsertests, these flags won't be needed. | 40 // running under content_browsertests, these flags won't be needed. |
41 // http://crbug.com/90448 | 41 // http://crbug.com/90448 |
42 // switches::kAlwaysAuthorizePlugins | 42 // switches::kAlwaysAuthorizePlugins |
43 command_line->AppendSwitch("always-authorize-plugins"); | 43 command_line->AppendSwitch("always-authorize-plugins"); |
44 } | 44 } |
45 }; | 45 }; |
46 | 46 |
47 IN_PROC_BROWSER_TEST_F(PluginDataRemoverTest, RemoveData) { | 47 IN_PROC_BROWSER_TEST_F(PluginDataRemoverTest, RemoveData) { |
48 PluginDataRemoverImpl plugin_data_remover( | 48 PluginDataRemoverImpl plugin_data_remover( |
49 shell()->web_contents()->GetBrowserContext()); | 49 shell()->web_contents()->GetBrowserContext()); |
50 plugin_data_remover.set_mime_type(kNPAPITestPluginMimeType); | 50 plugin_data_remover.set_mime_type(kNPAPITestPluginMimeType); |
51 base::WaitableEventWatcher watcher; | 51 base::WaitableEventWatcher watcher; |
52 base::WaitableEvent* event = | 52 base::WaitableEvent* event = |
53 plugin_data_remover.StartRemoving(base::Time()); | 53 plugin_data_remover.StartRemoving(base::Time()); |
54 watcher.StartWatching(event, this); | 54 watcher.StartWatching( |
| 55 event, |
| 56 base::Bind(&PluginDataRemoverTest::OnWaitableEventSignaled, this)); |
55 RunMessageLoop(); | 57 RunMessageLoop(); |
56 } | 58 } |
57 | 59 |
58 } // namespace content | 60 } // namespace content |
OLD | NEW |