use alloc::{borrow::ToOwned as _, string::String, vec, vec::Vec};
use insta::assert_snapshot;
use serde::Serialize;
#[derive(Serialize)]
struct NewType<T>(T);
#[test]
fn serialize_newtype_i32() {
let params = &[("field", Some(NewType(11)))];
assert_snapshot!(super::to_string(params).unwrap(), @"field=11");
}
#[test]
fn serialize_newtype_u128() {
let params = &[("field", Some(NewType(u128::MAX)))];
assert_snapshot!(super::to_string(params).unwrap(), @"field=340282366920938463463374607431768211455");
}
#[test]
fn serialize_newtype_i128() {
let params = &[("field", Some(NewType(i128::MIN)))];
assert_snapshot!(super::to_string(params).unwrap(), @"field=-170141183460469231731687303715884105728");
}
#[test]
fn serialize_option_map_int() {
let params = &[("first", Some(23)), ("middle", None), ("last", Some(42))];
assert_snapshot!(super::to_string(params).unwrap(), @"first=23&last=42");
}
#[test]
fn serialize_option_map_string() {
let params = &[("first", Some("hello")), ("middle", None), ("last", Some("world"))];
assert_snapshot!(super::to_string(params).unwrap(), @"first=hello&last=world");
}
#[test]
fn serialize_option_map_bool() {
let params = &[("one", Some(true)), ("two", Some(false))];
assert_snapshot!(super::to_string(params).unwrap(), @"one=true&two=false");
}
#[test]
fn serialize_map_bool() {
let params = &[("one", true), ("two", false)];
assert_snapshot!(super::to_string(params).unwrap(), @"one=true&two=false");
}
#[test]
fn serialize_map_duplicate_keys() {
let params = &[("foo", "a"), ("foo", "b")];
assert_snapshot!(super::to_string(params).unwrap(), @"foo=a&foo=b");
}
#[derive(Serialize)]
enum X {
A,
B,
C,
}
#[test]
fn serialize_unit_enum() {
let params = &[("one", X::A), ("two", X::B), ("three", X::C)];
assert_snapshot!(super::to_string(params).unwrap(), @"one=A&two=B&three=C");
}
#[derive(Serialize)]
struct Unit;
#[test]
fn serialize_unit_struct() {
assert_snapshot!(super::to_string(Unit).unwrap(), @"");
}
#[test]
fn serialize_unit_type() {
assert_snapshot!(super::to_string(()).unwrap(), @"");
}
#[derive(Serialize)]
struct Wrapper<T> {
item: T,
}
#[derive(Serialize)]
struct NewStruct {
list: Vec<String>,
}
#[derive(Serialize)]
struct Struct {
list: Vec<Option<String>>,
}
#[derive(Serialize)]
struct ListStruct {
list: Vec<NewType<usize>>,
}
#[test]
fn serialize_newstruct() {
let s = NewStruct { list: vec!["hello".into(), "world".into()] };
assert_snapshot!(super::to_string(s).unwrap(), @"list=hello&list=world");
}
#[test]
fn serialize_vec_bool() {
let params = Wrapper { item: vec![true, false, false] };
assert_snapshot!(super::to_string(params).unwrap(), @"item=true&item=false&item=false");
}
#[test]
fn serialize_vec_num() {
let params = Wrapper { item: vec![0, 1, 2] };
assert_snapshot!(super::to_string(params).unwrap(), @"item=0&item=1&item=2");
}
#[test]
fn serialize_vec_str() {
let params = Wrapper { item: vec!["hello", "world", "hello"] };
assert_snapshot!(super::to_string(params).unwrap(), @"item=hello&item=world&item=hello");
}
#[test]
fn serialize_struct_opt() {
let s = Struct { list: vec![Some("hello".into()), Some("world".into())] };
assert_snapshot!(super::to_string(s).unwrap(), @"list=hello&list=world");
}
#[test]
fn serialize_struct_newtype() {
let s = ListStruct { list: vec![NewType(0), NewType(1)] };
assert_snapshot!(super::to_string(s).unwrap(), @"list=0&list=1");
}
#[test]
fn serialize_struct_unit_enum() {
let params = Wrapper { item: vec![X::A, X::B, X::C] };
assert_snapshot!(super::to_string(params).unwrap(), @"item=A&item=B&item=C");
}
#[test]
fn serialize_list_of_str() {
let params = &[("list", vec!["hello", "world"])];
assert_snapshot!(super::to_string(params).unwrap(), @"list=hello&list=world");
}
#[test]
fn serialize_multiple_lists() {
#[derive(Serialize)]
struct Lists {
xs: Vec<bool>,
ys: Vec<u32>,
}
let params = Lists { xs: vec![true, false], ys: vec![3, 2, 1] };
assert_snapshot!(super::to_string(params).unwrap(), @"xs=true&xs=false&ys=3&ys=2&ys=1");
}
#[test]
fn serialize_nested_list() {
let params = &[("list", vec![vec![0_u8]])];
assert_snapshot!(super::to_string(params).unwrap_err(), @"unsupported value");
}
#[test]
fn serialize_list_of_option() {
let params = &[("list", vec![Some(10), Some(100)])];
assert_snapshot!(super::to_string(params).unwrap(), @"list=10&list=100");
}
#[test]
fn serialize_list_of_newtype() {
let params = &[("list", vec![NewType("test".to_owned())])];
assert_snapshot!(super::to_string(params).unwrap(), @"list=test");
}
#[test]
fn serialize_list_of_enum() {
let params = &[("item", vec![X::A, X::B, X::C])];
assert_snapshot!(super::to_string(params).unwrap(), @"item=A&item=B&item=C");
}
#[test]
fn serialize_map() {
let mut s = alloc::collections::BTreeMap::new();
s.insert("a", "hello");
s.insert("b", "world");
assert_snapshot!(super::to_string(s).unwrap(), @"a=hello&b=world");
}