summaryrefslogtreecommitdiffstats
path: root/extensions/common
diff options
context:
space:
mode:
authorrob@robwu.nl <rob@robwu.nl@0039d316-1c4b-4281-b951-d872f2087c98>2014-07-02 01:31:55 +0000
committerrob@robwu.nl <rob@robwu.nl@0039d316-1c4b-4281-b951-d872f2087c98>2014-07-02 01:31:55 +0000
commitd013efc32e29077d3e85b007546c3a65039ae3c2 (patch)
tree54084fe5bb02b1a5f5886603960fdd9fede23f79 /extensions/common
parent690117c4a57385facafbbe1c056e7bc3aa319981 (diff)
downloadchromium_src-d013efc32e29077d3e85b007546c3a65039ae3c2.zip
chromium_src-d013efc32e29077d3e85b007546c3a65039ae3c2.tar.gz
chromium_src-d013efc32e29077d3e85b007546c3a65039ae3c2.tar.bz2
Return if a host name in an URLPattern has no non-whitespace characters.
SplitString trims whitespace, so the |host_components| vector could be empty. BUG=390645 TEST=ExtensionURLPatternTest.ParseInvalid Review URL: https://codereview.chromium.org/364703002 git-svn-id: svn://svn.chromium.org/chrome/trunk/src@280935 0039d316-1c4b-4281-b951-d872f2087c98
Diffstat (limited to 'extensions/common')
-rw-r--r--extensions/common/url_pattern.cc5
-rw-r--r--extensions/common/url_pattern_unittest.cc1
2 files changed, 6 insertions, 0 deletions
diff --git a/extensions/common/url_pattern.cc b/extensions/common/url_pattern.cc
index ee7d164..b667981 100644
--- a/extensions/common/url_pattern.cc
+++ b/extensions/common/url_pattern.cc
@@ -228,6 +228,11 @@ URLPattern::ParseResult URLPattern::Parse(const std::string& pattern) {
// The first component can optionally be '*' to match all subdomains.
std::vector<std::string> host_components;
base::SplitString(host_, '.', &host_components);
+
+ // Could be empty if the host only consists of whitespace characters.
+ if (host_components.empty())
+ return PARSE_ERROR_EMPTY_HOST;
+
if (host_components[0] == "*") {
match_subdomains_ = true;
host_components.erase(host_components.begin(),
diff --git a/extensions/common/url_pattern_unittest.cc b/extensions/common/url_pattern_unittest.cc
index 3e0c816..8f353cc 100644
--- a/extensions/common/url_pattern_unittest.cc
+++ b/extensions/common/url_pattern_unittest.cc
@@ -31,6 +31,7 @@ TEST(ExtensionURLPatternTest, ParseInvalid) {
{ "about://", URLPattern::PARSE_ERROR_WRONG_SCHEME_SEPARATOR },
{ "http://", URLPattern::PARSE_ERROR_EMPTY_HOST },
{ "http:///", URLPattern::PARSE_ERROR_EMPTY_HOST },
+ { "http:// /", URLPattern::PARSE_ERROR_EMPTY_HOST },
{ "http://*foo/bar", URLPattern::PARSE_ERROR_INVALID_HOST_WILDCARD },
{ "http://foo.*.bar/baz", URLPattern::PARSE_ERROR_INVALID_HOST_WILDCARD },
{ "http://fo.*.ba:123/baz", URLPattern::PARSE_ERROR_INVALID_HOST_WILDCARD },