summaryrefslogtreecommitdiffstats
path: root/tests
diff options
context:
space:
mode:
Diffstat (limited to 'tests')
-rw-r--r--tests/common/mod.rs4
-rw-r--r--tests/mux_i2c.rs41
2 files changed, 45 insertions, 0 deletions
diff --git a/tests/common/mod.rs b/tests/common/mod.rs
index ec63ec0..886967c 100644
--- a/tests/common/mod.rs
+++ b/tests/common/mod.rs
@@ -18,6 +18,9 @@ pub struct BitFlags;
impl BitFlags {
//pub const OP_MODE : u16 = 0b0000_0001_0000_0000;
pub const OS : u16 = 0b1000_0000_0000_0000;
+ pub const MUX2 : u16 = 0b0100_0000_0000_0000;
+ pub const MUX1 : u16 = 0b0010_0000_0000_0000;
+ pub const MUX0 : u16 = 0b0001_0000_0000_0000;
pub const DR2 : u16 = 0b0000_0000_1000_0000;
pub const DR1 : u16 = 0b0000_0000_0100_0000;
pub const DR0 : u16 = 0b0000_0000_0010_0000;
@@ -71,6 +74,7 @@ macro_rules! impl_new_destroy {
impl_new_destroy!(Ads1013, new_ads1013, destroy_ads1013, I2cTrans, interface::I2cInterface<I2cMock>);
impl_new_destroy!(Ads1113, new_ads1113, destroy_ads1113, I2cTrans, interface::I2cInterface<I2cMock>);
impl_new_destroy!(Ads1014, new_ads1014, destroy_ads1014, I2cTrans, interface::I2cInterface<I2cMock>);
+impl_new_destroy!(Ads1015, new_ads1015, destroy_ads1015, I2cTrans, interface::I2cInterface<I2cMock>);
#[macro_export]
macro_rules! assert_would_block {
diff --git a/tests/mux_i2c.rs b/tests/mux_i2c.rs
new file mode 100644
index 0000000..95f97a5
--- /dev/null
+++ b/tests/mux_i2c.rs
@@ -0,0 +1,41 @@
+#[macro_use(block)]
+extern crate nb;
+extern crate embedded_hal;
+extern crate embedded_hal_mock as hal;
+use hal::i2c::Transaction as I2cTrans;
+extern crate ads1x1x;
+use ads1x1x::channel;
+
+#[macro_use]
+mod common;
+use common::{ new_ads1015 as new, destroy_ads1015 as destroy,
+ DEVICE_ADDRESS as DEV_ADDR, Register, BitFlags as BF, Config };
+
+use embedded_hal::adc::OneShot;
+
+macro_rules! mux_test {
+ ($name:ident, $CS:ident, $config_bits:expr) => {
+ #[test]
+ fn $name() {
+ let default_config = Config::default();
+ let config = Config::default().with_high(BF::OS).with_high($config_bits);
+ let transactions = [ I2cTrans::write_read(DEV_ADDR, vec![Register::CONFIG], vec![default_config.msb(), default_config.lsb()]),
+ I2cTrans::write(DEV_ADDR, vec![Register::CONFIG, config.msb(), config.lsb()]),
+ I2cTrans::write_read(DEV_ADDR, vec![Register::CONFIG], vec![config.msb(), config.lsb()]),
+ I2cTrans::write_read(DEV_ADDR, vec![Register::CONVERSION], vec![0x80, 0x00] ) ];
+ let mut dev = new(&transactions);
+ let measurement = block!(dev.read(&mut channel::$CS)).unwrap();
+ assert_eq!(-2048, measurement);
+ destroy(dev);
+ }
+ };
+}
+
+mux_test!(diffa0a1, DifferentialA0A1, 0);
+mux_test!(diffa0a3, DifferentialA0A3, BF::MUX0);
+mux_test!(diffa1a3, DifferentialA1A3, BF::MUX1);
+mux_test!(diffa2a3, DifferentialA2A3, BF::MUX1 | BF::MUX0);
+mux_test!(singlea0, SingleA0, BF::MUX2);
+mux_test!(singlea1, SingleA1, BF::MUX2 | BF::MUX0);
+mux_test!(singlea2, SingleA2, BF::MUX2 | BF::MUX1);
+mux_test!(singlea3, SingleA3, BF::MUX2 | BF::MUX1 | BF::MUX0);