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

Unified Diff: extensions/common/user_script_unittest.cc

Issue 2227193002: Make UserScript non-copyable. (Closed) Base URL: https://chromium.googlesource.com/chromium/src.git@master
Patch Set: uplaod with base Created 4 years, 4 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 side-by-side diff with in-line comments
Download patch
Index: extensions/common/user_script_unittest.cc
diff --git a/extensions/common/user_script_unittest.cc b/extensions/common/user_script_unittest.cc
index 5923f4c003cb9b0136487114d7236a661fdeeaea..ee0339d6e9504c691183929d83671b93fae294e9 100644
--- a/extensions/common/user_script_unittest.cc
+++ b/extensions/common/user_script_unittest.cc
@@ -6,6 +6,7 @@
#include <stdint.h>
#include "base/files/file_path.h"
+#include "base/memory/ptr_util.h"
#include "base/pickle.h"
#include "extensions/common/user_script.h"
#include "testing/gtest/include/gtest/gtest.h"
@@ -21,7 +22,7 @@ static const int kAllSchemes =
URLPattern::SCHEME_CHROMEUI;
TEST(ExtensionUserScriptTest, Glob_HostString) {
- UserScript script;
+ ScriptMetadata script;
script.add_glob("*mail.google.com*");
script.add_glob("*mail.yahoo.com*");
script.add_glob("*mail.msn.com*");
@@ -40,7 +41,7 @@ TEST(ExtensionUserScriptTest, Glob_HostString) {
}
TEST(ExtensionUserScriptTest, Glob_TrailingSlash) {
- UserScript script;
+ ScriptMetadata script;
script.add_glob("*mail.google.com/");
// GURL normalizes the URL to have a trailing "/"
EXPECT_TRUE(script.MatchesURL(GURL("http://mail.google.com")));
@@ -49,7 +50,7 @@ TEST(ExtensionUserScriptTest, Glob_TrailingSlash) {
}
TEST(ExtensionUserScriptTest, Glob_TrailingSlashStar) {
- UserScript script;
+ ScriptMetadata script;
script.add_glob("http://mail.google.com/*");
// GURL normalizes the URL to have a trailing "/"
EXPECT_TRUE(script.MatchesURL(GURL("http://mail.google.com")));
@@ -58,7 +59,7 @@ TEST(ExtensionUserScriptTest, Glob_TrailingSlashStar) {
}
TEST(ExtensionUserScriptTest, Glob_Star) {
- UserScript script;
+ ScriptMetadata script;
script.add_glob("*");
EXPECT_TRUE(script.MatchesURL(GURL("http://foo.com/bar")));
EXPECT_TRUE(script.MatchesURL(GURL("http://hot.com/dog")));
@@ -68,7 +69,7 @@ TEST(ExtensionUserScriptTest, Glob_Star) {
}
TEST(ExtensionUserScriptTest, Glob_StringAnywhere) {
- UserScript script;
+ ScriptMetadata script;
script.add_glob("*foo*");
EXPECT_TRUE(script.MatchesURL(GURL("http://foo.com/bar")));
EXPECT_TRUE(script.MatchesURL(GURL("http://baz.org/foo/bar")));
@@ -79,7 +80,7 @@ TEST(ExtensionUserScriptTest, UrlPattern) {
URLPattern pattern(kAllSchemes);
ASSERT_EQ(URLPattern::PARSE_SUCCESS, pattern.Parse("http://*/foo*"));
- UserScript script;
+ ScriptMetadata script;
script.add_url_pattern(pattern);
EXPECT_TRUE(script.MatchesURL(GURL("http://monkey.com/foobar")));
EXPECT_FALSE(script.MatchesURL(GURL("http://monkey.com/hotdog")));
@@ -88,7 +89,7 @@ TEST(ExtensionUserScriptTest, UrlPattern) {
}
TEST(ExtensionUserScriptTest, ExcludeUrlPattern) {
- UserScript script;
+ ScriptMetadata script;
URLPattern pattern(kAllSchemes);
ASSERT_EQ(URLPattern::PARSE_SUCCESS, pattern.Parse("http://*.nytimes.com/*"));
@@ -104,7 +105,7 @@ TEST(ExtensionUserScriptTest, ExcludeUrlPattern) {
}
TEST(ExtensionUserScriptTest, UrlPatternAndIncludeGlobs) {
- UserScript script;
+ ScriptMetadata script;
URLPattern pattern(kAllSchemes);
ASSERT_EQ(URLPattern::PARSE_SUCCESS, pattern.Parse("http://*.nytimes.com/*"));
@@ -118,7 +119,7 @@ TEST(ExtensionUserScriptTest, UrlPatternAndIncludeGlobs) {
}
TEST(ExtensionUserScriptTest, UrlPatternAndExcludeGlobs) {
- UserScript script;
+ ScriptMetadata script;
URLPattern pattern(kAllSchemes);
ASSERT_EQ(URLPattern::PARSE_SUCCESS, pattern.Parse("http://*.nytimes.com/*"));
@@ -133,7 +134,7 @@ TEST(ExtensionUserScriptTest, UrlPatternAndExcludeGlobs) {
TEST(ExtensionUserScriptTest, UrlPatternGlobInteraction) {
// If there are both, match intersection(union(globs), union(urlpatterns)).
- UserScript script;
+ ScriptMetadata script;
URLPattern pattern(kAllSchemes);
ASSERT_EQ(URLPattern::PARSE_SUCCESS,
@@ -172,19 +173,19 @@ TEST(ExtensionUserScriptTest, Pickle) {
ASSERT_EQ(URLPattern::PARSE_SUCCESS, exclude1.Parse("*://*/*bar"));
ASSERT_EQ(URLPattern::PARSE_SUCCESS, exclude2.Parse("https://*/*"));
- UserScript script1;
- script1.js_scripts().push_back(UserScript::File(
- base::FilePath(FILE_PATH_LITERAL("c:\\foo\\")),
- base::FilePath(FILE_PATH_LITERAL("foo.user.js")),
- GURL("chrome-extension://abc/foo.user.js")));
- script1.css_scripts().push_back(UserScript::File(
- base::FilePath(FILE_PATH_LITERAL("c:\\foo\\")),
- base::FilePath(FILE_PATH_LITERAL("foo.user.css")),
- GURL("chrome-extension://abc/foo.user.css")));
- script1.css_scripts().push_back(UserScript::File(
- base::FilePath(FILE_PATH_LITERAL("c:\\foo\\")),
- base::FilePath(FILE_PATH_LITERAL("foo2.user.css")),
- GURL("chrome-extension://abc/foo2.user.css")));
+ ScriptMetadata script1;
+ script1.js_scripts().push_back(base::WrapUnique(
+ new UserScriptFileInfo(base::FilePath(FILE_PATH_LITERAL("c:\\foo\\")),
+ base::FilePath(FILE_PATH_LITERAL("foo.user.js")),
+ GURL("chrome-extension://abc/foo.user.js"))));
+ script1.css_scripts().push_back(base::WrapUnique(
+ new UserScriptFileInfo(base::FilePath(FILE_PATH_LITERAL("c:\\foo\\")),
+ base::FilePath(FILE_PATH_LITERAL("foo.user.css")),
+ GURL("chrome-extension://abc/foo.user.css"))));
+ script1.css_scripts().push_back(base::WrapUnique(
+ new UserScriptFileInfo(base::FilePath(FILE_PATH_LITERAL("c:\\foo\\")),
+ base::FilePath(FILE_PATH_LITERAL("foo2.user.css")),
+ GURL("chrome-extension://abc/foo2.user.css"))));
script1.set_run_location(UserScript::DOCUMENT_START);
script1.add_url_pattern(pattern1);
@@ -199,18 +200,31 @@ TEST(ExtensionUserScriptTest, Pickle) {
script1.set_host_id(id);
base::Pickle pickle;
- script1.Pickle(&pickle);
+ // Pickle script.
+ {
+ // Only browser/ side (BrowserUserScript) and renderer/ side
+ // (RendererUserScript) implementation of user script is (de)serializable,
+ // ScriptMetadata is common/, so pickle it manually.
+ static_cast<UserScriptInfo*>(&script1)->Pickle(&pickle);
+ static_cast<UserScriptFiles<UserScriptFileInfo>*>(&script1)->PickleFiles(
+ &pickle);
+ }
base::PickleIterator iter(pickle);
- UserScript script2;
- script2.Unpickle(pickle, &iter);
+ ScriptMetadata script2;
+ {
+ // Same as Pickle step above, unpickle this manually.
+ static_cast<UserScriptInfo*>(&script2)->Unpickle(pickle, &iter);
+ static_cast<UserScriptFiles<UserScriptFileInfo>*>(&script2)->UnpickleFiles(
+ pickle, &iter);
+ }
EXPECT_EQ(1U, script2.js_scripts().size());
- EXPECT_EQ(script1.js_scripts()[0].url(), script2.js_scripts()[0].url());
+ EXPECT_EQ(script1.js_scripts()[0]->url(), script2.js_scripts()[0]->url());
EXPECT_EQ(2U, script2.css_scripts().size());
for (size_t i = 0; i < script2.js_scripts().size(); ++i) {
- EXPECT_EQ(script1.css_scripts()[i].url(), script2.css_scripts()[i].url());
+ EXPECT_EQ(script1.css_scripts()[i]->url(), script2.css_scripts()[i]->url());
}
ASSERT_EQ(script1.globs().size(), script2.globs().size());
@@ -226,7 +240,7 @@ TEST(ExtensionUserScriptTest, Pickle) {
}
TEST(ExtensionUserScriptTest, Defaults) {
- UserScript script;
+ ScriptMetadata script;
ASSERT_EQ(UserScript::DOCUMENT_IDLE, script.run_location());
}

Powered by Google App Engine
This is Rietveld 408576698