Chromium Code Reviews
chromiumcodereview-hr@appspot.gserviceaccount.com (chromiumcodereview-hr) | Please choose your nickname with Settings | Help | Chromium Project | Gerrit Changes | Sign out
(252)

Side by Side Diff: chrome/test/base/javascript_browser_test.cc

Issue 320753002: Support javascript gtests in an extension background page. (Closed) Base URL: svn://svn.chromium.org/chrome/trunk/src
Patch Set: lint Created 6 years, 6 months ago
Use n/p to move between diff chunks; N/P to move between comments. Draft comments are only viewable by you.
Jump to:
View unified diff | Download patch | Annotate | Revision Log
OLDNEW
(Empty)
1 // Copyright 2014 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 "chrome/test/base/javascript_browser_test.h"
6
7 #include "base/path_service.h"
8 #include "base/strings/utf_string_conversions.h"
9 #include "chrome/common/chrome_paths.h"
10 #include "content/public/browser/web_ui.h"
11 #include "ui/base/resource/resource_bundle.h"
12
13 // static
14 const base::FilePath::CharType
15 JavaScriptBrowserTest::kA11yAuditLibraryJSPath[] =
16 FILE_PATH_LITERAL("third_party/accessibility-audit/axs_testing.js");
17
18 // static
19 const base::FilePath::CharType JavaScriptBrowserTest::kMockJSPath[] =
20 FILE_PATH_LITERAL("chrome/third_party/mock4js/mock4js.js");
21
22 // static
23 const base::FilePath::CharType JavaScriptBrowserTest::kWebUILibraryJS[] =
24 FILE_PATH_LITERAL("test_api.js");
25
26 // static
27 const base::FilePath::CharType JavaScriptBrowserTest::kWebUITestFolder[] =
28 FILE_PATH_LITERAL("webui");
29
30 void JavaScriptBrowserTest::AddLibrary(const base::FilePath& library_path) {
31 user_libraries_.push_back(library_path);
32 }
33
34 JavaScriptBrowserTest::JavaScriptBrowserTest() {
35 }
36
37 JavaScriptBrowserTest::~JavaScriptBrowserTest() {
38 }
39
40 void JavaScriptBrowserTest::SetUpOnMainThread() {
41 base::FilePath test_data_directory;
42 ASSERT_TRUE(PathService::Get(chrome::DIR_TEST_DATA, &test_data_directory));
43 test_data_directory = test_data_directory.Append(kWebUITestFolder);
44 library_search_paths_.push_back(test_data_directory);
45
46 base::FilePath gen_test_data_directory;
47 ASSERT_TRUE(
48 PathService::Get(chrome::DIR_GEN_TEST_DATA, &gen_test_data_directory));
49 library_search_paths_.push_back(gen_test_data_directory);
50
51 base::FilePath source_root_directory;
52 ASSERT_TRUE(PathService::Get(base::DIR_SOURCE_ROOT, &source_root_directory));
53 library_search_paths_.push_back(source_root_directory);
54
55 base::FilePath resources_pack_path;
56 PathService::Get(chrome::FILE_RESOURCES_PACK, &resources_pack_path);
57 ResourceBundle::GetSharedInstance().AddDataPackFromPath(
58 resources_pack_path, ui::SCALE_FACTOR_NONE);
59
60 AddLibrary(base::FilePath(kMockJSPath));
61 AddLibrary(base::FilePath(kWebUILibraryJS));
62 }
63
64 void JavaScriptBrowserTest::BuildJavascriptLibraries(
65 std::vector<base::string16>* libraries) {
66 ASSERT_TRUE(libraries != NULL);
67 std::vector<base::FilePath>::iterator user_libraries_iterator;
68 for (user_libraries_iterator = user_libraries_.begin();
69 user_libraries_iterator != user_libraries_.end();
70 ++user_libraries_iterator) {
71 std::string library_content;
72 if (user_libraries_iterator->IsAbsolute()) {
73 ASSERT_TRUE(
74 base::ReadFileToString(*user_libraries_iterator, &library_content))
75 << user_libraries_iterator->value();
76 } else {
77 bool ok = false;
78 std::vector<base::FilePath>::iterator library_search_path_iterator;
79 for (library_search_path_iterator = library_search_paths_.begin();
80 library_search_path_iterator != library_search_paths_.end();
81 ++library_search_path_iterator) {
82 ok = base::ReadFileToString(
83 base::MakeAbsoluteFilePath(
84 library_search_path_iterator->Append(*user_libraries_iterator)),
85 &library_content);
86 if (ok)
87 break;
88 }
89 ASSERT_TRUE(ok) << "User library not found: "
Paweł Hajdan Jr. 2014/06/13 13:45:23 If possible please use bool return value to commun
David Tseng 2014/06/13 23:23:38 I've left a TODO because it would involve changing
90 << user_libraries_iterator->value();
91 }
92 library_content.append(";\n");
93
94 // This magic code puts filenames in stack traces.
95 library_content.append("//# sourceURL=");
96 library_content.append(user_libraries_iterator->BaseName().AsUTF8Unsafe());
97 library_content.append("\n");
98 libraries->push_back(base::UTF8ToUTF16(library_content));
99 }
100 }
101
102 base::string16 JavaScriptBrowserTest::BuildRunTestJSCall(
103 bool is_async,
104 const std::string& function_name,
105 const ConstValueVector& test_func_args) {
106 ConstValueVector arguments;
107 base::FundamentalValue* is_async_arg = new base::FundamentalValue(is_async);
108 arguments.push_back(is_async_arg);
109 base::StringValue* function_name_arg = new base::StringValue(function_name);
110 arguments.push_back(function_name_arg);
111 base::ListValue* baked_argument_list = new base::ListValue();
112 ConstValueVector::const_iterator arguments_iterator;
113 for (arguments_iterator = test_func_args.begin();
114 arguments_iterator != test_func_args.end();
115 ++arguments_iterator) {
116 baked_argument_list->Append((*arguments_iterator)->DeepCopy());
117 }
118 arguments.push_back(baked_argument_list);
119 return content::WebUI::GetJavascriptCall(std::string("runTest"),
120 arguments.get());
121 }
OLDNEW

Powered by Google App Engine
This is Rietveld 408576698