// Copyright 2013 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 "extensions/browser/file_highlighter.h"
#include <string>
#include "base/logging.h"
#include "base/strings/string_util.h"
#include "testing/gtest/include/gtest/gtest.h"
namespace extensions {
namespace {
const char kManifest[] =
"{\n"
" \"name\": \"Content Scripts\",\n"
" \"version\": \"2.0\",\n"
" // this is a comment with the word permissions.\n"
" /* This is a multine\n"
" comment with the word permissions\n"
" that shouldn't be highlighted */\n"
" \"permissions\": [\n"
" /* This is a tricky comment because it has brackets }]*/\n"
" \"tabs\"\n"
" ],\n"
" \"content_scripts\": [\n"
" {\n"
" \"matches\": [\"*://aaronboodman.com/*\", \"*://rdcronin.com/*\"],\n"
" \"js\": [\"myscript.js\"]\n"
" }\n"
" ],\n"
" \"test_key\": {\n"
" \"escaped_quoted\\\"\",\n"
" \"/*foo*/\"\n"
" },\n"
" \"manifest_version\": 2,\n"
" \"international_key\": \"還是不要\"\n"
"}";
} // namespace
TEST(ManifestHighlighterUnitTest, ManifestHighlighterUnitTest) {
// Get a full key.
const char kPermissionsFeature[] =
"\"permissions\": [\n"
" /* This is a tricky comment because it has brackets }]*/\n"
" \"tabs\"\n"
" ]";
ManifestHighlighter permissions(kManifest, "permissions", std::string());
EXPECT_EQ(kPermissionsFeature, permissions.GetFeature());
// Get a specific portion of a key.
const char kTabsFeature[] = "\"tabs\"";
ManifestHighlighter tabs(kManifest, "permissions", "tabs");
EXPECT_EQ(kTabsFeature, tabs.GetFeature());
// Get a single-character, non-quoted entity of a key.
const char kManifestVersionFeature[] = "2";
ManifestHighlighter version(kManifest, "manifest_version", "2");
EXPECT_EQ(kManifestVersionFeature, version.GetFeature());
// Get a compound portion of a key, including quoted '//' (which shouldn't be
// mistaken for comments).
const char kMatchesFeature[] =
"\"matches\": [\"*://aaronboodman.com/*\", \"*://rdcronin.com/*\"]";
ManifestHighlighter matches(kManifest, "content_scripts", "matches");
EXPECT_EQ(kMatchesFeature, matches.GetFeature());
// If a feature isn't present, we should get an empty string.
ManifestHighlighter not_present(kManifest, "a_fake_feature", std::string());
EXPECT_EQ(std::string(), not_present.GetFeature());
// If we request a specific portion of a key which is not found, we should
// get an empty string.
ManifestHighlighter specific_portion_not_present(
kManifest, "permissions", "a_fake_feature");
EXPECT_EQ(std::string(), specific_portion_not_present.GetFeature());
const char kEscapedQuotedFeature[] = "\"escaped_quoted\\\"\"";
ManifestHighlighter escaped_quoted(
kManifest, "test_key", "escaped_quoted\\\"");
EXPECT_EQ(kEscapedQuotedFeature, escaped_quoted.GetFeature());
const char kFeatureWithComment[] = "\"/*foo*/\"";
ManifestHighlighter feature_with_comment(kManifest, "test_key", "/*foo*/");
EXPECT_EQ(kFeatureWithComment, feature_with_comment.GetFeature());
// Check with non-ascii characters.
const char kInternationalFeature[] = "\"international_key\": \"還是不要\"";
ManifestHighlighter international_feature(
kManifest, "international_key", std::string());
EXPECT_EQ(kInternationalFeature, international_feature.GetFeature());
}
TEST(SouceHighlighterUnitTest, SourceHighlighterUnitTest) {
const char kBasicSourceFile[] = "line one\nline two\nline three";
SourceHighlighter basic1(kBasicSourceFile, 1u);
EXPECT_EQ("line one", basic1.GetFeature());
SourceHighlighter basic2(kBasicSourceFile, 2u);
EXPECT_EQ("line two", basic2.GetFeature());
SourceHighlighter basic3(kBasicSourceFile, 3u);
EXPECT_EQ("line three", basic3.GetFeature());
const char kNoNewlineSourceFile[] = "thisisonelonglinewithnobreaksinit";
SourceHighlighter full_line(kNoNewlineSourceFile, 1u);
EXPECT_EQ(kNoNewlineSourceFile, full_line.GetFeature());
SourceHighlighter line_zero(kNoNewlineSourceFile, 0u);
EXPECT_EQ(std::string(), line_zero.GetFeature());
SourceHighlighter out_of_bounds(kNoNewlineSourceFile, 2u);
EXPECT_EQ(std::string(), out_of_bounds.GetFeature());
}
} // namespace extensions