#![cfg(test)]
use anyhow::Result;
use regorus::*;
#[test]
fn non_string_key() -> Result<()> {
let mut obj = Value::new_object();
obj.as_object_mut()?.insert(Value::Null, Value::Null);
obj.as_object_mut()?.insert(Value::Bool(false), Value::Null);
obj.as_object_mut()?
.insert(Value::from(std::f64::consts::PI), Value::Null);
obj.as_object_mut()?.insert(
Value::from(vec![
Value::Bool(true),
Value::Null,
Value::from(std::f64::consts::PI),
]),
Value::Null,
);
let mut set = Value::new_set();
set.as_set_mut()?.insert(Value::Bool(true));
set.as_set_mut()?.insert(Value::Bool(false));
set.as_set_mut()?.insert(Value::Bool(true));
set.as_set_mut()?.insert(Value::from(std::f64::consts::PI));
obj.as_object_mut()?.insert(set, Value::Null);
obj.as_object_mut()?.insert(Value::Undefined, Value::Null);
let key_obj = obj.clone();
obj.as_object_mut()?.insert(key_obj, Value::Null);
let json = serde_json::to_string_pretty(&obj)?;
println!("{json}");
let expected = r#"{
"null": null,
"false": null,
"3.141592653589793": null,
"[true,null,3.141592653589793]": null,
"[false,true,3.141592653589793]": null,
"{\"null\":null,\"false\":null,\"3.141592653589793\":null,\"[true,null,3.141592653589793]\":null,\"[false,true,3.141592653589793]\":null,\"\\\"<undefined>\\\"\":null}": null,
"\"<undefined>\"": null
}"#;
assert_eq!(json, expected);
Ok(())
}
#[test]
fn serialize_number() -> Result<()> {
assert_eq!(serde_json::to_string_pretty(&Value::from(1.0))?, "1");
assert_eq!(serde_json::to_string_pretty(&Value::from(-1.0))?, "-1");
assert_eq!(serde_json::to_string_pretty(&Value::from(1.1))?, "1.1");
assert_eq!(serde_json::to_string_pretty(&Value::from(-1.1))?, "-1.1");
Ok(())
}
#[test]
fn serialize_string() -> Result<()> {
assert_eq!(
Value::String("Hello, World\n".into()).to_json_str()?,
"\"Hello, World\\n\""
);
Ok(())
}
#[test]
fn constructors() -> Result<()> {
assert_eq!(Value::new_object(), Value::from_json_str("{}")?);
assert!(Value::new_set().as_set()?.is_empty());
Ok(())
}
#[test]
fn value_as_index() -> Result<()> {
let idx = Value::from(2.0);
let mut item = Value::new_array();
item.as_array_mut()?.push(Value::from(3.0));
item.as_array_mut()?.push(Value::from(4.0));
item.as_array_mut()?.push(Value::from(5.0));
assert_eq!(&Value::from_json_str("[1, 2, [3, 4, 5]]")?[&idx], &item);
let idx = Value::from(5.0);
assert_eq!(
&Value::from_json_str("[1, 2, [3, 4, 5]]")?[&idx],
&Value::Undefined
);
assert_eq!(&Value::Undefined[&idx], &Value::Undefined);
assert_eq!(&Value::Null[&idx], &Value::Undefined);
assert_eq!(&Value::Bool(true)[&idx], &Value::Undefined);
assert_eq!(&Value::String("Hello".into())[&idx], &Value::Undefined);
assert_eq!(&Value::new_set()[&idx], &Value::Undefined);
Ok(())
}
#[test]
fn string_as_index() -> Result<()> {
let obj = Value::from_json_str(r#"{ "a" : 5, "b" : 6 }"#)?;
assert_eq!(&obj["a"], &Value::from(5.0));
assert_eq!(&obj["b".to_owned()], &Value::from(6.0));
Ok(())
}
#[test]
fn usize_as_index() -> Result<()> {
assert_eq!(&Value::from_json_str("[1, 2, 3]")?[0u64], &Value::from(1.0));
assert_eq!(&Value::from_json_str("[1, 2, 3]")?[5u64], &Value::Undefined);
Ok(())
}
#[test]
fn api() -> Result<()> {
assert!(&Value::from_json_str("{}")?.as_object()?.is_empty());
let mut v = Value::new_object();
v.as_object_mut()?
.insert(Value::String("a".into()), Value::from(3.145));
assert_eq!(v["a"], Value::from(3.145));
assert_eq!(v.as_object()?.len(), 1);
let v = Value::new_set();
assert_eq!(v.as_set()?.len(), 0);
assert!(Value::Undefined.as_object().is_err());
assert!(Value::Undefined.as_object_mut().is_err());
assert!(Value::Null.as_set().is_err());
assert!(Value::Null.as_set_mut().is_err());
assert!(Value::String("anc".into()).as_array().is_err());
assert!(Value::String("anc".into()).as_array_mut().is_err());
assert!(Value::new_object().as_number().is_err());
assert!(Value::new_object().as_number_mut().is_err());
assert!(Value::from(5.6).as_bool().is_err());
assert!(Value::from(5.6).as_bool_mut().is_err());
Ok(())
}