codama_nodes/link_nodes/
account_link_node.rsuse crate::{CamelCaseString, ProgramLinkNode};
use codama_nodes_derive::node;
#[node]
pub struct AccountLinkNode {
pub name: CamelCaseString,
#[serde(skip_serializing_if = "Option::is_none")]
pub program: Option<ProgramLinkNode>,
}
impl From<AccountLinkNode> for crate::Node {
fn from(val: AccountLinkNode) -> Self {
crate::Node::Link(val.into())
}
}
impl AccountLinkNode {
pub fn new<T>(name: T) -> Self
where
T: Into<CamelCaseString>,
{
Self {
name: name.into(),
program: None,
}
}
pub fn new_from_program<T>(name: T, program: ProgramLinkNode) -> Self
where
T: Into<CamelCaseString>,
{
Self {
name: name.into(),
program: Some(program),
}
}
}
impl From<String> for AccountLinkNode {
fn from(name: String) -> Self {
Self::new(name)
}
}
impl From<&str> for AccountLinkNode {
fn from(name: &str) -> Self {
Self::new(name)
}
}
#[cfg(test)]
mod tests {
use super::*;
#[test]
fn new() {
let node = AccountLinkNode::new("my_account");
assert_eq!(node.name, CamelCaseString::new("myAccount"));
}
#[test]
fn new_from_program() {
let node =
AccountLinkNode::new_from_program("my_account", ProgramLinkNode::new("my_program"));
assert_eq!(node.name, CamelCaseString::new("myAccount"));
assert_eq!(node.program, Some(ProgramLinkNode::new("myProgram")));
}
#[test]
fn from_string() {
let node: AccountLinkNode = String::from("my_account").into();
assert_eq!(node.name, CamelCaseString::new("myAccount"));
assert_eq!(node.program, None);
}
#[test]
fn from_str() {
let node: AccountLinkNode = "my_account".into();
assert_eq!(node.name, CamelCaseString::new("myAccount"));
assert_eq!(node.program, None);
}
#[test]
fn to_json() {
let node = AccountLinkNode::new("myAccount");
let json = serde_json::to_string(&node).unwrap();
assert_eq!(json, r#"{"kind":"accountLinkNode","name":"myAccount"}"#);
}
#[test]
fn from_json() {
let json = r#"{"kind":"accountLinkNode","name":"myAccount"}"#;
let node: AccountLinkNode = serde_json::from_str(json).unwrap();
assert_eq!(node, AccountLinkNode::new("myAccount"));
}
}