diff options
author | Diego Barrios Romero <eldruin@gmail.com> | 2019-03-30 13:36:06 +0200 |
---|---|---|
committer | Diego Barrios Romero <eldruin@gmail.com> | 2019-03-31 13:41:26 +0200 |
commit | 50223ad02e2f487540107e320c8bef40a9849582 (patch) | |
tree | 58b4e44e2261940d07aba96b8d8e83457e641f53 /tests | |
parent | ab1221e175f2da577c7a3fb510b5ae5cf41b0697 (diff) | |
download | ads1x1x-async-50223ad02e2f487540107e320c8bef40a9849582.tar.gz ads1x1x-async-50223ad02e2f487540107e320c8bef40a9849582.tar.xz ads1x1x-async-50223ad02e2f487540107e320c8bef40a9849582.zip |
Format code
Diffstat (limited to 'tests')
-rw-r--r-- | tests/common/mod.rs | 40 | ||||
-rw-r--r-- | tests/construction.rs | 5 | ||||
-rw-r--r-- | tests/mux.rs | 84 | ||||
-rw-r--r-- | tests/tier1.rs | 242 | ||||
-rw-r--r-- | tests/tier2.rs | 187 |
5 files changed, 433 insertions, 125 deletions
diff --git a/tests/common/mod.rs b/tests/common/mod.rs index ae3236c..223f97a 100644 --- a/tests/common/mod.rs +++ b/tests/common/mod.rs @@ -9,31 +9,31 @@ pub const DEVICE_ADDRESS: u8 = 0b100_1000; pub struct Register; #[allow(unused)] impl Register { - pub const CONVERSION : u8 = 0x00; - pub const CONFIG : u8 = 0x01; - pub const LOW_TH : u8 = 0x02; - pub const HIGH_TH : u8 = 0x03; + pub const CONVERSION: u8 = 0x00; + pub const CONFIG: u8 = 0x01; + pub const LOW_TH: u8 = 0x02; + pub const HIGH_TH: u8 = 0x03; } pub struct BitFlags; #[allow(unused)] impl BitFlags { - 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 PGA2 : u16 = 0b0000_1000_0000_0000; - pub const PGA1 : u16 = 0b0000_0100_0000_0000; - pub const PGA0 : u16 = 0b0000_0010_0000_0000; - pub const OP_MODE : u16 = 0b0000_0001_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; - pub const COMP_MODE : u16 = 0b0000_0000_0001_0000; - pub const COMP_POL : u16 = 0b0000_0000_0000_1000; - pub const COMP_LAT : u16 = 0b0000_0000_0000_0100; - pub const COMP_QUE1 : u16 = 0b0000_0000_0000_0010; - pub const COMP_QUE0 : u16 = 0b0000_0000_0000_0001; + 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 PGA2: u16 = 0b0000_1000_0000_0000; + pub const PGA1: u16 = 0b0000_0100_0000_0000; + pub const PGA0: u16 = 0b0000_0010_0000_0000; + pub const OP_MODE: u16 = 0b0000_0001_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; + pub const COMP_MODE: u16 = 0b0000_0000_0001_0000; + pub const COMP_POL: u16 = 0b0000_0000_0000_1000; + pub const COMP_LAT: u16 = 0b0000_0000_0000_0100; + pub const COMP_QUE1: u16 = 0b0000_0000_0000_0010; + pub const COMP_QUE0: u16 = 0b0000_0000_0000_0001; } pub struct Config { diff --git a/tests/construction.rs b/tests/construction.rs index 698d06a..f31ad2f 100644 --- a/tests/construction.rs +++ b/tests/construction.rs @@ -1,8 +1,7 @@ mod common; use common::{ - new_ads1013, destroy_ads1013, new_ads1113, destroy_ads1113, - new_ads1014, destroy_ads1014, new_ads1114, destroy_ads1114, - new_ads1015, destroy_ads1015, new_ads1115, destroy_ads1115 + destroy_ads1013, destroy_ads1014, destroy_ads1015, destroy_ads1113, destroy_ads1114, + destroy_ads1115, new_ads1013, new_ads1014, new_ads1015, new_ads1113, new_ads1114, new_ads1115, }; macro_rules! impl_tests { diff --git a/tests/mux.rs b/tests/mux.rs index b961fc7..309656e 100644 --- a/tests/mux.rs +++ b/tests/mux.rs @@ -7,24 +7,35 @@ extern crate ads1x1x; use ads1x1x::channel; mod common; -use common::{ new_ads1015 as new, destroy_ads1015 as destroy, - DEVICE_ADDRESS as DEV_ADDR, Register, BitFlags as BF, Config }; - +use common::{ + destroy_ads1015 as destroy, new_ads1015 as new, BitFlags as BF, Config, Register, + DEVICE_ADDRESS as DEV_ADDR, +}; macro_rules! mux_test { ($name:ident, $CS:ident, $config_bits:expr, $other_CS:ident, $other_config_bits:expr) => { mod $name { - use embedded_hal::adc::OneShot; use super::*; + use embedded_hal::adc::OneShot; #[test] fn can_read() { 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 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); @@ -36,12 +47,29 @@ macro_rules! mux_test { let default_config = Config::default(); let config = Config::default().with_high(BF::OS).with_high($config_bits); let other_config = Config::default().with_high($other_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(DEV_ADDR, vec![Register::CONFIG, other_config.msb(), other_config.lsb()]), - I2cTrans::write_read(DEV_ADDR, vec![Register::CONFIG], vec![other_config.msb(), other_config.lsb()]), - I2cTrans::write_read(DEV_ADDR, vec![Register::CONVERSION], vec![0x80, 0x00] ) ]; + 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( + DEV_ADDR, + vec![Register::CONFIG, other_config.msb(), other_config.lsb()], + ), + I2cTrans::write_read( + DEV_ADDR, + vec![Register::CONFIG], + vec![other_config.msb(), other_config.lsb()], + ), + I2cTrans::write_read(DEV_ADDR, vec![Register::CONVERSION], vec![0x80, 0x00]), + ]; let mut dev = new(&transactions); assert_would_block!(dev.read(&mut channel::$CS)); let measurement = block!(dev.read(&mut channel::$other_CS)).unwrap(); @@ -54,10 +82,14 @@ macro_rules! mux_test { let config1 = Config::default().with_low(BF::OP_MODE); let config2 = config1.with_high($config_bits); let transactions = [ - I2cTrans::write(DEV_ADDR, - vec![Register::CONFIG, config1.msb(), config1.lsb()]), - I2cTrans::write(DEV_ADDR, - vec![Register::CONFIG, config2.msb(), config2.lsb()]) + I2cTrans::write( + DEV_ADDR, + vec![Register::CONFIG, config1.msb(), config1.lsb()], + ), + I2cTrans::write( + DEV_ADDR, + vec![Register::CONFIG, config2.msb(), config2.lsb()], + ), ]; let dev = new(&transactions); let mut dev = dev.into_continuous().ok().unwrap(); @@ -71,8 +103,20 @@ macro_rules! mux_test { mux_test!(diffa0a1, DifferentialA0A1, 0, SingleA0, BF::MUX2); mux_test!(diffa0a3, DifferentialA0A3, BF::MUX0, SingleA0, BF::MUX2); mux_test!(diffa1a3, DifferentialA1A3, BF::MUX1, SingleA0, BF::MUX2); -mux_test!(diffa2a3, DifferentialA2A3, BF::MUX1 | BF::MUX0, SingleA0, BF::MUX2); +mux_test!( + diffa2a3, + DifferentialA2A3, + BF::MUX1 | BF::MUX0, + SingleA0, + BF::MUX2 +); mux_test!(singlea0, SingleA0, BF::MUX2, DifferentialA0A1, 0); mux_test!(singlea1, SingleA1, BF::MUX2 | BF::MUX0, SingleA0, BF::MUX2); mux_test!(singlea2, SingleA2, BF::MUX2 | BF::MUX1, SingleA0, BF::MUX2); -mux_test!(singlea3, SingleA3, BF::MUX2 | BF::MUX1 | BF::MUX0, SingleA0, BF::MUX2); +mux_test!( + singlea3, + SingleA3, + BF::MUX2 | BF::MUX1 | BF::MUX0, + SingleA0, + BF::MUX2 +); diff --git a/tests/tier1.rs b/tests/tier1.rs index de44b3c..89a60e0 100644 --- a/tests/tier1.rs +++ b/tests/tier1.rs @@ -7,22 +7,28 @@ extern crate ads1x1x; use ads1x1x::{channel, DataRate12Bit, DataRate16Bit}; mod common; -use common::{ new_ads1013, destroy_ads1013, new_ads1113, destroy_ads1113, - DEVICE_ADDRESS as DEV_ADDR, Register, BitFlags, Config }; +use common::{ + destroy_ads1013, destroy_ads1113, new_ads1013, new_ads1113, BitFlags as BF, Config, Register, + DEVICE_ADDRESS as DEV_ADDR, +}; macro_rules! measure_tests { ($IC:ident, $create:ident, $destroy:ident, $expected:expr) => { mod $IC { - use embedded_hal::adc::OneShot; use super::*; + use embedded_hal::adc::OneShot; 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 config = Config::default().with_low(BF::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); @@ -32,11 +38,24 @@ macro_rules! measure_tests { #[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 config_with_os = Config::default().with_high(BF::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); @@ -45,9 +64,11 @@ macro_rules! measure_tests { #[test] fn can_measure_continuous() { - let config = Config::default().with_low(BitFlags::OP_MODE); - let transactions = [ I2cTrans::write(DEV_ADDR, vec![Register::CONFIG, config.msb(), config.lsb()]), - I2cTrans::write_read(DEV_ADDR, vec![Register::CONVERSION], vec![0x80, 0x00] ) ]; + let config = Config::default().with_low(BF::OP_MODE); + let transactions = [ + I2cTrans::write(DEV_ADDR, vec![Register::CONFIG, config.msb(), config.lsb()]), + I2cTrans::write_read(DEV_ADDR, vec![Register::CONVERSION], vec![0x80, 0x00]), + ]; let dev = $create(&transactions); let mut dev = dev.into_continuous().ok().unwrap(); let measurement = dev.read().unwrap(); @@ -55,64 +76,180 @@ macro_rules! measure_tests { $destroy(dev); } } - } + }; } -measure_tests!(ads1013, new_ads1013, destroy_ads1013, -2048); +measure_tests!(ads1013, new_ads1013, destroy_ads1013, -2048); measure_tests!(ads1113, new_ads1113, destroy_ads1113, -32768); - mod data_rate_12bit { + use super::*; + macro_rules! test { ($name:ident, $variant:ident, $config:expr) => { #[test] fn $name() { - let transactions = [ I2cTrans::write(DEV_ADDR, vec![Register::CONFIG, $config.msb(), $config.lsb()]) ]; + let transactions = [I2cTrans::write( + DEV_ADDR, + vec![Register::CONFIG, $config.msb(), $config.lsb()], + )]; let mut dev = new_ads1013(&transactions); dev.set_data_rate(DataRate12Bit::$variant).unwrap(); destroy_ads1013(dev); } - } + }; } - use super::*; - test!(sps128, Sps128, Config::default().with_low( BitFlags::DR2).with_low( BitFlags::DR1).with_low( BitFlags::DR0)); - test!(sps250, Sps250, Config::default().with_low( BitFlags::DR2).with_low( BitFlags::DR1).with_high(BitFlags::DR0)); - test!(sps490, Sps490, Config::default().with_low( BitFlags::DR2).with_high(BitFlags::DR1).with_low( BitFlags::DR0)); - test!(sps920, Sps920, Config::default().with_low( BitFlags::DR2).with_high(BitFlags::DR1).with_high(BitFlags::DR0)); - test!(sps1600, Sps1600, Config::default().with_high(BitFlags::DR2).with_low( BitFlags::DR1).with_low( BitFlags::DR0)); - test!(sps2400, Sps2400, Config::default().with_high(BitFlags::DR2).with_low( BitFlags::DR1).with_high(BitFlags::DR0)); - test!(sps3300, Sps3300, Config::default().with_high(BitFlags::DR2).with_high(BitFlags::DR1).with_low( BitFlags::DR0)); + test!( + sps128, + Sps128, + Config::default() + .with_low(BF::DR2) + .with_low(BF::DR1) + .with_low(BF::DR0) + ); + test!( + sps250, + Sps250, + Config::default() + .with_low(BF::DR2) + .with_low(BF::DR1) + .with_high(BF::DR0) + ); + test!( + sps490, + Sps490, + Config::default() + .with_low(BF::DR2) + .with_high(BF::DR1) + .with_low(BF::DR0) + ); + test!( + sps920, + Sps920, + Config::default() + .with_low(BF::DR2) + .with_high(BF::DR1) + .with_high(BF::DR0) + ); + test!( + sps1600, + Sps1600, + Config::default() + .with_high(BF::DR2) + .with_low(BF::DR1) + .with_low(BF::DR0) + ); + test!( + sps2400, + Sps2400, + Config::default() + .with_high(BF::DR2) + .with_low(BF::DR1) + .with_high(BF::DR0) + ); + test!( + sps3300, + Sps3300, + Config::default() + .with_high(BF::DR2) + .with_high(BF::DR1) + .with_low(BF::DR0) + ); } mod data_rate_16bit { + use super::*; + macro_rules! test { ($name:ident, $variant:ident, $config:expr) => { #[test] fn $name() { - let transactions = [ I2cTrans::write(DEV_ADDR, vec![Register::CONFIG, $config.msb(), $config.lsb()]) ]; + let transactions = [I2cTrans::write( + DEV_ADDR, + vec![Register::CONFIG, $config.msb(), $config.lsb()], + )]; let mut dev = new_ads1113(&transactions); dev.set_data_rate(DataRate16Bit::$variant).unwrap(); destroy_ads1113(dev); } - } + }; } - use super::*; - test!(sps8, Sps8, Config::default().with_low( BitFlags::DR2).with_low( BitFlags::DR1).with_low( BitFlags::DR0)); - test!(sps16, Sps16, Config::default().with_low( BitFlags::DR2).with_low( BitFlags::DR1).with_high(BitFlags::DR0)); - test!(sps32, Sps32, Config::default().with_low( BitFlags::DR2).with_high(BitFlags::DR1).with_low( BitFlags::DR0)); - test!(sps64, Sps64, Config::default().with_low( BitFlags::DR2).with_high(BitFlags::DR1).with_high(BitFlags::DR0)); - test!(sps128, Sps128, Config::default().with_high(BitFlags::DR2).with_low( BitFlags::DR1).with_low( BitFlags::DR0)); - test!(sps250, Sps250, Config::default().with_high(BitFlags::DR2).with_low( BitFlags::DR1).with_high(BitFlags::DR0)); - test!(sps475, Sps475, Config::default().with_high(BitFlags::DR2).with_high(BitFlags::DR1).with_low( BitFlags::DR0)); - test!(sps860, Sps860, Config::default().with_high(BitFlags::DR2).with_high(BitFlags::DR1).with_high(BitFlags::DR0)); + test!( + sps8, + Sps8, + Config::default() + .with_low(BF::DR2) + .with_low(BF::DR1) + .with_low(BF::DR0) + ); + test!( + sps16, + Sps16, + Config::default() + .with_low(BF::DR2) + .with_low(BF::DR1) + .with_high(BF::DR0) + ); + test!( + sps32, + Sps32, + Config::default() + .with_low(BF::DR2) + .with_high(BF::DR1) + .with_low(BF::DR0) + ); + test!( + sps64, + Sps64, + Config::default() + .with_low(BF::DR2) + .with_high(BF::DR1) + .with_high(BF::DR0) + ); + test!( + sps128, + Sps128, + Config::default() + .with_high(BF::DR2) + .with_low(BF::DR1) + .with_low(BF::DR0) + ); + test!( + sps250, + Sps250, + Config::default() + .with_high(BF::DR2) + .with_low(BF::DR1) + .with_high(BF::DR0) + ); + test!( + sps475, + Sps475, + Config::default() + .with_high(BF::DR2) + .with_high(BF::DR1) + .with_low(BF::DR0) + ); + test!( + sps860, + Sps860, + Config::default() + .with_high(BF::DR2) + .with_high(BF::DR1) + .with_high(BF::DR0) + ); } #[test] fn can_read_measurement_in_progress() { - let config_os = Config::default().with_low(BitFlags::OS); - let transactions = [ I2cTrans::write_read(DEV_ADDR, vec![Register::CONFIG], vec![config_os.msb(), config_os.lsb()]) ]; + let config_os = Config::default().with_low(BF::OS); + let transactions = [I2cTrans::write_read( + DEV_ADDR, + vec![Register::CONFIG], + vec![config_os.msb(), config_os.lsb()], + )]; let mut dev = new_ads1013(&transactions); assert!(dev.is_measurement_in_progress().unwrap()); destroy_ads1013(dev); @@ -120,8 +257,12 @@ fn can_read_measurement_in_progress() { #[test] fn can_read_measurement_not_in_progress() { - let config_os = Config::default().with_high(BitFlags::OS); - let transactions = [ I2cTrans::write_read(DEV_ADDR, vec![Register::CONFIG], vec![config_os.msb(), config_os.lsb()]) ]; + let config_os = Config::default().with_high(BF::OS); + let transactions = [I2cTrans::write_read( + DEV_ADDR, + vec![Register::CONFIG], + vec![config_os.msb(), config_os.lsb()], + )]; let mut dev = new_ads1013(&transactions); assert!(!dev.is_measurement_in_progress().unwrap()); destroy_ads1013(dev); @@ -129,7 +270,7 @@ fn can_read_measurement_not_in_progress() { #[test] fn can_convert_to_continuous() { - let config = Config::default().with_low(BitFlags::OP_MODE); + let config = Config::default().with_low(BF::OP_MODE); let transactions = [I2cTrans::write( DEV_ADDR, vec![Register::CONFIG, config.msb(), config.lsb()], @@ -141,15 +282,18 @@ fn can_convert_to_continuous() { #[test] fn can_convert_to_one_shot() { - let config_cont = Config::default().with_low(BitFlags::OP_MODE); + let config_cont = Config::default().with_low(BF::OP_MODE); let config_os = Config::default(); - let transactions = [I2cTrans::write( - DEV_ADDR, - vec![Register::CONFIG, config_cont.msb(), config_cont.lsb()]), + let transactions = [ I2cTrans::write( - DEV_ADDR, - vec![Register::CONFIG, config_os.msb(), config_os.lsb()], - )]; + DEV_ADDR, + vec![Register::CONFIG, config_cont.msb(), config_cont.lsb()], + ), + I2cTrans::write( + DEV_ADDR, + vec![Register::CONFIG, config_os.msb(), config_os.lsb()], + ), + ]; let dev = new_ads1013(&transactions); let dev = dev.into_continuous().ok().unwrap(); let dev = dev.into_one_shot().ok().unwrap(); diff --git a/tests/tier2.rs b/tests/tier2.rs index 62a9759..e42a348 100644 --- a/tests/tier2.rs +++ b/tests/tier2.rs @@ -1,59 +1,96 @@ extern crate embedded_hal_mock; use embedded_hal_mock::i2c::Transaction as I2cTrans; extern crate ads1x1x; -use ads1x1x::{ FullScaleRange, ComparatorMode, ComparatorPolarity, - ComparatorLatching, ComparatorQueue }; +use ads1x1x::{ + ComparatorLatching, ComparatorMode, ComparatorPolarity, ComparatorQueue, FullScaleRange, +}; mod common; -use common::{ new_ads1014, destroy_ads1014, - DEVICE_ADDRESS as DEV_ADDR, Register, BitFlags, Config }; +use common::{ + destroy_ads1014, new_ads1014, BitFlags as BF, Config, Register, DEVICE_ADDRESS as DEV_ADDR, +}; macro_rules! set_value_test { ($name:ident, $method:ident, $value:expr, $reg:ident, $msb:expr, $lsb:expr) => { #[test] fn $name() { - let transactions = [ I2cTrans::write(DEV_ADDR, vec![Register::$reg, $msb, $lsb]) ]; + let transactions = [I2cTrans::write(DEV_ADDR, vec![Register::$reg, $msb, $lsb])]; let mut dev = new_ads1014(&transactions); dev.$method($value).unwrap(); destroy_ads1014(dev); } - } + }; } macro_rules! config_test { ($name:ident, $method:ident, $value:expr, $config:expr) => { set_value_test!($name, $method, $value, CONFIG, $config.msb(), $config.lsb()); - } + }; } mod can_set_comparator_thresholds { use super::*; - set_value_test!(low, set_low_threshold_raw, 2047, LOW_TH, 0x7F, 0xF0); + set_value_test!(low, set_low_threshold_raw, 2047, LOW_TH, 0x7F, 0xF0); set_value_test!(high, set_high_threshold_raw, 2047, HIGH_TH, 0x7F, 0xF0); } mod can_set_comparator_mode { use super::*; - config_test!(traditional, set_comparator_mode, ComparatorMode::Traditional, Config::default().with_low( BitFlags::COMP_MODE)); - config_test!(window, set_comparator_mode, ComparatorMode::Window, Config::default().with_high(BitFlags::COMP_MODE)); + config_test!( + traditional, + set_comparator_mode, + ComparatorMode::Traditional, + Config::default().with_low(BF::COMP_MODE) + ); + config_test!( + window, + set_comparator_mode, + ComparatorMode::Window, + Config::default().with_high(BF::COMP_MODE) + ); } mod can_set_comparator_polarity { use super::*; - config_test!(low, set_comparator_polarity, ComparatorPolarity::ActiveLow, Config::default().with_low( BitFlags::COMP_POL)); - config_test!(high, set_comparator_polarity, ComparatorPolarity::ActiveHigh, Config::default().with_high(BitFlags::COMP_POL)); + config_test!( + low, + set_comparator_polarity, + ComparatorPolarity::ActiveLow, + Config::default().with_low(BF::COMP_POL) + ); + config_test!( + high, + set_comparator_polarity, + ComparatorPolarity::ActiveHigh, + Config::default().with_high(BF::COMP_POL) + ); } mod can_set_comparator_latching { use super::*; - config_test!(non, set_comparator_latching, ComparatorLatching::Nonlatching, Config::default().with_low( BitFlags::COMP_LAT)); - config_test!(lat, set_comparator_latching, ComparatorLatching::Latching, Config::default().with_high(BitFlags::COMP_LAT)); + config_test!( + non, + set_comparator_latching, + ComparatorLatching::Nonlatching, + Config::default().with_low(BF::COMP_LAT) + ); + config_test!( + lat, + set_comparator_latching, + ComparatorLatching::Latching, + Config::default().with_high(BF::COMP_LAT) + ); } #[test] fn can_disable_comparator() { - let config = Config::default().with_high(BitFlags::COMP_QUE1).with_high(BitFlags::COMP_QUE0); - let transactions = [ I2cTrans::write(DEV_ADDR, vec![Register::CONFIG, config.msb(), config.lsb()]) ]; + let config = Config::default() + .with_high(BF::COMP_QUE1) + .with_high(BF::COMP_QUE0); + let transactions = [I2cTrans::write( + DEV_ADDR, + vec![Register::CONFIG, config.msb(), config.lsb()], + )]; let mut dev = new_ads1014(&transactions); dev.disable_comparator().unwrap(); destroy_ads1014(dev); @@ -61,15 +98,38 @@ fn can_disable_comparator() { mod can_set_comparator_queue { use super::*; - config_test!(one, set_comparator_queue, ComparatorQueue::One, Config::default().with_low( BitFlags::COMP_QUE1).with_low( BitFlags::COMP_QUE0)); - config_test!(two, set_comparator_queue, ComparatorQueue::Two, Config::default().with_low( BitFlags::COMP_QUE1).with_high(BitFlags::COMP_QUE0)); - config_test!(four, set_comparator_queue, ComparatorQueue::Four, Config::default().with_high(BitFlags::COMP_QUE1).with_low( BitFlags::COMP_QUE0)); + config_test!( + one, + set_comparator_queue, + ComparatorQueue::One, + Config::default() + .with_low(BF::COMP_QUE1) + .with_low(BF::COMP_QUE0) + ); + config_test!( + two, + set_comparator_queue, + ComparatorQueue::Two, + Config::default() + .with_low(BF::COMP_QUE1) + .with_high(BF::COMP_QUE0) + ); + config_test!( + four, + set_comparator_queue, + ComparatorQueue::Four, + Config::default() + .with_high(BF::COMP_QUE1) + .with_low(BF::COMP_QUE0) + ); } #[test] fn can_use_alert_rdy_pin_as_rdy_does_not_disable_comparator_if_already_disabled() { - let transactions = [ I2cTrans::write(DEV_ADDR, vec![Register::HIGH_TH, 0b1000_0000, 0]), - I2cTrans::write(DEV_ADDR, vec![Register::LOW_TH, 0, 0]), ]; + let transactions = [ + I2cTrans::write(DEV_ADDR, vec![Register::HIGH_TH, 0b1000_0000, 0]), + I2cTrans::write(DEV_ADDR, vec![Register::LOW_TH, 0, 0]), + ]; let mut dev = new_ads1014(&transactions); dev.use_alert_rdy_pin_as_ready().unwrap(); destroy_ads1014(dev); @@ -77,12 +137,25 @@ fn can_use_alert_rdy_pin_as_rdy_does_not_disable_comparator_if_already_disabled( #[test] fn can_use_alert_rdy_pin_as_rdy_disabled_comparator() { - let config = Config::default().with_low(BitFlags::COMP_QUE1).with_low(BitFlags::COMP_QUE0); - let config_disabled_comp = Config::default().with_high(BitFlags::COMP_QUE1).with_high(BitFlags::COMP_QUE0); - let transactions = [ I2cTrans::write(DEV_ADDR, vec![Register::CONFIG, config.msb(), config.lsb()]), - I2cTrans::write(DEV_ADDR, vec![Register::CONFIG, config_disabled_comp.msb(), config_disabled_comp.lsb()]), - I2cTrans::write(DEV_ADDR, vec![Register::HIGH_TH, 0b1000_0000, 0]), - I2cTrans::write(DEV_ADDR, vec![Register::LOW_TH, 0, 0]), ]; + let config = Config::default() + .with_low(BF::COMP_QUE1) + .with_low(BF::COMP_QUE0); + let config_disabled_comp = Config::default() + .with_high(BF::COMP_QUE1) + .with_high(BF::COMP_QUE0); + let transactions = [ + I2cTrans::write(DEV_ADDR, vec![Register::CONFIG, config.msb(), config.lsb()]), + I2cTrans::write( + DEV_ADDR, + vec![ + Register::CONFIG, + config_disabled_comp.msb(), + config_disabled_comp.lsb(), + ], + ), + I2cTrans::write(DEV_ADDR, vec![Register::HIGH_TH, 0b1000_0000, 0]), + I2cTrans::write(DEV_ADDR, vec![Register::LOW_TH, 0, 0]), + ]; let mut dev = new_ads1014(&transactions); dev.set_comparator_queue(ComparatorQueue::One).unwrap(); dev.use_alert_rdy_pin_as_ready().unwrap(); @@ -91,10 +164,58 @@ fn can_use_alert_rdy_pin_as_rdy_disabled_comparator() { mod can_set_full_scale_range { use super::*; - config_test!(fsr6, set_full_scale_range, FullScaleRange::Within6_144V, Config::default().with_low( BitFlags::PGA2).with_low( BitFlags::PGA1).with_low( BitFlags::PGA0)); - config_test!(fsr4, set_full_scale_range, FullScaleRange::Within4_096V, Config::default().with_low( BitFlags::PGA2).with_low( BitFlags::PGA1).with_high(BitFlags::PGA0)); - config_test!(fsr2, set_full_scale_range, FullScaleRange::Within2_048V, Config::default().with_low( BitFlags::PGA2).with_high(BitFlags::PGA1).with_low( BitFlags::PGA0)); - config_test!(fsr1, set_full_scale_range, FullScaleRange::Within1_024V, Config::default().with_low( BitFlags::PGA2).with_high(BitFlags::PGA1).with_high(BitFlags::PGA0)); - config_test!(fsr0_5, set_full_scale_range, FullScaleRange::Within0_512V, Config::default().with_high(BitFlags::PGA2).with_low( BitFlags::PGA1).with_low( BitFlags::PGA0)); - config_test!(fsr0_2, set_full_scale_range, FullScaleRange::Within0_256V, Config::default().with_high(BitFlags::PGA2).with_low( BitFlags::PGA1).with_high(BitFlags::PGA0)); + config_test!( + fsr6, + set_full_scale_range, + FullScaleRange::Within6_144V, + Config::default() + .with_low(BF::PGA2) + .with_low(BF::PGA1) + .with_low(BF::PGA0) + ); + config_test!( + fsr4, + set_full_scale_range, + FullScaleRange::Within4_096V, + Config::default() + .with_low(BF::PGA2) + .with_low(BF::PGA1) + .with_high(BF::PGA0) + ); + config_test!( + fsr2, + set_full_scale_range, + FullScaleRange::Within2_048V, + Config::default() + .with_low(BF::PGA2) + .with_high(BF::PGA1) + .with_low(BF::PGA0) + ); + config_test!( + fsr1, + set_full_scale_range, + FullScaleRange::Within1_024V, + Config::default() + .with_low(BF::PGA2) + .with_high(BF::PGA1) + .with_high(BF::PGA0) + ); + config_test!( + fsr0_5, + set_full_scale_range, + FullScaleRange::Within0_512V, + Config::default() + .with_high(BF::PGA2) + .with_low(BF::PGA1) + .with_low(BF::PGA0) + ); + config_test!( + fsr0_2, + set_full_scale_range, + FullScaleRange::Within0_256V, + Config::default() + .with_high(BF::PGA2) + .with_low(BF::PGA1) + .with_high(BF::PGA0) + ); } |