OLD | NEW |
---|---|
(Empty) | |
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 | |
3 // found in the LICENSE file. | |
4 | |
5 #include "base/command_line.h" | |
6 #include "base/memory/scoped_ptr.h" | |
7 #include "base/synchronization/waitable_event.h" | |
8 #include "chrome/browser/extensions/activity_log.h" | |
9 #include "chrome/browser/extensions/extension_service.h" | |
10 #include "chrome/browser/extensions/test_extension_system.h" | |
11 #include "chrome/common/chrome_constants.h" | |
12 #include "chrome/common/extensions/extension_builder.h" | |
13 #include "chrome/test/base/chrome_render_view_host_test_harness.h" | |
14 #include "chrome/test/base/testing_profile.h" | |
15 #include "content/public/browser/browser_thread.h" | |
16 #include "content/public/test/test_browser_thread.h" | |
17 #include "sql/statement.h" | |
18 #include "testing/gtest/include/gtest/gtest.h" | |
19 | |
20 namespace extensions { | |
21 | |
22 class ActivityLogTest : public ChromeRenderViewHostTestHarness { | |
23 public: | |
24 ActivityLogTest() | |
25 : ui_thread_(BrowserThread::UI, MessageLoop::current()), | |
26 db_thread_(BrowserThread::DB), | |
27 file_thread_(BrowserThread::FILE, MessageLoop::current()) {} | |
28 | |
29 virtual void SetUp() OVERRIDE { | |
30 ChromeRenderViewHostTestHarness::SetUp(); | |
31 CommandLine command_line(CommandLine::NO_PROGRAM); | |
32 profile_ = | |
33 Profile::FromBrowserContext(web_contents()->GetBrowserContext()); | |
34 extension_service_ = static_cast<TestExtensionSystem*>( | |
35 ExtensionSystem::Get(profile_))->CreateExtensionService( | |
36 &command_line, FilePath(), false); | |
37 db_thread_.Start(); | |
38 } | |
39 | |
40 ~ActivityLogTest() { | |
41 base::WaitableEvent done(false, false); | |
42 BrowserThread::PostTask(BrowserThread::DB, FROM_HERE, | |
43 base::Bind(&base::WaitableEvent::Signal, base::Unretained(&done))); | |
44 done.Wait(); | |
45 db_thread_.Stop(); | |
46 MessageLoop::current()->PostTask(FROM_HERE, MessageLoop::QuitClosure()); | |
47 MessageLoop::current()->Run(); | |
48 } | |
49 | |
50 protected: | |
51 ExtensionService* extension_service_; | |
52 Profile* profile_; | |
53 | |
54 private: | |
55 content::TestBrowserThread ui_thread_; | |
56 content::TestBrowserThread db_thread_; | |
57 content::TestBrowserThread file_thread_; | |
58 }; | |
59 | |
60 TEST_F(ActivityLogTest, ConstructAndLog) { | |
61 ActivityLog* activity_log = ActivityLog::GetInstance(profile_); | |
62 scoped_refptr<const Extension> extension = | |
63 ExtensionBuilder() | |
64 .SetManifest(DictionaryBuilder() | |
65 .Set("name", "Test extension") | |
66 .Set("version", "1.0.0") | |
67 .Set("manifest_version", 2)) | |
68 .Build(); | |
69 extension_service_->AddExtension(extension); | |
70 scoped_ptr<ListValue> args; | |
Eric Dingle
2012/12/19 18:33:47
scoped_ptr<ListValue> args(new ListValue());
felt
2013/01/07 23:44:22
Done.
| |
71 args.reset(new ListValue()); | |
72 for (int i = 0; i < 30; i++) { | |
73 // Run this a bunch of times and hope that if something goes wrong with | |
74 // threading, 30 times is enough to cause it to fail. | |
75 activity_log->LogAPIAction(extension, | |
76 std::string("tabs.testMethod"), | |
77 args.get()); | |
78 } | |
79 // Need to ensure the writes were completed. | |
80 base::PlatformThread::Sleep(base::TimeDelta::FromSeconds(3)); | |
81 FilePath db_file = profile_->GetPath().Append( | |
82 chrome::kExtensionActivityLogFilename); | |
83 sql::Connection db; | |
84 ASSERT_TRUE(db.Open(db_file)); | |
85 std::string sql_str = "SELECT * FROM " + | |
86 std::string(ManagerAction::kTableName); | |
87 sql::Statement statement(db.GetUniqueStatement(sql_str.c_str())); | |
88 ASSERT_TRUE(statement.Step()); | |
89 ASSERT_EQ("UNKNOWN_ACTION", statement.ColumnString(2)); | |
90 ASSERT_EQ("TABS", statement.ColumnString(3)); | |
91 ASSERT_EQ("tabs.testMethod()", statement.ColumnString(4)); | |
92 } | |
93 | |
94 } // namespace extensions | |
95 | |
OLD | NEW |