Hash :
ffd39978
Author :
Date :
2019-02-20T10:45:24
test: Replace _TEST_CASE_ with _TEST_SUITE_. Googletest is (at last) converging with industry-standard terminology [1]. We previously called test suites "test cases", which was rather confusing for folks coming from any other testing framework. Chrome now has a googletest version that supports _TEST_SUITE_ macros instead of _TEST_CASE_, so this CL cleans up some of the outdated usage. [1] https://github.com/google/googletest/blob/master/googletest/docs/primer.md#beware-of-the-nomenclature Bug: chromium:925652 Change-Id: Ia0deec0bc4216ef1adabc33985a7cbda89682608 Reviewed-on: https://chromium-review.googlesource.com/c/1477418 Reviewed-by: Geoff Lang <geofflang@chromium.org> Commit-Queue: Victor Costan <pwnall@chromium.org>
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86 87 88 89 90 91 92 93 94 95 96 97
//
// Copyright (c) 2012 The ANGLE Project 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 <algorithm>
#include <climits>
#include "PreprocessorTest.h"
#include "compiler/preprocessor/Token.h"
namespace angle
{
class CharTest : public PreprocessorTest, public testing::WithParamInterface<int>
{
public:
CharTest() : PreprocessorTest(SH_GLES2_SPEC) {}
};
static const char kPunctuators[] = {'.', '+', '-', '/', '*', '%', '<', '>', '[', ']', '(', ')',
'{', '}', '^', '|', '&', '~', '=', '!', ':', ';', ',', '?'};
static const int kNumPunctuators = sizeof(kPunctuators) / sizeof(kPunctuators[0]);
bool isPunctuator(char c)
{
static const char *kPunctuatorBeg = kPunctuators;
static const char *kPunctuatorEnd = kPunctuators + kNumPunctuators;
return std::find(kPunctuatorBeg, kPunctuatorEnd, c) != kPunctuatorEnd;
}
static const char kWhitespaces[] = {' ', '\t', '\v', '\f', '\n', '\r'};
static const int kNumWhitespaces = sizeof(kWhitespaces) / sizeof(kWhitespaces[0]);
bool isWhitespace(char c)
{
static const char *kWhitespaceBeg = kWhitespaces;
static const char *kWhitespaceEnd = kWhitespaces + kNumWhitespaces;
return std::find(kWhitespaceBeg, kWhitespaceEnd, c) != kWhitespaceEnd;
}
TEST_P(CharTest, Identified)
{
std::string str(1, static_cast<char>(GetParam()));
const char *cstr = str.c_str();
int length = 1;
// Note that we pass the length param as well because the invalid
// string may contain the null character.
ASSERT_TRUE(mPreprocessor.init(1, &cstr, &length));
int expectedType = pp::Token::LAST;
std::string expectedValue;
if (str[0] == '#')
{
// Lone '#' is ignored.
}
else if ((str[0] == '_') || ((str[0] >= 'a') && (str[0] <= 'z')) ||
((str[0] >= 'A') && (str[0] <= 'Z')))
{
expectedType = pp::Token::IDENTIFIER;
expectedValue = str;
}
else if (str[0] >= '0' && str[0] <= '9')
{
expectedType = pp::Token::CONST_INT;
expectedValue = str;
}
else if (isPunctuator(str[0]))
{
expectedType = str[0];
expectedValue = str;
}
else if (isWhitespace(str[0]))
{
// Whitespace is ignored.
}
else
{
// Everything else is invalid.
using testing::_;
EXPECT_CALL(mDiagnostics, print(pp::Diagnostics::PP_INVALID_CHARACTER, _, str));
}
pp::Token token;
mPreprocessor.lex(&token);
EXPECT_EQ(expectedType, token.type);
EXPECT_EQ(expectedValue, token.text);
}
// Note +1 for the max-value in range. It is there because the max-value
// not included in the range.
INSTANTIATE_TEST_SUITE_P(All, CharTest, testing::Range(CHAR_MIN, CHAR_MAX + 1));
} // namespace angle