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
|
// Copyright (C) 2018 ycmd contributors
//
// This file is part of ycmd.
//
// ycmd is free software: you can redistribute it and/or modify
// it under the terms of the GNU General Public License as published by
// the Free Software Foundation, either version 3 of the License, or
// (at your option) any later version.
//
// ycmd is distributed in the hope that it will be useful,
// but WITHOUT ANY WARRANTY; without even the implied warranty of
// MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
// GNU General Public License for more details.
//
// You should have received a copy of the GNU General Public License
// along with ycmd. If not, see <http://www.gnu.org/licenses/>.
#include "Character.h"
#include "Repository.h"
#include "CodePoint.h"
#include "TestUtils.h"
#include <array>
#include <gtest/gtest.h>
#include <gmock/gmock.h>
using ::testing::TestWithParam;
using ::testing::ValuesIn;
namespace YouCompleteMe {
struct NormalizationTuple {
const char* source;
const char* nfc;
const char* nfd;
const char* nfkc;
const char* nfkd;
};
std::ostream& operator<<( std::ostream& os,
const NormalizationTuple &tuple ) {
os << "{ " << PrintToString( tuple.source ) << ", "
<< PrintToString( tuple.nfc ) << ", "
<< PrintToString( tuple.nfd ) << ", "
<< PrintToString( tuple.nfkc ) << ", "
<< PrintToString( tuple.nfkd ) << " }";
return os;
}
class NormalizationTest : public TestWithParam< NormalizationTuple > {
protected:
NormalizationTest()
: repo_( Repository< Character >::Instance() ) {
}
virtual void SetUp() {
repo_.ClearElements();
tuple_ = GetParam();
}
Repository< Character > &repo_;
NormalizationTuple tuple_;
};
TEST_P( NormalizationTest, NormalizationFormDecompositionIsConform ) {
EXPECT_THAT( Character( NormalizeInput( tuple_.source ) ).Normal(),
Equals( tuple_.nfd ) );
EXPECT_THAT( Character( NormalizeInput( tuple_.nfc ) ).Normal(),
Equals( tuple_.nfd ) );
EXPECT_THAT( Character( NormalizeInput( tuple_.nfd ) ).Normal(),
Equals( tuple_.nfd ) );
EXPECT_THAT( Character( NormalizeInput( tuple_.nfkc ) ).Normal(),
Equals( tuple_.nfkd ) );
EXPECT_THAT( Character( NormalizeInput( tuple_.nfkd ) ).Normal(),
Equals( tuple_.nfkd ) );
}
// Tests generated from
// https://unicode.org/Public/UCD/latest/ucd/NormalizationTest.txt
const NormalizationTuple tests[] = {
#include "NormalizationCases.inc"
};
INSTANTIATE_TEST_SUITE_P( UnicodeTest, NormalizationTest, ValuesIn( tests ) );
} // namespace YouCompleteMe
|