test(tvix/serde): add initial set of deserialisation tests
Change-Id: I0a9779edf0296c25d37fb5f75f8fc5852fe00121 Reviewed-on: https://cl.tvl.fyi/c/depot/+/7715 Tested-by: BuildkiteCI Autosubmit: tazjin <tazjin@tvl.su> Reviewed-by: flokli <flokli@flokli.de>
This commit is contained in:
parent
4350be34d1
commit
00dab6142e
4 changed files with 87 additions and 1 deletions
|
@ -6633,6 +6633,7 @@ rec {
|
|||
{
|
||||
name = "serde";
|
||||
packageId = "serde";
|
||||
features = [ "derive" ];
|
||||
}
|
||||
{
|
||||
name = "tvix-eval";
|
||||
|
|
|
@ -5,4 +5,4 @@ edition = "2021"
|
|||
|
||||
[dependencies]
|
||||
tvix-eval = { path = "../eval" }
|
||||
serde = "1.0"
|
||||
serde = { version = "1.0", features = ["derive"] }
|
||||
|
|
82
tvix/serde/src/de_tests.rs
Normal file
82
tvix/serde/src/de_tests.rs
Normal file
|
@ -0,0 +1,82 @@
|
|||
use serde::Deserialize;
|
||||
use std::collections::HashMap;
|
||||
|
||||
use crate::de::from_str;
|
||||
|
||||
#[test]
|
||||
fn deserialize_none() {
|
||||
let result: Option<usize> = from_str("null").expect("should deserialize");
|
||||
assert_eq!(None, result);
|
||||
}
|
||||
|
||||
#[test]
|
||||
fn deserialize_some() {
|
||||
let result: Option<usize> = from_str("40 + 2").expect("should deserialize");
|
||||
assert_eq!(Some(42), result);
|
||||
}
|
||||
|
||||
#[test]
|
||||
fn deserialize_string() {
|
||||
let result: String = from_str(
|
||||
r#"
|
||||
let greeter = name: "Hello ${name}!";
|
||||
in greeter "Slartibartfast"
|
||||
"#,
|
||||
)
|
||||
.expect("should deserialize");
|
||||
|
||||
assert_eq!(result, "Hello Slartibartfast!");
|
||||
}
|
||||
|
||||
#[test]
|
||||
fn deserialize_empty_list() {
|
||||
let result: Vec<usize> = from_str("[ ]").expect("should deserialize");
|
||||
assert!(result.is_empty())
|
||||
}
|
||||
|
||||
#[test]
|
||||
fn deserialize_integer_list() {
|
||||
let result: Vec<usize> =
|
||||
from_str("builtins.map (n: n + 2) [ 21 40 67 ]").expect("should deserialize");
|
||||
assert_eq!(result, vec![23, 42, 69]);
|
||||
}
|
||||
|
||||
#[test]
|
||||
fn deserialize_empty_map() {
|
||||
let result: HashMap<String, usize> = from_str("{ }").expect("should deserialize");
|
||||
assert!(result.is_empty());
|
||||
}
|
||||
|
||||
#[test]
|
||||
fn deserialize_integer_map() {
|
||||
let result: HashMap<String, usize> = from_str("{ age = 40 + 2; }").expect("should deserialize");
|
||||
assert_eq!(result.len(), 1);
|
||||
assert_eq!(*result.get("age").unwrap(), 42);
|
||||
}
|
||||
|
||||
#[test]
|
||||
fn deserialize_struct() {
|
||||
#[derive(Debug, Deserialize, PartialEq)]
|
||||
struct Person {
|
||||
name: String,
|
||||
age: usize,
|
||||
}
|
||||
|
||||
let result: Person = from_str(
|
||||
r#"
|
||||
{
|
||||
name = "Slartibartfast";
|
||||
age = 42;
|
||||
}
|
||||
"#,
|
||||
)
|
||||
.expect("should deserialize");
|
||||
|
||||
assert_eq!(
|
||||
result,
|
||||
Person {
|
||||
name: "Slartibartfast".into(),
|
||||
age: 42,
|
||||
}
|
||||
);
|
||||
}
|
|
@ -6,3 +6,6 @@ mod de;
|
|||
mod error;
|
||||
|
||||
pub use de::from_str;
|
||||
|
||||
#[cfg(test)]
|
||||
mod de_tests;
|
||||
|
|
Loading…
Reference in a new issue