commit b541b28e0c0619e2167bec48c68445fe9e1e0154
parent 75e0fbd776662c4b3ce0e168f8c259a6a518e65a
Author: Vincent Forest <vincent.forest@meso-star.com>
Date: Mon, 24 Apr 2017 14:13:21 +0200
Test the ssol_data API
Diffstat:
2 files changed, 86 insertions(+), 0 deletions(-)
diff --git a/cmake/CMakeLists.txt b/cmake/CMakeLists.txt
@@ -153,6 +153,7 @@ if(NOT NO_TEST)
new_test(test_ssol_atmosphere)
new_test(test_ssol_by_receiver_integration)
new_test(test_ssol_camera)
+ new_test(test_ssol_data)
new_test(test_ssol_device)
new_test(test_ssol_image)
new_test(test_ssol_material)
diff --git a/src/test_ssol_data.c b/src/test_ssol_data.c
@@ -0,0 +1,85 @@
+/* Copyright (C) CNRS 2016-2017
+ *
+ * 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 "ssol.h"
+#include "test_ssol_utils.h"
+
+#include <rsys/math.h>
+
+static void
+get_wlen(const size_t i, double* wlen, double* data, void* ctx)
+{
+ NCHECK(wlen, NULL);
+ NCHECK(data, NULL);
+ *wlen = (double)(i+1);
+ *data = (double)(i+2);
+ (void)ctx;
+}
+
+int
+main(int argc, char** argv)
+{
+ struct mem_allocator allocator;
+ struct ssol_device* dev;
+ struct ssol_spectrum* spectrum;
+ struct ssol_data data = SSOL_DATA_NULL;
+ size_t i;
+ (void)argc, (void)argv;
+
+ CHECK(mem_init_proxy_allocator(&allocator, &mem_default_allocator), RES_OK);
+
+ CHECK(ssol_device_create
+ (NULL, &allocator, SSOL_NTHREADS_DEFAULT, 0, &dev), RES_OK);
+ CHECK(ssol_spectrum_create(dev, &spectrum), RES_OK);
+ CHECK(ssol_spectrum_setup(spectrum, get_wlen, 10, NULL), RES_OK);
+
+ CHECK(ssol_data_get_value(&data, 1), ssol_data_get_value(&SSOL_DATA_NULL, 1));
+ CHECK(ssol_data_get_value(&data, 4), ssol_data_get_value(&SSOL_DATA_NULL, 4));
+ CHECK(ssol_data_get_value(&data, 2), ssol_data_get_value(&SSOL_DATA_NULL, 2));
+ CHECK(ssol_data_get_value(&data, 7), ssol_data_get_value(&SSOL_DATA_NULL, 7));
+
+ CHECK(ssol_data_set_real(&data, 1.25), &data);
+ CHECK(ssol_data_get_value(&data, 1), 1.25);
+ CHECK(ssol_data_get_value(&data, 1.234), 1.25);
+ CHECK(data.type, SSOL_DATA_REAL);
+ CHECK(data.value.real, 1.25);
+
+ CHECK(ssol_data_set_spectrum(&data, spectrum), &data);
+ CHECK(ssol_data_set_spectrum(&data, spectrum), &data);
+
+ CHECK(data.type, SSOL_DATA_SPECTRUM);
+ CHECK(data.value.spectrum, spectrum);
+ CHECK(ssol_spectrum_ref_put(spectrum), RES_OK);
+
+ FOR_EACH(i, 0, 10) {
+ CHECK(ssol_data_get_value(&data, (double)(i+1)), (double)(i+2));
+ }
+
+ CHECK(eq_eps(ssol_data_get_value(&data, 1.5), 2.5, 1.e-6), 1);
+ CHECK(eq_eps(ssol_data_get_value(&data, 1.25), 2.25, 1.e-6), 1);
+ CHECK(ssol_data_get_value(&data, 0.5), 2);
+ CHECK(ssol_data_get_value(&data, 0.1), 2);
+ CHECK(ssol_data_get_value(&data, 10), 11);
+ CHECK(ssol_data_get_value(&data, 10.1), 11);
+
+ CHECK(ssol_device_ref_put(dev), RES_OK);
+ ssol_data_clear(&data);
+
+ check_memory_allocator(&allocator);
+ mem_shutdown_proxy_allocator(&allocator);
+ CHECK(mem_allocated_size(), 0);
+ return 0;
+}
+