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

Unified Diff: base/string_escape_unittest.cc

Issue 316016: Move the json-related files into a separate json directory. This hopefully al... (Closed) Base URL: svn://chrome-svn/chrome/trunk/src/
Patch Set: '' Created 11 years, 2 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
« no previous file with comments | « base/string_escape.cc ('k') | chrome/browser/automation/automation_extension_function.cc » ('j') | no next file with comments »
Expand Comments ('e') | Collapse Comments ('c') | Show Comments Hide Comments ('s')
Index: base/string_escape_unittest.cc
===================================================================
--- base/string_escape_unittest.cc (revision 29830)
+++ base/string_escape_unittest.cc (working copy)
@@ -1,95 +0,0 @@
-// Copyright (c) 2006-2008 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 "testing/gtest/include/gtest/gtest.h"
-#include "base/string_escape.h"
-#include "base/string_util.h"
-
-namespace {
-
-const struct json_narrow_test_data {
- const char* to_escape;
- const char* escaped;
-} json_narrow_cases[] = {
- {"\b\001aZ\"\\wee", "\\b\\u0001aZ\\\"\\\\wee"},
- {"a\b\f\n\r\t\v\1\\.\"z",
- "a\\b\\f\\n\\r\\t\\u000B\\u0001\\\\.\\\"z"},
- {"b\x0f\x7f\xf0\xff!", "b\\u000F\\u007F\\u00F0\\u00FF!"},
-};
-
-}
-
-TEST(StringEscapeTest, JsonDoubleQuoteNarrow) {
- for (size_t i = 0; i < arraysize(json_narrow_cases); ++i) {
- std::string in = json_narrow_cases[i].to_escape;
- std::string out;
- string_escape::JsonDoubleQuote(in, false, &out);
- EXPECT_EQ(std::string(json_narrow_cases[i].escaped), out);
- }
-
- std::string in = json_narrow_cases[0].to_escape;
- std::string out;
- string_escape::JsonDoubleQuote(in, false, &out);
-
- // test quoting
- std::string out_quoted;
- string_escape::JsonDoubleQuote(in, true, &out_quoted);
- EXPECT_EQ(out.length() + 2, out_quoted.length());
- EXPECT_EQ(out_quoted.find(out), 1U);
-
- // now try with a NULL in the string
- std::string null_prepend = "test";
- null_prepend.push_back(0);
- in = null_prepend + in;
- std::string expected = "test\\u0000";
- expected += json_narrow_cases[0].escaped;
- out.clear();
- string_escape::JsonDoubleQuote(in, false, &out);
- EXPECT_EQ(expected, out);
-}
-
-namespace {
-
-const struct json_wide_test_data {
- const wchar_t* to_escape;
- const char* escaped;
-} json_wide_cases[] = {
- {L"b\uffb1\u00ff", "b\\uFFB1\\u00FF"},
- {L"\b\001aZ\"\\wee", "\\b\\u0001aZ\\\"\\\\wee"},
- {L"a\b\f\n\r\t\v\1\\.\"z",
- "a\\b\\f\\n\\r\\t\\u000B\\u0001\\\\.\\\"z"},
- {L"b\x0f\x7f\xf0\xff!", "b\\u000F\\u007F\\u00F0\\u00FF!"},
-};
-
-}
-
-TEST(StringEscapeTest, JsonDoubleQuoteWide) {
-
- for (size_t i = 0; i < arraysize(json_wide_cases); ++i) {
- std::string out;
- string16 in = WideToUTF16(json_wide_cases[i].to_escape);
- string_escape::JsonDoubleQuote(in, false, &out);
- EXPECT_EQ(std::string(json_wide_cases[i].escaped), out);
- }
-
- string16 in = WideToUTF16(json_wide_cases[0].to_escape);
- std::string out;
- string_escape::JsonDoubleQuote(in, false, &out);
-
- // test quoting
- std::string out_quoted;
- string_escape::JsonDoubleQuote(in, true, &out_quoted);
- EXPECT_EQ(out.length() + 2, out_quoted.length());
- EXPECT_EQ(out_quoted.find(out), 1U);
-
- // now try with a NULL in the string
- string16 null_prepend = WideToUTF16(L"test");
- null_prepend.push_back(0);
- in = null_prepend + in;
- std::string expected = "test\\u0000";
- expected += json_wide_cases[0].escaped;
- out.clear();
- string_escape::JsonDoubleQuote(in, false, &out);
- EXPECT_EQ(expected, out);
-}
« no previous file with comments | « base/string_escape.cc ('k') | chrome/browser/automation/automation_extension_function.cc » ('j') | no next file with comments »

Powered by Google App Engine
This is Rietveld 408576698