aboutsummaryrefslogtreecommitdiffstats
path: root/test
diff options
context:
space:
mode:
authorJosh Blum <josh@joshknows.com>2010-01-28 19:54:55 -0800
committerJosh Blum <josh@joshknows.com>2010-01-28 19:54:55 -0800
commitd5d9da3114bf069c05a8dcb7fca32ccd70405512 (patch)
tree5c2c63efe9175ebd2b22c6b4899b997e9fed5b11 /test
parentfc1bffcfd9761c1f60cf322bb58e7f9c8096a5c0 (diff)
downloaduhd-d5d9da3114bf069c05a8dcb7fca32ccd70405512.tar.gz
uhd-d5d9da3114bf069c05a8dcb7fca32ccd70405512.tar.bz2
uhd-d5d9da3114bf069c05a8dcb7fca32ccd70405512.zip
Added gain handler class to manage wildcard gain settings.
Gets overall gains and sets overall gains when used. Wild card gain will be a gain with an empty string name.
Diffstat (limited to 'test')
-rw-r--r--test/Makefile.am1
-rw-r--r--test/gain_handler_test.cpp115
-rw-r--r--test/wax_test.cpp13
3 files changed, 129 insertions, 0 deletions
diff --git a/test/Makefile.am b/test/Makefile.am
index 46b1de0e6..baebd921a 100644
--- a/test/Makefile.am
+++ b/test/Makefile.am
@@ -23,6 +23,7 @@ main_test_SOURCES = \
main_test.cpp \
addr_test.cpp \
device_test.cpp \
+ gain_handler_test.cpp \
usrp_dboard_test.cpp \
wax_test.cpp
diff --git a/test/gain_handler_test.cpp b/test/gain_handler_test.cpp
new file mode 100644
index 000000000..339974af5
--- /dev/null
+++ b/test/gain_handler_test.cpp
@@ -0,0 +1,115 @@
+//
+// Copyright 2010 Ettus Research LLC
+//
+
+#include <boost/test/unit_test.hpp>
+#include <usrp_uhd/gain_handler.hpp>
+#include <usrp_uhd/utils.hpp>
+#include <iostream>
+
+using namespace usrp_uhd;
+
+enum prop_t{
+ PROP_GAIN,
+ PROP_GAIN_MIN,
+ PROP_GAIN_MAX,
+ PROP_GAIN_STEP,
+ PROP_GAIN_NAMES
+};
+
+class gainful_obj : public wax::obj{
+public:
+ gainful_obj(void){
+ _gain_handler = gain_handler::sptr(new gain_handler(
+ this, PROP_GAIN, PROP_GAIN_MIN, PROP_GAIN_MAX, PROP_GAIN_STEP, PROP_GAIN_NAMES
+ ));
+ _gains["g0"] = 0;
+ _gains["g1"] = 0;
+ _gains_min["g0"] = -10;
+ _gains_min["g1"] = 0;
+ _gains_max["g0"] = 0;
+ _gains_max["g1"] = 100;
+ _gains_step["g0"] = .1;
+ _gains_step["g1"] = 1.5;
+ }
+
+ ~gainful_obj(void){}
+
+private:
+ void get(const wax::type &key_, wax::type &val){
+ if (_gain_handler->intercept_get(key_, val)) return;
+
+ wax::type key; std::string name;
+ tie(key, name) = extract_named_prop(key_);
+
+ //handle the get request conditioned on the key
+ switch(wax::cast<prop_t>(key)){
+ case PROP_GAIN:
+ val = _gains[name];
+ return;
+
+ case PROP_GAIN_MIN:
+ val = _gains_min[name];
+ return;
+
+ case PROP_GAIN_MAX:
+ val = _gains_max[name];
+ return;
+
+ case PROP_GAIN_STEP:
+ val = _gains_step[name];
+ return;
+
+ case PROP_GAIN_NAMES:
+ val = prop_names_t(get_map_keys(_gains));
+ return;
+ }
+ }
+
+ void set(const wax::type &key_, const wax::type &val){
+ if (_gain_handler->intercept_set(key_, val)) return;
+
+ wax::type key; std::string name;
+ tie(key, name) = extract_named_prop(key_);
+
+ //handle the get request conditioned on the key
+ switch(wax::cast<prop_t>(key)){
+ case PROP_GAIN:
+ _gains[name] = wax::cast<gain_t>(val);
+ return;
+
+ case PROP_GAIN_MIN:
+ case PROP_GAIN_MAX:
+ case PROP_GAIN_STEP:
+ case PROP_GAIN_NAMES:
+ throw std::runtime_error("cannot set this property");
+ }
+ }
+
+ gain_handler::sptr _gain_handler;
+ std::map<std::string, gain_t> _gains;
+ std::map<std::string, gain_t> _gains_min;
+ std::map<std::string, gain_t> _gains_max;
+ std::map<std::string, gain_t> _gains_step;
+
+};
+
+BOOST_AUTO_TEST_CASE(test_gain_handler){
+ std::cout << "Testing the gain handler..." << std::endl;
+ gainful_obj go0;
+
+ BOOST_CHECK_THROW(
+ wax::cast<gain_t>(go0[named_prop_t(PROP_GAIN, "fail")]),
+ std::invalid_argument
+ );
+
+ std::cout << "verifying the overall min, max, step" << std::endl;
+ BOOST_CHECK_EQUAL(wax::cast<gain_t>(go0[PROP_GAIN_MIN]), gain_t(-10));
+ BOOST_CHECK_EQUAL(wax::cast<gain_t>(go0[PROP_GAIN_MAX]), gain_t(100));
+ BOOST_CHECK_EQUAL(wax::cast<gain_t>(go0[PROP_GAIN_STEP]), gain_t(1.5));
+
+ std::cout << "verifying the overall gain" << std::endl;
+ go0[named_prop_t(PROP_GAIN, "g0")] = gain_t(-5);
+ go0[named_prop_t(PROP_GAIN, "g1")] = gain_t(30);
+ BOOST_CHECK_EQUAL(wax::cast<gain_t>(go0[PROP_GAIN]), gain_t(25));
+}
diff --git a/test/wax_test.cpp b/test/wax_test.cpp
index 353130410..294fe0be7 100644
--- a/test/wax_test.cpp
+++ b/test/wax_test.cpp
@@ -5,6 +5,15 @@
#include <boost/test/unit_test.hpp>
#include <usrp_uhd/wax.hpp>
+enum opt_a_t{OPTION_A_0, OPTION_A_1};
+enum opt_b_t{OPTION_B_0, OPTION_B_1};
+
+BOOST_AUTO_TEST_CASE(test_enums){
+ wax::type opta = OPTION_A_0;
+ BOOST_CHECK_THROW(wax::cast<opt_b_t>(opta), wax::bad_cast);
+ BOOST_CHECK_EQUAL(wax::cast<opt_a_t>(opta), OPTION_A_0);
+}
+
/***********************************************************************
* demo class for wax framework
**********************************************************************/
@@ -69,6 +78,10 @@ BOOST_AUTO_TEST_CASE(test_proxy){
std::cout << "store proxy" << std::endl;
wax::proxy p = wd[size_t(0)][size_t(0)];
p[size_t(0)] = float(5);
+
+ std::cout << "assign proxy" << std::endl;
+ wax::type a = p[size_t(0)];
+ BOOST_CHECK_EQUAL(wax::cast<float>(a), float(5));
}
BOOST_AUTO_TEST_CASE(test_print){