#include "CmdProxy.h" #include "Detector.h" #include "catch.hpp" #include "sls_detector_defs.h" #include #include #include #include "tests/globals.h" using sls::CmdProxy; using sls::Detector; using test::GET; using test::PUT; TEST_CASE("Unknown command", "[.cmd]") { Detector det; CmdProxy proxy(&det); REQUIRE_THROWS(proxy.Call("vsaevrreavv", {}, -1, PUT)); } /* configuration */ TEST_CASE("config", "[.cmd][.new]") { Detector det; CmdProxy proxy(&det); // put only REQUIRE_THROWS(proxy.Call("config", {}, -1, GET)); } // free: not testing TEST_CASE("parameters", "[.cmd][.new]") { Detector det; CmdProxy proxy(&det); // put only REQUIRE_THROWS(proxy.Call("parameters", {}, -1, GET)); /* auto prev_val = det.getNumberOfFrames().tsquash("Number of frames has to be same to test"); { system("echo 'frames 2' > /tmp/tempsetup.det "); std::ostringstream oss; proxy.Call("parameters", {"/tmp/tempsetup.det"}, -1, PUT, oss); REQUIRE(oss.str() == "parameters /tmp/tempsetup.det\n"); REQUIRE(det.getNumberOfFrames().tsquash("failed") == 2); } { system("echo '0:frames 1' > /tmp/tempsetup.det "); std::ostringstream oss; proxy.Call("parameters", {"/tmp/tempsetup.det"}, -1, PUT, oss); REQUIRE(oss.str() == "parameters /tmp/tempsetup.det\n"); REQUIRE(det.getNumberOfFrames({0}).tsquash("failed") == 1); } det.setNumberOfFrames(prev_val); */ } TEST_CASE("hostname", "[.cmd][.new]") { Detector det; CmdProxy proxy(&det); REQUIRE_NOTHROW(proxy.Call("hostname", {}, -1, GET)); } // virtual: not testing TEST_CASE("versions", "[.cmd][.new]") { Detector det; CmdProxy proxy(&det); REQUIRE_NOTHROW(proxy.Call("versions", {}, -1, GET)); REQUIRE_THROWS(proxy.Call("versions", {"0"}, -1, PUT)); } TEST_CASE("packageversion", "[.cmd][.new]") { Detector det; CmdProxy proxy(&det); REQUIRE_NOTHROW(proxy.Call("packageversion", {}, -1, GET)); REQUIRE_THROWS(proxy.Call("packageversion", {"0"}, -1, PUT)); } TEST_CASE("clientversion", "[.cmd][.new]") { Detector det; CmdProxy proxy(&det); REQUIRE_NOTHROW(proxy.Call("clientversion", {}, -1, GET)); REQUIRE_THROWS(proxy.Call("clientversion", {"0"}, -1, PUT)); } TEST_CASE("firmwareversion", "[.cmd][.new]") { Detector det; CmdProxy proxy(&det); REQUIRE_NOTHROW(proxy.Call("firmwareversion", {}, -1, GET)); REQUIRE_THROWS(proxy.Call("firmwareversion", {"0"}, -1, PUT)); } TEST_CASE("detectorserverversion", "[.cmd][.new]") { Detector det; CmdProxy proxy(&det); REQUIRE_NOTHROW(proxy.Call("detectorserverversion", {}, -1, GET)); REQUIRE_THROWS(proxy.Call("detectorserverversion", {"0"}, -1, PUT)); } TEST_CASE("detectornumber", "[.cmd][.new]") { Detector det; CmdProxy proxy(&det); REQUIRE_NOTHROW(proxy.Call("detectornumber", {}, -1, GET)); REQUIRE_THROWS(proxy.Call("detectornumber", {"0"}, -1, PUT)); } TEST_CASE("type", "[.cmd][.new]") { Detector det; CmdProxy proxy(&det); auto dt = det.getDetectorType().squash(); std::ostringstream oss; proxy.Call("type", {}, -1, GET, oss); auto ans = oss.str().erase(0, strlen("type ")); REQUIRE(ans == sls::ToString(dt) + '\n'); REQUIRE(dt == test::type); } TEST_CASE("detsize", "[.cmd][.new]") { Detector det; CmdProxy proxy(&det); REQUIRE_NOTHROW(proxy.Call("detsize", {}, -1, GET)); } TEST_CASE("settings", "[.cmd][.new]") { Detector det; CmdProxy proxy(&det); auto det_type = det.getDetectorType().squash(); std::vector sett; switch (det_type) { case defs::EIGER: // FIXME: need to remove when settings removed break; case defs::JUNGFRAU: sett.push_back("dynamicgain"); sett.push_back("dynamichg0"); sett.push_back("fixgain1"); sett.push_back("fixgain2"); sett.push_back("forceswitchg1"); sett.push_back("forceswitchg2"); break; case defs::GOTTHARD: sett.push_back("highgain"); sett.push_back("dynamicgain"); sett.push_back("lowgain"); sett.push_back("mediumgain"); sett.push_back("veryhighgain"); break; case defs::GOTTHARD2: sett.push_back("dynamicgain"); sett.push_back("fixgain1"); sett.push_back("fixgain2"); break; case defs::MOENCH: sett.push_back("g1_hg"); sett.push_back("g1_lg"); sett.push_back("g2_hc_hg"); sett.push_back("g2_hc_lg"); sett.push_back("g2_lc_hg"); sett.push_back("g2_lc_lg"); sett.push_back("g4_hg"); sett.push_back("g4_lg"); break; default: REQUIRE_THROWS(proxy.Call("settings", {}, -1, GET)); return; } auto prev_val = det.getSettings(); for (auto &it : sett) { { std::ostringstream oss; proxy.Call("settings", {it}, -1, PUT, oss); REQUIRE(oss.str() == "settings " + it + "\n"); } { std::ostringstream oss; proxy.Call("settings", {}, -1, GET, oss); REQUIRE(oss.str() == "settings " + it + "\n"); } } for (int i = 0; i != det.size(); ++i) { if (prev_val[i] != defs::UNDEFINED && prev_val[i] != defs::UNINITIALIZED) { det.setSettings(prev_val[i], {i}); } } } TEST_CASE("trimbits", "[.cmd][.new]") { Detector det; CmdProxy proxy(&det); REQUIRE_NOTHROW(proxy.Call("trimbits", {}, -1, GET)); } TEST_CASE("trimval", "[.cmd][.new]") { Detector det; CmdProxy proxy(&det); auto det_type = det.getDetectorType().squash(); if (det_type == defs::MYTHEN3 || det_type == defs::EIGER) { auto prev_val = det.getAllTrimbits(); { std::ostringstream oss; proxy.Call("trimval", {"63"}, -1, PUT, oss); REQUIRE(oss.str() == "trimval 63\n"); } { std::ostringstream oss; proxy.Call("trimval", {"0"}, -1, PUT, oss); REQUIRE(oss.str() == "trimval 0\n"); } { std::ostringstream oss; proxy.Call("trimval", {}, -1, GET, oss); REQUIRE(oss.str() == "trimval 0\n"); } REQUIRE_THROWS(proxy.Call("trimval", {"64"}, -1, PUT)); REQUIRE_THROWS(proxy.Call("trimval", {"-1"}, -1, PUT)); for (int i = 0; i != det.size(); ++i) { if (prev_val[i] != -1) { det.setAllTrimbits(prev_val[i], {i}); } } } else { REQUIRE_THROWS(proxy.Call("trimval", {}, -1, GET)); } } /* acquisition parameters */ // acquire: not testing TEST_CASE("frames", "[.cmd][.new]") { Detector det; CmdProxy proxy(&det); auto prev_val = det.getNumberOfFrames().tsquash("#frames must be same to test"); { std::ostringstream oss; proxy.Call("frames", {"1000"}, -1, PUT, oss); REQUIRE(oss.str() == "frames 1000\n"); } { std::ostringstream oss; proxy.Call("frames", {}, -1, GET, oss); REQUIRE(oss.str() == "frames 1000\n"); } { std::ostringstream oss; proxy.Call("frames", {"1"}, -1, PUT, oss); REQUIRE(oss.str() == "frames 1\n"); } REQUIRE_THROWS(proxy.Call("frames", {"0"}, -1, PUT)); det.setNumberOfFrames(prev_val); } TEST_CASE("triggers", "[.cmd][.new]") { Detector det; CmdProxy proxy(&det); auto prev_val = det.getNumberOfTriggers().tsquash("#triggers must be same to test"); { std::ostringstream oss; proxy.Call("triggers", {"1000"}, -1, PUT, oss); REQUIRE(oss.str() == "triggers 1000\n"); } { std::ostringstream oss; proxy.Call("triggers", {}, -1, GET, oss); REQUIRE(oss.str() == "triggers 1000\n"); } { std::ostringstream oss; proxy.Call("triggers", {"1"}, -1, PUT, oss); REQUIRE(oss.str() == "triggers 1\n"); } REQUIRE_THROWS(proxy.Call("triggers", {"0"}, -1, PUT)); det.setNumberOfTriggers(prev_val); } TEST_CASE("exptime", "[.cmd][.new]") { Detector det; CmdProxy proxy(&det); auto prev_val = det.getExptime(); { std::ostringstream oss; proxy.Call("exptime", {"0.05"}, -1, PUT, oss); REQUIRE(oss.str() == "exptime 0.05\n"); } { std::ostringstream oss; proxy.Call("exptime", {}, -1, GET, oss); REQUIRE(oss.str() == "exptime 50ms\n"); } { std::ostringstream oss; proxy.Call("exptime", {"1s"}, -1, PUT, oss); REQUIRE(oss.str() == "exptime 1s\n"); } { std::ostringstream oss; proxy.Call("exptime", {"0"}, -1, PUT, oss); REQUIRE(oss.str() == "exptime 0\n"); } for (int i = 0; i != det.size(); ++i) { det.setExptime(prev_val[i], {i}); } } TEST_CASE("period", "[.cmd][.new]") { Detector det; CmdProxy proxy(&det); auto prev_val = det.getPeriod(); { std::ostringstream oss; proxy.Call("period", {"1.25s"}, -1, PUT, oss); REQUIRE(oss.str() == "period 1.25s\n"); } { std::ostringstream oss; proxy.Call("period", {}, -1, GET, oss); REQUIRE(oss.str() == "period 1.25s\n"); } { std::ostringstream oss; proxy.Call("period", {"0"}, -1, PUT, oss); REQUIRE(oss.str() == "period 0\n"); } for (int i = 0; i != det.size(); ++i) { det.setPeriod(prev_val[i], {i}); } } TEST_CASE("delay", "[.cmd][.new]") { Detector det; CmdProxy proxy(&det); auto det_type = det.getDetectorType().squash(); if (det_type == defs::EIGER) { REQUIRE_THROWS(proxy.Call("delay", {"1"}, -1, PUT)); REQUIRE_THROWS(proxy.Call("delay", {}, -1, GET)); } else if (det_type == defs::GOTTHARD) { // extra delays for master (can throw when setting) REQUIRE_NOTHROW(proxy.Call("delay", {}, -1, GET)); } else { auto prev_val = det.getDelayAfterTrigger(); { std::ostringstream oss; proxy.Call("delay", {"1.25s"}, -1, PUT, oss); REQUIRE(oss.str() == "delay 1.25s\n"); } { std::ostringstream oss; proxy.Call("delay", {}, -1, GET, oss); REQUIRE(oss.str() == "delay 1.25s\n"); } { std::ostringstream oss; proxy.Call("delay", {"0s"}, -1, PUT, oss); REQUIRE(oss.str() == "delay 0s\n"); } for (int i = 0; i != det.size(); ++i) { det.setDelayAfterTrigger(prev_val[i], {i}); } } } TEST_CASE("framesl", "[.cmd][.new]") { Detector det; CmdProxy proxy(&det); auto det_type = det.getDetectorType().squash(); if (det_type == defs::EIGER) { REQUIRE_THROWS(proxy.Call("framesl", {}, -1, GET)); } else { REQUIRE_NOTHROW(proxy.Call("framesl", {}, -1, GET)); } } TEST_CASE("triggersl", "[.cmd][.new]") { Detector det; CmdProxy proxy(&det); auto det_type = det.getDetectorType().squash(); if (det_type == defs::EIGER) { REQUIRE_THROWS(proxy.Call("triggersl", {}, -1, GET)); } else { REQUIRE_NOTHROW(proxy.Call("triggersl", {}, -1, GET)); } } TEST_CASE("delayl", "[.cmd][.new]") { Detector det; CmdProxy proxy(&det); auto det_type = det.getDetectorType().squash(); if (det_type == defs::EIGER) { REQUIRE_THROWS(proxy.Call("delayl", {}, -1, GET)); } else { REQUIRE_NOTHROW(proxy.Call("delayl", {}, -1, GET)); } } TEST_CASE("periodl", "[.cmd][.new]") { Detector det; CmdProxy proxy(&det); auto det_type = det.getDetectorType().squash(); if (det_type == defs::EIGER) { REQUIRE_THROWS(proxy.Call("periodl", {}, -1, GET)); } else { REQUIRE_NOTHROW(proxy.Call("periodl", {}, -1, GET)); } } TEST_CASE("timing", "[.cmd][.new]") { Detector det; CmdProxy proxy(&det); auto prev_val = det.getTimingMode(); det.setTimingMode(defs::AUTO_TIMING); { std::ostringstream oss1, oss2; proxy.Call("timing", {"auto"}, -1, PUT, oss1); REQUIRE(oss1.str() == "timing auto\n"); proxy.Call("timing", {}, -1, GET, oss2); REQUIRE(oss2.str() == "timing auto\n"); } { std::ostringstream oss1, oss2; proxy.Call("timing", {"trigger"}, -1, PUT, oss1); REQUIRE(oss1.str() == "timing trigger\n"); proxy.Call("timing", {}, -1, GET, oss2); REQUIRE(oss2.str() == "timing trigger\n"); } auto det_type = det.getDetectorType().squash(); if (det_type == defs::EIGER) { { std::ostringstream oss1, oss2; proxy.Call("timing", {"gating"}, -1, PUT, oss1); REQUIRE(oss1.str() == "timing gating\n"); proxy.Call("timing", {}, -1, GET, oss2); REQUIRE(oss2.str() == "timing gating\n"); } { std::ostringstream oss1, oss2; proxy.Call("timing", {"burst_trigger"}, -1, PUT, oss1); REQUIRE(oss1.str() == "timing burst_trigger\n"); proxy.Call("timing", {}, -1, GET, oss2); REQUIRE(oss2.str() == "timing burst_trigger\n"); } REQUIRE_THROWS(proxy.Call("timing", {"trigger_gating"}, -1, PUT)); } else if (det_type == defs::MYTHEN3) { { std::ostringstream oss1, oss2; proxy.Call("timing", {"gating"}, -1, PUT, oss1); REQUIRE(oss1.str() == "timing gating\n"); proxy.Call("timing", {}, -1, GET, oss2); REQUIRE(oss2.str() == "timing gating\n"); } { std::ostringstream oss1, oss2; proxy.Call("timing", {"trigger_gating"}, -1, PUT, oss1); REQUIRE(oss1.str() == "timing trigger_gating\n"); proxy.Call("timing", {}, -1, GET, oss2); REQUIRE(oss2.str() == "timing trigger_gating\n"); } REQUIRE_THROWS(proxy.Call("timing", {"burst_trigger"}, -1, PUT)); } else { REQUIRE_THROWS(proxy.Call("timing", {"gating"}, -1, PUT)); REQUIRE_THROWS(proxy.Call("timing", {"burst_trigger"}, -1, PUT)); REQUIRE_THROWS(proxy.Call("timing", {"trigger_gating"}, -1, PUT)); } for (int i = 0; i != det.size(); ++i) { det.setTimingMode(prev_val[i], {i}); } } TEST_CASE("speed", "[.cmd][.new]") { Detector det; CmdProxy proxy(&det); auto det_type = det.getDetectorType().squash(); if (det_type == defs::EIGER || det_type == defs::JUNGFRAU) { auto prev_val = det.getSpeed(); // full speed for jungfrau only works for new boards /* { std::ostringstream oss1, oss2, oss3, oss4; proxy.Call("speed", {"0"}, -1, PUT, oss1); REQUIRE(oss1.str() == "speed full_speed\n"); proxy.Call("speed", {}, -1, GET, oss2); REQUIRE(oss2.str() == "speed full_speed\n"); proxy.Call("speed", {"full_speed"}, -1, PUT, oss3); REQUIRE(oss3.str() == "speed full_speed\n"); proxy.Call("speed", {}, -1, GET, oss4); REQUIRE(oss4.str() == "speed full_speed\n"); } */ { std::ostringstream oss1, oss2, oss3, oss4; proxy.Call("speed", {"1"}, -1, PUT, oss1); REQUIRE(oss1.str() == "speed half_speed\n"); proxy.Call("speed", {}, -1, GET, oss2); REQUIRE(oss2.str() == "speed half_speed\n"); proxy.Call("speed", {"half_speed"}, -1, PUT, oss3); REQUIRE(oss3.str() == "speed half_speed\n"); proxy.Call("speed", {}, -1, GET, oss4); REQUIRE(oss4.str() == "speed half_speed\n"); } { std::ostringstream oss1, oss2, oss3, oss4; proxy.Call("speed", {"2"}, -1, PUT, oss1); REQUIRE(oss1.str() == "speed quarter_speed\n"); proxy.Call("speed", {}, -1, GET, oss2); REQUIRE(oss2.str() == "speed quarter_speed\n"); proxy.Call("speed", {"quarter_speed"}, -1, PUT, oss3); REQUIRE(oss3.str() == "speed quarter_speed\n"); proxy.Call("speed", {}, -1, GET, oss4); REQUIRE(oss4.str() == "speed quarter_speed\n"); } for (int i = 0; i != det.size(); ++i) { det.setSpeed(prev_val[i], {i}); } } else { REQUIRE_THROWS(proxy.Call("speed", {"0"}, -1, PUT)); REQUIRE_THROWS(proxy.Call("speed", {}, -1, GET)); } } TEST_CASE("adcphase", "[.cmd][.new]") { Detector det; CmdProxy proxy(&det); auto det_type = det.getDetectorType().squash(); if (det_type == defs::GOTTHARD || det_type == defs::JUNGFRAU || det_type == defs::CHIPTESTBOARD || det_type == defs::MOENCH) { if (det_type == defs::GOTTHARD) { std::ostringstream oss1; proxy.Call("adcphase", {"20"}, -1, PUT, oss1); REQUIRE(oss1.str() == "adcphase 20\n"); // cant get, cant use deg REQUIRE_THROWS(proxy.Call("adcphase", {}, -1, GET)); REQUIRE_THROWS(proxy.Call("adcphase", {"20", "deg"}, -1, PUT)); } else { auto prev_val = det.getADCPhase(); { std::ostringstream oss1, oss2; proxy.Call("adcphase", {"20"}, -1, PUT, oss1); REQUIRE(oss1.str() == "adcphase 20\n"); proxy.Call("adcphase", {}, -1, GET, oss2); REQUIRE(oss2.str() == "adcphase 20\n"); } { std::ostringstream oss1, oss2; proxy.Call("adcphase", {"20", "deg"}, -1, PUT, oss1); REQUIRE(oss1.str() == "adcphase 20 deg\n"); proxy.Call("adcphase", {"deg"}, -1, GET, oss2); REQUIRE(oss2.str() == "adcphase 20 deg\n"); } for (int i = 0; i != det.size(); ++i) { det.setADCPhase(prev_val[i], {i}); } } } else { REQUIRE_THROWS(proxy.Call("adcphase", {"0"}, -1, PUT)); REQUIRE_THROWS(proxy.Call("adcphase", {}, -1, GET)); } } TEST_CASE("maxadcphaseshift", "[.cmd][.new]") { Detector det; CmdProxy proxy(&det); auto det_type = det.getDetectorType().squash(); if (det_type == defs::JUNGFRAU || det_type == defs::CHIPTESTBOARD || det_type == defs::MOENCH || det_type == defs::MYTHEN3 || // only because clk index of 0 exists det_type == defs::GOTTHARD2) { // only because clk index of 0 exists REQUIRE_NOTHROW(proxy.Call("maxadcphaseshift", {}, -1, GET)); } else { REQUIRE_THROWS(proxy.Call("maxadcphaseshift", {}, -1, GET)); } } TEST_CASE("dbitphase", "[.cmd][.new]") { Detector det; CmdProxy proxy(&det); auto det_type = det.getDetectorType().squash(); if (det_type == defs::JUNGFRAU || det_type == defs::CHIPTESTBOARD) { auto prev_val = det.getDBITPhase(); { std::ostringstream oss1, oss2; proxy.Call("dbitphase", {"20"}, -1, PUT, oss1); REQUIRE(oss1.str() == "dbitphase 20\n"); proxy.Call("dbitphase", {}, -1, GET, oss2); REQUIRE(oss2.str() == "dbitphase 20\n"); } { std::ostringstream oss1, oss2; proxy.Call("dbitphase", {"20", "deg"}, -1, PUT, oss1); REQUIRE(oss1.str() == "dbitphase 20 deg\n"); proxy.Call("dbitphase", {"deg"}, -1, GET, oss2); REQUIRE(oss2.str() == "dbitphase 20 deg\n"); } for (int i = 0; i != det.size(); ++i) { det.setDBITPhase(prev_val[i], {i}); } } else { REQUIRE_THROWS(proxy.Call("dbitphase", {"0"}, -1, PUT)); REQUIRE_THROWS(proxy.Call("dbitphase", {}, -1, GET)); } } TEST_CASE("maxdbitphaseshift", "[.cmd][.new]") { Detector det; CmdProxy proxy(&det); auto det_type = det.getDetectorType().squash(); if (det_type == defs::JUNGFRAU || det_type == defs::CHIPTESTBOARD || det_type == defs::MYTHEN3 || // only because clk index of 0 exists det_type == defs::GOTTHARD2) { // only because clk index of 0 exists REQUIRE_NOTHROW(proxy.Call("maxdbitphaseshift", {}, -1, GET)); } else { REQUIRE_THROWS(proxy.Call("maxdbitphaseshift", {}, -1, GET)); } } TEST_CASE("clkfreq", "[.cmd][.new]") { Detector det; CmdProxy proxy(&det); auto det_type = det.getDetectorType().squash(); if (det_type == defs::MYTHEN3 || det_type == defs::GOTTHARD2) { REQUIRE_THROWS(proxy.Call("clkfreq", {"0", "2"}, -1, PUT)); REQUIRE_THROWS(proxy.Call("clkfreq", {}, -1, GET)); REQUIRE_THROWS(proxy.Call("clkfreq", {"7"}, -1, GET)); REQUIRE_NOTHROW(proxy.Call("clkfreq", {"0"}, -1, GET)); } else { REQUIRE_THROWS(proxy.Call("clkfreq", {"0"}, -1, GET)); } } TEST_CASE("clkphase", "[.cmd][.new]") { Detector det; CmdProxy proxy(&det); auto det_type = det.getDetectorType().squash(); if (det_type == defs::MYTHEN3 || det_type == defs::GOTTHARD2) { REQUIRE_THROWS(proxy.Call("clkphase", {}, -1, GET)); REQUIRE_THROWS(proxy.Call("clkphase", {"7"}, -1, GET)); REQUIRE_THROWS(proxy.Call("clkphase", {"4"}, -1, PUT)); REQUIRE_THROWS(proxy.Call("clkphase", {"7", "4"}, -1, PUT)); auto prev_val = det.getClockPhase(0); { std::ostringstream oss1, oss2; proxy.Call("clkphase", {"0", "20"}, -1, PUT, oss1); REQUIRE(oss1.str() == "clkphase 20\n"); proxy.Call("clkphase", {"0"}, -1, GET, oss2); REQUIRE(oss2.str() == "clkphase 20\n"); } std::string s_deg_val = "15"; if (det_type == defs::MYTHEN3) { s_deg_val = "14"; } { std::ostringstream oss1, oss2; proxy.Call("clkphase", {"0", s_deg_val, "deg"}, -1, PUT, oss1); REQUIRE(oss1.str() == "clkphase " + s_deg_val + " deg\n"); proxy.Call("clkphase", {"0", "deg"}, -1, GET, oss2); REQUIRE(oss2.str() == "clkphase " + s_deg_val + " deg\n"); } for (int i = 0; i != det.size(); ++i) { det.setClockPhase(0, prev_val[i], {i}); } } else { REQUIRE_THROWS(proxy.Call("clkphase", {"0"}, -1, GET)); } } TEST_CASE("clkdiv", "[.cmd][.new]") { Detector det; CmdProxy proxy(&det); auto det_type = det.getDetectorType().squash(); if (det_type == defs::MYTHEN3 || det_type == defs::GOTTHARD2) { REQUIRE_THROWS(proxy.Call("clkdiv", {}, -1, GET)); REQUIRE_THROWS(proxy.Call("clkdiv", {"7"}, -1, GET)); REQUIRE_THROWS(proxy.Call("clkdiv", {"7", "4"}, -1, PUT)); REQUIRE_THROWS(proxy.Call("clkdiv", {"7", "4"}, -1, PUT)); REQUIRE_THROWS(proxy.Call("clkdiv", {"0", "1"}, -1, PUT)); auto prev_val = det.getClockDivider(0); { std::ostringstream oss1, oss2; proxy.Call("clkdiv", {"0", "3"}, -1, PUT, oss1); REQUIRE(oss1.str() == "clkdiv 3\n"); proxy.Call("clkdiv", {"0"}, -1, GET, oss2); REQUIRE(oss2.str() == "clkdiv 3\n"); } for (int i = 0; i != det.size(); ++i) { det.setClockDivider(0, prev_val[i], {i}); } } else { REQUIRE_THROWS(proxy.Call("clkdiv", {"0"}, -1, GET)); } } TEST_CASE("maxclkphaseshift", "[.cmd][.new]") { Detector det; CmdProxy proxy(&det); auto det_type = det.getDetectorType().squash(); if (det_type == defs::MYTHEN3 || det_type == defs::GOTTHARD2) { REQUIRE_THROWS(proxy.Call("maxclkphaseshift", {"0", "2"}, -1, PUT)); REQUIRE_THROWS(proxy.Call("maxclkphaseshift", {}, -1, GET)); REQUIRE_THROWS(proxy.Call("maxclkphaseshift", {"7"}, -1, GET)); REQUIRE_NOTHROW(proxy.Call("maxclkphaseshift", {"0"}, -1, GET)); } else { REQUIRE_THROWS(proxy.Call("maxclkphaseshift", {"0"}, -1, GET)); } } TEST_CASE("vhighvoltage", "[.cmd][.new]") { Detector det; CmdProxy proxy(&det); auto det_type = det.getDetectorType().squash(); auto prev_val = det.getHighVoltage(); // selected values if (det_type == defs::GOTTHARD) { REQUIRE_THROWS(proxy.Call("vhighvoltage", {"50"}, -1, PUT)); { std::ostringstream oss1, oss2; proxy.Call("vhighvoltage", {"90"}, -1, PUT, oss1); REQUIRE(oss1.str() == "vhighvoltage 90\n"); proxy.Call("vhighvoltage", {}, -1, GET, oss2); REQUIRE(oss2.str() == "vhighvoltage 90\n"); } { std::ostringstream oss1, oss2; proxy.Call("vhighvoltage", {"0"}, -1, PUT, oss1); REQUIRE(oss1.str() == "vhighvoltage 0\n"); proxy.Call("vhighvoltage", {}, -1, GET, oss2); REQUIRE(oss2.str() == "vhighvoltage 0\n"); } } // range 0, 60 - 200 else if (det_type == defs::JUNGFRAU || det_type == defs::CHIPTESTBOARD || det_type == defs::MOENCH) { REQUIRE_THROWS(proxy.Call("vhighvoltage", {"50"}, -1, PUT)); { std::ostringstream oss1, oss2; proxy.Call("vhighvoltage", {"90"}, -1, PUT, oss1); REQUIRE(oss1.str() == "vhighvoltage 90\n"); proxy.Call("vhighvoltage", {}, -1, GET, oss2); REQUIRE(oss2.str() == "vhighvoltage 90\n"); } { std::ostringstream oss1, oss2; proxy.Call("vhighvoltage", {"0"}, -1, PUT, oss1); REQUIRE(oss1.str() == "vhighvoltage 0\n"); proxy.Call("vhighvoltage", {}, -1, GET, oss2); REQUIRE(oss2.str() == "vhighvoltage 0\n"); } } // full range 0 - 200 (get needs to wait) else if (det_type == defs::EIGER) { { std::ostringstream oss1, oss2; proxy.Call("vhighvoltage", {"50"}, 0, PUT, oss1); REQUIRE(oss1.str() == "vhighvoltage 50\n"); std::this_thread::sleep_for(std::chrono::seconds(2)); proxy.Call("vhighvoltage", {}, 0, GET, oss2); REQUIRE(oss2.str() == "vhighvoltage 50\n"); } { std::ostringstream oss1, oss2; proxy.Call("vhighvoltage", {"120"}, 0, PUT, oss1); REQUIRE(oss1.str() == "vhighvoltage 120\n"); std::this_thread::sleep_for(std::chrono::seconds(2)); proxy.Call("vhighvoltage", {}, 0, GET, oss2); REQUIRE(oss2.str() == "vhighvoltage 120\n"); } { std::ostringstream oss1, oss2; proxy.Call("vhighvoltage", {"0"}, 0, PUT, oss1); REQUIRE(oss1.str() == "vhighvoltage 0\n"); std::this_thread::sleep_for(std::chrono::seconds(2)); proxy.Call("vhighvoltage", {}, 0, GET, oss2); REQUIRE(oss2.str() == "vhighvoltage 0\n"); } } // full range 0 - 200 else { { std::ostringstream oss1, oss2; proxy.Call("vhighvoltage", {"50"}, -1, PUT, oss1); REQUIRE(oss1.str() == "vhighvoltage 50\n"); proxy.Call("vhighvoltage", {}, -1, GET, oss2); REQUIRE(oss2.str() == "vhighvoltage 50\n"); } { std::ostringstream oss1, oss2; proxy.Call("vhighvoltage", {"120"}, -1, PUT, oss1); REQUIRE(oss1.str() == "vhighvoltage 120\n"); proxy.Call("vhighvoltage", {}, -1, GET, oss2); REQUIRE(oss2.str() == "vhighvoltage 120\n"); } { std::ostringstream oss1, oss2; proxy.Call("vhighvoltage", {"0"}, -1, PUT, oss1); REQUIRE(oss1.str() == "vhighvoltage 0\n"); proxy.Call("vhighvoltage", {}, -1, GET, oss2); REQUIRE(oss2.str() == "vhighvoltage 0\n"); } } for (int i = 0; i != det.size(); ++i) { det.setHighVoltage(prev_val[i], {i}); } } TEST_CASE("powerchip", "[.cmd][.new]") { // TODO! this test currently fails with the // virtual detecto server Detector det; CmdProxy proxy(&det); auto det_type = det.getDetectorType().squash(); if (det_type == defs::JUNGFRAU || det_type == defs::MYTHEN3 || det_type == defs::GOTTHARD2 || det_type == defs::MOENCH) { auto prev_val = det.getPowerChip(); { std::ostringstream oss; proxy.Call("powerchip", {"1"}, -1, PUT, oss); REQUIRE(oss.str() == "powerchip 1\n"); } { std::ostringstream oss; proxy.Call("powerchip", {"0"}, -1, PUT, oss); REQUIRE(oss.str() == "powerchip 0\n"); } { std::ostringstream oss; proxy.Call("powerchip", {}, -1, GET, oss); REQUIRE(oss.str() == "powerchip 0\n"); } for (int i = 0; i != det.size(); ++i) { det.setPowerChip(prev_val[i], {i}); } } else { REQUIRE_THROWS(proxy.Call("powerchip", {}, -1, GET)); } } TEST_CASE("imagetest", "[.cmd][.new]") { Detector det; CmdProxy proxy(&det); auto det_type = det.getDetectorType().squash(); if (det_type == defs::GOTTHARD) { auto prev_val = det.getImageTestMode(); { std::ostringstream oss1, oss2; proxy.Call("imagetest", {"1"}, -1, PUT, oss1); REQUIRE(oss1.str() == "imagetest 1\n"); proxy.Call("imagetest", {}, -1, GET, oss2); REQUIRE(oss2.str() == "imagetest 1\n"); } { std::ostringstream oss1, oss2; proxy.Call("imagetest", {"0"}, -1, PUT, oss1); REQUIRE(oss1.str() == "imagetest 0\n"); proxy.Call("imagetest", {}, -1, GET, oss2); REQUIRE(oss2.str() == "imagetest 0\n"); } for (int i = 0; i != det.size(); ++i) { det.setImageTestMode(prev_val[i], {i}); } } else if (det_type != defs::JUNGFRAU && det_type != defs::EIGER) { // wont fail for eiger and jungfrau virtual servers REQUIRE_THROWS(proxy.Call("imagetest", {}, -1, GET)); } } TEST_CASE("extsig", "[.cmd][.new]") { Detector det; CmdProxy proxy(&det); auto det_type = det.getDetectorType().squash(); if (det_type == defs::GOTTHARD) { auto prev_val = det.getExternalSignalFlags(0); REQUIRE_THROWS(proxy.Call("extsig", {}, -1, GET)); REQUIRE_THROWS(proxy.Call("extsig", {"1"}, -1, GET)); REQUIRE_THROWS(proxy.Call("extsig", {"0", "inversion_on"}, -1, PUT)); REQUIRE_THROWS(proxy.Call("extsig", {"0", "inversion_off"}, -1, PUT)); { std::ostringstream oss1, oss2; proxy.Call("extsig", {"0", "trigger_in_rising_edge"}, -1, PUT, oss1); REQUIRE(oss1.str() == "extsig 0 trigger_in_rising_edge\n"); proxy.Call("extsig", {"0"}, -1, GET, oss2); REQUIRE(oss2.str() == "extsig trigger_in_rising_edge\n"); } { std::ostringstream oss1, oss2; proxy.Call("extsig", {"0", "trigger_in_falling_edge"}, -1, PUT, oss1); REQUIRE(oss1.str() == "extsig 0 trigger_in_falling_edge\n"); proxy.Call("extsig", {"0"}, -1, GET, oss2); REQUIRE(oss2.str() == "extsig 0 trigger_in_falling_edge\n"); } for (int i = 0; i != det.size(); ++i) { det.setExternalSignalFlags(0, prev_val[i], {i}); } } else if (det_type == defs::MYTHEN3) { auto prev_val_0 = det.getExternalSignalFlags(0); auto prev_val_1 = det.getExternalSignalFlags(1); REQUIRE_THROWS(proxy.Call("extsig", {}, -1, GET)); REQUIRE_THROWS(proxy.Call("extsig", {"8"}, -1, GET)); REQUIRE_THROWS(proxy.Call("extsig", {"0", "inversion_on"}, -1, PUT)); REQUIRE_THROWS(proxy.Call("extsig", {"0", "inversion_off"}, -1, PUT)); REQUIRE_THROWS( proxy.Call("extsig", {"1", "trigger_in_rising_edge"}, -1, PUT)); REQUIRE_THROWS( proxy.Call("extsig", {"1", "trigger_in_falling_edge"}, -1, PUT)); { std::ostringstream oss1, oss2; proxy.Call("extsig", {"0", "trigger_in_rising_edge"}, -1, PUT, oss1); REQUIRE(oss1.str() == "extsig 0 trigger_in_rising_edge\n"); proxy.Call("extsig", {"0"}, -1, GET, oss2); REQUIRE(oss2.str() == "extsig trigger_in_rising_edge\n"); } { std::ostringstream oss1, oss2; proxy.Call("extsig", {"0", "trigger_in_falling_edge"}, -1, PUT, oss1); REQUIRE(oss1.str() == "extsig 0 trigger_in_falling_edge\n"); proxy.Call("extsig", {"0"}, -1, GET, oss2); REQUIRE(oss2.str() == "extsig 0 trigger_in_falling_edge\n"); } { std::ostringstream oss1, oss2; proxy.Call("extsig", {"1", "inversion_off"}, -1, PUT, oss1); REQUIRE(oss1.str() == "extsig 1 inversion_off\n"); proxy.Call("extsig", {"1"}, -1, GET, oss2); REQUIRE(oss2.str() == "extsig inversion_off\n"); } { std::ostringstream oss1, oss2; proxy.Call("extsig", {"1", "inversion_on"}, -1, PUT, oss1); REQUIRE(oss1.str() == "extsig 1 inversion_on\n"); proxy.Call("extsig", {"1"}, -1, GET, oss2); REQUIRE(oss2.str() == "extsig 1 inversion_on\n"); } for (int i = 0; i != det.size(); ++i) { det.setExternalSignalFlags(0, prev_val_0[i], {i}); det.setExternalSignalFlags(1, prev_val_1[i], {i}); } } else { REQUIRE_THROWS(proxy.Call("extsig", {}, -1, GET)); } } /** temperature */ TEST_CASE("temp_adc", "[.cmd][.new]") { Detector det; CmdProxy proxy(&det); auto det_type = det.getDetectorType().squash(); if (det_type == defs::JUNGFRAU || det_type == defs::GOTTHARD) { REQUIRE_NOTHROW(proxy.Call("temp_adc", {}, -1, GET)); std::ostringstream oss; REQUIRE_NOTHROW(proxy.Call("temp_adc", {}, 0, GET, oss)); std::string s = (oss.str()).erase(0, strlen("temp_adc ")); REQUIRE(std::stoi(s) != -1); } else { REQUIRE_THROWS(proxy.Call("temp_adc", {}, -1, GET)); } } TEST_CASE("temp_fpga", "[.cmd][.new]") { Detector det; CmdProxy proxy(&det); auto det_type = det.getDetectorType().squash(); if (det_type == defs::JUNGFRAU || det_type == defs::GOTTHARD || det_type == defs::EIGER) { REQUIRE_NOTHROW(proxy.Call("temp_fpga", {}, -1, GET)); std::ostringstream oss; REQUIRE_NOTHROW(proxy.Call("temp_fpga", {}, 0, GET, oss)); std::string s = (oss.str()).erase(0, strlen("temp_fpga ")); REQUIRE(std::stoi(s) != -1); } else { REQUIRE_THROWS(proxy.Call("temp_fpga", {}, -1, GET)); } } /* acquisition */ TEST_CASE("clearbusy", "[.cmd][.new]") { Detector det; CmdProxy proxy(&det); REQUIRE_NOTHROW(proxy.Call("clearbusy", {}, -1, PUT)); REQUIRE_THROWS(proxy.Call("clearbusy", {"0"}, -1, PUT)); REQUIRE_THROWS(proxy.Call("clearbusy", {}, -1, GET)); } TEST_CASE("start", "[.cmd][.new]") { Detector det; CmdProxy proxy(&det); // PUT only command REQUIRE_THROWS(proxy.Call("start", {}, -1, GET)); auto prev_val = det.getExptime(); det.setExptime(std::chrono::seconds(2)); { std::ostringstream oss; proxy.Call("start", {}, -1, PUT, oss); REQUIRE(oss.str() == "start successful\n"); } { std::ostringstream oss; proxy.Call("status", {}, -1, GET, oss); REQUIRE(oss.str() == "status running\n"); } det.stopDetector(); for (int i = 0; i != det.size(); ++i) { det.setExptime(prev_val[i], {i}); } } TEST_CASE("stop", "[.cmd][.new]") { Detector det; CmdProxy proxy(&det); // PUT only command REQUIRE_THROWS(proxy.Call("stop", {}, -1, GET)); auto prev_val = det.getExptime(); det.setExptime(std::chrono::seconds(2)); det.startDetector(); { std::ostringstream oss; proxy.Call("status", {}, -1, GET, oss); REQUIRE(oss.str() == "status running\n"); } { std::ostringstream oss; proxy.Call("stop", {}, -1, PUT, oss); REQUIRE(oss.str() == "stop successful\n"); } { std::ostringstream oss; proxy.Call("status", {}, -1, GET, oss); REQUIRE(oss.str() == "status idle\n"); } for (int i = 0; i != det.size(); ++i) { det.setExptime(prev_val[i], {i}); } } TEST_CASE("status", "[.cmd][.new]") { Detector det; CmdProxy proxy(&det); auto prev_val = det.getExptime(); det.setExptime(std::chrono::seconds(2)); det.startDetector(); { std::ostringstream oss; proxy.Call("status", {}, -1, GET, oss); REQUIRE(oss.str() == "status running\n"); } det.stopDetector(); { std::ostringstream oss; proxy.Call("status", {}, -1, GET, oss); REQUIRE(oss.str() == "status idle\n"); } for (int i = 0; i != det.size(); ++i) { det.setExptime(prev_val[i], {i}); } } TEST_CASE("startingfnum", "[.cmd][.new]") { Detector det; CmdProxy proxy(&det); auto det_type = det.getDetectorType().squash(); if (det_type == defs::EIGER || det_type == defs::JUNGFRAU) { auto prev_sfnum = det.getStartingFrameNumber(); REQUIRE_THROWS(proxy.Call("startingfnum", {"0"}, -1, PUT)); { std::ostringstream oss; proxy.Call("startingfnum", {"3"}, -1, PUT, oss); REQUIRE(oss.str() == "startingfnum 3\n"); } { std::ostringstream oss; proxy.Call("startingfnum", {}, -1, GET, oss); REQUIRE(oss.str() == "startingfnum 3\n"); } { std::ostringstream oss; proxy.Call("startingfnum", {"1"}, -1, PUT, oss); REQUIRE(oss.str() == "startingfnum 1\n"); } for (int i = 0; i != det.size(); ++i) { det.setStartingFrameNumber(prev_sfnum[i], {i}); } } else { REQUIRE_THROWS(proxy.Call("startingfnum", {}, -1, GET)); } } /* Network Configuration (Detector<->Receiver) */ TEST_CASE("numinterfaces", "[.cmd][.new]") { Detector det; CmdProxy proxy(&det); auto det_type = det.getDetectorType().squash(); if (det_type == defs::JUNGFRAU || det_type == defs::GOTTHARD2) { auto prev_val = det.getNumberofUDPInterfaces().tsquash( "inconsistent numinterfaces to test"); { std::ostringstream oss; proxy.Call("numinterfaces", {"2"}, -1, PUT, oss); REQUIRE(oss.str() == "numinterfaces 2\n"); } { std::ostringstream oss; proxy.Call("numinterfaces", {"1"}, -1, PUT, oss); REQUIRE(oss.str() == "numinterfaces 1\n"); } { std::ostringstream oss; proxy.Call("numinterfaces", {}, -1, GET, oss); REQUIRE(oss.str() == "numinterfaces 1\n"); } det.setNumberofUDPInterfaces(prev_val); } else { std::ostringstream oss; proxy.Call("numinterfaces", {}, -1, GET, oss); REQUIRE(oss.str() == "numinterfaces 1\n"); REQUIRE_THROWS(proxy.Call("numinterfaces", {"1"}, -1, PUT)); } REQUIRE_THROWS(proxy.Call("numinterfaces", {"3"}, -1, PUT)); REQUIRE_THROWS(proxy.Call("numinterfaces", {"0"}, -1, PUT)); } /* Advanced */ TEST_CASE("initialchecks", "[.cmd]") { Detector det; CmdProxy proxy(&det); auto check = det.getInitialChecks(); auto dtstr = sls::ToString(check); auto hostname = det.getHostname(); std::string hostnamestr; for (auto &it : hostname) { hostnamestr += (it + "+"); } { std::ostringstream oss; proxy.Call("initialchecks", {"0"}, -1, PUT, oss); REQUIRE(oss.str() == "initialchecks 0\n"); } { std::ostringstream oss; proxy.Call("initialchecks", {}, -1, GET, oss); REQUIRE(oss.str() == "initialchecks 0\n"); } { det.setHostname(hostname); std::ostringstream oss; proxy.Call("initialchecks", {}, -1, GET, oss); REQUIRE(oss.str() == "initialchecks 0\n"); } det.setInitialChecks(check); } /* Insignificant */ TEST_CASE("port", "[.cmd]") { Detector det; CmdProxy proxy(&det); { std::ostringstream oss; proxy.Call("port", {"1942"}, -1, PUT, oss); REQUIRE(oss.str() == "port 1942\n"); } { std::ostringstream oss; proxy.Call("port", {}, -1, GET, oss); REQUIRE(oss.str() == "port 1942\n"); } proxy.Call("port", {"1952"}, -1, PUT); } TEST_CASE("stopport", "[.cmd]") { Detector det; CmdProxy proxy(&det); { std::ostringstream oss; proxy.Call("stopport", {"1942"}, -1, PUT, oss); REQUIRE(oss.str() == "stopport 1942\n"); } { std::ostringstream oss; proxy.Call("stopport", {}, -1, GET, oss); REQUIRE(oss.str() == "stopport 1942\n"); } proxy.Call("stopport", {"1953"}, -1, PUT); auto port = det.getStopPort().squash(); REQUIRE(port == 1953); } // TEST_CASE("execcommand", "[.cmd]") { // REQUIRE_NOTHROW(multiSlsDetectorClient("execcommand ls", PUT)); // } TEST_CASE("user", "[.cmd]") { Detector det; CmdProxy proxy(&det); proxy.Call("user", {}, -1, GET); // This is a get only command REQUIRE_THROWS(proxy.Call("user", {}, -1, PUT)); } // TEST_CASE("reg", "[.cmd]") { // if (test::type == defs::JUNGFRAU) { // { // std::ostringstream oss; // REQUIRE_NOTHROW(multiSlsDetectorClient("reg 0x01", GET, nullptr, // oss)); REQUIRE(oss.str() == "reg 0xacdc2014\n"); // } // { // std::ostringstream oss; // REQUIRE_NOTHROW(multiSlsDetectorClient("reg 0x64 5", PUT, // nullptr, oss)); REQUIRE(oss.str() == "reg [0x64, 5]\n"); // } // { // std::ostringstream oss; // REQUIRE_NOTHROW(multiSlsDetectorClient("frames", GET, nullptr, // oss)); REQUIRE(oss.str() == "frames 5\n"); // } // { // std::ostringstream oss; // REQUIRE_NOTHROW(multiSlsDetectorClient("getbit 0x64 0", GET, // nullptr, oss)); REQUIRE(oss.str() == "getbit 1\n"); // } // { // std::ostringstream oss; // REQUIRE_NOTHROW(multiSlsDetectorClient("setbit 0x64 1", PUT, // nullptr, oss)); REQUIRE(oss.str() == "setbit [0x64, 1]\n"); // } // { // std::ostringstream oss; // REQUIRE_NOTHROW(multiSlsDetectorClient("clearbit 0x64 0", PUT, // nullptr, oss)); REQUIRE(oss.str() == "clearbit [0x64, 0]\n"); // } // { // std::ostringstream oss; // REQUIRE_NOTHROW(multiSlsDetectorClient("frames", GET, nullptr, // oss)); REQUIRE(oss.str() == "frames 6\n"); // } // REQUIRE_NOTHROW(multiSlsDetectorClient("frames 1", PUT)); // } else if (test::type == defs::GOTTHARD) { // { // std::ostringstream oss; // REQUIRE_NOTHROW(multiSlsDetectorClient("reg 0x023", GET, nullptr, // oss)); REQUIRE(oss.str() == "reg 0xacdc1980\n"); // } // { // std::ostringstream oss; // REQUIRE_NOTHROW(multiSlsDetectorClient("reg 0x70 5", PUT, // nullptr, oss)); REQUIRE(oss.str() == "reg [0x70, 5]\n"); // } // { // std::ostringstream oss; // REQUIRE_NOTHROW(multiSlsDetectorClient("frames", GET, nullptr, // oss)); REQUIRE(oss.str() == "frames 5\n"); // } // { // std::ostringstream oss; // REQUIRE_NOTHROW(multiSlsDetectorClient("getbit 0x70 0", GET, // nullptr, oss)); REQUIRE(oss.str() == "getbit 1\n"); // } // { // std::ostringstream oss; // REQUIRE_NOTHROW(multiSlsDetectorClient("setbit 0x70 1", PUT, // nullptr, oss)); REQUIRE(oss.str() == "setbit [0x70, 1]\n"); // } // { // std::ostringstream oss; // REQUIRE_NOTHROW(multiSlsDetectorClient("clearbit 0x70 0", PUT, // nullptr, oss)); REQUIRE(oss.str() == "clearbit [0x70, 0]\n"); // } // { // std::ostringstream oss; // REQUIRE_NOTHROW(multiSlsDetectorClient("frames", GET, nullptr, // oss)); REQUIRE(oss.str() == "frames 6\n"); // } // REQUIRE_NOTHROW(multiSlsDetectorClient("frames 1", PUT)); // } else if (test::type == defs::CHIPTESTBOARD) { // { // std::ostringstream oss; // REQUIRE_NOTHROW(multiSlsDetectorClient("reg 0x01", GET, nullptr, // oss)); REQUIRE(oss.str() == "reg 0xacdc2016\n"); // } // { // std::ostringstream oss; // REQUIRE_NOTHROW(multiSlsDetectorClient("reg 0x64 5", PUT, // nullptr, oss)); REQUIRE(oss.str() == "reg [0x64, 5]\n"); // } // { // std::ostringstream oss; // REQUIRE_NOTHROW(multiSlsDetectorClient("frames", GET, nullptr, // oss)); REQUIRE(oss.str() == "frames 5\n"); // } // { // std::ostringstream oss; // REQUIRE_NOTHROW(multiSlsDetectorClient("getbit 0x64 0", GET, // nullptr, oss)); REQUIRE(oss.str() == "getbit 1\n"); // } // { // std::ostringstream oss; // REQUIRE_NOTHROW(multiSlsDetectorClient("setbit 0x64 1", PUT, // nullptr, oss)); REQUIRE(oss.str() == "setbit [0x64, 1]\n"); // } // { // std::ostringstream oss; // REQUIRE_NOTHROW(multiSlsDetectorClient("clearbit 0x64 0", PUT, // nullptr, oss)); REQUIRE(oss.str() == "clearbit [0x64, 0]\n"); // } // { // std::ostringstream oss; // REQUIRE_NOTHROW(multiSlsDetectorClient("frames", GET, nullptr, // oss)); REQUIRE(oss.str() == "frames 6\n"); // } // REQUIRE_NOTHROW(multiSlsDetectorClient("frames 1", PUT)); // } // } // TEST_CASE("update", "[.cmd][.ctb][.jungfrau]") { // if (test::type == defs::JUNGFRAU || test::type == // defs::CHIPTESTBOARD) { // REQUIRE_THROWS(multiSlsDetectorClient("update", PUT)); // REQUIRE_THROWS(multiSlsDetectorClient("update // jungfrauDetectorServer_developer", PUT)); // REQUIRE_THROWS(multiSlsDetectorClient("update // jungfrauDetectorServer_developer pc13784", PUT)); // REQUIRE_THROWS(multiSlsDetectorClient("update // jungfrauDetectorServer_developer pc13784 dfd.pff", PUT)); // //REQUIRE_NOTHROW(multiSlsDetectorClient("update // jungfrauDetectorServer_developer pc13784 // /afs/psi.ch/project/sls_det_firmware/jungfrau_firmware/cyclone_V/v0_8/Jungfrau_MCB.pof", // PUT)); // } else { // REQUIRE_THROWS(multiSlsDetectorClient("update", GET)); // } // } // TEST_CASE("copydetectorserver", "[.cmd][.ctb][.jungfrau]") { // if (test::type == defs::JUNGFRAU || test::type == // defs::CHIPTESTBOARD) { // REQUIRE_THROWS(multiSlsDetectorClient("copydetectorserver", PUT)); // REQUIRE_THROWS(multiSlsDetectorClient("copydetectorserver // jungfrauDetectorServer_developer", PUT)); // //REQUIRE_NOTHROW(multiSlsDetectorClient("copydetectorserver // jungfrauDetectorServer_developer pc13784", PUT)); // } else { // REQUIRE_THROWS(multiSlsDetectorClient("copydetectorserver", GET)); // } // } // TEST_CASE("rebootcontroller", "[.cmd][.ctb][.jungfrau]") { // if (test::type == defs::JUNGFRAU || test::type == // defs::CHIPTESTBOARD) { // ;//REQUIRE_NOTHROW(multiSlsDetectorClient("rebootcontroller", PUT)); // } else { // REQUIRE_THROWS(multiSlsDetectorClient("rebootcontroller", GET)); // } // } // TEST_CASE("programfpga", "[.cmd][.ctb][.jungfrau]") { // if (test::type == defs::JUNGFRAU || test::type == // defs::CHIPTESTBOARD) { // REQUIRE_THROWS(multiSlsDetectorClient("programfpga fdgd.oki", PUT)); // //REQUIRE_NOTHROW(multiSlsDetectorClient("programfpga // /afs/psi.ch/project/sls_det_firmware/jungfrau_firmware/cyclone_V/v0_8/Jungfrau_MCB.pof", // PUT)); // } else { // REQUIRE_THROWS(multiSlsDetectorClient("programfpga", GET)); // } // } // TEST_CASE("detectormode", "[.cmd][.moench]") { // { // std::ostringstream oss; // REQUIRE_NOTHROW(multiSlsDetectorClient("detectormode counting", PUT, // nullptr, oss)); REQUIRE(oss.str() == "detectormode counting\n"); // } // { // std::ostringstream oss; // REQUIRE_NOTHROW(multiSlsDetectorClient("detectormode interpolating", // PUT, nullptr, oss)); REQUIRE(oss.str() == "detectormode // interpolating\n"); // } // { // std::ostringstream oss; // REQUIRE_NOTHROW(multiSlsDetectorClient("detectormode analog", PUT, // nullptr, oss)); REQUIRE(oss.str() == "detectormode analog\n"); // } // REQUIRE_NOTHROW(multiSlsDetectorClient("detectormode counting", PUT)); // REQUIRE_THROWS(multiSlsDetectorClient("detectormode pedestal", PUT)); // } // TEST_CASE("framemode", "[.cmd][.moench]") { // { // std::ostringstream oss; // REQUIRE_NOTHROW(multiSlsDetectorClient("framemode pedestal", PUT, // nullptr, oss)); REQUIRE(oss.str() == "framemode pedestal\n"); // } // { // std::ostringstream oss; // REQUIRE_NOTHROW(multiSlsDetectorClient("framemode newpedestal", PUT, // nullptr, oss)); REQUIRE(oss.str() == "framemode newpedestal\n"); // } // { // std::ostringstream oss; // REQUIRE_NOTHROW(multiSlsDetectorClient("framemode flatfield", PUT, // nullptr, oss)); REQUIRE(oss.str() == "framemode flatfield\n"); // } // { // std::ostringstream oss; // REQUIRE_NOTHROW(multiSlsDetectorClient("framemode newflatfield", PUT, // nullptr, oss)); REQUIRE(oss.str() == "framemode newflatfield\n"); // } // REQUIRE_NOTHROW(multiSlsDetectorClient("framemode pedestal", PUT)); // REQUIRE_THROWS(multiSlsDetectorClient("framemode counting", PUT)); // } // TEST_CASE("emin", "[.cmd][.moench]") { // { // std::ostringstream oss; // REQUIRE_NOTHROW(multiSlsDetectorClient("emin 100", PUT, nullptr, // oss)); REQUIRE(oss.str() == "emin 100\n"); // } // { // std::ostringstream oss; // REQUIRE_NOTHROW(multiSlsDetectorClient("emax 200", PUT, nullptr, // oss)); REQUIRE(oss.str() == "emax 200\n"); // } // { // std::ostringstream oss; // REQUIRE_NOTHROW(multiSlsDetectorClient("rx_jsonpara emax", GET, // nullptr, oss)); REQUIRE(oss.str() == "rx_jsonpara 200\n"); // } // REQUIRE_NOTHROW(multiSlsDetectorClient("rx_jsonaddheader \"\"", PUT)); // } // TEST_CASE("patsetbit", "[.cmd][.ctb]") { // if (test::type == defs::CHIPTESTBOARD) { // uint64_t val = 0; // { // std::ostringstream oss; // REQUIRE_NOTHROW(multiSlsDetectorClient("patsetbit", GET, nullptr, // oss)); std::string s = (oss.str()).erase (0, strlen("patsetbit // ")); val = stoul(s, 0, 16); // } // { // std::ostringstream oss; // REQUIRE_NOTHROW(multiSlsDetectorClient("patsetbit // 0x842f020204200dc0", PUT, nullptr, oss)); REQUIRE(oss.str() == // "patsetbit 0x842f020204200dc0\n"); // } // REQUIRE_NOTHROW(multiSlsDetectorClient("patsetbit " + // sls::ToStringHex(val), PUT)); // } else { // REQUIRE_THROWS(multiSlsDetectorClient("patsetbit", GET)); // } // } // TEST_CASE("patmask", "[.cmd][.ctb]") { // if (test::type == defs::CHIPTESTBOARD) { // uint64_t val = 0; // { // std::ostringstream oss; // REQUIRE_NOTHROW(multiSlsDetectorClient("patmask", GET, nullptr, // oss)); std::string s = (oss.str()).erase (0, strlen("patmask ")); // val = stoul(s, 0, 16); // } // { // std::ostringstream oss; // REQUIRE_NOTHROW(multiSlsDetectorClient("patmask // 0x842f020204200dc0", PUT, nullptr, oss)); REQUIRE(oss.str() == // "patmask 0x842f020204200dc0\n"); // } // REQUIRE_NOTHROW(multiSlsDetectorClient("patmask " + // sls::ToStringHex(val), PUT)); // } else { // REQUIRE_THROWS(multiSlsDetectorClient("patmask", GET)); // } // } // TEST_CASE("patwaittime", "[.cmd][.ctb]") { // for (int loop = 0; loop < 3; ++loop) { // if (test::type == defs::CHIPTESTBOARD) { // uint64_t val = 0; // { // std::ostringstream oss; // REQUIRE_NOTHROW(multiSlsDetectorClient("patwaittime" + // std::to_string(loop), GET, nullptr, oss)); std::string s = // (oss.str()).erase (0, strlen("patwaittime") + 2); val = // std::stoul(s); // } // { // std::ostringstream oss; // REQUIRE_NOTHROW(multiSlsDetectorClient("patwaittime" + // std::to_string(loop) + " 8589936640", PUT, nullptr, oss)); // REQUIRE(oss.str() == "patwaittime" + std::to_string(loop) + " // 8589936640\n"); // } // REQUIRE_NOTHROW(multiSlsDetectorClient("patwaittime" + // std::to_string(loop) + ' ' + std::to_string(val), PUT)); // } else { // REQUIRE_THROWS(multiSlsDetectorClient("patwaittime" + // std::to_string(loop), GET)); // } // } // } // TEST_CASE("patwait", "[.cmd][.ctb]") { // for (int loop = 0; loop < 3; ++loop) { // if (test::type == defs::CHIPTESTBOARD) { // int val = 0; // { // std::ostringstream oss; // REQUIRE_NOTHROW(multiSlsDetectorClient("patwait" + // std::to_string(loop), GET, nullptr, oss)); std::string s = // (oss.str()).erase (0, strlen("patwait") + 2); val = stoul(s, // 0, 16); // } // { // std::ostringstream oss; // REQUIRE_NOTHROW(multiSlsDetectorClient("patwait" + // std::to_string(loop) + " 0x5c", PUT, nullptr, oss)); // REQUIRE(oss.str() == "patwait" + std::to_string(loop) + " // 0x5c\n"); // } // REQUIRE_NOTHROW(multiSlsDetectorClient("patwait" + // std::to_string(loop) + ' ' + sls::ToStringHex(val), PUT)); // } else { // REQUIRE_THROWS(multiSlsDetectorClient("patwait" + // std::to_string(loop), GET)); // } // } // } // TEST_CASE("patnloop", "[.cmd][.ctb]") { // for (int loop = 0; loop < 3; ++loop) { // if (test::type == defs::CHIPTESTBOARD) { // int val = 0; // { // std::ostringstream oss; // REQUIRE_NOTHROW(multiSlsDetectorClient("patnloop" + // std::to_string(loop), GET, nullptr, oss)); std::string s = // (oss.str()).erase (0, strlen("patnloop") + 2); val = // std::stoi(s); // } // { // std::ostringstream oss; // REQUIRE_NOTHROW(multiSlsDetectorClient("patnloop" + // std::to_string(loop) + " 5", PUT, nullptr, oss)); // REQUIRE(oss.str() == "patnloop" + std::to_string(loop) + " // 5\n"); // } // REQUIRE_NOTHROW(multiSlsDetectorClient("patnloop" + // std::to_string(loop) + ' ' + std::to_string(val), PUT)); // } else { // REQUIRE_THROWS(multiSlsDetectorClient("patnloop" + // std::to_string(loop), GET)); // } // } // } // TEST_CASE("patloop", "[.cmd][.ctb]") { // for (int loop = 0; loop < 3; ++loop) { // if (test::type == defs::CHIPTESTBOARD) { // uint32_t limit1 = 0, limit2 = 0; // { // std::ostringstream oss; // REQUIRE_NOTHROW(multiSlsDetectorClient("patloop" + // std::to_string(loop), GET, nullptr, oss)); std::string s = // oss.str(); auto t = sls::split(s, ' '); s = t[1].erase (0, // 1); limit1 = stoul(s, 0, 16); limit2 = stoul(t[2], 0, 16); // } // { // std::ostringstream oss; // REQUIRE_NOTHROW(multiSlsDetectorClient("patloop" + // std::to_string(loop) + " 0x20 0x5c", PUT, nullptr, oss)); // REQUIRE(oss.str() == "patloop" + std::to_string(loop) + " // [0x20, 0x5c]\n"); // } // REQUIRE_NOTHROW(multiSlsDetectorClient("patloop" + // std::to_string(loop) + ' ' + sls::ToStringHex(limit1) + ' ' + // sls::ToStringHex(limit2), PUT)); // REQUIRE_THROWS(multiSlsDetectorClient("patloop" + // std::to_string(loop) + " 0x3", PUT)); // } else { // REQUIRE_THROWS(multiSlsDetectorClient("patloop" + // std::to_string(loop), GET)); // } // } // } // TEST_CASE("patlimits", "[.cmd][.ctb]") { // if (test::type == defs::CHIPTESTBOARD) { // uint32_t patlimit1 = 0, patlimit2 = 0; // { // std::ostringstream oss; // REQUIRE_NOTHROW(multiSlsDetectorClient("patlimits", GET, nullptr, // oss)); std::string s = oss.str(); auto t = sls::split(s, ' '); s // = t[1].erase (0, 1); patlimit1 = stoul(s, 0, 16); patlimit2 = // stoul(t[2], 0, 16); // } // { // std::ostringstream oss; // REQUIRE_NOTHROW(multiSlsDetectorClient("patlimits 0x20 0x5c", // PUT, nullptr, oss)); REQUIRE(oss.str() == "patlimits [0x20, // 0x5c]\n"); // } // REQUIRE_NOTHROW(multiSlsDetectorClient("patlimits " + // sls::ToStringHex(patlimit1) + ' ' + sls::ToStringHex(patlimit2), // PUT)); // } else { // REQUIRE_THROWS(multiSlsDetectorClient("patlimits", GET)); // } // } // TEST_CASE("patword", "[.cmd][.ctb]") { // if (test::type == defs::CHIPTESTBOARD) { // uint64_t prev_value = 0; // { // std::ostringstream oss; // REQUIRE_NOTHROW(multiSlsDetectorClient("patword 0x23", GET, // nullptr, oss)); std::string s = (oss.str()).erase (0, // strlen("patword ")); prev_value = stoul(s, 0, 16); // } // { // std::ostringstream oss; // REQUIRE_NOTHROW(multiSlsDetectorClient("patword 0x23 // 0xc15004808d0a21a4", PUT, nullptr, oss)); REQUIRE(oss.str() == // "patword [0x23, 0xc15004808d0a21a4]\n"); // } // { // std::ostringstream oss; // REQUIRE_NOTHROW(multiSlsDetectorClient("patword 0x23 0x0", PUT, // nullptr, oss)); REQUIRE(oss.str() == "patword [0x23, 0x0]\n"); // } // { // std::ostringstream oss; // REQUIRE_NOTHROW(multiSlsDetectorClient("patword 0x23", GET, // nullptr, oss)); REQUIRE(oss.str() == "patword 0x0\n"); // } // REQUIRE_NOTHROW(multiSlsDetectorClient("patword 0x23 " + // std::to_string(prev_value), PUT)); // } else { // REQUIRE_THROWS(multiSlsDetectorClient("patword 0x23", GET)); // } // } // TEST_CASE("patclkctrl", "[.cmd][.ctb]") { // if (test::type == defs::CHIPTESTBOARD) { // uint64_t prev_value = 0; // { // std::ostringstream oss; // REQUIRE_NOTHROW(multiSlsDetectorClient("patclkctrl", GET, // nullptr, oss)); std::string s = (oss.str()).erase (0, // strlen("patclkctrl ")); prev_value = stoul(s, 0, 16); // } // { // std::ostringstream oss; // REQUIRE_NOTHROW(multiSlsDetectorClient("patclkctrl // 0xc15004808d0a21a4", PUT, nullptr, oss)); REQUIRE(oss.str() == // "patclkctrl 0xc15004808d0a21a4\n"); // } // { // std::ostringstream oss; // REQUIRE_NOTHROW(multiSlsDetectorClient("patclkctrl 0x0", PUT, // nullptr, oss)); REQUIRE(oss.str() == "patclkctrl 0x0\n"); // } // { // std::ostringstream oss; // REQUIRE_NOTHROW(multiSlsDetectorClient("patclkctrl", GET, // nullptr, oss)); REQUIRE(oss.str() == "patclkctrl 0x0\n"); // } // REQUIRE_NOTHROW(multiSlsDetectorClient("patclkctrl " + // std::to_string(prev_value), PUT)); // } else { // REQUIRE_THROWS(multiSlsDetectorClient("patclkctrl", GET)); // } // } // TEST_CASE("patioctrl", "[.cmd][.ctb]") { // if (test::type == defs::CHIPTESTBOARD) { // uint64_t prev_value = 0; // { // std::ostringstream oss; // REQUIRE_NOTHROW(multiSlsDetectorClient("patioctrl", GET, nullptr, // oss)); std::string s = (oss.str()).erase (0, strlen("patioctrl // ")); prev_value = stoul(s, 0, 16); // } // { // std::ostringstream oss; // REQUIRE_NOTHROW(multiSlsDetectorClient("patioctrl // 0xc15004808d0a21a4", PUT, nullptr, oss)); REQUIRE(oss.str() == // "patioctrl 0xc15004808d0a21a4\n"); // } // { // std::ostringstream oss; // REQUIRE_NOTHROW(multiSlsDetectorClient("patioctrl 0x0", PUT, // nullptr, oss)); REQUIRE(oss.str() == "patioctrl 0x0\n"); // } // { // std::ostringstream oss; // REQUIRE_NOTHROW(multiSlsDetectorClient("patioctrl", GET, nullptr, // oss)); REQUIRE(oss.str() == "patioctrl 0x0\n"); // } // REQUIRE_NOTHROW(multiSlsDetectorClient("patioctrl " + // std::to_string(prev_value), PUT)); // } else { // REQUIRE_THROWS(multiSlsDetectorClient("patioctrl", GET)); // } // } // TEST_CASE("savepattern", "[.cmd][.ctb]") { // REQUIRE_THROWS(multiSlsDetectorClient("savepattern", GET)); // if (test::type == defs::CHIPTESTBOARD) { // { // std::ostringstream oss; // REQUIRE_NOTHROW(multiSlsDetectorClient("savepattern // /tmp/pat.txt", PUT, nullptr, oss)); REQUIRE(oss.str() == // "savepattern /tmp/pat.txt\n"); // } // } else { // REQUIRE_THROWS(multiSlsDetectorClient("savepattern /tmp/pat.txt", // PUT)); // } // } // TEST_CASE("pattern", "[.cmd][.ctb]") { // REQUIRE_THROWS(multiSlsDetectorClient("pattern", GET)); // if (test::type == defs::CHIPTESTBOARD) { // ;// todo test with real file? // } // } // TEST_CASE("led", "[.cmd][.ctb]") { // if (test::type == defs::CHIPTESTBOARD) { // { // std::ostringstream oss; // REQUIRE_NOTHROW(multiSlsDetectorClient("led 1", PUT, nullptr, // oss)); REQUIRE(oss.str() == "led 1\n"); // } // { // std::ostringstream oss; // REQUIRE_NOTHROW(multiSlsDetectorClient("led 0", PUT, nullptr, // oss)); REQUIRE(oss.str() == "led 0\n"); // } // { // std::ostringstream oss; // REQUIRE_NOTHROW(multiSlsDetectorClient("led", GET, nullptr, // oss)); REQUIRE(oss.str() == "led 0\n"); // } // } else { // REQUIRE_THROWS(multiSlsDetectorClient("led", GET)); // } // } // TEST_CASE("diodelay", "[.cmd][.ctb]") { // if (test::type == defs::CHIPTESTBOARD) { // REQUIRE_NOTHROW(multiSlsDetectorClient("diodelay 0x01010 125", PUT)); // { // std::ostringstream oss; // REQUIRE_NOTHROW(multiSlsDetectorClient("diodelay 0x01010 775", // PUT, nullptr, oss)); REQUIRE(oss.str() == "diodelay [0x01010, // 775]\n"); // } // REQUIRE_NOTHROW(multiSlsDetectorClient("diodelay 0x01010 0", PUT)); // REQUIRE_THROWS(multiSlsDetectorClient("diodelay [0x01010, 776]", // PUT)); // } else { // REQUIRE_THROWS(multiSlsDetectorClient("diodelay", GET)); // } // } // TEST_CASE("extsampling", "[.cmd][.ctb]") { // if (test::type == defs::CHIPTESTBOARD) { // { // std::ostringstream oss; // REQUIRE_NOTHROW(multiSlsDetectorClient("extsampling 1", PUT, // nullptr, oss)); REQUIRE(oss.str() == "extsampling 1\n"); // } // { // std::ostringstream oss; // REQUIRE_NOTHROW(multiSlsDetectorClient("extsampling", GET, // nullptr, oss)); REQUIRE(oss.str() == "extsampling 1\n"); // } // { // std::ostringstream oss; // REQUIRE_NOTHROW(multiSlsDetectorClient("extsampling 0", PUT, // nullptr, oss)); REQUIRE(oss.str() == "extsampling 0\n"); // } // } else { // REQUIRE_THROWS(multiSlsDetectorClient("extsampling", GET)); // } // } // TEST_CASE("extsamplingsrc", "[.cmd][.ctb]") { // if (test::type == defs::CHIPTESTBOARD) { // { // std::ostringstream oss; // REQUIRE_NOTHROW(multiSlsDetectorClient("extsamplingsrc 1", PUT, // nullptr, oss)); REQUIRE(oss.str() == "extsamplingsrc 1\n"); // } // { // std::ostringstream oss; // REQUIRE_NOTHROW(multiSlsDetectorClient("extsamplingsrc 0", PUT, // nullptr, oss)); REQUIRE(oss.str() == "extsamplingsrc 0\n"); // } // { // std::ostringstream oss; // REQUIRE_NOTHROW(multiSlsDetectorClient("extsamplingsrc 15", PUT, // nullptr, oss)); REQUIRE(oss.str() == "extsamplingsrc 15\n"); // } // { // std::ostringstream oss; // REQUIRE_NOTHROW(multiSlsDetectorClient("extsamplingsrc", GET, // nullptr, oss)); REQUIRE(oss.str() == "extsamplingsrc 15\n"); // } // REQUIRE_THROWS(multiSlsDetectorClient("extsamplingsrc 64", PUT)); // } else { // REQUIRE_THROWS(multiSlsDetectorClient("extsamplingsrc", GET)); // } // } // TEST_CASE("adcinvert", "[.cmd][.ctb]") { // if (test::type == defs::CHIPTESTBOARD || test::type == // defs::JUNGFRAU) { // std::string s; // { // std::ostringstream oss; // REQUIRE_NOTHROW(multiSlsDetectorClient("adcinvert", GET, nullptr, // oss)); s = oss.str(); // } // { // std::ostringstream oss; // REQUIRE_NOTHROW(multiSlsDetectorClient("adcinvert 0x8d0a21d4", // PUT, nullptr, oss)); REQUIRE(oss.str() == "adcinvert // 0x8d0a21d4\n"); // } // { // std::ostringstream oss; // REQUIRE_NOTHROW(multiSlsDetectorClient(s, PUT, nullptr, oss)); // REQUIRE(oss.str() == s); // } // } else { // REQUIRE_THROWS(multiSlsDetectorClient("adcinvert", GET)); // } // } // TEST_CASE("adcenable", "[.cmd][.ctb]") { // if (test::type == defs::CHIPTESTBOARD) { // std::string s; // { // std::ostringstream oss; // REQUIRE_NOTHROW(multiSlsDetectorClient("adcenable", GET, nullptr, // oss)); s = oss.str(); // } // { // std::ostringstream oss; // REQUIRE_NOTHROW(multiSlsDetectorClient("adcenable 0x8d0a21d4", // PUT, nullptr, oss)); REQUIRE(oss.str() == "adcenable // 0x8d0a21d4\n"); // } // { // std::ostringstream oss; // REQUIRE_NOTHROW(multiSlsDetectorClient(s, PUT, nullptr, oss)); // REQUIRE(oss.str() == s); // } // } else { // REQUIRE_THROWS(multiSlsDetectorClient("adcenable", GET)); // } // } // TEST_CASE("vm_a", "[.cmd][.ctb]") { // if (test::type == defs::CHIPTESTBOARD) { // REQUIRE_NOTHROW(multiSlsDetectorClient("vm_a", GET)); // REQUIRE_NOTHROW(multiSlsDetectorClient("vm_b", GET)); // REQUIRE_NOTHROW(multiSlsDetectorClient("vm_c", GET)); // REQUIRE_NOTHROW(multiSlsDetectorClient("vm_d", GET)); // REQUIRE_NOTHROW(multiSlsDetectorClient("vm_io", GET)); // REQUIRE_NOTHROW(multiSlsDetectorClient("im_a", GET)); // REQUIRE_NOTHROW(multiSlsDetectorClient("im_b", GET)); // REQUIRE_NOTHROW(multiSlsDetectorClient("im_c", GET)); // REQUIRE_NOTHROW(multiSlsDetectorClient("im_d", GET)); // REQUIRE_NOTHROW(multiSlsDetectorClient("im_io", GET)); // } else { // REQUIRE_THROWS(multiSlsDetectorClient("vm_a", GET)); // REQUIRE_THROWS(multiSlsDetectorClient("vm_b", GET)); // REQUIRE_THROWS(multiSlsDetectorClient("vm_c", GET)); // REQUIRE_THROWS(multiSlsDetectorClient("vm_d", GET)); // REQUIRE_THROWS(multiSlsDetectorClient("vm_io", GET)); // REQUIRE_THROWS(multiSlsDetectorClient("im_a", GET)); // REQUIRE_THROWS(multiSlsDetectorClient("im_b", GET)); // REQUIRE_THROWS(multiSlsDetectorClient("im_c", GET)); // REQUIRE_THROWS(multiSlsDetectorClient("im_d", GET)); // REQUIRE_THROWS(multiSlsDetectorClient("im_io", GET)); // } // } // TEST_CASE("v_a", "[.cmd][.ctb]") { // if (test::type == defs::CHIPTESTBOARD) { // std::string s; // { // std::ostringstream oss; // REQUIRE_NOTHROW(multiSlsDetectorClient("0:v_limit", GET, nullptr, // oss)); s = oss.str(); // } // { // std::ostringstream oss; // REQUIRE_NOTHROW(multiSlsDetectorClient("v_limit 1500", PUT, // nullptr, oss)); REQUIRE(oss.str() == "v_limit 1500\n"); // } // { // std::ostringstream oss; // REQUIRE_NOTHROW(multiSlsDetectorClient("v_limit", GET, nullptr, // oss)); REQUIRE(oss.str() == "v_limit 1500\n"); // } // REQUIRE_NOTHROW(multiSlsDetectorClient(s, PUT)); // { // std::ostringstream oss; // REQUIRE_NOTHROW(multiSlsDetectorClient("0:v_a", GET, nullptr, // oss)); s = oss.str(); // } // { // std::ostringstream oss; // REQUIRE_NOTHROW(multiSlsDetectorClient(s, PUT, nullptr, oss)); // REQUIRE(oss.str() == s); // } // { // std::ostringstream oss; // REQUIRE_NOTHROW(multiSlsDetectorClient("0:v_b", GET, nullptr, // oss)); s = oss.str(); // } // { // std::ostringstream oss; // REQUIRE_NOTHROW(multiSlsDetectorClient(s, PUT, nullptr, oss)); // REQUIRE(oss.str() == s); // } // { // std::ostringstream oss; // REQUIRE_NOTHROW(multiSlsDetectorClient("0:v_c", GET, nullptr, // oss)); s = oss.str(); // } // { // std::ostringstream oss; // REQUIRE_NOTHROW(multiSlsDetectorClient(s, PUT, nullptr, oss)); // REQUIRE(oss.str() == s); // } // { // std::ostringstream oss; // REQUIRE_NOTHROW(multiSlsDetectorClient("0:v_d", GET, nullptr, // oss)); s = oss.str(); // } // { // std::ostringstream oss; // REQUIRE_NOTHROW(multiSlsDetectorClient(s, PUT, nullptr, oss)); // REQUIRE(oss.str() == s); // } // REQUIRE_NOTHROW(multiSlsDetectorClient("0:v_io", GET)); // REQUIRE_NOTHROW(multiSlsDetectorClient("0:v_chip", GET)); // do not // set vchip // } else { // REQUIRE_THROWS(multiSlsDetectorClient("v_limit", GET)); // REQUIRE_THROWS(multiSlsDetectorClient("v_a", GET)); // REQUIRE_THROWS(multiSlsDetectorClient("v_b", GET)); // REQUIRE_THROWS(multiSlsDetectorClient("v_c", GET)); // REQUIRE_THROWS(multiSlsDetectorClient("v_d", GET)); // REQUIRE_THROWS(multiSlsDetectorClient("v_io", GET)); // REQUIRE_THROWS(multiSlsDetectorClient("v_chip", GET)); // } // } // TEST_CASE("adcvpp", "[.cmd][.ctb]") { // if (test::type == defs::CHIPTESTBOARD) { // int prev_val = 0; // { // std::ostringstream oss; // REQUIRE_NOTHROW(multiSlsDetectorClient("adcvpp", GET, nullptr, // oss)); std::string s = (oss.str()).erase (0, strlen("adcvpp ")); // prev_val = std::stoi(s); // } // { // REQUIRE_NOTHROW(multiSlsDetectorClient("adcvpp 1", PUT)); // std::ostringstream oss; // REQUIRE_NOTHROW(multiSlsDetectorClient("adcvpp", GET, nullptr, // oss)); REQUIRE(oss.str() == "adcvpp 1\n"); // } // { // REQUIRE_NOTHROW(multiSlsDetectorClient("adcvpp 1140 mv", PUT)); // std::ostringstream oss; // REQUIRE_NOTHROW(multiSlsDetectorClient("adcvpp mv", GET, nullptr, // oss)); REQUIRE(oss.str() == "adcvpp 1140 mv\n"); // } // REQUIRE_NOTHROW(multiSlsDetectorClient("adcvpp " + // std::to_string(prev_val), PUT)); // } else { // REQUIRE_THROWS(multiSlsDetectorClient("adcvpp", GET)); // } // } // TEST_CASE("dbitpipeline", "[.cmd][.ctb]") { // if (test::type == defs::CHIPTESTBOARD) { // { // std::ostringstream oss; // REQUIRE_NOTHROW(multiSlsDetectorClient("dbitpipeline 1", PUT, // nullptr, oss)); REQUIRE(oss.str() == "dbitpipeline 1\n"); // } // { // std::ostringstream oss; // REQUIRE_NOTHROW(multiSlsDetectorClient("dbitpipeline 0", PUT, // nullptr, oss)); REQUIRE(oss.str() == "dbitpipeline 0\n"); // } // { // std::ostringstream oss; // REQUIRE_NOTHROW(multiSlsDetectorClient("dbitpipeline 15", PUT, // nullptr, oss)); REQUIRE(oss.str() == "dbitpipeline 15\n"); // } // { // std::ostringstream oss; // REQUIRE_NOTHROW(multiSlsDetectorClient("dbitpipeline", GET, // nullptr, oss)); REQUIRE(oss.str() == "dbitpipeline 15\n"); // } // REQUIRE_NOTHROW(multiSlsDetectorClient("dbitpipeline 0", PUT)); // } else { // REQUIRE_THROWS(multiSlsDetectorClient("dbitpipeline", GET)); // } // } // TEST_CASE("adcpipeline", "[.cmd][.ctb]") { // if (test::type == defs::CHIPTESTBOARD) { // { // std::ostringstream oss; // REQUIRE_NOTHROW(multiSlsDetectorClient("adcpipeline 1", PUT, // nullptr, oss)); REQUIRE(oss.str() == "adcpipeline 1\n"); // } // { // std::ostringstream oss; // REQUIRE_NOTHROW(multiSlsDetectorClient("adcpipeline 0", PUT, // nullptr, oss)); REQUIRE(oss.str() == "adcpipeline 0\n"); // } // { // std::ostringstream oss; // REQUIRE_NOTHROW(multiSlsDetectorClient("adcpipeline 15", PUT, // nullptr, oss)); REQUIRE(oss.str() == "adcpipeline 15\n"); // } // { // std::ostringstream oss; // REQUIRE_NOTHROW(multiSlsDetectorClient("adcpipeline", GET, // nullptr, oss)); REQUIRE(oss.str() == "adcpipeline 15\n"); // } // REQUIRE_NOTHROW(multiSlsDetectorClient("adcpipeline 0", PUT)); // } else { // REQUIRE_THROWS(multiSlsDetectorClient("adcpipeline", GET)); // } // } // TEST_CASE("romode", "[.cmd][.ctb]") { // if (test::type == defs::CHIPTESTBOARD) { // { // std::ostringstream oss; // REQUIRE_NOTHROW(multiSlsDetectorClient("romode digital", PUT, // nullptr, oss)); REQUIRE(oss.str() == "romode digital\n"); // } // { // std::ostringstream oss; // REQUIRE_NOTHROW(multiSlsDetectorClient("romode analog_digital", // PUT, nullptr, oss)); REQUIRE(oss.str() == "romode // analog_digital\n"); // } // { // std::ostringstream oss; // REQUIRE_NOTHROW(multiSlsDetectorClient("romode analog", PUT, // nullptr, oss)); REQUIRE(oss.str() == "romode analog\n"); // } // { // std::ostringstream oss; // REQUIRE_NOTHROW(multiSlsDetectorClient("romode", GET, nullptr, // oss)); REQUIRE(oss.str() == "romode analog\n"); // } // } else { // REQUIRE_THROWS(multiSlsDetectorClient("romode", GET)); // } // } // TEST_CASE("samples", "[.cmd][.ctb]") { // if (test::type == defs::CHIPTESTBOARD) { // uint64_t prev_value1 = 0; // { // std::ostringstream oss; // REQUIRE_NOTHROW(multiSlsDetectorClient("asamples", GET, nullptr, // oss)); std::string s = (oss.str()).erase (0, strlen("asamples // ")); prev_value1 = std::stoi(s); // } // std::cout<<"asamples:"<= 0); // REQUIRE(val < 1000); // } // REQUIRE_NOTHROW(multiSlsDetectorClient("stop", PUT)); // REQUIRE_NOTHROW(multiSlsDetectorClient("exptime 1 ms", PUT)); // } else { // REQUIRE_THROWS(multiSlsDetectorClient("exptimel", GET)); // } // } // TEST_CASE("periodl", "[.cmd][.gotthard]") { // if (test::type == defs::GOTTHARD || test::type == // defs::JUNGFRAU || test::type == // defs::CHIPTESTBOARD) { // REQUIRE_NOTHROW(multiSlsDetectorClient("frames 2", PUT)); // REQUIRE_NOTHROW(multiSlsDetectorClient("period 5", PUT)); // REQUIRE_NOTHROW(multiSlsDetectorClient("start", PUT)); // { // std::ostringstream oss; // REQUIRE_NOTHROW(multiSlsDetectorClient("0:periodl s", GET, // nullptr, oss)); std::string st = oss.str(); std::string s = // st.erase (0, strlen("periodl ")); double val = std::stod(s); // REQUIRE(val >= 0); // REQUIRE(val < 1000); // } // REQUIRE_NOTHROW(multiSlsDetectorClient("stop", PUT)); // REQUIRE_NOTHROW(multiSlsDetectorClient("period 1 s", PUT)); // REQUIRE_NOTHROW(multiSlsDetectorClient("frames 1", PUT)); // } else { // REQUIRE_THROWS(multiSlsDetectorClient("periodl", GET)); // } // } // TEST_CASE("roi", "[.cmd][.gotthard]") { // if (test::type == defs::GOTTHARD) { // { // std::ostringstream oss; // REQUIRE_NOTHROW(multiSlsDetectorClient("roi 0 255", PUT, nullptr, // oss)); REQUIRE(oss.str() == "roi [0, 255] \n"); // } // { // std::ostringstream oss; // REQUIRE_NOTHROW(multiSlsDetectorClient("roi 256 511", PUT, // nullptr, oss)); REQUIRE(oss.str() == "roi [256, 511] \n"); // } // { // std::ostringstream oss; // REQUIRE_NOTHROW(multiSlsDetectorClient("clearroi", PUT, nullptr, // oss)); REQUIRE(oss.str() == "clearroi [-1, -1] \n"); // } // REQUIRE_THROWS(multiSlsDetectorClient("roi 0 256", PUT)); // } else { // REQUIRE_THROWS(multiSlsDetectorClient("roi", GET)); // REQUIRE_THROWS(multiSlsDetectorClient("clearroi", PUT)); // } // } // TEST_CASE("storagecell_delay", "[.cmd][.jungfrau]") { // if (test::type == defs::JUNGFRAU) { // { // std::ostringstream oss; // REQUIRE_NOTHROW(multiSlsDetectorClient("storagecell_delay 1.62ms", // PUT, nullptr, oss)); REQUIRE(oss.str() == // "storagecell_delay 1.62ms\n"); // } // { // std::ostringstream oss; // REQUIRE_NOTHROW(multiSlsDetectorClient("storagecell_delay", GET, // nullptr, oss)); REQUIRE(oss.str() == // "storagecell_delay 1.62ms\n"); // } // { // std::ostringstream oss; // REQUIRE_NOTHROW(multiSlsDetectorClient("storagecell_delay 0", // PUT, nullptr, oss)); REQUIRE(oss.str() == "storagecell_delay // 0\n"); // } // REQUIRE_THROWS(multiSlsDetectorClient("storagecell_delay 1638376ns", // PUT)); } else { // REQUIRE_THROWS(multiSlsDetectorClient("storagecell_delay", GET)); // } // } // TEST_CASE("storagecell_start", "[.cmd][.jungfrau]") { // if (test::type == defs::JUNGFRAU) { // { // std::ostringstream oss; // REQUIRE_NOTHROW(multiSlsDetectorClient("storagecell_start 1", // PUT, nullptr, oss)); REQUIRE(oss.str() == "storagecell_start // 1\n"); // } // { // std::ostringstream oss; // REQUIRE_NOTHROW(multiSlsDetectorClient("storagecell_start 0", // PUT, nullptr, oss)); REQUIRE(oss.str() == "storagecell_start // 0\n"); // } // { // std::ostringstream oss; // REQUIRE_NOTHROW(multiSlsDetectorClient("storagecell_start 15", // PUT, nullptr, oss)); REQUIRE(oss.str() == "storagecell_start // 15\n"); // } // { // std::ostringstream oss; // REQUIRE_NOTHROW(multiSlsDetectorClient("storagecell_start", GET, // nullptr, oss)); REQUIRE(oss.str() == "storagecell_start 15\n"); // } // REQUIRE_THROWS(multiSlsDetectorClient("storagecell_start 16", PUT)); // } else { // REQUIRE_THROWS(multiSlsDetectorClient("storagecell_start", GET)); // } // } // TEST_CASE("storagecells", "[.cmd][.jungfrau]") { // if (test::type == defs::JUNGFRAU) { // { // std::ostringstream oss; // REQUIRE_NOTHROW(multiSlsDetectorClient("storagecells 1", PUT, // nullptr, oss)); REQUIRE(oss.str() == "storagecells 1\n"); // } // { // std::ostringstream oss; // REQUIRE_NOTHROW(multiSlsDetectorClient("storagecells 15", PUT, // nullptr, oss)); REQUIRE(oss.str() == "storagecells 15\n"); // } // { // std::ostringstream oss; // REQUIRE_NOTHROW(multiSlsDetectorClient("storagecells 0", PUT, // nullptr, oss)); REQUIRE(oss.str() == "storagecells 0\n"); // } // { // std::ostringstream oss; // REQUIRE_NOTHROW(multiSlsDetectorClient("storagecells", GET, // nullptr, oss)); REQUIRE(oss.str() == "storagecells 0\n"); // } // REQUIRE_THROWS(multiSlsDetectorClient("storagecells 16", PUT)); // } else { // REQUIRE_THROWS(multiSlsDetectorClient("storagecells", GET)); // } // } // TEST_CASE("auto_comp_disable", "[.cmd][.jungfrau]") { // if (test::type == defs::JUNGFRAU) { // { // std::ostringstream oss; // REQUIRE_NOTHROW(multiSlsDetectorClient("auto_comp_disable 1", // PUT, nullptr, oss)); REQUIRE(oss.str() == "auto_comp_disable // 1\n"); // } // { // std::ostringstream oss; // REQUIRE_NOTHROW(multiSlsDetectorClient("auto_comp_disable 0", // PUT, nullptr, oss)); REQUIRE(oss.str() == "auto_comp_disable // 0\n"); // } // { // std::ostringstream oss; // REQUIRE_NOTHROW(multiSlsDetectorClient("auto_comp_disable", GET, // nullptr, oss)); REQUIRE(oss.str() == "auto_comp_disable 0\n"); // } // } else { // REQUIRE_THROWS(multiSlsDetectorClient("auto_comp_disable", GET)); // } // } // TEST_CASE("temp_", "[.cmd][.jungfrau]") { // if (test::type == defs::JUNGFRAU) { // std::string s; // { // std::ostringstream oss; // REQUIRE_NOTHROW(multiSlsDetectorClient("0:temp_threshold", GET, // nullptr, oss)); s = oss.str(); // } // { // std::ostringstream oss; // REQUIRE_NOTHROW(multiSlsDetectorClient(s, PUT, nullptr, oss)); // REQUIRE(oss.str() == s); // } // { // std::ostringstream oss; // REQUIRE_NOTHROW(multiSlsDetectorClient("temp_control 1", PUT, // nullptr, oss)); REQUIRE(oss.str() == "temp_control 1\n"); // } // { // std::ostringstream oss; // REQUIRE_NOTHROW(multiSlsDetectorClient("temp_control 0", PUT, // nullptr, oss)); REQUIRE(oss.str() == "temp_control 0\n"); // } // { // std::ostringstream oss; // REQUIRE_NOTHROW(multiSlsDetectorClient("temp_control", GET, // nullptr, oss)); REQUIRE(oss.str() == "temp_control 0\n"); // } // { // std::ostringstream oss; // REQUIRE_NOTHROW(multiSlsDetectorClient("temp_event", GET, // nullptr, oss)); REQUIRE(oss.str() == "temp_event 0\n"); // } // { // std::ostringstream oss; // REQUIRE_NOTHROW(multiSlsDetectorClient("temp_event 0", PUT, // nullptr, oss)); REQUIRE(oss.str() == "temp_event cleared\n"); // } // REQUIRE_THROWS(multiSlsDetectorClient("temp_event 1", PUT)); // } else { // REQUIRE_THROWS(multiSlsDetectorClient("temp_threshold", GET)); // REQUIRE_THROWS(multiSlsDetectorClient("temp_control", GET)); // REQUIRE_THROWS(multiSlsDetectorClient("temp_event", GET)); // } // } // TEST_CASE("pulse", "[.cmd][.eiger]") { // REQUIRE_THROWS(multiSlsDetectorClient("pulse", GET)); // REQUIRE_THROWS(multiSlsDetectorClient("pulsenmove", GET)); // REQUIRE_THROWS(multiSlsDetectorClient("pulsechip", GET)); // if (test::type == defs::EIGER) { // REQUIRE_NOTHROW(multiSlsDetectorClient("pulse 1 1 5", PUT)); // REQUIRE_NOTHROW(multiSlsDetectorClient("pulsenmove 1 1 5", PUT)); // REQUIRE_NOTHROW(multiSlsDetectorClient("pulsechip 1", PUT)); // } else { // REQUIRE_THROWS(multiSlsDetectorClient("pulse 1 1 5", PUT)); // REQUIRE_THROWS(multiSlsDetectorClient("pulsenmove 1 1 5", PUT)); // REQUIRE_THROWS(multiSlsDetectorClient("pulsechip 1", PUT)); // } // } // TEST_CASE("partialreset", "[.cmd][.eiger]") { // if (test::type == defs::EIGER) { // { // std::ostringstream oss; // REQUIRE_NOTHROW(multiSlsDetectorClient("partialreset 1", PUT, // nullptr, oss)); REQUIRE(oss.str() == "partialreset 1\n"); // } // { // std::ostringstream oss; // REQUIRE_NOTHROW(multiSlsDetectorClient("partialreset", GET, // nullptr, oss)); REQUIRE(oss.str() == "partialreset 1\n"); // } // { // std::ostringstream oss; // REQUIRE_NOTHROW(multiSlsDetectorClient("partialreset 0", PUT, // nullptr, oss)); REQUIRE(oss.str() == "partialreset 0\n"); // } // REQUIRE_NOTHROW(multiSlsDetectorClient("partialreset 1", PUT)); // REQUIRE_NOTHROW(multiSlsDetectorClient("partialreset 0", PUT)); // } else { // REQUIRE_THROWS(multiSlsDetectorClient("partialreset", GET)); // } // } // TEST_CASE("measuredsubperiod", "[.cmd][.eiger]") { // if (test::type == defs::EIGER) { // REQUIRE_NOTHROW(multiSlsDetectorClient("frames 1", PUT)); // REQUIRE_NOTHROW(multiSlsDetectorClient("dr 32", PUT)); // REQUIRE_NOTHROW(multiSlsDetectorClient("start", PUT)); // sleep(3); // { // std::ostringstream oss; // REQUIRE_NOTHROW(multiSlsDetectorClient("0:measuredsubperiod ms", // GET, nullptr, oss)); std::string st = oss.str(); std::string s = // st.erase (0, strlen("measuredsubperiod ")); double val = // std::stod(s); REQUIRE(val >= 0); REQUIRE(val < 1000); // } // REQUIRE_NOTHROW(multiSlsDetectorClient("dr 16", PUT)); // } else { // REQUIRE_THROWS(multiSlsDetectorClient("measuredsubperiod", GET)); // } // } // TEST_CASE("measuredperiod", "[.cmd][.eiger]") { // if (test::type == defs::EIGER) { // REQUIRE_NOTHROW(multiSlsDetectorClient("frames 2", PUT)); // REQUIRE_NOTHROW(multiSlsDetectorClient("period 1", PUT)); // REQUIRE_NOTHROW(multiSlsDetectorClient("start", PUT)); // sleep(3); // { // std::ostringstream oss; // REQUIRE_NOTHROW(multiSlsDetectorClient("0:measuredperiod", GET, // nullptr, oss)); std::string st = oss.str(); std::string s = // st.erase (0, strlen("measuredperiod ")); double val = // std::stod(s); REQUIRE(val >= 1.0); REQUIRE(val < 2.0); // } // REQUIRE_NOTHROW(multiSlsDetectorClient("frames 1", PUT)); // } else { // REQUIRE_THROWS(multiSlsDetectorClient("measuredperiod", GET)); // } // } // TEST_CASE("readnlines", "[.cmd][.eiger]") { // if (test::type == defs::EIGER) { // { // std::ostringstream oss; // REQUIRE_NOTHROW(multiSlsDetectorClient("readnlines 256", PUT, // nullptr, oss)); REQUIRE(oss.str() == "readnlines 256\n"); // } // { // std::ostringstream oss; // REQUIRE_NOTHROW(multiSlsDetectorClient("readnlines", GET, // nullptr, oss)); REQUIRE(oss.str() == "readnlines 256\n"); // } // { // std::ostringstream oss; // REQUIRE_NOTHROW(multiSlsDetectorClient("readnlines 16", PUT, // nullptr, oss)); REQUIRE(oss.str() == "readnlines 16\n"); // } // REQUIRE_THROWS(multiSlsDetectorClient("readnlines 0", PUT)); // REQUIRE_NOTHROW(multiSlsDetectorClient("readnlines 256", PUT)); // } else { // REQUIRE_THROWS(multiSlsDetectorClient("readnlines", GET)); // } // } // TEST_CASE("ratecorr", "[.cmd][.eiger]") { // if (test::type == defs::EIGER) { // { // std::ostringstream oss; // REQUIRE_NOTHROW(multiSlsDetectorClient("ratecorr 120", PUT, // nullptr, oss)); REQUIRE(oss.str() == "ratecorr 120ns\n"); // } // { // std::ostringstream oss; // REQUIRE_NOTHROW(multiSlsDetectorClient("ratecorr", GET, nullptr, // oss)); REQUIRE(oss.str() == "ratecorr 120ns\n"); // } // { // std::ostringstream oss; // REQUIRE_NOTHROW(multiSlsDetectorClient("ratecorr 0", PUT, // nullptr, oss)); REQUIRE(oss.str() == "ratecorr 0ns\n"); // } // REQUIRE_NOTHROW(multiSlsDetectorClient("ratecorr -1", PUT)); // REQUIRE_NOTHROW(multiSlsDetectorClient("ratecorr 0", PUT)); // } else { // REQUIRE_THROWS(multiSlsDetectorClient("ratecorr", GET)); // } // } // TEST_CASE("flippeddatax", "[.cmd][.eiger]") { // if (test::type == defs::EIGER) { // { // std::ostringstream oss; // REQUIRE_NOTHROW(multiSlsDetectorClient("0:flippeddatax", GET, // nullptr, oss)); REQUIRE(oss.str() == "flippeddatax 0\n"); // } // DetectorImpl d; // if (d.size() > 1) { // std::ostringstream oss; // REQUIRE_NOTHROW(multiSlsDetectorClient("1:flippeddatax", GET, // nullptr, oss)); REQUIRE(oss.str() == "flippeddatax 1\n"); // } // } else { // std::ostringstream oss; // REQUIRE_NOTHROW(multiSlsDetectorClient("flippeddatax", GET, nullptr, // oss)); REQUIRE(oss.str() == "flippeddatax 0\n"); // } // } // TEST_CASE("parallel", "[.cmd][.eiger]") { // if (test::type == defs::EIGER) { // { // std::ostringstream oss; // REQUIRE_NOTHROW(multiSlsDetectorClient("parallel 1", PUT, // nullptr, oss)); REQUIRE(oss.str() == "parallel 1\n"); // } // { // std::ostringstream oss; // REQUIRE_NOTHROW(multiSlsDetectorClient("parallel", GET, nullptr, // oss)); REQUIRE(oss.str() == "parallel 1\n"); // } // { // std::ostringstream oss; // REQUIRE_NOTHROW(multiSlsDetectorClient("parallel 0", PUT, // nullptr, oss)); REQUIRE(oss.str() == "parallel 0\n"); // } // } else { // REQUIRE_THROWS(multiSlsDetectorClient("parallel", GET)); // } // } // TEST_CASE("gappixels", "[.cmd][.eiger]") { // if (test::type == defs::EIGER) { // { // std::ostringstream oss; // REQUIRE_NOTHROW(multiSlsDetectorClient("gappixels 1", PUT, // nullptr, oss)); REQUIRE(oss.str() == "gappixels 1\n"); // } // { // std::ostringstream oss; // REQUIRE_NOTHROW(multiSlsDetectorClient("gappixels", GET, nullptr, // oss)); REQUIRE(oss.str() == "gappixels 1\n"); // } // { // std::ostringstream oss; // REQUIRE_NOTHROW(multiSlsDetectorClient("gappixels 0", PUT, // nullptr, oss)); REQUIRE(oss.str() == "gappixels 0\n"); // } // } else { // std::ostringstream oss; // REQUIRE_NOTHROW(multiSlsDetectorClient("gappixels", GET, nullptr, // oss)); REQUIRE(oss.str() == "gappixels 0\n"); // REQUIRE_THROWS(multiSlsDetectorClient("gappixels 1", PUT)); // } // } // TEST_CASE("settingspath", "[.cmd][.eiger]") { // std::string s; // std::ostringstream oss; // REQUIRE_NOTHROW(multiSlsDetectorClient("settingspath", GET, nullptr, // oss)); s = oss.str(); REQUIRE_NOTHROW(multiSlsDetectorClient(s, PUT)); // } TEST_CASE("zmqip", "[.cmd]") { Detector det; CmdProxy proxy(&det); std::ostringstream oss1, oss2; auto zmqip = det.getClientZmqIp(); proxy.Call("zmqip", {}, 0, GET, oss1); REQUIRE(oss1.str() == "zmqip " + zmqip[0].str() + '\n'); proxy.Call("zmqip", {zmqip[0].str()}, 0, PUT, oss2); REQUIRE(oss2.str() == "zmqip " + zmqip[0].str() + '\n'); for (int i = 0; i != det.size(); ++i) { det.setRxZmqIP(zmqip[i], {i}); } } TEST_CASE("zmqport", "[.cmd]") { Detector det; CmdProxy proxy(&det); int socketsperdetector = 1; auto det_type = det.getDetectorType().squash(); int prev = 1; if (det_type == defs::EIGER) { socketsperdetector *= 2; } else if (det_type == defs::JUNGFRAU) { prev = det.getNumberofUDPInterfaces().squash(); det.setNumberofUDPInterfaces(2); socketsperdetector *= 2; } int port = 3500; auto port_str = std::to_string(port); { std::ostringstream oss; proxy.Call("zmqport", {port_str}, -1, PUT, oss); REQUIRE(oss.str() == "zmqport " + port_str + '\n'); } for (int i = 0; i != det.size(); ++i) { std::ostringstream oss; proxy.Call("zmqport", {}, i, GET, oss); REQUIRE(oss.str() == "zmqport " + std::to_string(port + i * socketsperdetector) + '\n'); } port = 1954; port_str = std::to_string(port); { std::ostringstream oss; proxy.Call("zmqport", {port_str}, -1, PUT, oss); REQUIRE(oss.str() == "zmqport " + port_str + '\n'); } for (int i = 0; i != det.size(); ++i) { std::ostringstream oss; proxy.Call("zmqport", {}, i, GET, oss); REQUIRE(oss.str() == "zmqport " + std::to_string(port + i * socketsperdetector) + '\n'); } if (det_type == defs::JUNGFRAU) { det.setNumberofUDPInterfaces(prev); } } // TEST_CASE("txndelay", "[.cmd][.eiger][.jungfrau]") { // if (test::type == defs::EIGER) { // { // REQUIRE_NOTHROW(multiSlsDetectorClient("0:txndelay_frame 50000", // PUT)); std::ostringstream oss; // REQUIRE_NOTHROW(multiSlsDetectorClient("0:txndelay_frame", GET, // nullptr, oss)); REQUIRE(oss.str() == "txndelay_frame 50000\n"); // } // { // REQUIRE_NOTHROW(multiSlsDetectorClient("txndelay_frame 0", PUT)); // std::ostringstream oss; // REQUIRE_NOTHROW(multiSlsDetectorClient("0:txndelay_frame", GET, // nullptr, oss)); REQUIRE(oss.str() == "txndelay_frame 0\n"); // } // { // REQUIRE_NOTHROW(multiSlsDetectorClient("0:txndelay_left 50000", // PUT)); std::ostringstream oss; // REQUIRE_NOTHROW(multiSlsDetectorClient("0:txndelay_left", GET, // nullptr, oss)); REQUIRE(oss.str() == "txndelay_left 50000\n"); // } // { // REQUIRE_NOTHROW(multiSlsDetectorClient("txndelay_left 0", PUT)); // std::ostringstream oss; // REQUIRE_NOTHROW(multiSlsDetectorClient("0:txndelay_left", GET, // nullptr, oss)); REQUIRE(oss.str() == "txndelay_left 0\n"); // } // { // REQUIRE_NOTHROW(multiSlsDetectorClient("0:txndelay_right 50000", // PUT)); std::ostringstream oss; // REQUIRE_NOTHROW(multiSlsDetectorClient("0:txndelay_right", GET, // nullptr, oss)); REQUIRE(oss.str() == "txndelay_right 50000\n"); // } // { // REQUIRE_NOTHROW(multiSlsDetectorClient("txndelay_right 0", PUT)); // std::ostringstream oss; // REQUIRE_NOTHROW(multiSlsDetectorClient("0:txndelay_right", GET, // nullptr, oss)); REQUIRE(oss.str() == "txndelay_right 0\n"); // } // } else if (test::type == defs::JUNGFRAU) { // { // REQUIRE_NOTHROW(multiSlsDetectorClient("txndelay_frame 5", PUT)); // std::ostringstream oss; // REQUIRE_NOTHROW(multiSlsDetectorClient("0:txndelay_frame", GET, // nullptr, oss)); REQUIRE(oss.str() == "txndelay_frame 5\n"); // } // { // REQUIRE_NOTHROW(multiSlsDetectorClient("txndelay_frame 0", PUT)); // std::ostringstream oss; // REQUIRE_NOTHROW(multiSlsDetectorClient("0:txndelay_frame", GET, // nullptr, oss)); REQUIRE(oss.str() == "txndelay_frame 0\n"); // } // REQUIRE_THROWS(multiSlsDetectorClient("txndelay_frame 32", PUT)); // REQUIRE_THROWS(multiSlsDetectorClient("txndelay_left 32", PUT)); // REQUIRE_THROWS(multiSlsDetectorClient("txndelay_right 32", PUT)); // } else { // REQUIRE_THROWS(multiSlsDetectorClient("txndelay_frame", GET)); // REQUIRE_THROWS(multiSlsDetectorClient("txndelay_left 32", PUT)); // REQUIRE_THROWS(multiSlsDetectorClient("txndelay_right 32", PUT)); // } // } // TEST_CASE("flowcontrol_10g", "[.cmd][.eiger][.jungfrau]") { // if (test::type == defs::EIGER || test::type == // defs::JUNGFRAU) { // { // REQUIRE_NOTHROW(multiSlsDetectorClient("flowcontrol_10g 1", // PUT)); std::ostringstream oss; // REQUIRE_NOTHROW(multiSlsDetectorClient("0:flowcontrol_10g", GET, // nullptr, oss)); REQUIRE(oss.str() == "flowcontrol_10g 1\n"); // } // { // REQUIRE_NOTHROW(multiSlsDetectorClient("flowcontrol_10g 0", // PUT)); std::ostringstream oss; // REQUIRE_NOTHROW(multiSlsDetectorClient("0:flowcontrol_10g", GET, // nullptr, oss)); REQUIRE(oss.str() == "flowcontrol_10g 0\n"); // } // } else { // REQUIRE_THROWS(multiSlsDetectorClient("flowcontrol_10g", GET)); // } // } // TEST_CASE("network", "[.cmd]") { // /* {TODO custom srcip in globals // REQUIRE_NOTHROW(multiSlsDetectorClient("0:udp_srcip 129.129.205.203", // PUT)); std::ostringstream oss; // REQUIRE_NOTHROW(multiSlsDetectorClient("0:udp_srcip", GET, nullptr, // oss)); REQUIRE(oss.str() == "udp_srcip 129.129.205.203\n"); // }*/ // std::string udp_dstip; // { // std::ostringstream oss; // REQUIRE_NOTHROW(multiSlsDetectorClient("0:udp_dstip", GET, nullptr, // oss)); udp_dstip = oss.str(); // } // { // REQUIRE_NOTHROW(multiSlsDetectorClient(udp_dstip, PUT)); // std::ostringstream oss; // REQUIRE_NOTHROW(multiSlsDetectorClient("0:udp_dstip", GET, nullptr, // oss)); REQUIRE(oss.str() == udp_dstip); // } // /* {TODO custom dstip in globals // REQUIRE_NOTHROW(multiSlsDetectorClient("0:udp_dstmac // 10:e7:c6:48:bd:3f", PUT)); std::ostringstream oss; // REQUIRE_NOTHROW(multiSlsDetectorClient("0:udp_dstmac", GET, nullptr, // oss)); REQUIRE(oss.str() == "udp_dstmac 10:e7:c6:48:bd:3f\n"); // } */ // { // REQUIRE_NOTHROW(multiSlsDetectorClient("0:udp_dstport 6200", PUT)); // std::ostringstream oss; // REQUIRE_NOTHROW(multiSlsDetectorClient("0:udp_dstport", GET, nullptr, // oss)); REQUIRE(oss.str() == "udp_dstport 6200\n"); // } // { // DetectorImpl d; // int socketsperdetector = 1; // if (test::type == defs::EIGER) { // socketsperdetector *= 2; // } else if (test::type == defs::JUNGFRAU) { // REQUIRE_NOTHROW(multiSlsDetectorClient("numinterfaces 2", PUT)); // socketsperdetector *= 2; // } // int port = 5500; // REQUIRE_NOTHROW(multiSlsDetectorClient("udp_dstport " + // std::to_string(port), PUT)); for (int i = 0; i != d.size(); ++i) { // std::ostringstream oss; // REQUIRE_NOTHROW(multiSlsDetectorClient(std::to_string(i) + // ":udp_dstport", GET, nullptr, oss)); REQUIRE(oss.str() == // "udp_dstport " + std::to_string(port + i * socketsperdetector) + // '\n'); // } // port = 50001; // REQUIRE_NOTHROW(multiSlsDetectorClient("udp_dstport " + // std::to_string(port), PUT)); for (int i = 0; i != d.size(); ++i) { // std::ostringstream oss; // REQUIRE_NOTHROW(multiSlsDetectorClient(std::to_string(i) + // ":udp_dstport", GET, nullptr, oss)); REQUIRE(oss.str() == // "udp_dstport " + std::to_string(port + i * socketsperdetector) + // '\n'); // } // if (test::type == defs::JUNGFRAU) { // REQUIRE_NOTHROW(multiSlsDetectorClient("numinterfaces 1", PUT)); // } // REQUIRE_NOTHROW(multiSlsDetectorClient("udp_dstport 50001", PUT)); // } // REQUIRE_THROWS(multiSlsDetectorClient("udp_srcip 0.0.0.0", PUT)); // REQUIRE_THROWS(multiSlsDetectorClient("udp_srcip 124586954", PUT)); // REQUIRE_THROWS(multiSlsDetectorClient("udp_srcip 999.999.0.0.0.5", PUT)); // if (test::type == defs::JUNGFRAU) { // /* {TODO custom srcip2 in globals // REQUIRE_NOTHROW(multiSlsDetectorClient("0:udp_srcip2 // 129.129.205.203", PUT)); std::ostringstream oss; // REQUIRE_NOTHROW(multiSlsDetectorClient("0:udp_srcip2", GET, // nullptr, oss)); REQUIRE(oss.str() == "udp_srcip2 // 129.129.205.203\n"); // }*/ // { // std::ostringstream oss; // REQUIRE_NOTHROW(multiSlsDetectorClient("0:udp_dstip2", GET, // nullptr, oss)); udp_dstip = oss.str(); // } // { // REQUIRE_NOTHROW(multiSlsDetectorClient(udp_dstip, PUT)); // std::ostringstream oss; // REQUIRE_NOTHROW(multiSlsDetectorClient("0:udp_dstip2", GET, // nullptr, oss)); REQUIRE(oss.str() == udp_dstip); // } // { // REQUIRE_NOTHROW(multiSlsDetectorClient("0:udp_dstmac2 // 10:e7:c6:48:bd:3f", PUT)); std::ostringstream oss; // REQUIRE_NOTHROW(multiSlsDetectorClient("0:udp_dstmac2", GET, // nullptr, oss)); REQUIRE(oss.str() == "udp_dstmac2 // 10:e7:c6:48:bd:3f\n"); // } // { // REQUIRE_NOTHROW(multiSlsDetectorClient("0:udp_dstport2 6400", // PUT)); std::ostringstream oss; // REQUIRE_NOTHROW(multiSlsDetectorClient("0:udp_dstport2", GET, // nullptr, oss)); REQUIRE(oss.str() == "udp_dstport2 6400\n"); // } // REQUIRE_NOTHROW(multiSlsDetectorClient("udp_dstport2 50002", PUT)); // } else if (test::type == defs::EIGER) { // { // REQUIRE_NOTHROW(multiSlsDetectorClient("0:udp_dstport2 6400", // PUT)); std::ostringstream oss; // REQUIRE_NOTHROW(multiSlsDetectorClient("0:udp_dstport2", GET, // nullptr, oss)); REQUIRE(oss.str() == "udp_dstport2 6400\n"); // } // REQUIRE_NOTHROW(multiSlsDetectorClient("udp_dstport2 50002", PUT)); // } else { // REQUIRE_THROWS(multiSlsDetectorClient("udp_srcip2", GET)); // REQUIRE_THROWS(multiSlsDetectorClient("udp_dstip2", GET)); // REQUIRE_THROWS(multiSlsDetectorClient("udp_srcmac2", GET)); // REQUIRE_THROWS(multiSlsDetectorClient("udp_dstmac2", GET)); // REQUIRE_THROWS(multiSlsDetectorClient("udp_dstport2", GET)); // } // } // TEST_CASE("selinterface", "[.cmd][.jungfrau]") { // if (test::type == defs::JUNGFRAU) { // REQUIRE_NOTHROW(multiSlsDetectorClient("numinterfaces 1", PUT)); // { // REQUIRE_NOTHROW(multiSlsDetectorClient("selinterface 0", PUT)); // std::ostringstream oss; // REQUIRE_NOTHROW(multiSlsDetectorClient("0:selinterface", GET, // nullptr, oss)); REQUIRE(oss.str() == "selinterface 0\n"); // } // { // REQUIRE_NOTHROW(multiSlsDetectorClient("selinterface 1", PUT)); // std::ostringstream oss; // REQUIRE_NOTHROW(multiSlsDetectorClient("0:selinterface", GET, // nullptr, oss)); REQUIRE(oss.str() == "selinterface 1\n"); // } // REQUIRE_THROWS(multiSlsDetectorClient("selinterface 2", PUT)); // } else { // REQUIRE_THROWS(multiSlsDetectorClient("selinterface", GET)); // } // } // TEST_CASE("adc", "[.cmd][.ctb]") { // if (test::type != defs::CHIPTESTBOARD) { // REQUIRE_THROWS(multiSlsDetectorClient("adc 8", GET)); // } else { // REQUIRE_THROWS(multiSlsDetectorClient("adc", GET)); // REQUIRE_THROWS(multiSlsDetectorClient("adc 5", PUT)); // for(int i = 0; i <= 8; ++i) { // REQUIRE_NOTHROW(multiSlsDetectorClient("adc " + // std::to_string(i), GET)); // } // } // } // TEST_CASE("syncclk", "[.cmd][.ctb]") { // if(test::type != defs::CHIPTESTBOARD) { // REQUIRE_THROWS(multiSlsDetectorClient("syncclk", GET)); // } else { // REQUIRE_NOTHROW(multiSlsDetectorClient("syncclk", GET)); // REQUIRE_THROWS(multiSlsDetectorClient("syncclk 40", PUT)); // } // } // TEST_CASE("adcclk", "[.cmd][.ctb]") { // if(test::type != defs::CHIPTESTBOARD) { // REQUIRE_THROWS(multiSlsDetectorClient("adcclk", GET)); // } else { // int prev_clk = 0; // { // std::ostringstream oss; // REQUIRE_NOTHROW(multiSlsDetectorClient("adcclk", GET, nullptr, // oss)); std::string s = (oss.str()).erase (0, strlen("adcclk ")); // prev_clk = std::stoi(s); // } // { // REQUIRE_NOTHROW(multiSlsDetectorClient("adcclk 20", PUT)); // std::ostringstream oss; // REQUIRE_NOTHROW(multiSlsDetectorClient("adcclk", GET, nullptr, // oss)); REQUIRE(oss.str() == "adcclk 20\n"); // } // { // REQUIRE_NOTHROW(multiSlsDetectorClient("adcclk 10", PUT)); // std::ostringstream oss; // REQUIRE_NOTHROW(multiSlsDetectorClient("adcclk", GET, nullptr, // oss)); REQUIRE(oss.str() == "adcclk 10\n"); // } // REQUIRE_NOTHROW(multiSlsDetectorClient("adcclk " + // std::to_string(prev_clk), PUT)); // } // } // TEST_CASE("dbitclk", "[.cmd][.ctb]") { // if(test::type != defs::CHIPTESTBOARD) { // REQUIRE_THROWS(multiSlsDetectorClient("dbitclk", GET)); // } else { // int prev_clk = 0; // { // std::ostringstream oss; // REQUIRE_NOTHROW(multiSlsDetectorClient("dbitclk", GET, nullptr, // oss)); std::string s = (oss.str()).erase (0, strlen("dbitclk ")); // prev_clk = std::stoi(s); // } // { // REQUIRE_NOTHROW(multiSlsDetectorClient("dbitclk 20", PUT)); // std::ostringstream oss; // REQUIRE_NOTHROW(multiSlsDetectorClient("dbitclk", GET, nullptr, // oss)); REQUIRE(oss.str() == "dbitclk 20\n"); // } // { // REQUIRE_NOTHROW(multiSlsDetectorClient("dbitclk 10", PUT)); // std::ostringstream oss; // REQUIRE_NOTHROW(multiSlsDetectorClient("dbitclk", GET, nullptr, // oss)); REQUIRE(oss.str() == "dbitclk 10\n"); // } // REQUIRE_NOTHROW(multiSlsDetectorClient("dbitclk " + // std::to_string(prev_clk), PUT)); // } // } // TEST_CASE("runclk", "[.cmd][.ctb]") { // if(test::type != defs::CHIPTESTBOARD) { // REQUIRE_THROWS(multiSlsDetectorClient("runclk", GET)); // } else { // int prev_runclk = 0; // { // std::ostringstream oss; // REQUIRE_NOTHROW(multiSlsDetectorClient("runclk", GET, nullptr, // oss)); std::string s = (oss.str()).erase (0, strlen("runclk ")); // prev_runclk = std::stoi(s); // } // { // REQUIRE_NOTHROW(multiSlsDetectorClient("runclk 20", PUT)); // std::ostringstream oss; // REQUIRE_NOTHROW(multiSlsDetectorClient("runclk", GET, nullptr, // oss)); REQUIRE(oss.str() == "runclk 20\n"); // } // { // REQUIRE_NOTHROW(multiSlsDetectorClient("runclk 10", PUT)); // std::ostringstream oss; // REQUIRE_NOTHROW(multiSlsDetectorClient("runclk", GET, nullptr, // oss)); REQUIRE(oss.str() == "runclk 10\n"); // } // REQUIRE_NOTHROW(multiSlsDetectorClient("runclk " + // std::to_string(prev_runclk), PUT)); // } // } // TEST_CASE("threshold", "[.cmd]") { // if (test::type == defs::EIGER) { // REQUIRE_NOTHROW(multiSlsDetectorClient("threshold 6400 standard", // PUT)); REQUIRE_NOTHROW(multiSlsDetectorClient("thresholdnotb 6400 // standard", PUT)); REQUIRE_NOTHROW(multiSlsDetectorClient("threshold // 6400", PUT)); REQUIRE_NOTHROW(multiSlsDetectorClient("thresholdnotb // 6400", PUT)); // { // std::ostringstream oss; // REQUIRE_NOTHROW(multiSlsDetectorClient("threshold", GET, nullptr, // oss)); std::string s = (oss.str()).erase (0, strlen("threshold // ")); REQUIRE(std::stoi(s) == 6400); // REQUIRE_THROWS(multiSlsDetectorClient("thresholdnotb", GET)); // } // } else { // REQUIRE_THROWS(multiSlsDetectorClient("threshold", GET)); // REQUIRE_THROWS(multiSlsDetectorClient("thresholdnotb", GET)); // } // } // TEST_CASE("detsize", "[.cmd]") { // CHECK_NOTHROW(multiSlsDetectorClient("detsize", GET)); // } // TEST_CASE("type", "[.cmd]") { // CHECK_NOTHROW(multiSlsDetectorClient("type", GET)); // } // TEST_CASE("status", "[.cmd]") { // Detector det; // CmdProxy proxy(&det); // proxy.Call("timing", {"auto"}, -1, PUT); // proxy.Call("frames", {"10"}, -1, PUT); // proxy.Call("period", {"1"}, -1, PUT); // { // std::ostringstream oss; // proxy.Call("start", {}, -1, PUT, oss); // REQUIRE(oss.str() == "start successful\n"); // } // { // std::ostringstream oss; // proxy.Call("status", {}, -1, GET, oss); // REQUIRE(oss.str() == "status running\n"); // } // { // std::ostringstream oss; // proxy.Call("stop", {}, -1, PUT, oss); // REQUIRE(oss.str() == "stop successful\n"); // } // { // std::ostringstream oss; // REQUIRE_NOTHROW(multiSlsDetectorClient("status", GET, nullptr, oss)); // REQUIRE(oss.str() != "status running\n"); // REQUIRE(oss.str() != "status waiting\n"); // REQUIRE(oss.str() != "status transmitting\n"); // } // REQUIRE_NOTHROW(multiSlsDetectorClient("frames 1", PUT)); // proxy.Call("frames", {"1"}, -1, PUT); // } TEST_CASE("lock", "[.cmd]") { Detector det; CmdProxy proxy(&det); { std::ostringstream oss; proxy.Call("lock", {"1"}, -1, PUT, oss); REQUIRE(oss.str() == "lock 1\n"); } { std::ostringstream oss; proxy.Call("lock", {}, -1, GET, oss); REQUIRE(oss.str() == "lock 1\n"); } { std::ostringstream oss; proxy.Call("lock", {"0"}, -1, PUT, oss); REQUIRE(oss.str() == "lock 0\n"); } } // TEST_CASE("lastclient", "[.cmd]") { // REQUIRE_NOTHROW(multiSlsDetectorClient("lastclient", GET)); // }