aboutsummaryrefslogtreecommitdiff
path: root/llvm/unittests/ADT/StringRefTest.cpp
diff options
context:
space:
mode:
authorNick Kledzik <kledzik@apple.com>2012-10-03 18:15:27 +0000
committerNick Kledzik <kledzik@apple.com>2012-10-03 18:15:27 +0000
commitf8a75eef85efc2347c70a20a60fbdf1e0982266c (patch)
tree48262cee21577dd823fe80ee47df9730f6507ef3 /llvm/unittests/ADT/StringRefTest.cpp
parent76f50f48a1cf3fc9702b5615da21d44f81b35c2d (diff)
downloadllvm-f8a75eef85efc2347c70a20a60fbdf1e0982266c.zip
llvm-f8a75eef85efc2347c70a20a60fbdf1e0982266c.tar.gz
llvm-f8a75eef85efc2347c70a20a60fbdf1e0982266c.tar.bz2
Add getAsUnsignedInteger test case that checks that known bad values are rejected
llvm-svn: 165136
Diffstat (limited to 'llvm/unittests/ADT/StringRefTest.cpp')
-rw-r--r--llvm/unittests/ADT/StringRefTest.cpp19
1 files changed, 19 insertions, 0 deletions
diff --git a/llvm/unittests/ADT/StringRefTest.cpp b/llvm/unittests/ADT/StringRefTest.cpp
index 315eacb..59eed54 100644
--- a/llvm/unittests/ADT/StringRefTest.cpp
+++ b/llvm/unittests/ADT/StringRefTest.cpp
@@ -456,4 +456,23 @@ TEST(StringRefTest, getAsInteger) {
}
}
+
+static const char* BadStrings[] = {
+ "18446744073709551617" // value just over max
+ , "123456789012345678901" // value way too large
+ , "4t23v" // illegal decimal characters
+ , "0x123W56" // illegal hex characters
+};
+
+
+TEST(StringRefTest, getAsUnsignedIntegerBadStrings) {
+ uint64_t U64;
+ for (size_t i = 0; i < array_lengthof(BadStrings); ++i) {
+ bool IsBadNumber = getAsUnsignedInteger(BadStrings[i], 0, U64);
+ ASSERT_TRUE(IsBadNumber);
+ }
+}
+
+
+
} // end anonymous namespace