// SPDX-FileCopyrightText: 2024 Filip Leonarski, Paul Scherrer Institute // SPDX-License-Identifier: GPL-3.0-only #include #include "../common/DetectorSetup.h" #include "../common/NetworkAddressConvert.h" TEST_CASE("DetectorSetup_MismatchInSize") { REQUIRE_THROWS(DetectorSetup(DetectorGeometry(8), DetectorType::JUNGFRAU, "JF", {"mx1","mx2","mx3","mx4"})); REQUIRE_THROWS(DetectorSetup(DetectorGeometry(2), DetectorType::JUNGFRAU, "JF", {"mx1","mx2","mx3","mx4"})); REQUIRE_NOTHROW(DetectorSetup(DetectorGeometry(4), DetectorType::JUNGFRAU, "JF", {"mx1","mx2","mx3","mx4"})); } TEST_CASE("DetectorSetup_ProtoBuf") { DetectorSetup setup(DetectorGeometry(4), DetectorType::JUNGFRAU, "JF", {"mx1","mx2","mx3","mx4"}); REQUIRE(setup.GetDescription() == "JF"); REQUIRE(setup.GetDetectorModuleHostname().size() == 4); REQUIRE(setup.GetDetectorModuleHostname()[3] == "mx4"); REQUIRE(setup.GetPixelSize_mm() == Catch::Approx(0.075)); REQUIRE(setup.GetModulesNum() == 4); REQUIRE(setup.GetGeometry().GetModulesNum() == 4); } TEST_CASE("DetectorSetup_ProtoBuf_FullSpeed") { DetectorSetup setup(DetectorGeometry(4), DetectorType::JUNGFRAU, "JF", {"mx1","mx2","mx3","mx4"}); REQUIRE(setup.GetUDPInterfaceCount() == 2); REQUIRE_NOTHROW(setup.UDPInterfaceCount(1)); REQUIRE_THROWS(setup.UDPInterfaceCount(0)); REQUIRE_THROWS(setup.UDPInterfaceCount(5)); REQUIRE_THROWS(setup.UDPInterfaceCount(-56)); REQUIRE(setup.GetUDPInterfaceCount() == 1); } TEST_CASE("DetectorSetup_IPv4Base_2Interfaces") { DetectorSetup detector(DetectorGeometry(2)); detector.UDPInterfaceCount(2); REQUIRE_NOTHROW(detector.BaseIPv4Addr("64.1.124.1")); REQUIRE(detector.GetSrcIPv4Addr(0) == IPv4AddressFromStr("64.1.124.1")); REQUIRE(detector.GetSrcIPv4Addr(1) == IPv4AddressFromStr("64.1.124.2")); REQUIRE(detector.GetSrcIPv4Addr(3) == IPv4AddressFromStr("64.1.124.4")); REQUIRE_THROWS(detector.GetSrcIPv4Addr(4)); } TEST_CASE("DetectorSetup_IPv4Base_1Interface") { DetectorSetup detector(DetectorGeometry(4)); detector.UDPInterfaceCount(1); REQUIRE_NOTHROW(detector.BaseIPv4Addr("64.1.124.1")); REQUIRE(detector.GetSrcIPv4Addr(0) == IPv4AddressFromStr("64.1.124.1")); REQUIRE(detector.GetSrcIPv4Addr(1) == IPv4AddressFromStr("64.1.124.2")); REQUIRE(detector.GetSrcIPv4Addr(3) == IPv4AddressFromStr("64.1.124.4")); REQUIRE_THROWS(detector.GetSrcIPv4Addr(4)); } TEST_CASE("DetectorSetup_LoadGainFile") { DetectorSetup setup(DetectorGeometry(4), DetectorType::JUNGFRAU, "JF", {"mx1","mx2","mx3","mx4"}); REQUIRE_THROWS(setup.LoadGain({})); REQUIRE(setup.GetGainCalibration().empty()); REQUIRE_THROWS(setup.LoadGain({ "../../tests/test_data/gainMaps_M049.bin", "../../tests/test_data/gainMaps_M049.bin", "../../tests/test_data/gainMaps_M049.bin" })); REQUIRE_THROWS(setup.LoadGain({ "../../tests/test_data/gainMaps_M049.bin", "../../tests/test_data/gainMaps_M049.bin", "../../tests/test_data/gainMaps_M049.bin", "../../tests/test_data/gainMaps_M049.bin", "../../tests/test_data/gainMaps_M049.bin" })); REQUIRE_NOTHROW(setup.LoadGain({ "../../tests/test_data/gainMaps_M049.bin", "../../tests/test_data/gainMaps_M049.bin", "../../tests/test_data/gainMaps_M049.bin", "../../tests/test_data/gainMaps_M049.bin" })); REQUIRE(setup.GetGainCalibration().size() == 4); }