File: test_example.c

package info (click to toggle)
libhomfly 1.02r6-1
  • links: PTS, VCS
  • area: main
  • in suites: bookworm, bullseye, forky, sid, trixie
  • size: 220 kB
  • sloc: ansic: 1,740; makefile: 19; sh: 1
file content (80 lines) | stat: -rw-r--r-- 1,627 bytes parent folder | download | duplicates (2)
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
/**
 * Run tests
 */

#include <stdio.h>
#include <stdlib.h>
#include <string.h>

#include "homfly.h"

#define BUFFER_SIZE 2048

/**
 * Test the library against given data
 *
 * usage: $TEST/test_example data.txt
 *
 * the data.txt must be formatted with 3 lines per test:
 *  1 - name
 *  2 - link info
 *  3 - expected output
 *
 * Each line can be at most 2048 characters.
 */
int main(int argc, char *argv[])
{
    char name[BUFFER_SIZE];
    char input[BUFFER_SIZE];
    char test[BUFFER_SIZE];
    char *out;
    int i;
    FILE *f;

    if (argc != 2)
    {
        printf("must give exactly one file to test\n");
        return 2;
    }

    f = fopen(argv[1], "r");
    if (f == NULL)
    {
        fclose(f);
        return 1;
    }

    while(fgets(name, sizeof(name), f) != NULL)
    {
        if(fgets(input, sizeof(input), f) == NULL)
        {
            fclose(f);
            printf("missing link data");
            return 3;
        }
        if(fgets(test, sizeof(test), f) == NULL)
        {
            fclose(f);
            printf("missing output data");
            return 3;
        }
        // File ends with \n, but we need to ignore it
        name[strlen(name)-1] = '\0';
        input[strlen(input)-1] = '\0';
        test[strlen(test)-1] = '\0';

        out = homfly_str(input);
        if(strcmp(test, out) != 0)
        {
            printf("error in computation: %s\n", name);
            printf("expected: %s\n", test);
            printf("got     : %s\n", out);
            fclose(f);
            return 1;
        }
    }

    printf("correct result\n");
    fclose(f);
    return 0;
}