aboutsummaryrefslogtreecommitdiff
path: root/minctest.c
blob: 82bb552dabf40d2cb320473ebf5f57f9223e441a (plain) (blame)
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
/**
 * MinCTest - Minimalistic C unit test framework
 * Copyright (C) 2015  Camil Staps

 * This program is free software: you can redistribute it and/or modify
 * it under the terms of the GNU General Public License as published by
 * the Free Software Foundation, either version 3 of the License, or
 * (at your option) any later version.

 * This program is distributed in the hope that it will be useful,
 * but WITHOUT ANY WARRANTY; without even the implied warranty of
 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
 * GNU General Public License for more details.

 * You should have received a copy of the GNU General Public License
 * along with this program.  If not, see <http://www.gnu.org/licenses/>.
 */
#include <stdio.h>
#include <malloc.h>
#include <stdlib.h>
#include "minctest.h"

// Colours for terminal output
#define KRED  "\x1B[31m"
#define KGRN  "\x1B[32m"
#define RESET "\x1B[0m"

tester* test_initialize(void) {
    tester* test = malloc(sizeof(tester));
    if (test == NULL) return NULL;
    test->passed = 0;
    test->failed = 0;
    test->show_pass = true;
    test_start_timer(test);
    return test;
}

void test_wrapup(tester* tester) {
    if (tester->failed == 0) {
        printf(KGRN "\nAll tests passed (%d)\n" RESET, tester->passed);
    } else {
        printf(KRED "\n%d test%s failed" RESET " (%d passed)\n", 
                tester->failed, tester->failed > 1 ? "s" : "", tester->passed);
    }
}

void test_destroy(tester* tester) {
    free(tester);
}

void test_exit(tester* tester) {
    bool all_passed = tester->failed == 0;
    test_destroy(tester);
    exit(all_passed ? 0 : -1);
}

void test_start_timer(tester* tester) {
    gettimeofday(&tester->start_last_test, NULL);
}

void test_true(tester* tester, bool check, const char* text) {
    struct timeval end;
    gettimeofday(&end, NULL);

    if (!check || tester->show_pass) {
        printf(check ? KGRN : KRED);
        printf(check ? "Test passed" : "Test failed");
        if (text != NULL)
            printf(": %s", text);
        printf(" [%.3fs]", ((float) end.tv_usec - tester->start_last_test.tv_usec) / 1000);
        printf("\n" RESET);
    }

    *(check ? &tester->passed : &tester->failed) += 1;

    test_start_timer(tester);
}