]> git.proxmox.com Git - rustc.git/blame - src/libcore/tests/time.rs
New upstream version 1.29.0+dfsg1
[rustc.git] / src / libcore / tests / time.rs
CommitLineData
83c7162d
XL
1// Copyright 2018 The Rust Project Developers. See the COPYRIGHT
2// file at the top-level directory of this distribution and at
3// http://rust-lang.org/COPYRIGHT.
4//
5// Licensed under the Apache License, Version 2.0 <LICENSE-APACHE or
6// http://www.apache.org/licenses/LICENSE-2.0> or the MIT license
7// <LICENSE-MIT or http://opensource.org/licenses/MIT>, at your
8// option. This file may not be copied, modified, or distributed
9// except according to those terms.
10
11use core::time::Duration;
12
13#[test]
14fn creation() {
15 assert!(Duration::from_secs(1) != Duration::from_secs(0));
16 assert_eq!(Duration::from_secs(1) + Duration::from_secs(2),
17 Duration::from_secs(3));
18 assert_eq!(Duration::from_millis(10) + Duration::from_secs(4),
19 Duration::new(4, 10 * 1_000_000));
20 assert_eq!(Duration::from_millis(4000), Duration::new(4, 0));
21}
22
23#[test]
24fn secs() {
25 assert_eq!(Duration::new(0, 0).as_secs(), 0);
94b46f34
XL
26 assert_eq!(Duration::new(0, 500_000_005).as_secs(), 0);
27 assert_eq!(Duration::new(0, 1_050_000_001).as_secs(), 1);
83c7162d
XL
28 assert_eq!(Duration::from_secs(1).as_secs(), 1);
29 assert_eq!(Duration::from_millis(999).as_secs(), 0);
30 assert_eq!(Duration::from_millis(1001).as_secs(), 1);
94b46f34
XL
31 assert_eq!(Duration::from_micros(999_999).as_secs(), 0);
32 assert_eq!(Duration::from_micros(1_000_001).as_secs(), 1);
33 assert_eq!(Duration::from_nanos(999_999_999).as_secs(), 0);
34 assert_eq!(Duration::from_nanos(1_000_000_001).as_secs(), 1);
35}
36
37#[test]
38fn millis() {
39 assert_eq!(Duration::new(0, 0).subsec_millis(), 0);
40 assert_eq!(Duration::new(0, 500_000_005).subsec_millis(), 500);
41 assert_eq!(Duration::new(0, 1_050_000_001).subsec_millis(), 50);
42 assert_eq!(Duration::from_secs(1).subsec_millis(), 0);
43 assert_eq!(Duration::from_millis(999).subsec_millis(), 999);
44 assert_eq!(Duration::from_millis(1001).subsec_millis(), 1);
45 assert_eq!(Duration::from_micros(999_999).subsec_millis(), 999);
46 assert_eq!(Duration::from_micros(1_001_000).subsec_millis(), 1);
47 assert_eq!(Duration::from_nanos(999_999_999).subsec_millis(), 999);
48 assert_eq!(Duration::from_nanos(1_001_000_000).subsec_millis(), 1);
49}
50
51#[test]
52fn micros() {
53 assert_eq!(Duration::new(0, 0).subsec_micros(), 0);
54 assert_eq!(Duration::new(0, 500_000_005).subsec_micros(), 500_000);
55 assert_eq!(Duration::new(0, 1_050_000_001).subsec_micros(), 50_000);
56 assert_eq!(Duration::from_secs(1).subsec_micros(), 0);
57 assert_eq!(Duration::from_millis(999).subsec_micros(), 999_000);
58 assert_eq!(Duration::from_millis(1001).subsec_micros(), 1_000);
59 assert_eq!(Duration::from_micros(999_999).subsec_micros(), 999_999);
60 assert_eq!(Duration::from_micros(1_000_001).subsec_micros(), 1);
61 assert_eq!(Duration::from_nanos(999_999_999).subsec_micros(), 999_999);
62 assert_eq!(Duration::from_nanos(1_000_001_000).subsec_micros(), 1);
83c7162d
XL
63}
64
65#[test]
66fn nanos() {
67 assert_eq!(Duration::new(0, 0).subsec_nanos(), 0);
68 assert_eq!(Duration::new(0, 5).subsec_nanos(), 5);
69 assert_eq!(Duration::new(0, 1_000_000_001).subsec_nanos(), 1);
70 assert_eq!(Duration::from_secs(1).subsec_nanos(), 0);
94b46f34
XL
71 assert_eq!(Duration::from_millis(999).subsec_nanos(), 999_000_000);
72 assert_eq!(Duration::from_millis(1001).subsec_nanos(), 1_000_000);
73 assert_eq!(Duration::from_micros(999_999).subsec_nanos(), 999_999_000);
74 assert_eq!(Duration::from_micros(1_000_001).subsec_nanos(), 1000);
75 assert_eq!(Duration::from_nanos(999_999_999).subsec_nanos(), 999_999_999);
76 assert_eq!(Duration::from_nanos(1_000_000_001).subsec_nanos(), 1);
83c7162d
XL
77}
78
79#[test]
80fn add() {
81 assert_eq!(Duration::new(0, 0) + Duration::new(0, 1),
82 Duration::new(0, 1));
83 assert_eq!(Duration::new(0, 500_000_000) + Duration::new(0, 500_000_001),
84 Duration::new(1, 1));
85}
86
87#[test]
88fn checked_add() {
89 assert_eq!(Duration::new(0, 0).checked_add(Duration::new(0, 1)),
90 Some(Duration::new(0, 1)));
91 assert_eq!(Duration::new(0, 500_000_000).checked_add(Duration::new(0, 500_000_001)),
92 Some(Duration::new(1, 1)));
93 assert_eq!(Duration::new(1, 0).checked_add(Duration::new(::core::u64::MAX, 0)), None);
94}
95
96#[test]
97fn sub() {
98 assert_eq!(Duration::new(0, 1) - Duration::new(0, 0),
99 Duration::new(0, 1));
100 assert_eq!(Duration::new(0, 500_000_001) - Duration::new(0, 500_000_000),
101 Duration::new(0, 1));
102 assert_eq!(Duration::new(1, 0) - Duration::new(0, 1),
103 Duration::new(0, 999_999_999));
104}
105
106#[test]
107fn checked_sub() {
108 let zero = Duration::new(0, 0);
109 let one_nano = Duration::new(0, 1);
110 let one_sec = Duration::new(1, 0);
111 assert_eq!(one_nano.checked_sub(zero), Some(Duration::new(0, 1)));
112 assert_eq!(one_sec.checked_sub(one_nano),
113 Some(Duration::new(0, 999_999_999)));
114 assert_eq!(zero.checked_sub(one_nano), None);
115 assert_eq!(zero.checked_sub(one_sec), None);
116}
117
118#[test]
119#[should_panic]
120fn sub_bad1() {
121 let _ = Duration::new(0, 0) - Duration::new(0, 1);
122}
123
124#[test]
125#[should_panic]
126fn sub_bad2() {
127 let _ = Duration::new(0, 0) - Duration::new(1, 0);
128}
129
130#[test]
131fn mul() {
132 assert_eq!(Duration::new(0, 1) * 2, Duration::new(0, 2));
133 assert_eq!(Duration::new(1, 1) * 3, Duration::new(3, 3));
134 assert_eq!(Duration::new(0, 500_000_001) * 4, Duration::new(2, 4));
135 assert_eq!(Duration::new(0, 500_000_001) * 4000,
136 Duration::new(2000, 4000));
137}
138
139#[test]
140fn checked_mul() {
141 assert_eq!(Duration::new(0, 1).checked_mul(2), Some(Duration::new(0, 2)));
142 assert_eq!(Duration::new(1, 1).checked_mul(3), Some(Duration::new(3, 3)));
143 assert_eq!(Duration::new(0, 500_000_001).checked_mul(4), Some(Duration::new(2, 4)));
144 assert_eq!(Duration::new(0, 500_000_001).checked_mul(4000),
145 Some(Duration::new(2000, 4000)));
146 assert_eq!(Duration::new(::core::u64::MAX - 1, 0).checked_mul(2), None);
147}
148
149#[test]
150fn div() {
151 assert_eq!(Duration::new(0, 1) / 2, Duration::new(0, 0));
152 assert_eq!(Duration::new(1, 1) / 3, Duration::new(0, 333_333_333));
153 assert_eq!(Duration::new(99, 999_999_000) / 100,
154 Duration::new(0, 999_999_990));
155}
156
157#[test]
158fn checked_div() {
159 assert_eq!(Duration::new(2, 0).checked_div(2), Some(Duration::new(1, 0)));
160 assert_eq!(Duration::new(1, 0).checked_div(2), Some(Duration::new(0, 500_000_000)));
161 assert_eq!(Duration::new(2, 0).checked_div(0), None);
162}
94b46f34 163
8faf50e0
XL
164#[test]
165fn correct_sum() {
166 let durations = [
167 Duration::new(1, 999_999_999),
168 Duration::new(2, 999_999_999),
169 Duration::new(0, 999_999_999),
170 Duration::new(0, 999_999_999),
171 Duration::new(0, 999_999_999),
172 Duration::new(5, 0),
173 ];
174 let sum = durations.iter().sum::<Duration>();
175 assert_eq!(sum, Duration::new(1+2+5+4, 1_000_000_000 - 5));
176}
177
94b46f34
XL
178#[test]
179fn debug_formatting_extreme_values() {
180 assert_eq!(
181 format!("{:?}", Duration::new(18_446_744_073_709_551_615, 123_456_789)),
182 "18446744073709551615.123456789s"
183 );
184}
185
186#[test]
187fn debug_formatting_secs() {
188 assert_eq!(format!("{:?}", Duration::new(7, 000_000_000)), "7s");
189 assert_eq!(format!("{:?}", Duration::new(7, 100_000_000)), "7.1s");
190 assert_eq!(format!("{:?}", Duration::new(7, 000_010_000)), "7.00001s");
191 assert_eq!(format!("{:?}", Duration::new(7, 000_000_001)), "7.000000001s");
192 assert_eq!(format!("{:?}", Duration::new(7, 123_456_789)), "7.123456789s");
193
194 assert_eq!(format!("{:?}", Duration::new(88, 000_000_000)), "88s");
195 assert_eq!(format!("{:?}", Duration::new(88, 100_000_000)), "88.1s");
196 assert_eq!(format!("{:?}", Duration::new(88, 000_010_000)), "88.00001s");
197 assert_eq!(format!("{:?}", Duration::new(88, 000_000_001)), "88.000000001s");
198 assert_eq!(format!("{:?}", Duration::new(88, 123_456_789)), "88.123456789s");
199
200 assert_eq!(format!("{:?}", Duration::new(999, 000_000_000)), "999s");
201 assert_eq!(format!("{:?}", Duration::new(999, 100_000_000)), "999.1s");
202 assert_eq!(format!("{:?}", Duration::new(999, 000_010_000)), "999.00001s");
203 assert_eq!(format!("{:?}", Duration::new(999, 000_000_001)), "999.000000001s");
204 assert_eq!(format!("{:?}", Duration::new(999, 123_456_789)), "999.123456789s");
205}
206
207#[test]
208fn debug_formatting_millis() {
209 assert_eq!(format!("{:?}", Duration::new(0, 7_000_000)), "7ms");
210 assert_eq!(format!("{:?}", Duration::new(0, 7_100_000)), "7.1ms");
211 assert_eq!(format!("{:?}", Duration::new(0, 7_000_001)), "7.000001ms");
212 assert_eq!(format!("{:?}", Duration::new(0, 7_123_456)), "7.123456ms");
213
214 assert_eq!(format!("{:?}", Duration::new(0, 88_000_000)), "88ms");
215 assert_eq!(format!("{:?}", Duration::new(0, 88_100_000)), "88.1ms");
216 assert_eq!(format!("{:?}", Duration::new(0, 88_000_001)), "88.000001ms");
217 assert_eq!(format!("{:?}", Duration::new(0, 88_123_456)), "88.123456ms");
218
219 assert_eq!(format!("{:?}", Duration::new(0, 999_000_000)), "999ms");
220 assert_eq!(format!("{:?}", Duration::new(0, 999_100_000)), "999.1ms");
221 assert_eq!(format!("{:?}", Duration::new(0, 999_000_001)), "999.000001ms");
222 assert_eq!(format!("{:?}", Duration::new(0, 999_123_456)), "999.123456ms");
223}
224
225#[test]
226fn debug_formatting_micros() {
227 assert_eq!(format!("{:?}", Duration::new(0, 7_000)), "7µs");
228 assert_eq!(format!("{:?}", Duration::new(0, 7_100)), "7.1µs");
229 assert_eq!(format!("{:?}", Duration::new(0, 7_001)), "7.001µs");
230 assert_eq!(format!("{:?}", Duration::new(0, 7_123)), "7.123µs");
231
232 assert_eq!(format!("{:?}", Duration::new(0, 88_000)), "88µs");
233 assert_eq!(format!("{:?}", Duration::new(0, 88_100)), "88.1µs");
234 assert_eq!(format!("{:?}", Duration::new(0, 88_001)), "88.001µs");
235 assert_eq!(format!("{:?}", Duration::new(0, 88_123)), "88.123µs");
236
237 assert_eq!(format!("{:?}", Duration::new(0, 999_000)), "999µs");
238 assert_eq!(format!("{:?}", Duration::new(0, 999_100)), "999.1µs");
239 assert_eq!(format!("{:?}", Duration::new(0, 999_001)), "999.001µs");
240 assert_eq!(format!("{:?}", Duration::new(0, 999_123)), "999.123µs");
241}
242
243#[test]
244fn debug_formatting_nanos() {
245 assert_eq!(format!("{:?}", Duration::new(0, 0)), "0ns");
246 assert_eq!(format!("{:?}", Duration::new(0, 1)), "1ns");
247 assert_eq!(format!("{:?}", Duration::new(0, 88)), "88ns");
248 assert_eq!(format!("{:?}", Duration::new(0, 999)), "999ns");
249}
250
251#[test]
252fn debug_formatting_precision_zero() {
253 assert_eq!(format!("{:.0?}", Duration::new(0, 0)), "0ns");
254 assert_eq!(format!("{:.0?}", Duration::new(0, 123)), "123ns");
255
256 assert_eq!(format!("{:.0?}", Duration::new(0, 1_001)), "1µs");
257 assert_eq!(format!("{:.0?}", Duration::new(0, 1_499)), "1µs");
258 assert_eq!(format!("{:.0?}", Duration::new(0, 1_500)), "2µs");
259 assert_eq!(format!("{:.0?}", Duration::new(0, 1_999)), "2µs");
260
261 assert_eq!(format!("{:.0?}", Duration::new(0, 1_000_001)), "1ms");
262 assert_eq!(format!("{:.0?}", Duration::new(0, 1_499_999)), "1ms");
263 assert_eq!(format!("{:.0?}", Duration::new(0, 1_500_000)), "2ms");
264 assert_eq!(format!("{:.0?}", Duration::new(0, 1_999_999)), "2ms");
265
266 assert_eq!(format!("{:.0?}", Duration::new(1, 000_000_001)), "1s");
267 assert_eq!(format!("{:.0?}", Duration::new(1, 499_999_999)), "1s");
268 assert_eq!(format!("{:.0?}", Duration::new(1, 500_000_000)), "2s");
269 assert_eq!(format!("{:.0?}", Duration::new(1, 999_999_999)), "2s");
270}
271
272#[test]
273fn debug_formatting_precision_two() {
274 assert_eq!(format!("{:.2?}", Duration::new(0, 0)), "0.00ns");
275 assert_eq!(format!("{:.2?}", Duration::new(0, 123)), "123.00ns");
276
277 assert_eq!(format!("{:.2?}", Duration::new(0, 1_000)), "1.00µs");
278 assert_eq!(format!("{:.2?}", Duration::new(0, 7_001)), "7.00µs");
279 assert_eq!(format!("{:.2?}", Duration::new(0, 7_100)), "7.10µs");
280 assert_eq!(format!("{:.2?}", Duration::new(0, 7_109)), "7.11µs");
281 assert_eq!(format!("{:.2?}", Duration::new(0, 7_199)), "7.20µs");
282 assert_eq!(format!("{:.2?}", Duration::new(0, 1_999)), "2.00µs");
283
284 assert_eq!(format!("{:.2?}", Duration::new(0, 1_000_000)), "1.00ms");
285 assert_eq!(format!("{:.2?}", Duration::new(0, 3_001_000)), "3.00ms");
286 assert_eq!(format!("{:.2?}", Duration::new(0, 3_100_000)), "3.10ms");
287 assert_eq!(format!("{:.2?}", Duration::new(0, 1_999_999)), "2.00ms");
288
289 assert_eq!(format!("{:.2?}", Duration::new(1, 000_000_000)), "1.00s");
290 assert_eq!(format!("{:.2?}", Duration::new(4, 001_000_000)), "4.00s");
291 assert_eq!(format!("{:.2?}", Duration::new(2, 100_000_000)), "2.10s");
292 assert_eq!(format!("{:.2?}", Duration::new(2, 104_990_000)), "2.10s");
293 assert_eq!(format!("{:.2?}", Duration::new(2, 105_000_000)), "2.11s");
294 assert_eq!(format!("{:.2?}", Duration::new(8, 999_999_999)), "9.00s");
295}
296
297#[test]
298fn debug_formatting_precision_high() {
299 assert_eq!(format!("{:.5?}", Duration::new(0, 23_678)), "23.67800µs");
300
301 assert_eq!(format!("{:.9?}", Duration::new(1, 000_000_000)), "1.000000000s");
302 assert_eq!(format!("{:.10?}", Duration::new(4, 001_000_000)), "4.0010000000s");
303 assert_eq!(format!("{:.20?}", Duration::new(4, 001_000_000)), "4.00100000000000000000s");
304}