| Index: net/base/data_url_unittest.cc
|
| diff --git a/net/base/data_url_unittest.cc b/net/base/data_url_unittest.cc
|
| deleted file mode 100644
|
| index bcb2b49ad6c013ea88d7614a04089539c979cf67..0000000000000000000000000000000000000000
|
| --- a/net/base/data_url_unittest.cc
|
| +++ /dev/null
|
| @@ -1,241 +0,0 @@
|
| -// Copyright (c) 2012 The Chromium Authors. All rights reserved.
|
| -// Use of this source code is governed by a BSD-style license that can be
|
| -// found in the LICENSE file.
|
| -
|
| -#include "base/basictypes.h"
|
| -#include "net/base/data_url.h"
|
| -#include "testing/gtest/include/gtest/gtest.h"
|
| -#include "url/gurl.h"
|
| -
|
| -namespace {
|
| -
|
| -struct ParseTestData {
|
| - const char* url;
|
| - bool is_valid;
|
| - const char* mime_type;
|
| - const char* charset;
|
| - const char* data;
|
| -};
|
| -
|
| -}
|
| -
|
| -TEST(DataURLTest, Parse) {
|
| - const ParseTestData tests[] = {
|
| - { "data:",
|
| - false,
|
| - "",
|
| - "",
|
| - "" },
|
| -
|
| - { "data:,",
|
| - true,
|
| - "text/plain",
|
| - "US-ASCII",
|
| - "" },
|
| -
|
| - { "data:;base64,",
|
| - true,
|
| - "text/plain",
|
| - "US-ASCII",
|
| - "" },
|
| -
|
| - { "data:;charset=,test",
|
| - false,
|
| - "",
|
| - "",
|
| - "" },
|
| -
|
| - { "data:TeXt/HtMl,<b>x</b>",
|
| - true,
|
| - "text/html",
|
| - "US-ASCII",
|
| - "<b>x</b>" },
|
| -
|
| - { "data:,foo",
|
| - true,
|
| - "text/plain",
|
| - "US-ASCII",
|
| - "foo" },
|
| -
|
| - { "data:;base64,aGVsbG8gd29ybGQ=",
|
| - true,
|
| - "text/plain",
|
| - "US-ASCII",
|
| - "hello world" },
|
| -
|
| - // Allow invalid mediatype for backward compatibility but set mime_type to
|
| - // "text/plain" instead of the invalid mediatype.
|
| - { "data:foo,boo",
|
| - true,
|
| - "text/plain",
|
| - "US-ASCII",
|
| - "boo" },
|
| -
|
| - // When accepting an invalid mediatype, override charset with "US-ASCII"
|
| - { "data:foo;charset=UTF-8,boo",
|
| - true,
|
| - "text/plain",
|
| - "US-ASCII",
|
| - "boo" },
|
| -
|
| - // Invalid mediatype. Includes a slash but the type part is not a token.
|
| - { "data:f(oo/bar;baz=1;charset=kk,boo",
|
| - true,
|
| - "text/plain",
|
| - "US-ASCII",
|
| - "boo" },
|
| -
|
| - { "data:foo/bar;baz=1;charset=kk,boo",
|
| - true,
|
| - "foo/bar",
|
| - "kk",
|
| - "boo" },
|
| -
|
| - { "data:foo/bar;charset=kk;baz=1,boo",
|
| - true,
|
| - "foo/bar",
|
| - "kk",
|
| - "boo" },
|
| -
|
| - { "data:text/html,%3Chtml%3E%3Cbody%3E%3Cb%3Ehello%20world"
|
| - "%3C%2Fb%3E%3C%2Fbody%3E%3C%2Fhtml%3E",
|
| - true,
|
| - "text/html",
|
| - "US-ASCII",
|
| - "<html><body><b>hello world</b></body></html>" },
|
| -
|
| - { "data:text/html,<html><body><b>hello world</b></body></html>",
|
| - true,
|
| - "text/html",
|
| - "US-ASCII",
|
| - "<html><body><b>hello world</b></body></html>" },
|
| -
|
| - // the comma cannot be url-escaped!
|
| - { "data:%2Cblah",
|
| - false,
|
| - "",
|
| - "",
|
| - "" },
|
| -
|
| - // invalid base64 content
|
| - { "data:;base64,aGVs_-_-",
|
| - false,
|
| - "",
|
| - "",
|
| - "" },
|
| -
|
| - // Spaces should be removed from non-text data URLs (we already tested
|
| - // spaces above).
|
| - { " bG8gd2 9ybGQ=",
|
| - true,
|
| - "text/plain",
|
| - "US-ASCII",
|
| - "hello world" },
|
| -
|
| - // Other whitespace should also be removed from anything base-64 encoded.
|
| - { "data:;base64,aGVs bG8gd2 \n9ybGQ=",
|
| - true,
|
| - "text/plain",
|
| - "US-ASCII",
|
| - "hello world" },
|
| -
|
| - // In base64 encoding, escaped whitespace should be stripped.
|
| - // (This test was taken from acid3)
|
| - // http://b/1054495
|
| - { "data:text/javascript;base64,%20ZD%20Qg%0D%0APS%20An%20Zm91cic%0D%0A%207"
|
| - "%20",
|
| - true,
|
| - "text/javascript",
|
| - "US-ASCII",
|
| - "d4 = 'four';" },
|
| -
|
| - // Only unescaped whitespace should be stripped in non-base64.
|
| - // http://b/1157796
|
| - { "data:img/png,A B %20 %0A C",
|
| - true,
|
| - "img/png",
|
| - "US-ASCII",
|
| - "AB \nC" },
|
| -
|
| - { "data:text/plain;charset=utf-8;base64,SGVsbMO2",
|
| - true,
|
| - "text/plain",
|
| - "utf-8",
|
| - "Hell\xC3\xB6" },
|
| -
|
| - // Not sufficiently padded.
|
| - { "data:;base64,aGVsbG8gd29ybGQ",
|
| - true,
|
| - "text/plain",
|
| - "US-ASCII",
|
| - "hello world" },
|
| -
|
| - // Bad encoding (truncated).
|
| - { "data:;base64,aGVsbG8gd29yb",
|
| - false,
|
| - "",
|
| - "",
|
| - "" },
|
| -
|
| - // BiDi control characters should be unescaped and preserved as is, and
|
| - // should not be replaced with % versions. In the below case, \xE2\x80\x8F
|
| - // is the RTL mark and the parsed text should preserve it as is.
|
| - {
|
| - "data:text/plain;charset=utf-8,\xE2\x80\x8Ftest",
|
| - true,
|
| - "text/plain",
|
| - "utf-8",
|
| - "\xE2\x80\x8Ftest"},
|
| -
|
| - // Same as above but with Arabic text after RTL mark.
|
| - {
|
| - "data:text/plain;charset=utf-8,"
|
| - "\xE2\x80\x8F\xD8\xA7\xD8\xAE\xD8\xAA\xD8\xA8\xD8\xA7\xD8\xB1",
|
| - true,
|
| - "text/plain",
|
| - "utf-8",
|
| - "\xE2\x80\x8F\xD8\xA7\xD8\xAE\xD8\xAA\xD8\xA8\xD8\xA7\xD8\xB1"},
|
| -
|
| - // RTL mark encoded as %E2%80%8F should be unescaped too. Note that when
|
| - // wrapped in a GURL, this URL and the next effectively become the same as
|
| - // the previous two URLs.
|
| - {
|
| - "data:text/plain;charset=utf-8,%E2%80%8Ftest",
|
| - true,
|
| - "text/plain",
|
| - "utf-8",
|
| - "\xE2\x80\x8Ftest"},
|
| -
|
| - // Same as above but with Arabic text after RTL mark.
|
| - {
|
| - "data:text/plain;charset=utf-8,"
|
| - "%E2%80%8F\xD8\xA7\xD8\xAE\xD8\xAA\xD8\xA8\xD8\xA7\xD8\xB1",
|
| - true,
|
| - "text/plain",
|
| - "utf-8",
|
| - "\xE2\x80\x8F\xD8\xA7\xD8\xAE\xD8\xAA\xD8\xA8\xD8\xA7\xD8\xB1"}
|
| -
|
| - // TODO(darin): add more interesting tests
|
| - };
|
| -
|
| - for (size_t i = 0; i < arraysize(tests); ++i) {
|
| - std::string mime_type;
|
| - std::string charset;
|
| - std::string data;
|
| - bool ok =
|
| - net::DataURL::Parse(GURL(tests[i].url), &mime_type, &charset, &data);
|
| - EXPECT_EQ(ok, tests[i].is_valid);
|
| - if (tests[i].is_valid) {
|
| - EXPECT_EQ(tests[i].mime_type, mime_type);
|
| - EXPECT_EQ(tests[i].charset, charset);
|
| - EXPECT_EQ(tests[i].data, data);
|
| - }
|
| - }
|
| -}
|
|
|