aboutsummaryrefslogtreecommitdiffstats
path: root/test
diff options
context:
space:
mode:
authorJosh Blum <josh@joshknows.com>2010-01-12 14:43:43 -0800
committerJosh Blum <josh@joshknows.com>2010-01-12 14:43:43 -0800
commitcbb8e474bb5592753a340ba31d3afbab7226f7c6 (patch)
tree6dd14d37d8d46f3a506a309f57d82ed1ed05f781 /test
parent4e94574aeaa46c671bba0a6fc83cb967d228c880 (diff)
downloaduhd-cbb8e474bb5592753a340ba31d3afbab7226f7c6.tar.gz
uhd-cbb8e474bb5592753a340ba31d3afbab7226f7c6.tar.bz2
uhd-cbb8e474bb5592753a340ba31d3afbab7226f7c6.zip
Reorganized structure into include, lib, test, firmware, fpga.
The fpga and firmware are empty placeholders for now.
Diffstat (limited to 'test')
-rw-r--r--test/.gitignore3
-rw-r--r--test/Makefile.am20
-rw-r--r--test/wax_test.cpp81
3 files changed, 104 insertions, 0 deletions
diff --git a/test/.gitignore b/test/.gitignore
new file mode 100644
index 000000000..3d6649c66
--- /dev/null
+++ b/test/.gitignore
@@ -0,0 +1,3 @@
+/Makefile
+/Makefile.in
+/wax_test
diff --git a/test/Makefile.am b/test/Makefile.am
new file mode 100644
index 000000000..3373d838c
--- /dev/null
+++ b/test/Makefile.am
@@ -0,0 +1,20 @@
+#
+# Copyright 2010 Ettus Research LLC
+#
+
+include $(top_srcdir)/Makefile.common
+
+SUBDIRS =
+
+AM_CPPFLAGS = $(GENERAL_CPPFLAGS)
+
+LDADD = \
+ $(GENERAL_LDDFLAGS)
+ $(USRP_UHD_LA)
+
+noinst_PROGRAMS = \
+ wax_test
+
+wax_test_SOURCES = wax_test.cpp
+
+TESTS = $(noinst_PROGRAMS)
diff --git a/test/wax_test.cpp b/test/wax_test.cpp
new file mode 100644
index 000000000..88c9e0f32
--- /dev/null
+++ b/test/wax_test.cpp
@@ -0,0 +1,81 @@
+//
+// Copyright 2010 Ettus Research LLC
+//
+
+#include <usrp_uhd/wax.hpp>
+#include <iostream>
+#include <stdexcept>
+#include <vector>
+#include <boost/assert.hpp>
+
+class wax_demo : public wax::obj{
+private:
+ std::vector<float> d_nums;
+ std::vector<wax_demo> d_subs;
+public:
+ wax_demo(size_t sub_demos, size_t len){
+ d_nums = std::vector<float>(len);
+ if (sub_demos != 0){
+ for (size_t i = 0; i < len; i++){
+ d_subs.push_back(wax_demo(sub_demos-1, len));
+ }
+ }
+ }
+ ~wax_demo(void){
+ /* NOP */
+ }
+ void get(const wax::type &key, wax::type &value){
+ if (d_subs.size() == 0){
+ value = d_nums[wax::cast<size_t>(key)];
+ }else{
+ value = obj::cast(&d_subs[wax::cast<size_t>(key)]);
+ }
+ }
+ void set(const wax::type &key, const wax::type &value){
+ if (d_subs.size() == 0){
+ d_nums[wax::cast<size_t>(key)] = wax::cast<float>(value);
+ }else{
+ throw std::runtime_error("cant set to a wax demo with sub demos");
+ }
+ }
+};
+
+#define transform(i, j, k) float(i * j * k + i + j + k);
+
+int main(void){
+ try{
+ wax_demo wd(2, 10);
+ //test chained access
+ std::cout << "chain 1" << std::endl;
+ wd[size_t(0)];
+ std::cout << "chain 2" << std::endl;
+ wd[size_t(0)][size_t(0)];
+ std::cout << "chain 3" << std::endl;
+ wd[size_t(0)][size_t(0)][size_t(0)];
+ //set a bunch of values
+ std::cout << "set and get all" << std::endl;
+ for (size_t i = 0; i < 10; i++){
+ for (size_t j = 0; j < 10; j++){
+ for (size_t k = 0; k < 10; k++){
+ float val = transform(i, j, k);
+ //std::cout << i << " " << j << " " << k << std::endl;
+ wd[i][j][k] = val;
+ BOOST_ASSERT(wax::cast<float>(wd[i][j][k]) == val);
+ }
+ }
+ }
+ //test storing a proxy
+ std::cout << "store proxy" << std::endl;
+ wax::proxy p = wd[size_t(0)][size_t(0)];
+ p[size_t(0)] = float(5);
+ //test printing a type
+ std::cout << "print type" << std::endl;
+ wax::type test_type = float(3.33);
+ std::cout << test_type << std::endl;
+ std::cout << "done" << std::endl;
+ }catch(std::exception const& e){
+ std::cout << "Exception: " << e.what() << std::endl;
+ return ~0;
+ }
+ return 0;
+}