-
Notifications
You must be signed in to change notification settings - Fork 367
/
Copy pathserde.rs
124 lines (108 loc) · 3.51 KB
/
serde.rs
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
// This file simply re-exports some methods from serde_json
// The reason is two fold:
// 1. To easily ensure that all calling libraries use the same version (minimize code size)
// 2. To allow us to switch out to eg. serde-json-core more easily
use serde::{de::DeserializeOwned, Serialize};
use std::any::type_name;
use crate::binary::Binary;
use crate::errors::{StdError, StdResult};
pub fn from_slice<T: DeserializeOwned>(value: &[u8]) -> StdResult<T> {
serde_json_wasm::from_slice(value).map_err(|e| StdError::parse_err(type_name::<T>(), e))
}
pub fn from_binary<T: DeserializeOwned>(value: &Binary) -> StdResult<T> {
from_slice(value.as_slice())
}
pub fn to_vec<T>(data: &T) -> StdResult<Vec<u8>>
where
T: Serialize + ?Sized,
{
serde_json_wasm::to_vec(data).map_err(|e| StdError::serialize_err(type_name::<T>(), e))
}
pub fn to_binary<T>(data: &T) -> StdResult<Binary>
where
T: Serialize + ?Sized,
{
to_vec(data).map(Binary)
}
#[cfg(test)]
mod tests {
use super::*;
use serde::Deserialize;
#[derive(Serialize, Deserialize, Debug, PartialEq)]
#[serde(rename_all = "snake_case")]
enum SomeMsg {
Refund {},
ReleaseAll {
image: String,
amount: u32,
time: u64,
karma: i32,
},
Cowsay {
text: String,
},
}
#[test]
fn to_vec_works() {
let msg = SomeMsg::Refund {};
let serialized = to_vec(&msg).unwrap();
assert_eq!(serialized, br#"{"refund":{}}"#);
let msg = SomeMsg::ReleaseAll {
image: "foo".to_string(),
amount: 42,
time: 9007199254740999, // Number.MAX_SAFE_INTEGER + 7
karma: -17,
};
let serialized = String::from_utf8(to_vec(&msg).unwrap()).unwrap();
assert_eq!(
serialized,
r#"{"release_all":{"image":"foo","amount":42,"time":9007199254740999,"karma":-17}}"#
);
}
#[test]
fn from_slice_works() {
let deserialized: SomeMsg = from_slice(br#"{"refund":{}}"#).unwrap();
assert_eq!(deserialized, SomeMsg::Refund {});
let deserialized: SomeMsg = from_slice(
br#"{"release_all":{"image":"foo","amount":42,"time":18446744073709551615,"karma":-17}}"#,
)
.unwrap();
assert_eq!(
deserialized,
SomeMsg::ReleaseAll {
image: "foo".to_string(),
amount: 42,
time: 18446744073709551615,
karma: -17
}
);
}
#[test]
fn from_slice_or_binary() {
let msg = SomeMsg::Refund {};
let serialized: Binary = to_binary(&msg).unwrap();
let parse_binary: SomeMsg = from_binary(&serialized).unwrap();
assert_eq!(parse_binary, msg);
let parse_slice: SomeMsg = from_slice(&serialized).unwrap();
assert_eq!(parse_slice, msg);
}
#[test]
fn to_vec_works_for_special_chars() {
let msg = SomeMsg::Cowsay {
text: "foo\"bar\\\"bla".to_string(),
};
let serialized = String::from_utf8(to_vec(&msg).unwrap()).unwrap();
assert_eq!(serialized, r#"{"cowsay":{"text":"foo\"bar\\\"bla"}}"#);
}
#[test]
fn from_slice_works_for_special_chars() {
let deserialized: SomeMsg =
from_slice(br#"{"cowsay":{"text":"foo\"bar\\\"bla"}}"#).unwrap();
assert_eq!(
deserialized,
SomeMsg::Cowsay {
text: "foo\"bar\\\"bla".to_string(),
}
);
}
}