Skip to content

Commit

Permalink
test: added more correctness checks
Browse files Browse the repository at this point in the history
In particular, we now check the correct relationship between .times,
.at_least, .at_most, and .never for each exact call counts.
  • Loading branch information
Snaipe committed Jul 13, 2017
1 parent 52d40fb commit fc1b2d6
Showing 1 changed file with 74 additions and 22 deletions.
96 changes: 74 additions & 22 deletions test/test.c
@@ -1,6 +1,7 @@
#include <mimick.h>
#include <mimick/assert.h>
#include <stdlib.h>
#include <limits.h>

#include "libfoo.h"

Expand Down Expand Up @@ -34,40 +35,91 @@ void set_valid(void) {
valid = 1;
}

static int int_eq_called;
static int expected_int;

int int_eq(int val) {
int_eq_called = 1;
return val == expected_int;
}

#define check_called_exact(Expr, Times) do { \
size_t times = (Times); \
if (times == 0) { \
mmk_assert(mmk_verify(Expr, .never = 1)); \
} else { \
mmk_assert(mmk_verify(Expr, .times = times)); \
mmk_assert(mmk_verify(Expr, .at_least = times)); \
mmk_assert(mmk_verify(Expr, .at_most = times)); \
mmk_assert(mmk_verify(Expr, .at_least = times, .at_most = times)); \
mmk_assert(!mmk_verify(Expr, .never = 1)); \
} \
if (times > 1) { \
mmk_assert(!mmk_verify(Expr, .times = times - 1)); \
mmk_assert(mmk_verify(Expr, .at_least = times - 1)); \
mmk_assert(!mmk_verify(Expr, .at_most = times - 1)); \
} \
if (times < (size_t)-1) { \
mmk_assert(!mmk_verify(Expr, .times = times + 1)); \
mmk_assert(mmk_verify(Expr, .at_most = times + 1)); \
mmk_assert(!mmk_verify(Expr, .at_least = times + 1)); \
} \
} while (0)

int main(void)
{
mmk_mock("fn_vv", fn_vv_mock);
mmk_when(fn_vv(), .then_call = (mmk_fn) set_valid);

mmk_assert(mmk_verify(fn_vv(), .never = 1));
mmk_assert(mmk_verify(fn_vv(), .at_most = 1));

mmk_assert(!mmk_verify(fn_vv(), .times = 1));
mmk_assert(!mmk_verify(fn_vv(), .at_least = 1));
mmk_assert(!mmk_verify(fn_vv(), .at_least = 1, .at_most = 1));

check_called_exact(fn_vv(), 0);
fn_vv();
mmk_assert(valid);
mmk_assert(mmk_verify(fn_vv(), .times = 1));
mmk_assert(mmk_verify(fn_vv(), .at_least = 1));
mmk_assert(mmk_verify(fn_vv(), .at_most = 1));
mmk_assert(mmk_verify(fn_vv(), .at_least = 1, .at_most = 1));
mmk_assert(!mmk_verify(fn_vv(), .never = 1));
mmk_assert(!mmk_verify(fn_vv(), .times = 2));
mmk_assert(!mmk_verify(fn_vv(), .at_least = 2));
check_called_exact(fn_vv(), 1);
mmk_reset(fn_vv);

int err = 0xfefefefe;
mmk_mock("fn_ii", fn_ii_mock);
mmk_when(fn_ii(1), .then_return = mmk_val(int, 1), .then_errno = err);

mmk_assert(fn_ii(1) == 1 && errno == err);
mmk_assert(fn_ii(42) == 0);

mmk_assert(mmk_verify(fn_ii(mmk_any(int)), .times = 2));
mmk_assert(mmk_verify(fn_ii(1), .times = 1));
mmk_assert(mmk_verify(fn_ii(42), .times = 1));
mmk_assert(mmk_verify(fn_ii(12), .never = 1));
mmk_when(fn_ii(mmk_eq(int, 2)), .then_return = mmk_val(int, 2), .then_errno = err + 1);
mmk_when(fn_ii(mmk_ge(int, 3)), .then_return = mmk_val(int, 3), .then_errno = err + 2);
mmk_when(fn_ii(mmk_gt(int, 4)), .then_return = mmk_val(int, 4), .then_errno = err + 3);
mmk_when(fn_ii(mmk_le(int, -2)), .then_return = mmk_val(int, 5), .then_errno = err + 4);
mmk_when(fn_ii(mmk_lt(int, -3)), .then_return = mmk_val(int, 6), .then_errno = err + 5);
mmk_when(fn_ii(mmk_that(int, int_eq)), .then_return = mmk_val(int, 7), .then_errno = err + 6);

mmk_assert(fn_ii(1) == 1 && errno == err);
mmk_assert(fn_ii(2) == 2 && errno == err + 1);
mmk_assert(fn_ii(3) == 3 && errno == err + 2);
mmk_assert(fn_ii(4) == 3 && errno == err + 2);
mmk_assert(fn_ii(5) == 4 && errno == err + 3);
mmk_assert(fn_ii(6) == 4 && errno == err + 3);
mmk_assert(fn_ii(INT_MAX) == 4 && errno == err + 3);
mmk_assert(fn_ii(-1) == 0);
mmk_assert(fn_ii(-2) == 5 && errno == err + 4);
mmk_assert(fn_ii(-3) == 5 && errno == err + 4);
mmk_assert(fn_ii(-4) == 6 && errno == err + 5);
mmk_assert(fn_ii(-5) == 6 && errno == err + 5);
mmk_assert(fn_ii(INT_MIN) == 6 && errno == err + 5);

expected_int = 1;
mmk_assert(fn_ii(1) == 7 && errno == err + 6 && int_eq_called);
int_eq_called = 0;

check_called_exact(fn_ii(mmk_any(int)), 14);
check_called_exact(fn_ii(1), 2);
check_called_exact(fn_ii(2), 1);
check_called_exact(fn_ii(3), 1);
check_called_exact(fn_ii(4), 1);
check_called_exact(fn_ii(5), 1);
check_called_exact(fn_ii(6), 1);
check_called_exact(fn_ii(INT_MAX), 1);
check_called_exact(fn_ii(-1), 1);
check_called_exact(fn_ii(-2), 1);
check_called_exact(fn_ii(-3), 1);
check_called_exact(fn_ii(-4), 1);
check_called_exact(fn_ii(-5), 1);
check_called_exact(fn_ii(INT_MIN), 1);
check_called_exact(fn_ii(12), 0);
mmk_reset(fn_ii);


Expand Down

0 comments on commit fc1b2d6

Please sign in to comment.