Skip to content

Commit 39087ab

Browse files
committed
tests: core::strtol: test for some more edge-cases
Some edge cases were currently completely untested, e.g. parsing numbers greater than INT64_{MIN,MAX}, truncating buffers by length and invalid characters. Add tests to verify that the system under test performs as expected.
1 parent 8d7fa88 commit 39087ab

1 file changed

Lines changed: 31 additions & 0 deletions

File tree

tests/core/strtol.c

Lines changed: 31 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -20,13 +20,24 @@ static void assert_l64_parses(const char *string, int64_t expected, int base)
2020
cl_assert_equal_i(i, expected);
2121
}
2222

23+
static void assert_l64_fails(const char *string, int base)
24+
{
25+
int64_t i;
26+
cl_git_fail(git__strntol64(&i, string, strlen(string), NULL, base));
27+
}
28+
2329
void test_core_strtol__int32(void)
2430
{
2531
assert_l32_parses("123", 123, 10);
2632
assert_l32_parses(" +123 ", 123, 10);
2733
assert_l32_parses(" +2147483647 ", 2147483647, 10);
2834
assert_l32_parses(" -2147483648 ", -2147483648LL, 10);
35+
assert_l32_parses("A", 10, 16);
36+
assert_l32_parses("1x1", 1, 10);
2937

38+
assert_l32_fails("", 10);
39+
assert_l32_fails("a", 10);
40+
assert_l32_fails("x10x", 10);
3041
assert_l32_fails(" 2147483657 ", 10);
3142
assert_l32_fails(" -2147483657 ", 10);
3243
}
@@ -43,4 +54,24 @@ void test_core_strtol__int64(void)
4354
assert_l64_parses(" -9223372036854775808 ", INT64_MIN, 10);
4455
assert_l64_parses(" 0x7fffffffffffffff ", INT64_MAX, 16);
4556
assert_l64_parses(" -0x8000000000000000 ", INT64_MIN, 16);
57+
assert_l64_parses("1a", 26, 16);
58+
assert_l64_parses("1A", 26, 16);
59+
60+
assert_l64_fails("", 10);
61+
assert_l64_fails("a", 10);
62+
assert_l64_fails("x10x", 10);
63+
assert_l64_fails("0x8000000000000000", 16);
64+
assert_l64_fails("-0x8000000000000001", 16);
65+
}
66+
67+
void test_core_strtol__buffer_length_truncates(void)
68+
{
69+
int32_t i32;
70+
int64_t i64;
71+
72+
cl_git_pass(git__strntol32(&i32, "11", 1, NULL, 10));
73+
cl_assert_equal_i(i32, 1);
74+
75+
cl_git_pass(git__strntol64(&i64, "11", 1, NULL, 10));
76+
cl_assert_equal_i(i64, 1);
4677
}

0 commit comments

Comments
 (0)