blob: ff04f5bd57f74771929e49bcb1699c7624c9f2b6 [file] [log] [blame]
Daniel Dunbare5df1972009-07-16 17:00:06 +00001//===- 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
Daniel Dunbare5df1972009-07-16 17:00:06 +000014#include "llvm/ADT/SmallString.h"
Chandler Carruth130cec22012-12-04 10:23:08 +000015#include "gtest/gtest.h"
Daniel Dunbare5df1972009-07-16 17:00:06 +000016#include <climits>
17#include <cstring>
Chandler Carruth130cec22012-12-04 10:23:08 +000018#include <stdarg.h>
Daniel Dunbare5df1972009-07-16 17:00:06 +000019
20using namespace llvm;
21
22namespace {
23
24// Test fixture class
25class SmallStringTest : public testing::Test {
26protected:
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.
41TEST_F(SmallStringTest, EmptyStringTest) {
42 SCOPED_TRACE("EmptyStringTest");
43 assertEmpty(theString);
44 EXPECT_TRUE(theString.rbegin() == theString.rend());
45}
46
Talin77c4ff22012-01-24 23:43:59 +000047TEST_F(SmallStringTest, AssignRepeated) {
48 theString.assign(3, 'a');
49 EXPECT_EQ(3u, theString.size());
50 EXPECT_STREQ("aaa", theString.c_str());
Daniel Dunbare5df1972009-07-16 17:00:06 +000051}
52
Talin77c4ff22012-01-24 23:43:59 +000053TEST_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
60TEST_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
68TEST_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
76TEST_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
David Blaikied028adf2014-03-09 06:17:01 +000084TEST_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
92TEST_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
Talin77c4ff22012-01-24 23:43:59 +0000101TEST_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
110TEST_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
118TEST_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
127TEST_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
161TEST_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
172TEST(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}