Files
OpenSpace/tests/test_horizons.cpp
Alexander Bock 1a88d898d8 Update submodules
2023-02-01 23:41:55 +01:00

832 lines
28 KiB
C++

/*****************************************************************************************
* *
* OpenSpace *
* *
* Copyright (c) 2014-2023 *
* *
* Permission is hereby granted, free of charge, to any person obtaining a copy of this *
* software and associated documentation files (the "Software"), to deal in the Software *
* without restriction, including without limitation the rights to use, copy, modify, *
* merge, publish, distribute, sublicense, and/or sell copies of the Software, and to *
* permit persons to whom the Software is furnished to do so, subject to the following *
* conditions: *
* *
* The above copyright notice and this permission notice shall be included in all copies *
* or substantial portions of the Software. *
* *
* THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR IMPLIED, *
* INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, FITNESS FOR A *
* PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT *
* HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF *
* CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE *
* OR THE USE OR OTHER DEALINGS IN THE SOFTWARE. *
****************************************************************************************/
#include <catch2/catch_approx.hpp>
#include <catch2/catch_test_macros.hpp>
#include <openspace/json.h>
#include <openspace/util/spicemanager.h>
#include <ghoul/filesystem/filesystem.h>
#include <ghoul/logging/logmanager.h>
#ifdef OPENSPACE_MODULE_SPACE_ENABLED
#include <modules/space/horizonsfile.h>
#endif // OPENSPACE_MODULE_SPACE_ENABLED
using namespace openspace;
using json = nlohmann::json;
// Struct to hold the data for some of the tests
struct HorizonsTestData {
std::string observer, target, start, stop, step, unit;
};
// Avoid repetitive code by using these functions
#ifdef OPENSPACE_MODULE_SPACE_ENABLED
void testHorizonsAnswer(const HorizonsTestData& data, HorizonsType type,
std::filesystem::path filePath,
HorizonsResultCode expectedAnswerCode)
{
std::string url = constructHorizonsUrl(
type,
data.target,
data.observer,
data.start,
data.stop,
data.step,
data.unit
);
json answer = sendHorizonsRequest(url, filePath);
HorizonsResultCode code = isValidHorizonsAnswer(answer);
CHECK(code == expectedAnswerCode);
CHECK(std::filesystem::is_regular_file(filePath));
std::filesystem::remove(filePath);
CHECK(!std::filesystem::is_regular_file(filePath));
}
void testHorizonsAnswerAndResult(const HorizonsTestData& data, HorizonsType type,
std::filesystem::path filePath,
HorizonsResultCode expectedAnswerCode,
HorizonsResultCode expectedResultCode,
bool shouldDeleteFile = true)
{
std::string url = constructHorizonsUrl(
type,
data.target,
data.observer,
data.start,
data.stop,
data.step,
data.unit
);
json answer = sendHorizonsRequest(url, filePath);
HorizonsResultCode answerCode = isValidHorizonsAnswer(answer);
CHECK(answerCode == expectedAnswerCode);
// Extract the result from the json object and test it
auto result = answer.find("result");
CHECK(result != answer.end());
HorizonsFile horizonsFile(filePath, *result);
HorizonsResultCode resultCode = isValidHorizonsFile(horizonsFile.file());
CHECK(resultCode == expectedResultCode);
CHECK(std::filesystem::is_regular_file(filePath));
if (shouldDeleteFile) {
std::filesystem::remove(filePath);
CHECK(!std::filesystem::is_regular_file(filePath));
}
}
void testReadingHorizons(HorizonsType type, std::filesystem::path filePath,
const double t0, const double x0, const double y0, const double z0,
const double t1, const double x1, const double y1, const double z1,
const double t2, const double x2, const double y2, const double z2)
{
// Get files and make sure they exist
std::filesystem::path kernel = absPath("${TESTDIR}/horizonsTest/naif0012.tls");
CHECK(std::filesystem::is_regular_file(kernel));
CHECK(std::filesystem::is_regular_file(filePath));
// Initialize SpiceManager and load leap second kernel
SpiceManager::initialize();
openspace::SpiceManager::ref().loadKernel(kernel.string());
// Read the file
HorizonsResult result = readHorizonsFile(filePath);
// Check the result
CHECK(result.type == type);
CHECK(result.errorCode == HorizonsResultCode::Valid);
std::vector<HorizonsKeyframe> data = result.data;
REQUIRE(data.size() == 3);
CHECK(data[0].time == Catch::Approx(t0));
CHECK(data[0].position.x == Catch::Approx(x0));
CHECK(data[0].position.y == Catch::Approx(y0));
CHECK(data[0].position.z == Catch::Approx(z0));
CHECK(data[1].time == Catch::Approx(t1));
CHECK(data[1].position.x == Catch::Approx(x1));
CHECK(data[1].position.y == Catch::Approx(y1));
CHECK(data[1].position.z == Catch::Approx(z1));
CHECK(data[2].time == Catch::Approx(t2));
CHECK(data[2].position.x == Catch::Approx(x2));
CHECK(data[2].position.y == Catch::Approx(y2));
CHECK(data[2].position.z == Catch::Approx(z2));
// Clean up
openspace::SpiceManager::ref().unloadKernel(kernel.string());
openspace::SpiceManager::deinitialize();
}
#endif // OPENSPACE_MODULE_SPACE_ENABLED
// Test if the space module is enable or not
TEST_CASE("HorizonsFile: Space module", "[horizonsfile]") {
#ifdef OPENSPACE_MODULE_SPACE_ENABLED
CHECK(true);
LINFOC("test_horizons", "Downloading Horizons test data ...");
#else
LERRORC("test_horizons", "These tests requires the Space module to be enabled");
CHECK(false);
#endif // OPENSPACE_MODULE_SPACE_ENABLED
}
// Test Horizons requests and error handling
// Test the errors that are captured by the error field in the json result
TEST_CASE("HorizonsFile: File size too large", "[horizonsfile]") {
#ifdef OPENSPACE_MODULE_SPACE_ENABLED
HorizonsTestData data;
data.observer = "@ssb";
data.target = "-74"; // MRO
data.start = "2005-08-13 00:00:00";
data.stop = "2022-07-01 00:00:00";
data.step = "1";
data.unit = "m";
std::filesystem::path filePath = absPath("${TESTDIR}/horizonsTest/horizonstest_1.hrz");
HorizonsResultCode expectedAnswerCode = HorizonsResultCode::ErrorSize;
// Test Vector format
HorizonsType type = HorizonsType::Vector;
testHorizonsAnswer(data, type, filePath, expectedAnswerCode);
// Test Observer format
type = HorizonsType::Observer;
testHorizonsAnswer(data, type, filePath, expectedAnswerCode);
#endif // OPENSPACE_MODULE_SPACE_ENABLED
}
TEST_CASE("HorizonsFile: Time steps too large", "[horizonsfile]") {
#ifdef OPENSPACE_MODULE_SPACE_ENABLED
HorizonsTestData data;
data.observer = "@ssb";
data.target = "-74"; // MRO
data.start = "2005-08-13 00:00:00";
data.stop = "2022-07-01 00:00:00";
data.step = "1111111111";
data.unit = "d";
std::filesystem::path filePath = absPath("${TESTDIR}/horizonsTest/horizonstest_2.hrz");
HorizonsResultCode expectedAnswerCode = HorizonsResultCode::ErrorSpan;
// Test Vector format
HorizonsType type = HorizonsType::Vector;
testHorizonsAnswer(data, type, filePath, expectedAnswerCode);
// Test Observer format
type = HorizonsType::Observer;
testHorizonsAnswer(data,type, filePath, expectedAnswerCode);
#endif // OPENSPACE_MODULE_SPACE_ENABLED
}
TEST_CASE("HorizonsFile: Outside available time range", "[horizonsfile]") {
#ifdef OPENSPACE_MODULE_SPACE_ENABLED
HorizonsTestData data;
data.observer = "@ssb";
data.target = "Tesla";
data.start = "1950-05-19 00:00:00";
data.stop = "2000-05-19 00:00:00";
data.step = "1";
data.unit = "d";
std::filesystem::path filePath = absPath("${TESTDIR}/horizonsTest/horizonstest_3.hrz");
HorizonsResultCode expectedAnswerCode = HorizonsResultCode::ErrorTimeRange;
// Test Vector format
HorizonsType type = HorizonsType::Vector;
testHorizonsAnswer(data, type, filePath, expectedAnswerCode);
// Test Observer format
type = HorizonsType::Observer;
testHorizonsAnswer(data, type, filePath, expectedAnswerCode);
#endif // OPENSPACE_MODULE_SPACE_ENABLED
}
TEST_CASE("HorizonsFile: No observer", "[horizonsfile]") {
#ifdef OPENSPACE_MODULE_SPACE_ENABLED
HorizonsTestData data;
data.observer = "abcdefghijkl";
data.target = "Tesla";
data.start = "2021-05-19 00:00:00";
data.stop = "2022-05-19 00:00:00";
data.step = "1";
data.unit = "d";
std::filesystem::path filePath = absPath("${TESTDIR}/horizonsTest/horizonstest_4.hrz");
HorizonsResultCode expectedAnswerCode = HorizonsResultCode::ErrorNoObserver;
// Test Vector format
HorizonsType type = HorizonsType::Vector;
testHorizonsAnswer(data, type, filePath, expectedAnswerCode);
// Test Observer format
type = HorizonsType::Observer;
testHorizonsAnswer(data, type, filePath, expectedAnswerCode);
#endif // OPENSPACE_MODULE_SPACE_ENABLED
}
TEST_CASE("HorizonsFile: Observer and target same", "[horizonsfile]") {
#ifdef OPENSPACE_MODULE_SPACE_ENABLED
HorizonsTestData data;
data.observer = "500@4"; // Mars barycenter
data.target = "4"; // Mars barycenter
data.start = "2021-05-19 00:00:00";
data.stop = "2022-05-19 00:00:00";
data.step = "1";
data.unit = "d";
std::filesystem::path filePath = absPath("${TESTDIR}/horizonsTest/horizonstest_5.hrz");
HorizonsResultCode expectedAnswerCode = HorizonsResultCode::ErrorObserverTargetSame;
// This test is only for Observer type format
HorizonsType type = HorizonsType::Observer;
testHorizonsAnswer(data, type, filePath, expectedAnswerCode);
#endif // OPENSPACE_MODULE_SPACE_ENABLED
}
TEST_CASE("HorizonsFile: Multiple observer stations", "[horizonsfile]") {
#ifdef OPENSPACE_MODULE_SPACE_ENABLED
HorizonsTestData data;
data.observer = "l2";
data.target = "Tesla";
data.start = "2021-05-19 00:00:00";
data.stop = "2022-05-19 00:00:00";
data.step = "1";
data.unit = "d";
std::filesystem::path filePath = absPath("${TESTDIR}/horizonsTest/horizonstest_6.hrz");
HorizonsResultCode expectedAnswerCode = HorizonsResultCode::MultipleObserverStations;
// Test Vector format
HorizonsType type = HorizonsType::Vector;
testHorizonsAnswer(data, type, filePath, expectedAnswerCode);
// Test Observer format
type = HorizonsType::Observer;
testHorizonsAnswer(data, type, filePath, expectedAnswerCode);
#endif // OPENSPACE_MODULE_SPACE_ENABLED
}
// Test errors that are nat captured by the error field in the json result
TEST_CASE("HorizonsFile: Multiple observers", "[horizonsfile]") {
#ifdef OPENSPACE_MODULE_SPACE_ENABLED
HorizonsTestData data;
data.observer = "@mars";
data.target = "Tesla";
data.start = "2021-05-19 00:00:00";
data.stop = "2022-05-19 00:00:00";
data.step = "1";
data.unit = "d";
std::filesystem::path filePath = absPath("${TESTDIR}/horizonsTest/horizonstest_7.hrz");
HorizonsResultCode expectedAnswerCode = HorizonsResultCode::Valid;
HorizonsResultCode expectedResultCode = HorizonsResultCode::MultipleObserver;
// Test Vector format
HorizonsType type = HorizonsType::Vector;
testHorizonsAnswerAndResult(
data,
type,
filePath,
expectedAnswerCode,
expectedResultCode
);
// Test Observer format
type = HorizonsType::Observer;
testHorizonsAnswerAndResult(
data,
type,
filePath,
expectedAnswerCode,
expectedResultCode
);
#endif // OPENSPACE_MODULE_SPACE_ENABLED
}
TEST_CASE("HorizonsFile: No target", "[horizonsfile]") {
#ifdef OPENSPACE_MODULE_SPACE_ENABLED
HorizonsTestData data;
data.observer = "@ssb";
data.target = "abcdefghijkl";
data.start = "2021-05-20 00:00:00";
data.stop = "2022-05-20 00:00:00";
data.step = "1";
data.unit = "d";
std::filesystem::path filePath = absPath("${TESTDIR}/horizonsTest/horizonstest_8.hrz");
HorizonsResultCode expectedAnswerCode = HorizonsResultCode::Valid;
HorizonsResultCode expectedResultCode = HorizonsResultCode::ErrorNoTarget;
// Test Vector format
HorizonsType type = HorizonsType::Vector;
testHorizonsAnswerAndResult(
data,
type,
filePath,
expectedAnswerCode,
expectedResultCode
);
// Test Observer format
type = HorizonsType::Observer;
testHorizonsAnswerAndResult(
data,
type,
filePath,
expectedAnswerCode,
expectedResultCode
);
#endif // OPENSPACE_MODULE_SPACE_ENABLED
}
TEST_CASE("HorizonsFile: Multiple targets (major bodies)", "[horizonsfile]") {
#ifdef OPENSPACE_MODULE_SPACE_ENABLED
HorizonsTestData data;
data.observer = "@ssb";
data.target = "mars";
data.start = "2021-05-20 00:00:00";
data.stop = "2022-05-20 00:00:00";
data.step = "1";
data.unit = "d";
std::filesystem::path filePath = absPath("${TESTDIR}/horizonsTest/horizonstest_9.hrz");
HorizonsResultCode expectedAnswerCode = HorizonsResultCode::Valid;
HorizonsResultCode expectedResultCode = HorizonsResultCode::MultipleTarget;
// Test Vector format
HorizonsType type = HorizonsType::Vector;
testHorizonsAnswerAndResult(
data,
type,
filePath,
expectedAnswerCode,
expectedResultCode
);
// Test Observer format
type = HorizonsType::Observer;
testHorizonsAnswerAndResult(
data,
type,
filePath,
expectedAnswerCode,
expectedResultCode
);
#endif // OPENSPACE_MODULE_SPACE_ENABLED
}
TEST_CASE("HorizonsFile: Multiple targets (minor bodies case 1)", "[horizonsfile]") {
#ifdef OPENSPACE_MODULE_SPACE_ENABLED
HorizonsTestData data;
data.observer = "@ssb";
data.target = "DES = 141P;";
data.start = "2021-05-20 00:00:00";
data.stop = "2022-05-20 00:00:00";
data.step = "1";
data.unit = "d";
std::filesystem::path filePath = absPath("${TESTDIR}/horizonsTest/horizonstest_10.hrz");
HorizonsResultCode expectedAnswerCode = HorizonsResultCode::Valid;
HorizonsResultCode expectedResultCode = HorizonsResultCode::MultipleTarget;
// Test Vector format
HorizonsType type = HorizonsType::Vector;
testHorizonsAnswerAndResult(
data,
type,
filePath,
expectedAnswerCode,
expectedResultCode
);
// Test Observer format
type = HorizonsType::Observer;
testHorizonsAnswerAndResult(
data,
type,
filePath,
expectedAnswerCode,
expectedResultCode
);
#endif // OPENSPACE_MODULE_SPACE_ENABLED
}
TEST_CASE("HorizonsFile: Multiple targets (minor bodies case 2)", "[horizonsfile]") {
#ifdef OPENSPACE_MODULE_SPACE_ENABLED
HorizonsTestData data;
data.observer = "@ssb";
data.target = "borisov";
data.start = "2021-05-20 00:00:00";
data.stop = "2022-05-20 00:00:00";
data.step = "1";
data.unit = "d";
std::filesystem::path filePath = absPath("${TESTDIR}/horizonsTest/horizonstest_11.hrz");
HorizonsResultCode expectedAnswerCode = HorizonsResultCode::Valid;
HorizonsResultCode expectedResultCode = HorizonsResultCode::MultipleTarget;
// Test Vector format
HorizonsType type = HorizonsType::Vector;
testHorizonsAnswerAndResult(
data,
type,
filePath,
expectedAnswerCode,
expectedResultCode
);
// Test Observer format
type = HorizonsType::Observer;
testHorizonsAnswerAndResult(
data,
type,
filePath,
expectedAnswerCode,
expectedResultCode
);
#endif // OPENSPACE_MODULE_SPACE_ENABLED
}
TEST_CASE("HorizonsFile: Detect multiple observers or targets", "[horizonsfile]") {
#ifdef OPENSPACE_MODULE_SPACE_ENABLED
HorizonsTestData data;
data.observer = "@l2";
data.target = "90001048"; // 141P Machholz 2 epoch 2019
data.start = "2021-05-23 00:00:00";
data.stop = "2022-05-23 00:00:00";
data.step = "1";
data.unit = "d";
std::filesystem::path filePath = absPath("${TESTDIR}/horizonsTest/horizonstest_12.hrz");
HorizonsResultCode expectedAnswerCode = HorizonsResultCode::Valid;
HorizonsResultCode expectedResultCode = HorizonsResultCode::MultipleObserver;
// Test Vector format
HorizonsType type = HorizonsType::Vector;
testHorizonsAnswerAndResult(
data,
type,
filePath,
expectedAnswerCode,
expectedResultCode
);
// Test Observer format
type = HorizonsType::Observer;
testHorizonsAnswerAndResult(
data,
type,
filePath,
expectedAnswerCode,
expectedResultCode
);
#endif // OPENSPACE_MODULE_SPACE_ENABLED
}
TEST_CASE("HorizonsFile: Valid request and response", "[horizonsfile]") {
#ifdef OPENSPACE_MODULE_SPACE_ENABLED
HorizonsTestData data;
data.observer = "@ssb";
data.target = "Tesla";
data.start = "2022-05-22 00:00:00";
data.stop = "2022-05-23 00:00:00";
data.step = "12";
data.unit = "h";
std::filesystem::path filePathVector = absPath("${TESTDIR}/horizonsTest/validVectorFile.hrz");
std::filesystem::path filePathObserver = absPath("${TESTDIR}/horizonsTest/validObserverFile.hrz");
HorizonsResultCode expectedAnswerCode = HorizonsResultCode::Valid;
HorizonsResultCode expectedResultCode = HorizonsResultCode::Valid;
// Test Vector format
HorizonsType type = HorizonsType::Vector;
testHorizonsAnswerAndResult(
data,
type,
filePathVector,
expectedAnswerCode,
expectedResultCode,
false
);
// Test Observer format
type = HorizonsType::Observer;
testHorizonsAnswerAndResult(
data,
type,
filePathObserver,
expectedAnswerCode,
expectedResultCode,
false
);
#endif // OPENSPACE_MODULE_SPACE_ENABLED
}
// Test parsing of timeranges
// Since data can get updated this is tested towards stored files
TEST_CASE("HorizonsFile: Parsing time range with time", "[horizonsfile]") {
#ifdef OPENSPACE_MODULE_SPACE_ENABLED
std::filesystem::path filePath =
absPath("${TESTDIR}/horizonsTest/timerange_time.hrz");
HorizonsFile horizonsFile(filePath);
// Parse time range
std::pair<std::string, std::string> timeRange = horizonsFile.parseValidTimeRange(
"Trajectory files",
"************",
"Trajectory name"
);
CHECK(timeRange.first == "2005-Aug-12 T 12:42");
CHECK(timeRange.second == "2022-Sep-02 T 02:55");
#endif // OPENSPACE_MODULE_SPACE_ENABLED
}
TEST_CASE("HorizonsFile: Parsing time range without time", "[horizonsfile]") {
#ifdef OPENSPACE_MODULE_SPACE_ENABLED
std::filesystem::path filePath =
absPath("${TESTDIR}/horizonsTest/timerange_no_time.hrz");
HorizonsFile horizonsFile(filePath);
// Parse time range
std::pair<std::string, std::string> timeRange = horizonsFile.parseValidTimeRange(
"Trajectory files",
"************",
"Trajectory name",
false
);
CHECK(timeRange.first == "2013-Dec-19");
CHECK(timeRange.second == "2026-Sep-14");
#endif // OPENSPACE_MODULE_SPACE_ENABLED
}
// Test parsing of matches
// Since data can get updated this is tested towards stored files
TEST_CASE("HorizonsFile: Parsing multiple matching observers", "[horizonsfile]") {
#ifdef OPENSPACE_MODULE_SPACE_ENABLED
std::filesystem::path filePath =
absPath("${TESTDIR}/horizonsTest/parse_multiple_observers.hrz");
HorizonsFile horizonsFile(filePath);
// Parse matches
std::vector<std::string> matches =
horizonsFile.parseMatches("Name", "matches", ">MATCH NAME<");
REQUIRE(matches.size() == 3);
CHECK(matches[0] ==
" ID# Name Designation IAU/aliases/other "
);
CHECK(matches[1] ==
" 3 Earth-Moon Barycenter EMB "
);
CHECK(matches[2] ==
" 399 Earth Geocenter "
);
#endif // OPENSPACE_MODULE_SPACE_ENABLED
}
TEST_CASE("HorizonsFile: Parsing multiple matching targets", "[horizonsfile]") {
#ifdef OPENSPACE_MODULE_SPACE_ENABLED
std::filesystem::path filePath =
absPath("${TESTDIR}/horizonsTest/parse_multiple_targets.hrz");
HorizonsFile horizonsFile(filePath);
// Parse matches
std::vector<std::string> matches =
horizonsFile.parseMatches("Name", "matches", ">MATCH NAME<");
REQUIRE(matches.size() == 11);
CHECK(matches[0] ==
" ID# Name Designation IAU/aliases/other "
);
CHECK(matches[1] ==
" 4 Mars Barycenter "
);
CHECK(matches[2] ==
" 499 Mars "
);
CHECK(matches[3] ==
" -3 Mars Orbiter Mission (MOM) (spacec Mangalyaan "
);
CHECK(matches[4] ==
" -41 Mars Express (spacecraft) MEX "
);
CHECK(matches[5] ==
" -53 Mars Odyssey (spacecraft) "
);
CHECK(matches[6] ==
" -530 Mars Pathfinder (spacecraft) MPF "
);
CHECK(matches[7] ==
" -74 Mars Reconnaissance Orbiter (space MRO "
);
CHECK(matches[8] ==
" -76 Mars Science Laboratory (spacecraf Curiosity MSL "
);
CHECK(matches[9] ==
" -143 ExoMars16 TGO (spacecraft) "
);
CHECK(matches[10] ==
" -168 Mars2020 (spacecraft) Perserverance Ingenu "
);
#endif // OPENSPACE_MODULE_SPACE_ENABLED
}
TEST_CASE("HorizonsFile: Parsing multiple matching stations", "[horizonsfile]") {
#ifdef OPENSPACE_MODULE_SPACE_ENABLED
std::filesystem::path filePath =
absPath("${TESTDIR}/horizonsTest/parse_multiple_stations.hrz");
CHECK(std::filesystem::is_regular_file(filePath));
HorizonsFile horizonsFile(filePath);
// Parse matches
std::vector<std::string> matches =
horizonsFile.parseMatches("Observatory Name", "Multiple matching stations found");
REQUIRE(matches.size() == 11);
CHECK(matches[0] ==
" # E. Lon DXY DZ Observatory Name"
);
CHECK(matches[1] ==
" L20 18.3207 +308014 +293859 AG_Sarajevo Observatory, Sarajevo"
);
CHECK(matches[2] ==
" L21 27.4213 +307050 +294814 Ostrov Observatory, Constanta"
);
CHECK(matches[3] ==
" L22 27.6695 +295446 +306365 Barlad Observatory"
);
CHECK(matches[4] ==
" L23 27.8319 +299346 +302574 Schela"
);
CHECK(matches[5] ==
" L24 27.9289 +383214 -186499 Gauteng"
);
CHECK(matches[6] ==
" L25 14.4374 +255033 +340528 Smolecin"
);
CHECK(matches[7] ==
" L26 11.8102 +316937 +284229 Sanderphil Urban Obs., Civitavecchia"
);
CHECK(matches[8] ==
" L27 5.6470 +307222 +294693 29PREMOTE Obs., Dauban {Soulier]"
);
CHECK(matches[9] ==
" L28 15.4634 +323190 +277274 ISON-Castelgrande Observatory"
);
CHECK(matches[10] ==
" L29 18.0169 +391400 -168725 Drebach-South Observatory, Windhoek"
);
#endif // OPENSPACE_MODULE_SPACE_ENABLED
}
// Test reading of data and compare a recent request with a stored file
TEST_CASE("HorizonsFile: Reading Vector data from request", "[horizonsfile]") {
#ifdef OPENSPACE_MODULE_SPACE_ENABLED
HorizonsType type = HorizonsType::Vector;
std::filesystem::path filePathVector =
absPath("${TESTDIR}/horizonsTest/validVectorFile.hrz");
const double t0 = 706449669.18513119;
const double x0 = -126379670172.70331;
const double y0 = 63049830070.652786;
const double z0 = -126710964556.55870;
const double t1 = 706492869.18512082;
const double x1 = -127019567853.94952;
const double y1 = 62510445746.414017;
const double z1 = -125904395646.64995;
const double t2 = 706536069.18511045;
const double x2 = -127654909093.56494;
const double y2 = 61968790989.645737;
const double z2 = -125093260079.10854;
testReadingHorizons(
type, filePathVector,
t0, x0, y0, z0,
t1, x1, y1, z1,
t2, x2, y2, z2
);
// Clean up
std::filesystem::remove(filePathVector);
CHECK(!std::filesystem::is_regular_file(filePathVector));
#endif // OPENSPACE_MODULE_SPACE_ENABLED
}
TEST_CASE("HorizonsFile: Reading Observer data from request", "[horizonsfile]") {
#ifdef OPENSPACE_MODULE_SPACE_ENABLED
HorizonsType type = HorizonsType::Observer;
std::filesystem::path filePathObserver =
absPath("${TESTDIR}/horizonsTest/validObserverFile.hrz");
const double t0 = 706449669.18513119;
const double x0 = -126371142157.29857;
const double y0 = 63056923889.044579;
const double z0 = -126721572150.18513;
const double t1 = 706492869.18512082;
const double x1 = -127011112787.76295;
const double y1 = 62517559574.749786;
const double z1 = -125915045896.36182;
const double t2 = 706536069.18511045;
const double x2 = -127646529740.40393;
const double y2 = 61975921972.090714;
const double z2 = -125103951590.60988;
testReadingHorizons(
type, filePathObserver,
t0, x0, y0, z0,
t1, x1, y1, z1,
t2, x2, y2, z2
);
// Clean up
std::filesystem::remove(filePathObserver);
CHECK(!std::filesystem::is_regular_file(filePathObserver));
#endif // OPENSPACE_MODULE_SPACE_ENABLED
}
TEST_CASE("HorizonsFile: Reading Vector data from file", "[horizonsfile]") {
#ifdef OPENSPACE_MODULE_SPACE_ENABLED
HorizonsType type = HorizonsType::Vector;
std::filesystem::path filePathVector =
absPath("${TESTDIR}/horizonsTest/vectorFileTest.hrz");
const double t0 = 706449669.18513119;
const double x0 = -126379670172.70331;
const double y0 = 63049830070.652786;
const double z0 = -126710964556.55870;
const double t1 = 706492869.18512082;
const double x1 = -127019567853.94952;
const double y1 = 62510445746.414017;
const double z1 = -125904395646.64995;
const double t2 = 706536069.18511045;
const double x2 = -127654909093.56494;
const double y2 = 61968790989.645737;
const double z2 = -125093260079.10854;
testReadingHorizons(
type, filePathVector,
t0, x0, y0, z0,
t1, x1, y1, z1,
t2, x2, y2, z2
);
#endif // OPENSPACE_MODULE_SPACE_ENABLED
}
TEST_CASE("HorizonsFile: Reading Observer data from file", "[horizonsfile]") {
#ifdef OPENSPACE_MODULE_SPACE_ENABLED
HorizonsType type = HorizonsType::Observer;
std::filesystem::path filePathObserver =
absPath("${TESTDIR}/horizonsTest/observerFileTest.hrz");
const double t0 = 706449669.18513119;
const double x0 = -126371142157.29857;
const double y0 = 63056923889.044579;
const double z0 = -126721572150.18513;
const double t1 = 706492869.18512082;
const double x1 = -127011112787.76295;
const double y1 = 62517559574.749786;
const double z1 = -125915045896.36182;
const double t2 = 706536069.18511045;
const double x2 = -127646529740.40393;
const double y2 = 61975921972.090714;
const double z2 = -125103951590.60988;
testReadingHorizons(
type, filePathObserver,
t0, x0, y0, z0,
t1, x1, y1, z1,
t2, x2, y2, z2
);
#endif // OPENSPACE_MODULE_SPACE_ENABLED
}