Skip to content

Commit

Permalink
tests: Add async codec test
Browse files Browse the repository at this point in the history
  • Loading branch information
RaulTrombin committed Apr 11, 2024
1 parent 2f41286 commit 50ded13
Showing 1 changed file with 115 additions and 0 deletions.
115 changes: 115 additions & 0 deletions tests/async_codec.rs
Original file line number Diff line number Diff line change
@@ -0,0 +1,115 @@
use futures::{SinkExt, StreamExt};
use ping_rs::codec::PingCodec;
use ping_rs::{common, message::ProtocolMessage, ping1d, Messages};
use std::convert::TryFrom;
use tokio::time::{sleep, Duration};
use tokio_serial::SerialPortBuilderExt;
use tokio_util::codec::{Decoder, Framed};

async fn run_ping_test() -> Result<(), Box<dyn std::error::Error>> {
let mut port = tokio_serial::new("/dev/ttyUSB0", 115_200).open_native_async()?;
#[cfg(unix)]
port.set_exclusive(false)?;

let stream: Framed<tokio_serial::SerialStream, PingCodec> = PingCodec::new().framed(port);
let (mut tx, mut rx) = stream.split();

let request_id_list = [
1200, 1201, 1202, 1203, 1204, 1205, 1206, 1207, 1208, 1210, 1211, 1212, 1213, 1214, 1215,
1300,
];

tokio::spawn(async move {
for request_id in request_id_list {
let request = common::Messages::GeneralRequest(common::GeneralRequestStruct {
requested_id: request_id,
});
let mut package = ProtocolMessage::new();
package.set_message(&request);

tx.send(package).await.unwrap();
}
});

for _n in 0..request_id_list.len() {
let item = rx
.next()
.await
.expect("Error awaiting future in RX stream.")
.expect("Reading stream resulted in an error");

assert!(item.has_valid_crc());

match Messages::try_from(&item) {
Ok(Messages::Ping1D(ping1d::Messages::FirmwareVersion(answer))) => {
println!("{:?}", answer)
}
Ok(Messages::Ping1D(ping1d::Messages::DeviceId(answer))) => {
println!("{:?}", answer)
}
Ok(Messages::Ping1D(ping1d::Messages::Voltage5(answer))) => {
println!("{:?}", answer)
}
Ok(Messages::Ping1D(ping1d::Messages::SpeedOfSound(answer))) => {
println!("{:?}", answer)
}
Ok(Messages::Ping1D(ping1d::Messages::Range(answer))) => {
println!("{:?}", answer)
}
Ok(Messages::Ping1D(ping1d::Messages::ModeAuto(answer))) => {
println!("{:?}", answer)
}
Ok(Messages::Ping1D(ping1d::Messages::PingInterval(answer))) => {
println!("{:?}", answer)
}
Ok(Messages::Ping1D(ping1d::Messages::GainSetting(answer))) => {
println!("{:?}", answer)
}
Ok(Messages::Ping1D(ping1d::Messages::TransmitDuration(answer))) => {
println!("{:?}", answer)
}
Ok(Messages::Ping1D(ping1d::Messages::GeneralInfo(answer))) => {
println!("{:?}", answer)
}
Ok(Messages::Ping1D(ping1d::Messages::DistanceSimple(answer))) => {
println!("{:?}", answer)
}
Ok(Messages::Ping1D(ping1d::Messages::Distance(answer))) => {
println!("{:?}", answer)
}
Ok(Messages::Ping1D(ping1d::Messages::ProcessorTemperature(answer))) => {
println!("{:?}", answer)
}
Ok(Messages::Ping1D(ping1d::Messages::PcbTemperature(answer))) => {
println!("{:?}", answer)
}
Ok(Messages::Ping1D(ping1d::Messages::PingEnable(answer))) => {
println!("{:?}", answer)
}
Ok(Messages::Ping1D(ping1d::Messages::Profile(answer))) => {
println!("{:?}", answer)
}
Ok(_) => {
panic!("Unexpected package. {:#?}", &item)
}
Err(e) => {
panic!("Error on decoder: {:?}", e)
}
}
}

Ok(())
}

#[tokio::test]
#[cfg_attr(not(feature = "local_runner"), ignore)]
async fn test_run_ping_test() {
let result = tokio::try_join!(run_ping_test());

match result {
Ok(_) => {}
Err(e) => {
panic!("Test failed: {:?}", e);
}
}
}

0 comments on commit 50ded13

Please sign in to comment.