ruma_common/identifiers/
device_id.rs
use ruma_macros::IdZst;
#[cfg(feature = "rand")]
use super::generate_localpart;
use super::{IdParseError, KeyName};
#[repr(transparent)]
#[derive(PartialEq, Eq, PartialOrd, Ord, Hash, IdZst)]
pub struct DeviceId(str);
impl DeviceId {
#[cfg(feature = "rand")]
#[allow(clippy::new_ret_no_self)]
pub fn new() -> OwnedDeviceId {
Self::from_borrowed(&generate_localpart(8)).to_owned()
}
}
impl KeyName for DeviceId {
fn validate(_s: &str) -> Result<(), IdParseError> {
Ok(())
}
}
impl KeyName for OwnedDeviceId {
fn validate(_s: &str) -> Result<(), IdParseError> {
Ok(())
}
}
#[cfg(test)]
mod tests {
use super::{DeviceId, OwnedDeviceId};
#[cfg(feature = "rand")]
#[test]
fn generate_device_id() {
assert_eq!(DeviceId::new().as_str().len(), 8);
}
#[test]
fn create_device_id_from_str() {
let ref_id: &DeviceId = "abcdefgh".into();
assert_eq!(ref_id.as_str(), "abcdefgh");
}
#[test]
fn create_boxed_device_id_from_str() {
let box_id: OwnedDeviceId = "12345678".into();
assert_eq!(box_id.as_str(), "12345678");
}
#[test]
fn create_device_id_from_box() {
let box_str: Box<str> = "ijklmnop".into();
let device_id: OwnedDeviceId = box_str.into();
assert_eq!(device_id.as_str(), "ijklmnop");
}
}