aboutsummaryrefslogtreecommitdiff
path: root/test/tests/TestInt.c
diff options
context:
space:
mode:
Diffstat (limited to 'test/tests/TestInt.c')
-rw-r--r--test/tests/TestInt.c177
1 files changed, 177 insertions, 0 deletions
diff --git a/test/tests/TestInt.c b/test/tests/TestInt.c
new file mode 100644
index 0000000..f372d4e
--- /dev/null
+++ b/test/tests/TestInt.c
@@ -0,0 +1,177 @@
+#include <BH/String.h>
+#include <BH/Unit.h>
+
+
+BH_UNIT_TEST(Int8)
+{
+ char str[9];
+ size_t size;
+
+ BH_VERIFY(BH_StringFromInt8s(str, 9, -13, 16, NULL) == BH_OK);
+ BH_VERIFY(BH_StringToInt8s(str, &size, 16) == -13);
+ BH_VERIFY(size == 2);
+
+ BH_VERIFY(BH_StringFromInt8s(str, 9, -13, 10, NULL) == BH_OK);
+ BH_VERIFY(BH_StringToInt8s(str, &size, 10) == -13);
+ BH_VERIFY(size == 3);
+
+ BH_VERIFY(BH_StringFromInt8s(str, 9, -13, 8, NULL) == BH_OK);
+ BH_VERIFY(BH_StringToInt8s(str, &size, 8) == -13);
+ BH_VERIFY(size == 3);
+
+ BH_VERIFY(BH_StringFromInt8s(str, 9, -13, 2, NULL) == BH_OK);
+ BH_VERIFY(BH_StringToInt8s(str, &size, 2) == -13);
+ BH_VERIFY(size == 5);
+
+ BH_VERIFY(BH_StringFromInt8u(str, 9, 200, 16, NULL) == BH_OK);
+ BH_VERIFY(BH_StringToInt8u(str, &size, 16) == 200);
+ BH_VERIFY(size == 2);
+
+ BH_VERIFY(BH_StringFromInt8u(str, 9, 200, 10, NULL) == BH_OK);
+ BH_VERIFY(BH_StringToInt8u(str, &size, 10) == 200);
+ BH_VERIFY(size == 3);
+
+ BH_VERIFY(BH_StringFromInt8u(str, 9, 200, 8, NULL) == BH_OK);
+ BH_VERIFY(BH_StringToInt8u(str, &size, 8) == 200);
+ BH_VERIFY(size == 3);
+
+ BH_VERIFY(BH_StringFromInt8u(str, 9, 200, 2, NULL) == BH_OK);
+ BH_VERIFY(BH_StringToInt8u(str, &size, 2) == 200);
+ BH_VERIFY(size == 8);
+
+ return 0;
+}
+
+
+BH_UNIT_TEST(Int16)
+{
+ char str[17];
+ size_t size;
+
+ BH_VERIFY(BH_StringFromInt16s(str, 17, -1234, 16, NULL) == BH_OK);
+ BH_VERIFY(BH_StringToInt16s(str, &size, 16) == -1234);
+ BH_VERIFY(size == 4);
+
+ BH_VERIFY(BH_StringFromInt16s(str, 17, -1234, 10, NULL) == BH_OK);
+ BH_VERIFY(BH_StringToInt16s(str, &size, 10) == -1234);
+ BH_VERIFY(size == 5);
+
+ BH_VERIFY(BH_StringFromInt16s(str, 17, -1234, 8, NULL) == BH_OK);
+ BH_VERIFY(BH_StringToInt16s(str, &size, 8) == -1234);
+ BH_VERIFY(size == 5);
+
+ BH_VERIFY(BH_StringFromInt16s(str, 17, -1234, 2, NULL) == BH_OK);
+ BH_VERIFY(BH_StringToInt16s(str, &size, 2) == -1234);
+ BH_VERIFY(size == 12);
+
+ BH_VERIFY(BH_StringFromInt16u(str, 17, 43210, 16, NULL) == BH_OK);
+ BH_VERIFY(BH_StringToInt16u(str, &size, 16) == 43210);
+ BH_VERIFY(size == 4);
+
+ BH_VERIFY(BH_StringFromInt16u(str, 17, 43210, 10, NULL) == BH_OK);
+ BH_VERIFY(BH_StringToInt16u(str, &size, 10) == 43210);
+ BH_VERIFY(size == 5);
+
+ BH_VERIFY(BH_StringFromInt16u(str, 17, 43210, 8, NULL) == BH_OK);
+ BH_VERIFY(BH_StringToInt16u(str, &size, 8) == 43210);
+ BH_VERIFY(size == 6);
+
+ BH_VERIFY(BH_StringFromInt16u(str, 17, 43210, 2, NULL) == BH_OK);
+ BH_VERIFY(BH_StringToInt16u(str, &size, 2) == 43210);
+ BH_VERIFY(size == 16);
+
+ return 0;
+}
+
+
+BH_UNIT_TEST(Int32)
+{
+ char str[33];
+ size_t size;
+
+ BH_VERIFY(BH_StringFromInt32s(str, 33, -1234567890l, 16, NULL) == BH_OK);
+ BH_VERIFY(BH_StringToInt32s(str, &size, 16) == -1234567890l);
+ BH_VERIFY(size == 9);
+
+ BH_VERIFY(BH_StringFromInt32s(str, 33, -1234567890l, 10, NULL) == BH_OK);
+ BH_VERIFY(BH_StringToInt32s(str, &size, 10) == -1234567890l);
+ BH_VERIFY(size == 11);
+
+ BH_VERIFY(BH_StringFromInt32s(str, 33, -1234567890l, 8, NULL) == BH_OK);
+ BH_VERIFY(BH_StringToInt32s(str, &size, 8) == -1234567890l);
+ BH_VERIFY(size == 12);
+
+ BH_VERIFY(BH_StringFromInt32s(str, 33, -1234567890l, 2, NULL) == BH_OK);
+ BH_VERIFY(BH_StringToInt32s(str, &size, 2) == -1234567890l);
+ BH_VERIFY(size == 32);
+
+ BH_VERIFY(BH_StringFromInt32u(str, 33, 3456789012ul, 16, NULL) == BH_OK);
+ BH_VERIFY(BH_StringToInt32u(str, &size, 16) == 3456789012ul);
+ BH_VERIFY(size == 8);
+
+ BH_VERIFY(BH_StringFromInt32u(str, 33, 3456789012ul, 10, NULL) == BH_OK);
+ BH_VERIFY(BH_StringToInt32u(str, &size, 10) == 3456789012ul);
+ BH_VERIFY(size == 10);
+
+ BH_VERIFY(BH_StringFromInt32u(str, 33, 3456789012ul, 8, NULL) == BH_OK);
+ BH_VERIFY(BH_StringToInt32u(str, &size, 8) == 3456789012ul);
+ BH_VERIFY(size == 11);
+
+ BH_VERIFY(BH_StringFromInt32u(str, 33, 3456789012ul, 2, NULL) == BH_OK);
+ BH_VERIFY(BH_StringToInt32u(str, &size, 2) == 3456789012ul);
+ BH_VERIFY(size == 32);
+
+ return 0;
+}
+
+
+BH_UNIT_TEST(Parsing)
+{
+ size_t size;
+
+ BH_VERIFY(BH_StringToInt32s(" 0x1234", &size, 16) == 0x1234);
+ BH_VERIFY(size == 9);
+
+ BH_VERIFY(BH_StringToInt32s(" 12345", &size, 10) == 12345);
+ BH_VERIFY(size == 8);
+
+ BH_VERIFY(BH_StringToInt32s(" 0123", &size, 8) == 0123);
+ BH_VERIFY(size == 7);
+
+ BH_VERIFY(BH_StringToInt32s(" 0b1111Hello", &size, 2) == 15);
+ BH_VERIFY(size == 9);
+
+ BH_VERIFY(BH_StringToInt32s(" 0x1234", &size, 0) == 0x1234);
+ BH_VERIFY(size == 9);
+
+ BH_VERIFY(BH_StringToInt32s(" 0123", &size, 0) == 0123);
+ BH_VERIFY(size == 7);
+
+ BH_VERIFY(BH_StringToInt32s(" 123", &size, 0) == 123);
+ BH_VERIFY(size == 6);
+
+ BH_VERIFY(BH_StringToInt32s(" 0b1111", &size, 0) == 15);
+ BH_VERIFY(size == 9);
+
+ BH_VERIFY(BH_StringToInt32s(" 12345Hello", &size, 10) == 12345);
+ BH_VERIFY(size == 8);
+
+ BH_VERIFY(BH_StringToInt32s(" Hello", &size, 10) == 0);
+ BH_VERIFY(size == 0);
+
+ return 0;
+}
+
+
+int main(int argc, char **argv)
+{
+ BH_UNUSED(argc);
+ BH_UNUSED(argv);
+
+ BH_UNIT_ADD(Int8);
+ BH_UNIT_ADD(Int16);
+ BH_UNIT_ADD(Int32);
+ BH_UNIT_ADD(Parsing);
+
+ return BH_UnitRun();
+}