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