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 113 114 115 116 117 118 119
|
#include <check.h>
#include <coord.h>
#include <freesasa.h>
#include <freesasa_internal.h>
#include <math.h>
#include <stdlib.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));
coord_t *c3 = freesasa_coord_clone(c2);
ck_assert(c3 != NULL);
ck_assert(float_eq(freesasa_coord_dist2_12(c3, c2, 0, 0), 0, 1e-10));
freesasa_coord_set_length_all(c2, 10);
ck_assert_int_eq(freesasa_coord_copy(c3, c2), FREESASA_SUCCESS);
ck_assert(float_eq(freesasa_coord_dist2_12(c3, c2, 0, 0), 0, 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_clone(&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;
}
|