| Crates.io | moto-hses-mock |
| lib.rs | moto-hses-mock |
| version | 0.2.1 |
| created_at | 2025-09-21 23:15:37.199447+00 |
| updated_at | 2026-01-25 01:15:51.750669+00 |
| description | Mock HSES UDP server for testing and development |
| homepage | https://github.com/masayuki-kono/moto-hses |
| repository | https://github.com/masayuki-kono/moto-hses |
| max_upload_size | |
| id | 1849298 |
| size | 166,209 |
Mock HSES UDP server for testing and development.
This crate provides a mock implementation of the Yaskawa High-Speed Ethernet Server (HSES) protocol for testing and development purposes. It simulates a real Yaskawa robot's HSES server, allowing you to test your client applications without requiring actual hardware.
The following robot models have been tested and verified for compatibility:
| Robot Model | Status |
|---|---|
| DX100 | ❌ Not verified |
| FS100 | ❌ Not verified |
| DX200 | ❌ Not verified |
| YRC1000 | ❌ Not verified |
| YRC1000micro | ✅ Verified |
| Command No | Command Name |
|---|---|
| 0x70 | Alarm Data Reading Command |
| 0x71 | Alarm History Reading Command |
| 0x72 | Read Status Information |
| 0x73 | Executing Job Information Reading Command |
| 0x75 | Robot Position Data Reading Command |
| 0x78 | I/O Data Reading / Writing Command |
| 0x79 | Register Data Reading / Writing Command |
| 0x7A | Byte Variable (B) Reading / Writing Command |
| 0x7B | Integer Type Variable (I) Reading / Writing Command |
| 0x7C | Double Precision Integer Type Variable (D) Reading / Writing Command |
| 0x7D | Real Type Variable (R) Reading / Writing Command |
| 0x7E | Character Type Variable (S) Reading / Writing Command |
| 0x82 | Alarm Reset / Error Cancel Command |
| 0x83 | Hold / Servo On/off Command |
| 0x84 | Step / Cycle / Continuous Switching Command |
| 0x86 | Start-up (Job Start) Command |
| 0x87 | Job Select Command |
| 0x300 | Plural I/O Data Reading / Writing Command |
| 0x301 | Plural Register Data Reading / Writing Command |
| 0x302 | Plural Byte Type Variable (B) Reading / Writing Command |
| 0x303 | Plural Integer Type Variable (I) Reading / Writing Command |
| 0x304 | Plural Double Precision Integer Type Variable (D) Reading / Writing Command |
| 0x305 | Plural Real Type Variable (R) Reading / Writing Command |
| 0x306 | Plural Character Type Variable (S) Reading / Writing Command |
| Service | Command Name |
|---|---|
| 0x09 | File Delete |
| 0x16 | File saving command (Controller to the PC) |
| 0x32 | File list acquiring |
Add this to your Cargo.toml:
[dev-dependencies]
moto-hses-mock = "0.2"
tokio = { version = "1.0", features = ["full"] }
use moto_hses_mock::{MockServer, MockServerBuilder};
use moto_hses_proto::Alarm;
#[tokio::main]
async fn main() -> Result<(), Box<dyn std::error::Error>> {
// Start mock server with custom configuration using builder pattern
let server = MockServerBuilder::new()
.host("192.168.0.3")
.robot_port(20000)
.file_port(20001)
.with_alarm(Alarm::new(1001, 0, 0, "2024-01-01 12:00:00".to_string(), "Test alarm".to_string()))
.with_io_state(1, true)
.build()
.await?;
// Server will run until the program exits
server.run().await?;
Ok(())
}
The crate includes examples demonstrating various usage patterns:
mock_basic_usage.rs - Basic mock server usagemoto-hses-client for end-to-end testing# Run the basic usage example
cargo run --example mock_basic_usage
# Run with custom address and port
cargo run --example mock_basic_usage -- 192.168.0.3 10040 10041
This project is licensed under the Apache License, Version 2.0. See the LICENSE file for details.
moto-hses-proto - Protocol definitions and serializationmoto-hses-client - Async UDP client for HSES communication