fuchsia_inspect/writer/types/
string_property.rsuse crate::writer::{Inner, InnerPropertyType, InspectType, Property};
use log::error;
#[derive(Debug, PartialEq, Eq, Default)]
pub struct StringProperty {
inner: Inner<InnerPropertyType>,
}
impl<'t> Property<'t> for StringProperty {
type Type = &'t str;
fn set(&self, value: &'t str) {
if let Some(ref inner_ref) = self.inner.inner_ref() {
inner_ref
.state
.try_lock()
.and_then(|mut state| state.set_property(inner_ref.block_index, value.as_bytes()))
.unwrap_or_else(|e| error!("Failed to set property. Error: {:?}", e));
}
}
}
impl InspectType for StringProperty {}
crate::impl_inspect_type_internal!(StringProperty);
#[cfg(test)]
mod tests {
use super::*;
use crate::writer::testing_utils::{get_state, GetBlockExt};
use crate::writer::Node;
use inspect_format::{BlockType, PropertyFormat};
#[fuchsia::test]
fn string_property() {
let default = StringProperty::default();
default.set("test");
let state = get_state(4096);
let root = Node::new_root(state);
let node = root.create_child("node");
{
let property = node.create_string("property", "test");
property.get_block(|property_block| {
assert_eq!(property_block.block_type(), BlockType::BufferValue);
assert_eq!(property_block.total_length().unwrap(), 4);
assert_eq!(property_block.property_format().unwrap(), PropertyFormat::String);
});
node.get_block(|node_block| {
assert_eq!(node_block.child_count().unwrap(), 1);
});
property.set("test-set");
property.get_block(|property_block| {
assert_eq!(property_block.total_length().unwrap(), 8);
});
}
node.get_block(|node_block| {
assert_eq!(node_block.child_count().unwrap(), 0);
});
}
}