| Index: third_party/re2/re2/testing/re2_arg_test.cc
|
| diff --git a/third_party/re2/re2/testing/re2_arg_test.cc b/third_party/re2/re2/testing/re2_arg_test.cc
|
| deleted file mode 100644
|
| index d843ffa5fadd9d5eb0e9a2c447b8bdae6ad15a95..0000000000000000000000000000000000000000
|
| --- a/third_party/re2/re2/testing/re2_arg_test.cc
|
| +++ /dev/null
|
| @@ -1,133 +0,0 @@
|
| -// Copyright 2005 The RE2 Authors. All Rights Reserved.
|
| -// Use of this source code is governed by a BSD-style
|
| -// license that can be found in the LICENSE file.
|
| -
|
| -// This tests to make sure numbers are parsed from strings
|
| -// correctly.
|
| -// Todo: Expand the test to validate strings parsed to the other types
|
| -// supported by RE2::Arg class
|
| -
|
| -#include "util/test.h"
|
| -#include "re2/re2.h"
|
| -
|
| -namespace re2 {
|
| -
|
| -struct SuccessTable {
|
| - const char * value_string;
|
| - int64 value;
|
| - bool success[6];
|
| -};
|
| -
|
| -// Test boundary cases for different integral sizes.
|
| -// Specifically I want to make sure that values outside the boundries
|
| -// of an integral type will fail and that negative numbers will fail
|
| -// for unsigned types. The following table contains the boundaries for
|
| -// the various integral types and has entries for whether or not each
|
| -// type can contain the given value.
|
| -const SuccessTable kSuccessTable[] = {
|
| -// string integer value short ushort int uint int64 uint64
|
| -// 0 to 2^7-1
|
| -{ "0", 0, { true, true, true, true, true, true }},
|
| -{ "127", 127, { true, true, true, true, true, true }},
|
| -
|
| -// -1 to -2^7
|
| -{ "-1", -1, { true, false, true, false, true, false }},
|
| -{ "-128", -128, { true, false, true, false, true, false }},
|
| -
|
| -// 2^7 to 2^8-1
|
| -{ "128", 128, { true, true, true, true, true, true }},
|
| -{ "255", 255, { true, true, true, true, true, true }},
|
| -
|
| -// 2^8 to 2^15-1
|
| -{ "256", 256, { true, true, true, true, true, true }},
|
| -{ "32767", 32767, { true, true, true, true, true, true }},
|
| -
|
| -// -2^7-1 to -2^15
|
| -{ "-129", -129, { true, false, true, false, true, false }},
|
| -{ "-32768", -32768, { true, false, true, false, true, false }},
|
| -
|
| -// 2^15 to 2^16-1
|
| -{ "32768", 32768, { false, true, true, true, true, true }},
|
| -{ "65535", 65535, { false, true, true, true, true, true }},
|
| -
|
| -// 2^16 to 2^31-1
|
| -{ "65536", 65536, { false, false, true, true, true, true }},
|
| -{ "2147483647", 2147483647, { false, false, true, true, true, true }},
|
| -
|
| -// -2^15-1 to -2^31
|
| -{ "-32769", -32769, { false, false, true, false, true, false }},
|
| -{ "-2147483648",
|
| - static_cast<int64>(0xFFFFFFFF80000000LL),
|
| -{ false, false, true, false, true, false }},
|
| -
|
| -// 2^31 to 2^32-1
|
| -{ "2147483648", 2147483648U, { false, false, false, true, true, true }},
|
| -{ "4294967295", 4294967295U, { false, false, false, true, true, true }},
|
| -
|
| -// 2^32 to 2^63-1
|
| -{ "4294967296", 4294967296LL, { false, false, false, false, true, true }},
|
| -{ "9223372036854775807",
|
| - 9223372036854775807LL, { false, false, false, false, true, true }},
|
| -
|
| -// -2^31-1 to -2^63
|
| -{ "-2147483649", -2147483649LL, { false, false, false, false, true, false }},
|
| -{ "-9223372036854775808", static_cast<int64>(0x8000000000000000LL),
|
| - { false, false, false, false, true, false }},
|
| -
|
| -// 2^63 to 2^64-1
|
| -{ "9223372036854775808", static_cast<int64>(9223372036854775808ULL),
|
| - { false, false, false, false, false, true }},
|
| -{ "18446744073709551615", static_cast<int64>(18446744073709551615ULL),
|
| - { false, false, false, false, false, true }},
|
| -
|
| -// >= 2^64
|
| -{ "18446744073709551616", 0, { false, false, false, false, false, false }},
|
| -};
|
| -
|
| -const int kNumStrings = arraysize(kSuccessTable);
|
| -
|
| -// It's ugly to use a macro, but we apparently can't use the EXPECT_EQ
|
| -// macro outside of a TEST block and this seems to be the only way to
|
| -// avoid code duplication. I can also pull off a couple nice tricks
|
| -// using concatenation for the type I'm checking against.
|
| -#define PARSE_FOR_TYPE(type, column) { \
|
| - type r; \
|
| - for (int i = 0; i < kNumStrings; ++i) { \
|
| - RE2::Arg arg(&r); \
|
| - const char* const p = kSuccessTable[i].value_string; \
|
| - bool retval = arg.Parse(p, static_cast<int>(strlen(p))); \
|
| - bool success = kSuccessTable[i].success[column]; \
|
| - EXPECT_EQ(retval, success) \
|
| - << "Parsing '" << p << "' for type " #type " should return " \
|
| - << success; \
|
| - if (success) { \
|
| - EXPECT_EQ(r, (type)kSuccessTable[i].value); \
|
| - } \
|
| - } \
|
| -}
|
| -
|
| -TEST(REArgTest, Int16Test) {
|
| - PARSE_FOR_TYPE(int16, 0);
|
| -}
|
| -
|
| -TEST(REArgTest, Uint16Test) {
|
| - PARSE_FOR_TYPE(uint16, 1);
|
| -}
|
| -
|
| -TEST(REArgTest, IntTest) {
|
| - PARSE_FOR_TYPE(int, 2);
|
| -}
|
| -
|
| -TEST(REArgTest, UInt32Test) {
|
| - PARSE_FOR_TYPE(uint32, 3);
|
| -}
|
| -
|
| -TEST(REArgTest, Iint64Test) {
|
| - PARSE_FOR_TYPE(int64, 4);
|
| -}
|
| -
|
| -TEST(REArgTest, Uint64Test) {
|
| - PARSE_FOR_TYPE(uint64, 5);
|
| -}
|
| -
|
| -} // namespace re2
|
|
|