summaryrefslogtreecommitdiffstats
path: root/tests/tier1_i2c.rs
diff options
context:
space:
mode:
Diffstat (limited to 'tests/tier1_i2c.rs')
-rw-r--r--tests/tier1_i2c.rs56
1 files changed, 56 insertions, 0 deletions
diff --git a/tests/tier1_i2c.rs b/tests/tier1_i2c.rs
new file mode 100644
index 0000000..37a68d5
--- /dev/null
+++ b/tests/tier1_i2c.rs
@@ -0,0 +1,56 @@
+#[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_ads1013, destroy_ads1013, new_ads1113, destroy_ads1113,
+ DEVICE_ADDRESS as DEV_ADDR, Register, BitFlags, Config };
+
+macro_rules! impl_tests {
+ ($IC:ident, $create:ident, $destroy:ident, $expected:expr) => {
+ mod $IC {
+ use embedded_hal::adc::OneShot;
+ use super::*;
+ #[test]
+ fn can_create() {
+ let dev = $create(&[]);
+ $destroy(dev);
+ }
+
+ mod would_block {
+ use super::*;
+
+ #[test]
+ fn read_if_measurement_in_progress() {
+ let config = Config::default().with_low(BitFlags::OS);
+ let transactions = [ I2cTrans::write_read(DEV_ADDR, vec![Register::CONFIG], vec![config.msb(), config.lsb()] ) ];
+ let mut dev = $create(&transactions);
+ assert_would_block!(dev.read(&mut channel::DifferentialA0A1));
+ $destroy(dev);
+ }
+ }
+
+ #[test]
+ fn can_measure() {
+ let default_config = Config::default();
+ let config_with_os = Config::default().with_high(BitFlags::OS);
+ 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_with_os.msb(), config_with_os.lsb()]),
+ I2cTrans::write_read(DEV_ADDR, vec![Register::CONFIG], vec![config_with_os.msb(), config_with_os.lsb()]),
+ I2cTrans::write_read(DEV_ADDR, vec![Register::CONVERSION], vec![0x80, 0x00] ) ];
+ let mut dev = $create(&transactions);
+ let measurement = block!(dev.read(&mut channel::DifferentialA0A1)).unwrap();
+ assert_eq!($expected, measurement);
+ $destroy(dev);
+ }
+ }
+ }
+}
+
+impl_tests!(ads1013, new_ads1013, destroy_ads1013, -2048);
+impl_tests!(ads1113, new_ads1113, destroy_ads1113, -32768);