]> git.lizzy.rs Git - rust.git/blob - src/libserialize/tests/opaque.rs
Rollup merge of #64428 - GuillaumeGomez:error-explanation-E0524, r=Centril
[rust.git] / src / libserialize / tests / opaque.rs
1 #![allow(rustc::internal)]
2
3 extern crate serialize as rustc_serialize;
4
5 use rustc_serialize::{Encodable, Decodable};
6 use rustc_serialize::opaque::{Encoder, Decoder};
7 use std::fmt::Debug;
8
9 #[derive(PartialEq, Clone, Debug, RustcEncodable, RustcDecodable)]
10 struct Struct {
11     a: (),
12     b: u8,
13     c: u16,
14     d: u32,
15     e: u64,
16     f: usize,
17
18     g: i8,
19     h: i16,
20     i: i32,
21     j: i64,
22     k: isize,
23
24     l: char,
25     m: String,
26     n: f32,
27     o: f64,
28     p: bool,
29     q: Option<u32>,
30 }
31
32
33 fn check_round_trip<T: Encodable + Decodable + PartialEq + Debug>(values: Vec<T>) {
34     let mut encoder = Encoder::new(Vec::new());
35
36     for value in &values {
37         Encodable::encode(&value, &mut encoder).unwrap();
38     }
39
40     let data = encoder.into_inner();
41     let mut decoder = Decoder::new(&data[..], 0);
42
43     for value in values {
44         let decoded = Decodable::decode(&mut decoder).unwrap();
45         assert_eq!(value, decoded);
46     }
47 }
48
49 #[test]
50 fn test_unit() {
51     check_round_trip(vec![(), (), (), ()]);
52 }
53
54 #[test]
55 fn test_u8() {
56     let mut vec = vec![];
57     for i in ::std::u8::MIN..::std::u8::MAX {
58         vec.push(i);
59     }
60     check_round_trip(vec);
61 }
62
63 #[test]
64 fn test_u16() {
65     for i in ::std::u16::MIN..::std::u16::MAX {
66         check_round_trip(vec![1, 2, 3, i, i, i]);
67     }
68 }
69
70 #[test]
71 fn test_u32() {
72     check_round_trip(vec![1, 2, 3, ::std::u32::MIN, 0, 1, ::std::u32::MAX, 2, 1]);
73 }
74
75 #[test]
76 fn test_u64() {
77     check_round_trip(vec![1, 2, 3, ::std::u64::MIN, 0, 1, ::std::u64::MAX, 2, 1]);
78 }
79
80 #[test]
81 fn test_usize() {
82     check_round_trip(vec![1, 2, 3, ::std::usize::MIN, 0, 1, ::std::usize::MAX, 2, 1]);
83 }
84
85 #[test]
86 fn test_i8() {
87     let mut vec = vec![];
88     for i in ::std::i8::MIN..::std::i8::MAX {
89         vec.push(i);
90     }
91     check_round_trip(vec);
92 }
93
94 #[test]
95 fn test_i16() {
96     for i in ::std::i16::MIN..::std::i16::MAX {
97         check_round_trip(vec![-1, 2, -3, i, i, i, 2]);
98     }
99 }
100
101 #[test]
102 fn test_i32() {
103     check_round_trip(vec![-1, 2, -3, ::std::i32::MIN, 0, 1, ::std::i32::MAX, 2, 1]);
104 }
105
106 #[test]
107 fn test_i64() {
108     check_round_trip(vec![-1, 2, -3, ::std::i64::MIN, 0, 1, ::std::i64::MAX, 2, 1]);
109 }
110
111 #[test]
112 fn test_isize() {
113     check_round_trip(vec![-1, 2, -3, ::std::isize::MIN, 0, 1, ::std::isize::MAX, 2, 1]);
114 }
115
116 #[test]
117 fn test_bool() {
118     check_round_trip(vec![false, true, true, false, false]);
119 }
120
121 #[test]
122 fn test_f32() {
123     let mut vec = vec![];
124     for i in -100..100 {
125         vec.push((i as f32) / 3.0);
126     }
127     check_round_trip(vec);
128 }
129
130 #[test]
131 fn test_f64() {
132     let mut vec = vec![];
133     for i in -100..100 {
134         vec.push((i as f64) / 3.0);
135     }
136     check_round_trip(vec);
137 }
138
139 #[test]
140 fn test_char() {
141     let vec = vec!['a', 'b', 'c', 'd', 'A', 'X', ' ', '#', 'Ö', 'Ä', 'µ', '€'];
142     check_round_trip(vec);
143 }
144
145 #[test]
146 fn test_string() {
147     let vec = vec!["abcbuÖeiovÄnameÜavmpßvmea€µsbpnvapeapmaebn".to_string(),
148                    "abcbuÖganeiovÄnameÜavmpßvmea€µsbpnvapeapmaebn".to_string(),
149                    "abcbuÖganeiovÄnameÜavmpßvmea€µsbpapmaebn".to_string(),
150                    "abcbuÖganeiovÄnameÜavmpßvmeabpnvapeapmaebn".to_string(),
151                    "abcbuÖganeiÄnameÜavmpßvmea€µsbpnvapeapmaebn".to_string(),
152                    "abcbuÖganeiovÄnameÜavmpßvmea€µsbpmaebn".to_string(),
153                    "abcbuÖganeiovÄnameÜavmpßvmea€µnvapeapmaebn".to_string()];
154
155     check_round_trip(vec);
156 }
157
158 #[test]
159 fn test_option() {
160     check_round_trip(vec![Some(-1i8)]);
161     check_round_trip(vec![Some(-2i16)]);
162     check_round_trip(vec![Some(-3i32)]);
163     check_round_trip(vec![Some(-4i64)]);
164     check_round_trip(vec![Some(-5isize)]);
165
166     let none_i8: Option<i8> = None;
167     check_round_trip(vec![none_i8]);
168
169     let none_i16: Option<i16> = None;
170     check_round_trip(vec![none_i16]);
171
172     let none_i32: Option<i32> = None;
173     check_round_trip(vec![none_i32]);
174
175     let none_i64: Option<i64> = None;
176     check_round_trip(vec![none_i64]);
177
178     let none_isize: Option<isize> = None;
179     check_round_trip(vec![none_isize]);
180 }
181
182 #[test]
183 fn test_struct() {
184     check_round_trip(vec![Struct {
185                               a: (),
186                               b: 10,
187                               c: 11,
188                               d: 12,
189                               e: 13,
190                               f: 14,
191
192                               g: 15,
193                               h: 16,
194                               i: 17,
195                               j: 18,
196                               k: 19,
197
198                               l: 'x',
199                               m: "abc".to_string(),
200                               n: 20.5,
201                               o: 21.5,
202                               p: false,
203                               q: None,
204                           }]);
205
206     check_round_trip(vec![Struct {
207                               a: (),
208                               b: 101,
209                               c: 111,
210                               d: 121,
211                               e: 131,
212                               f: 141,
213
214                               g: -15,
215                               h: -16,
216                               i: -17,
217                               j: -18,
218                               k: -19,
219
220                               l: 'y',
221                               m: "def".to_string(),
222                               n: -20.5,
223                               o: -21.5,
224                               p: true,
225                               q: Some(1234567),
226                           }]);
227 }
228
229 #[derive(PartialEq, Clone, Debug, RustcEncodable, RustcDecodable)]
230 enum Enum {
231     Variant1,
232     Variant2(usize, f32),
233     Variant3 {
234         a: i32,
235         b: char,
236         c: bool,
237     },
238 }
239
240 #[test]
241 fn test_enum() {
242     check_round_trip(vec![Enum::Variant1,
243                           Enum::Variant2(1, 2.5),
244                           Enum::Variant3 {
245                               a: 3,
246                               b: 'b',
247                               c: false,
248                           },
249                           Enum::Variant3 {
250                               a: -4,
251                               b: 'f',
252                               c: true,
253                           }]);
254 }
255
256 #[test]
257 fn test_sequence() {
258     let mut vec = vec![];
259     for i in -100i64..100i64 {
260         vec.push(i * 100000);
261     }
262
263     check_round_trip(vec![vec]);
264 }
265
266 #[test]
267 fn test_hash_map() {
268     use std::collections::HashMap;
269     let mut map = HashMap::new();
270     for i in -100i64..100i64 {
271         map.insert(i * 100000, i * 10000);
272     }
273
274     check_round_trip(vec![map]);
275 }
276
277 #[test]
278 fn test_tuples() {
279     check_round_trip(vec![('x', (), false, 0.5f32)]);
280     check_round_trip(vec![(9i8, 10u16, 1.5f64)]);
281     check_round_trip(vec![(-12i16, 11u8, 12usize)]);
282     check_round_trip(vec![(1234567isize, 100000000000000u64, 99999999999999i64)]);
283     check_round_trip(vec![(String::new(), "some string".to_string())]);
284 }