//! Test that segmented CoE uploads work. //! //! - EK1914 mod util; use env_logger::Env; use ethercrab::{error::Error, Client, ClientConfig, PduStorage, Timeouts}; use std::path::PathBuf; const MAX_SLAVES: usize = 16; const MAX_PDU_DATA: usize = PduStorage::element_size(1100); const MAX_FRAMES: usize = 128; const PDI_LEN: usize = 128; #[tokio::test] #[cfg_attr(miri, ignore)] async fn replay_ek1914_segmented_upload() -> Result<(), Error> { env_logger::Builder::from_env(Env::default().default_filter_or("info")).init(); static PDU_STORAGE: PduStorage = PduStorage::new(); let (tx, rx, pdu_loop) = PDU_STORAGE.try_split().expect("can only split once"); let client = Client::new( pdu_loop, Timeouts::default(), ClientConfig { dc_static_sync_iterations: 100, ..Default::default() }, ); let test_name = PathBuf::from(file!()) .file_stem() .unwrap() .to_string_lossy() .to_string(); util::spawn_tx_rx(&format!("tests/{test_name}.pcapng"), tx, rx); // Read configurations from slave EEPROMs and configure devices. let group = client .init_single_group::(|| 0) .await .expect("Init"); assert_eq!(group.slave(&client, 0)?.name(), "EK1914"); let first = group.slave(&client, 0).expect("EK1914 must be first"); let name_coe = first .sdo_read::>(0x1008, 0) .await .expect("Failed to read name"); log::info!("Device name: {:?}", name_coe); assert_eq!(&name_coe, "EK1914"); Ok(()) }