xref: /aosp_15_r20/external/llvm/unittests/ADT/SmallStringTest.cpp (revision 9880d6810fe72a1726cb53787c6711e909410d58)
1*9880d681SAndroid Build Coastguard Worker //===- llvm/unittest/ADT/SmallStringTest.cpp ------------------------------===//
2*9880d681SAndroid Build Coastguard Worker //
3*9880d681SAndroid Build Coastguard Worker //                     The LLVM Compiler Infrastructure
4*9880d681SAndroid Build Coastguard Worker //
5*9880d681SAndroid Build Coastguard Worker // This file is distributed under the University of Illinois Open Source
6*9880d681SAndroid Build Coastguard Worker // License. See LICENSE.TXT for details.
7*9880d681SAndroid Build Coastguard Worker //
8*9880d681SAndroid Build Coastguard Worker //===----------------------------------------------------------------------===//
9*9880d681SAndroid Build Coastguard Worker //
10*9880d681SAndroid Build Coastguard Worker // SmallString unit tests.
11*9880d681SAndroid Build Coastguard Worker //
12*9880d681SAndroid Build Coastguard Worker //===----------------------------------------------------------------------===//
13*9880d681SAndroid Build Coastguard Worker 
14*9880d681SAndroid Build Coastguard Worker #include "llvm/ADT/SmallString.h"
15*9880d681SAndroid Build Coastguard Worker #include "gtest/gtest.h"
16*9880d681SAndroid Build Coastguard Worker #include <climits>
17*9880d681SAndroid Build Coastguard Worker #include <cstring>
18*9880d681SAndroid Build Coastguard Worker #include <stdarg.h>
19*9880d681SAndroid Build Coastguard Worker 
20*9880d681SAndroid Build Coastguard Worker using namespace llvm;
21*9880d681SAndroid Build Coastguard Worker 
22*9880d681SAndroid Build Coastguard Worker namespace {
23*9880d681SAndroid Build Coastguard Worker 
24*9880d681SAndroid Build Coastguard Worker // Test fixture class
25*9880d681SAndroid Build Coastguard Worker class SmallStringTest : public testing::Test {
26*9880d681SAndroid Build Coastguard Worker protected:
27*9880d681SAndroid Build Coastguard Worker   typedef SmallString<40> StringType;
28*9880d681SAndroid Build Coastguard Worker 
29*9880d681SAndroid Build Coastguard Worker   StringType theString;
30*9880d681SAndroid Build Coastguard Worker 
assertEmpty(StringType & v)31*9880d681SAndroid Build Coastguard Worker   void assertEmpty(StringType & v) {
32*9880d681SAndroid Build Coastguard Worker     // Size tests
33*9880d681SAndroid Build Coastguard Worker     EXPECT_EQ(0u, v.size());
34*9880d681SAndroid Build Coastguard Worker     EXPECT_TRUE(v.empty());
35*9880d681SAndroid Build Coastguard Worker     // Iterator tests
36*9880d681SAndroid Build Coastguard Worker     EXPECT_TRUE(v.begin() == v.end());
37*9880d681SAndroid Build Coastguard Worker   }
38*9880d681SAndroid Build Coastguard Worker };
39*9880d681SAndroid Build Coastguard Worker 
40*9880d681SAndroid Build Coastguard Worker // New string test.
TEST_F(SmallStringTest,EmptyStringTest)41*9880d681SAndroid Build Coastguard Worker TEST_F(SmallStringTest, EmptyStringTest) {
42*9880d681SAndroid Build Coastguard Worker   SCOPED_TRACE("EmptyStringTest");
43*9880d681SAndroid Build Coastguard Worker   assertEmpty(theString);
44*9880d681SAndroid Build Coastguard Worker   EXPECT_TRUE(theString.rbegin() == theString.rend());
45*9880d681SAndroid Build Coastguard Worker }
46*9880d681SAndroid Build Coastguard Worker 
TEST_F(SmallStringTest,AssignRepeated)47*9880d681SAndroid Build Coastguard Worker TEST_F(SmallStringTest, AssignRepeated) {
48*9880d681SAndroid Build Coastguard Worker   theString.assign(3, 'a');
49*9880d681SAndroid Build Coastguard Worker   EXPECT_EQ(3u, theString.size());
50*9880d681SAndroid Build Coastguard Worker   EXPECT_STREQ("aaa", theString.c_str());
51*9880d681SAndroid Build Coastguard Worker }
52*9880d681SAndroid Build Coastguard Worker 
TEST_F(SmallStringTest,AssignIterPair)53*9880d681SAndroid Build Coastguard Worker TEST_F(SmallStringTest, AssignIterPair) {
54*9880d681SAndroid Build Coastguard Worker   StringRef abc = "abc";
55*9880d681SAndroid Build Coastguard Worker   theString.assign(abc.begin(), abc.end());
56*9880d681SAndroid Build Coastguard Worker   EXPECT_EQ(3u, theString.size());
57*9880d681SAndroid Build Coastguard Worker   EXPECT_STREQ("abc", theString.c_str());
58*9880d681SAndroid Build Coastguard Worker }
59*9880d681SAndroid Build Coastguard Worker 
TEST_F(SmallStringTest,AssignStringRef)60*9880d681SAndroid Build Coastguard Worker TEST_F(SmallStringTest, AssignStringRef) {
61*9880d681SAndroid Build Coastguard Worker   StringRef abc = "abc";
62*9880d681SAndroid Build Coastguard Worker   theString.assign(abc);
63*9880d681SAndroid Build Coastguard Worker   EXPECT_EQ(3u, theString.size());
64*9880d681SAndroid Build Coastguard Worker   EXPECT_STREQ("abc", theString.c_str());
65*9880d681SAndroid Build Coastguard Worker }
66*9880d681SAndroid Build Coastguard Worker 
TEST_F(SmallStringTest,AssignSmallVector)67*9880d681SAndroid Build Coastguard Worker TEST_F(SmallStringTest, AssignSmallVector) {
68*9880d681SAndroid Build Coastguard Worker   StringRef abc = "abc";
69*9880d681SAndroid Build Coastguard Worker   SmallVector<char, 10> abcVec(abc.begin(), abc.end());
70*9880d681SAndroid Build Coastguard Worker   theString.assign(abcVec);
71*9880d681SAndroid Build Coastguard Worker   EXPECT_EQ(3u, theString.size());
72*9880d681SAndroid Build Coastguard Worker   EXPECT_STREQ("abc", theString.c_str());
73*9880d681SAndroid Build Coastguard Worker }
74*9880d681SAndroid Build Coastguard Worker 
TEST_F(SmallStringTest,AppendIterPair)75*9880d681SAndroid Build Coastguard Worker TEST_F(SmallStringTest, AppendIterPair) {
76*9880d681SAndroid Build Coastguard Worker   StringRef abc = "abc";
77*9880d681SAndroid Build Coastguard Worker   theString.append(abc.begin(), abc.end());
78*9880d681SAndroid Build Coastguard Worker   theString.append(abc.begin(), abc.end());
79*9880d681SAndroid Build Coastguard Worker   EXPECT_EQ(6u, theString.size());
80*9880d681SAndroid Build Coastguard Worker   EXPECT_STREQ("abcabc", theString.c_str());
81*9880d681SAndroid Build Coastguard Worker }
82*9880d681SAndroid Build Coastguard Worker 
TEST_F(SmallStringTest,AppendStringRef)83*9880d681SAndroid Build Coastguard Worker TEST_F(SmallStringTest, AppendStringRef) {
84*9880d681SAndroid Build Coastguard Worker   StringRef abc = "abc";
85*9880d681SAndroid Build Coastguard Worker   theString.append(abc);
86*9880d681SAndroid Build Coastguard Worker   theString.append(abc);
87*9880d681SAndroid Build Coastguard Worker   EXPECT_EQ(6u, theString.size());
88*9880d681SAndroid Build Coastguard Worker   EXPECT_STREQ("abcabc", theString.c_str());
89*9880d681SAndroid Build Coastguard Worker }
90*9880d681SAndroid Build Coastguard Worker 
TEST_F(SmallStringTest,AppendSmallVector)91*9880d681SAndroid Build Coastguard Worker TEST_F(SmallStringTest, AppendSmallVector) {
92*9880d681SAndroid Build Coastguard Worker   StringRef abc = "abc";
93*9880d681SAndroid Build Coastguard Worker   SmallVector<char, 10> abcVec(abc.begin(), abc.end());
94*9880d681SAndroid Build Coastguard Worker   theString.append(abcVec);
95*9880d681SAndroid Build Coastguard Worker   theString.append(abcVec);
96*9880d681SAndroid Build Coastguard Worker   EXPECT_EQ(6u, theString.size());
97*9880d681SAndroid Build Coastguard Worker   EXPECT_STREQ("abcabc", theString.c_str());
98*9880d681SAndroid Build Coastguard Worker }
99*9880d681SAndroid Build Coastguard Worker 
TEST_F(SmallStringTest,Substr)100*9880d681SAndroid Build Coastguard Worker TEST_F(SmallStringTest, Substr) {
101*9880d681SAndroid Build Coastguard Worker   theString = "hello";
102*9880d681SAndroid Build Coastguard Worker   EXPECT_EQ("lo", theString.substr(3));
103*9880d681SAndroid Build Coastguard Worker   EXPECT_EQ("", theString.substr(100));
104*9880d681SAndroid Build Coastguard Worker   EXPECT_EQ("hello", theString.substr(0, 100));
105*9880d681SAndroid Build Coastguard Worker   EXPECT_EQ("o", theString.substr(4, 10));
106*9880d681SAndroid Build Coastguard Worker }
107*9880d681SAndroid Build Coastguard Worker 
TEST_F(SmallStringTest,Slice)108*9880d681SAndroid Build Coastguard Worker TEST_F(SmallStringTest, Slice) {
109*9880d681SAndroid Build Coastguard Worker   theString = "hello";
110*9880d681SAndroid Build Coastguard Worker   EXPECT_EQ("l", theString.slice(2, 3));
111*9880d681SAndroid Build Coastguard Worker   EXPECT_EQ("ell", theString.slice(1, 4));
112*9880d681SAndroid Build Coastguard Worker   EXPECT_EQ("llo", theString.slice(2, 100));
113*9880d681SAndroid Build Coastguard Worker   EXPECT_EQ("", theString.slice(2, 1));
114*9880d681SAndroid Build Coastguard Worker   EXPECT_EQ("", theString.slice(10, 20));
115*9880d681SAndroid Build Coastguard Worker }
116*9880d681SAndroid Build Coastguard Worker 
TEST_F(SmallStringTest,Find)117*9880d681SAndroid Build Coastguard Worker TEST_F(SmallStringTest, Find) {
118*9880d681SAndroid Build Coastguard Worker   theString = "hello";
119*9880d681SAndroid Build Coastguard Worker   EXPECT_EQ(2U, theString.find('l'));
120*9880d681SAndroid Build Coastguard Worker   EXPECT_EQ(StringRef::npos, theString.find('z'));
121*9880d681SAndroid Build Coastguard Worker   EXPECT_EQ(StringRef::npos, theString.find("helloworld"));
122*9880d681SAndroid Build Coastguard Worker   EXPECT_EQ(0U, theString.find("hello"));
123*9880d681SAndroid Build Coastguard Worker   EXPECT_EQ(1U, theString.find("ello"));
124*9880d681SAndroid Build Coastguard Worker   EXPECT_EQ(StringRef::npos, theString.find("zz"));
125*9880d681SAndroid Build Coastguard Worker   EXPECT_EQ(2U, theString.find("ll", 2));
126*9880d681SAndroid Build Coastguard Worker   EXPECT_EQ(StringRef::npos, theString.find("ll", 3));
127*9880d681SAndroid Build Coastguard Worker   EXPECT_EQ(0U, theString.find(""));
128*9880d681SAndroid Build Coastguard Worker 
129*9880d681SAndroid Build Coastguard Worker   EXPECT_EQ(3U, theString.rfind('l'));
130*9880d681SAndroid Build Coastguard Worker   EXPECT_EQ(StringRef::npos, theString.rfind('z'));
131*9880d681SAndroid Build Coastguard Worker   EXPECT_EQ(StringRef::npos, theString.rfind("helloworld"));
132*9880d681SAndroid Build Coastguard Worker   EXPECT_EQ(0U, theString.rfind("hello"));
133*9880d681SAndroid Build Coastguard Worker   EXPECT_EQ(1U, theString.rfind("ello"));
134*9880d681SAndroid Build Coastguard Worker   EXPECT_EQ(StringRef::npos, theString.rfind("zz"));
135*9880d681SAndroid Build Coastguard Worker 
136*9880d681SAndroid Build Coastguard Worker   EXPECT_EQ(2U, theString.find_first_of('l'));
137*9880d681SAndroid Build Coastguard Worker   EXPECT_EQ(1U, theString.find_first_of("el"));
138*9880d681SAndroid Build Coastguard Worker   EXPECT_EQ(StringRef::npos, theString.find_first_of("xyz"));
139*9880d681SAndroid Build Coastguard Worker 
140*9880d681SAndroid Build Coastguard Worker   EXPECT_EQ(1U, theString.find_first_not_of('h'));
141*9880d681SAndroid Build Coastguard Worker   EXPECT_EQ(4U, theString.find_first_not_of("hel"));
142*9880d681SAndroid Build Coastguard Worker   EXPECT_EQ(StringRef::npos, theString.find_first_not_of("hello"));
143*9880d681SAndroid Build Coastguard Worker 
144*9880d681SAndroid Build Coastguard Worker   theString = "hellx xello hell ello world foo bar hello";
145*9880d681SAndroid Build Coastguard Worker   EXPECT_EQ(36U, theString.find("hello"));
146*9880d681SAndroid Build Coastguard Worker   EXPECT_EQ(28U, theString.find("foo"));
147*9880d681SAndroid Build Coastguard Worker   EXPECT_EQ(12U, theString.find("hell", 2));
148*9880d681SAndroid Build Coastguard Worker   EXPECT_EQ(0U, theString.find(""));
149*9880d681SAndroid Build Coastguard Worker }
150*9880d681SAndroid Build Coastguard Worker 
TEST_F(SmallStringTest,Count)151*9880d681SAndroid Build Coastguard Worker TEST_F(SmallStringTest, Count) {
152*9880d681SAndroid Build Coastguard Worker   theString = "hello";
153*9880d681SAndroid Build Coastguard Worker   EXPECT_EQ(2U, theString.count('l'));
154*9880d681SAndroid Build Coastguard Worker   EXPECT_EQ(1U, theString.count('o'));
155*9880d681SAndroid Build Coastguard Worker   EXPECT_EQ(0U, theString.count('z'));
156*9880d681SAndroid Build Coastguard Worker   EXPECT_EQ(0U, theString.count("helloworld"));
157*9880d681SAndroid Build Coastguard Worker   EXPECT_EQ(1U, theString.count("hello"));
158*9880d681SAndroid Build Coastguard Worker   EXPECT_EQ(1U, theString.count("ello"));
159*9880d681SAndroid Build Coastguard Worker   EXPECT_EQ(0U, theString.count("zz"));
160*9880d681SAndroid Build Coastguard Worker }
161*9880d681SAndroid Build Coastguard Worker 
TEST_F(SmallStringTest,Realloc)162*9880d681SAndroid Build Coastguard Worker TEST_F(SmallStringTest, Realloc) {
163*9880d681SAndroid Build Coastguard Worker   theString = "abcd";
164*9880d681SAndroid Build Coastguard Worker   theString.reserve(100);
165*9880d681SAndroid Build Coastguard Worker   EXPECT_EQ("abcd", theString);
166*9880d681SAndroid Build Coastguard Worker   unsigned const N = 100000;
167*9880d681SAndroid Build Coastguard Worker   theString.reserve(N);
168*9880d681SAndroid Build Coastguard Worker   for (unsigned i = 0; i < N - 4; ++i)
169*9880d681SAndroid Build Coastguard Worker     theString.push_back('y');
170*9880d681SAndroid Build Coastguard Worker   EXPECT_EQ("abcdyyy", theString.slice(0, 7));
171*9880d681SAndroid Build Coastguard Worker }
172*9880d681SAndroid Build Coastguard Worker 
TEST(StringRefTest,Comparisons)173*9880d681SAndroid Build Coastguard Worker TEST(StringRefTest, Comparisons) {
174*9880d681SAndroid Build Coastguard Worker   EXPECT_EQ(-1, SmallString<10>("aab").compare("aad"));
175*9880d681SAndroid Build Coastguard Worker   EXPECT_EQ( 0, SmallString<10>("aab").compare("aab"));
176*9880d681SAndroid Build Coastguard Worker   EXPECT_EQ( 1, SmallString<10>("aab").compare("aaa"));
177*9880d681SAndroid Build Coastguard Worker   EXPECT_EQ(-1, SmallString<10>("aab").compare("aabb"));
178*9880d681SAndroid Build Coastguard Worker   EXPECT_EQ( 1, SmallString<10>("aab").compare("aa"));
179*9880d681SAndroid Build Coastguard Worker   EXPECT_EQ( 1, SmallString<10>("\xFF").compare("\1"));
180*9880d681SAndroid Build Coastguard Worker 
181*9880d681SAndroid Build Coastguard Worker   EXPECT_EQ(-1, SmallString<10>("AaB").compare_lower("aAd"));
182*9880d681SAndroid Build Coastguard Worker   EXPECT_EQ( 0, SmallString<10>("AaB").compare_lower("aab"));
183*9880d681SAndroid Build Coastguard Worker   EXPECT_EQ( 1, SmallString<10>("AaB").compare_lower("AAA"));
184*9880d681SAndroid Build Coastguard Worker   EXPECT_EQ(-1, SmallString<10>("AaB").compare_lower("aaBb"));
185*9880d681SAndroid Build Coastguard Worker   EXPECT_EQ( 1, SmallString<10>("AaB").compare_lower("aA"));
186*9880d681SAndroid Build Coastguard Worker   EXPECT_EQ( 1, SmallString<10>("\xFF").compare_lower("\1"));
187*9880d681SAndroid Build Coastguard Worker 
188*9880d681SAndroid Build Coastguard Worker   EXPECT_EQ(-1, SmallString<10>("aab").compare_numeric("aad"));
189*9880d681SAndroid Build Coastguard Worker   EXPECT_EQ( 0, SmallString<10>("aab").compare_numeric("aab"));
190*9880d681SAndroid Build Coastguard Worker   EXPECT_EQ( 1, SmallString<10>("aab").compare_numeric("aaa"));
191*9880d681SAndroid Build Coastguard Worker   EXPECT_EQ(-1, SmallString<10>("aab").compare_numeric("aabb"));
192*9880d681SAndroid Build Coastguard Worker   EXPECT_EQ( 1, SmallString<10>("aab").compare_numeric("aa"));
193*9880d681SAndroid Build Coastguard Worker   EXPECT_EQ(-1, SmallString<10>("1").compare_numeric("10"));
194*9880d681SAndroid Build Coastguard Worker   EXPECT_EQ( 0, SmallString<10>("10").compare_numeric("10"));
195*9880d681SAndroid Build Coastguard Worker   EXPECT_EQ( 0, SmallString<10>("10a").compare_numeric("10a"));
196*9880d681SAndroid Build Coastguard Worker   EXPECT_EQ( 1, SmallString<10>("2").compare_numeric("1"));
197*9880d681SAndroid Build Coastguard Worker   EXPECT_EQ( 0, SmallString<10>("llvm_v1i64_ty").compare_numeric("llvm_v1i64_ty"));
198*9880d681SAndroid Build Coastguard Worker   EXPECT_EQ( 1, SmallString<10>("\xFF").compare_numeric("\1"));
199*9880d681SAndroid Build Coastguard Worker   EXPECT_EQ( 1, SmallString<10>("V16").compare_numeric("V1_q0"));
200*9880d681SAndroid Build Coastguard Worker   EXPECT_EQ(-1, SmallString<10>("V1_q0").compare_numeric("V16"));
201*9880d681SAndroid Build Coastguard Worker   EXPECT_EQ(-1, SmallString<10>("V8_q0").compare_numeric("V16"));
202*9880d681SAndroid Build Coastguard Worker   EXPECT_EQ( 1, SmallString<10>("V16").compare_numeric("V8_q0"));
203*9880d681SAndroid Build Coastguard Worker   EXPECT_EQ(-1, SmallString<10>("V1_q0").compare_numeric("V8_q0"));
204*9880d681SAndroid Build Coastguard Worker   EXPECT_EQ( 1, SmallString<10>("V8_q0").compare_numeric("V1_q0"));
205*9880d681SAndroid Build Coastguard Worker }
206*9880d681SAndroid Build Coastguard Worker 
207*9880d681SAndroid Build Coastguard Worker }
208