File size: 4,386 Bytes
a3f3d91
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
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
106
107
108
109
110
111
112
#include <stdlib.h>
#include <math.h>
#include <check.h>
#include <freesasa.h>
#include <freesasa_internal.h>
#include <coord.h>
#include "tools.h"

coord_t *coord;

static void setup(void)
{
    coord = freesasa_coord_new();
}
static void teardown(void)
{
    if (coord) free(coord);
}

START_TEST (test_coord)
{
    ck_assert_ptr_ne(coord,NULL);
    double xyz[9] = {0,0,0, 1,0,0, 0,1,0};
    ck_assert_int_eq(freesasa_coord_append(coord,(double*)xyz,3),FREESASA_SUCCESS);
    ck_assert(float_eq(freesasa_coord_dist(coord,0,2), 1, 1e-10));
    ck_assert(float_eq(freesasa_coord_dist(coord,1,2), sqrt(2), 1e-10));
    ck_assert(float_eq(freesasa_coord_dist(coord,1,0), 1, 1e-10));
    ck_assert(float_eq(freesasa_coord_dist2(coord,0,0), 0, 1e-10));
    ck_assert(float_eq(freesasa_coord_dist2(coord,0,1), 1, 1e-10));
    ck_assert(float_eq(freesasa_coord_dist2(coord,0,2), 1, 1e-10));
    ck_assert(float_eq(freesasa_coord_dist2(coord,1,2), 2, 1e-10));
    ck_assert(float_eq(freesasa_coord_dist2(coord,1,0), 1, 1e-10));
    double xyz2[3] = {1,1,1};
    freesasa_coord_set_i(coord,2,(double*)xyz2);
    ck_assert(float_eq(freesasa_coord_dist(coord,0,0), 0, 1e-10));
    ck_assert(float_eq(freesasa_coord_dist(coord,0,2), sqrt(3), 1e-10));
    ck_assert(float_eq(freesasa_coord_dist(coord,1,2), sqrt(2), 1e-10));
    ck_assert(float_eq(freesasa_coord_dist2(coord,0,2), 3, 1e-10));
    ck_assert(float_eq(freesasa_coord_dist2(coord,1,2), 2, 1e-10));
    freesasa_coord_set_i_xyz(coord,1,-1,-1,-1);
    ck_assert(float_eq(freesasa_coord_dist(coord,1,1), 0, 1e-10));
    ck_assert(float_eq(freesasa_coord_dist(coord,1,2), sqrt(12), 1e-10));
    ck_assert(float_eq(freesasa_coord_dist(coord,1,0), sqrt(3), 1e-10));
    ck_assert(float_eq(freesasa_coord_dist2(coord,1,2), 12, 1e-10));
    ck_assert(float_eq(freesasa_coord_dist2(coord,0,2), 3, 1e-10));

    freesasa_coord_set_all(coord,&xyz[3],2);
    ck_assert(float_eq(freesasa_coord_dist(coord,0,0), 0, 1e-10));
    ck_assert(float_eq(freesasa_coord_dist2(coord,0,1), 2, 1e-10));

    double x[2] = {2,2}, y[2] = {1,2}, z[2] = {0,1};
    ck_assert_int_eq(freesasa_coord_append_xyz(coord,(double*)x,(double*)y,(double*)z,2),FREESASA_SUCCESS);
    ck_assert(float_eq(freesasa_coord_dist2(coord,0,2), 2, 1e-10));
    ck_assert(float_eq(freesasa_coord_dist2(coord,1,2), 4, 1e-10));
    ck_assert(float_eq(freesasa_coord_dist2(coord,0,3), 6, 1e-10));

    freesasa_coord_set_all_xyz(coord,x,y,z,2);
    ck_assert(freesasa_coord_n(coord) == 2);
    ck_assert(float_eq(freesasa_coord_dist2(coord,0,1), 2, 1e-10));

    freesasa_coord_set_length_i(coord,1,6);
    const double *ci = freesasa_coord_i(coord,1);
    ck_assert(ci != NULL);
    ck_assert(float_eq(ci[0], 4, 1e-10) && float_eq(ci[1], 4, 1e-10) && float_eq(ci[2], 2, 1e-10));

    freesasa_coord_set_length_all(coord,3);
    ck_assert(float_eq(ci[0], 2, 1e-10) && float_eq(ci[1], 2, 1e-10) && float_eq(ci[2], 1, 1e-10));

    coord_t *c2 = freesasa_coord_new();
    ck_assert(c2 != NULL);
    ck_assert_int_eq(freesasa_coord_append(c2, xyz2, 1), FREESASA_SUCCESS);
    ck_assert(float_eq(freesasa_coord_dist2_12(coord, c2, 1, 0), 2, 1e-10));
    freesasa_coord_free(c2);
}
END_TEST

START_TEST (test_memerr)
{
    set_fail_after(0);
    static double v[18] = {0,0,0, 1,1,1, -1,1,-1, 2,0,-2, 2,2,0, -5,5,5};
    struct coord_t coord = {.xyz = v, .n = 6, .is_linked = 0};
    coord_t *coord_dyn = freesasa_coord_new();
    set_fail_after(1);
    freesasa_set_verbosity(FREESASA_V_SILENT);
    void *ptr[] = {freesasa_coord_new(),
                   freesasa_coord_copy(&coord),
                   freesasa_coord_new_linked(v,1)};
    int ret[] = {freesasa_coord_append(coord_dyn, v, 1),
               freesasa_coord_append_xyz(coord_dyn, v, v+1, v+2, 1)};
    set_fail_after(0);
    for (int i = 0; i < sizeof(ptr)/sizeof(void*); ++i)
        ck_assert_ptr_eq(ptr[i],NULL);
    for (int i = 0; i < sizeof(ret)/sizeof(int); ++i)
        ck_assert_int_eq(ret[i], FREESASA_FAIL);

    freesasa_set_verbosity(FREESASA_V_NORMAL);
    freesasa_coord_free(coord_dyn);
    set_fail_after(0);
}
END_TEST

Suite* coord_suite()
{
    Suite *s = suite_create("Coord");
    TCase *tc_core = tcase_create("Core");
    tcase_add_checked_fixture(tc_core,setup,teardown);
    tcase_add_test(tc_core,test_coord);
    tcase_add_test(tc_core,test_memerr);
    suite_add_tcase(s,tc_core);
    return s;
}