summaryrefslogtreecommitdiffstats
path: root/tests/unit/test_adds.c
blob: fdc671f5c639a5fb7a46b6574a81c68c9ef9c752 (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
// SPDX-FileCopyrightText: 2023, Alejandro Colomar <alx@kernel.org>
// SPDX-License-Identifier: BSD-3-Clause


#include <limits.h>

#include <stdarg.h>  // Required by <cmocka.h>
#include <stddef.h>  // Required by <cmocka.h>
#include <setjmp.h>  // Required by <cmocka.h>
#include <stdint.h>  // Required by <cmocka.h>
#include <cmocka.h>

#include "adds.h"


static void test_addsl_2_ok(void **state);
static void test_addsl_2_underflow(void **state);
static void test_addsl_2_overflow(void **state);
static void test_addsl_3_ok(void **state);
static void test_addsl_3_underflow(void **state);
static void test_addsl_3_overflow(void **state);
static void test_addsl_5_ok(void **state);


int
main(void)
{
    const struct CMUnitTest  tests[] = {
        cmocka_unit_test(test_addsl_2_ok),
        cmocka_unit_test(test_addsl_2_underflow),
        cmocka_unit_test(test_addsl_2_overflow),
        cmocka_unit_test(test_addsl_3_ok),
        cmocka_unit_test(test_addsl_3_underflow),
        cmocka_unit_test(test_addsl_3_overflow),
        cmocka_unit_test(test_addsl_5_ok),
    };

    return cmocka_run_group_tests(tests, NULL, NULL);
}


static void
test_addsl_2_ok(void **state)
{
	assert_true(addsl(1, 3)			== 1 + 3);
	assert_true(addsl(-4321, 7)		== -4321 + 7);
	assert_true(addsl(1, 1)			== 1 + 1);
	assert_true(addsl(-1, -2)		== -1 - 2);
	assert_true(addsl(LONG_MAX, -1)		== LONG_MAX - 1);
	assert_true(addsl(LONG_MIN, 1)		== LONG_MIN + 1);
	assert_true(addsl(LONG_MIN, LONG_MAX)	== LONG_MIN + LONG_MAX);
	assert_true(addsl(0, 0)			== 0);
}


static void
test_addsl_2_underflow(void **state)
{
	assert_true(addsl(LONG_MIN, -1)		== LONG_MIN);
	assert_true(addsl(LONG_MIN + 3, -7)	== LONG_MIN);
	assert_true(addsl(LONG_MIN, LONG_MIN)	== LONG_MIN);
}


static void
test_addsl_2_overflow(void **state)
{
	assert_true(addsl(LONG_MAX, 1)		== LONG_MAX);
	assert_true(addsl(LONG_MAX - 3, 7)	== LONG_MAX);
	assert_true(addsl(LONG_MAX, LONG_MAX)	== LONG_MAX);
}


static void
test_addsl_3_ok(void **state)
{
	assert_true(addsl(1, 2, 3)		== 1 + 2 + 3);
	assert_true(addsl(LONG_MIN, -3, 4)	== LONG_MIN + 4 - 3);
	assert_true(addsl(LONG_MAX, LONG_MAX, LONG_MIN)
						== LONG_MAX + LONG_MIN + LONG_MAX);
}


static void
test_addsl_3_underflow(void **state)
{
	assert_true(addsl(LONG_MIN, 2, -3)	== LONG_MIN);
	assert_true(addsl(LONG_MIN, -1, 0)	== LONG_MIN);
}


static void
test_addsl_3_overflow(void **state)
{
	assert_true(addsl(LONG_MAX, -1, 2)	== LONG_MAX);
	assert_true(addsl(LONG_MAX, +1, 0)	== LONG_MAX);
	assert_true(addsl(LONG_MAX, LONG_MAX, 0)== LONG_MAX);
}


static void
test_addsl_5_ok(void **state)
{
	assert_true(addsl(LONG_MAX, LONG_MAX, LONG_MIN, LONG_MIN, 44) == 42);
}