jfaustin's picture
secretion-scores (#4)
a3f3d91 verified
#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;
}