1 use core::time::Duration;
5 assert_ne!(Duration::from_secs(1), Duration::from_secs(0));
6 assert_eq!(Duration::from_secs(1) + Duration::from_secs(2), Duration::from_secs(3));
8 Duration::from_millis(10) + Duration::from_secs(4),
9 Duration::new(4, 10 * 1_000_000)
11 assert_eq!(Duration::from_millis(4000), Duration::new(4, 0));
16 assert_eq!(Duration::new(0, 0).as_secs(), 0);
17 assert_eq!(Duration::new(0, 500_000_005).as_secs(), 0);
18 assert_eq!(Duration::new(0, 1_050_000_001).as_secs(), 1);
19 assert_eq!(Duration::from_secs(1).as_secs(), 1);
20 assert_eq!(Duration::from_millis(999).as_secs(), 0);
21 assert_eq!(Duration::from_millis(1001).as_secs(), 1);
22 assert_eq!(Duration::from_micros(999_999).as_secs(), 0);
23 assert_eq!(Duration::from_micros(1_000_001).as_secs(), 1);
24 assert_eq!(Duration::from_nanos(999_999_999).as_secs(), 0);
25 assert_eq!(Duration::from_nanos(1_000_000_001).as_secs(), 1);
30 assert_eq!(Duration::new(0, 0).subsec_millis(), 0);
31 assert_eq!(Duration::new(0, 500_000_005).subsec_millis(), 500);
32 assert_eq!(Duration::new(0, 1_050_000_001).subsec_millis(), 50);
33 assert_eq!(Duration::from_secs(1).subsec_millis(), 0);
34 assert_eq!(Duration::from_millis(999).subsec_millis(), 999);
35 assert_eq!(Duration::from_millis(1001).subsec_millis(), 1);
36 assert_eq!(Duration::from_micros(999_999).subsec_millis(), 999);
37 assert_eq!(Duration::from_micros(1_001_000).subsec_millis(), 1);
38 assert_eq!(Duration::from_nanos(999_999_999).subsec_millis(), 999);
39 assert_eq!(Duration::from_nanos(1_001_000_000).subsec_millis(), 1);
44 assert_eq!(Duration::new(0, 0).subsec_micros(), 0);
45 assert_eq!(Duration::new(0, 500_000_005).subsec_micros(), 500_000);
46 assert_eq!(Duration::new(0, 1_050_000_001).subsec_micros(), 50_000);
47 assert_eq!(Duration::from_secs(1).subsec_micros(), 0);
48 assert_eq!(Duration::from_millis(999).subsec_micros(), 999_000);
49 assert_eq!(Duration::from_millis(1001).subsec_micros(), 1_000);
50 assert_eq!(Duration::from_micros(999_999).subsec_micros(), 999_999);
51 assert_eq!(Duration::from_micros(1_000_001).subsec_micros(), 1);
52 assert_eq!(Duration::from_nanos(999_999_999).subsec_micros(), 999_999);
53 assert_eq!(Duration::from_nanos(1_000_001_000).subsec_micros(), 1);
58 assert_eq!(Duration::new(0, 0).subsec_nanos(), 0);
59 assert_eq!(Duration::new(0, 5).subsec_nanos(), 5);
60 assert_eq!(Duration::new(0, 1_000_000_001).subsec_nanos(), 1);
61 assert_eq!(Duration::from_secs(1).subsec_nanos(), 0);
62 assert_eq!(Duration::from_millis(999).subsec_nanos(), 999_000_000);
63 assert_eq!(Duration::from_millis(1001).subsec_nanos(), 1_000_000);
64 assert_eq!(Duration::from_micros(999_999).subsec_nanos(), 999_999_000);
65 assert_eq!(Duration::from_micros(1_000_001).subsec_nanos(), 1000);
66 assert_eq!(Duration::from_nanos(999_999_999).subsec_nanos(), 999_999_999);
67 assert_eq!(Duration::from_nanos(1_000_000_001).subsec_nanos(), 1);
72 assert_eq!(Duration::new(0, 0) + Duration::new(0, 1), Duration::new(0, 1));
73 assert_eq!(Duration::new(0, 500_000_000) + Duration::new(0, 500_000_001), Duration::new(1, 1));
78 assert_eq!(Duration::new(0, 0).checked_add(Duration::new(0, 1)), Some(Duration::new(0, 1)));
80 Duration::new(0, 500_000_000).checked_add(Duration::new(0, 500_000_001)),
81 Some(Duration::new(1, 1))
83 assert_eq!(Duration::new(1, 0).checked_add(Duration::new(::core::u64::MAX, 0)), None);
88 assert_eq!(Duration::new(0, 1) - Duration::new(0, 0), Duration::new(0, 1));
89 assert_eq!(Duration::new(0, 500_000_001) - Duration::new(0, 500_000_000), Duration::new(0, 1));
90 assert_eq!(Duration::new(1, 0) - Duration::new(0, 1), Duration::new(0, 999_999_999));
95 let zero = Duration::new(0, 0);
96 let one_nano = Duration::new(0, 1);
97 let one_sec = Duration::new(1, 0);
98 assert_eq!(one_nano.checked_sub(zero), Some(Duration::new(0, 1)));
99 assert_eq!(one_sec.checked_sub(one_nano), Some(Duration::new(0, 999_999_999)));
100 assert_eq!(zero.checked_sub(one_nano), None);
101 assert_eq!(zero.checked_sub(one_sec), None);
107 let _ = Duration::new(0, 0) - Duration::new(0, 1);
113 let _ = Duration::new(0, 0) - Duration::new(1, 0);
118 assert_eq!(Duration::new(0, 1) * 2, Duration::new(0, 2));
119 assert_eq!(Duration::new(1, 1) * 3, Duration::new(3, 3));
120 assert_eq!(Duration::new(0, 500_000_001) * 4, Duration::new(2, 4));
121 assert_eq!(Duration::new(0, 500_000_001) * 4000, Duration::new(2000, 4000));
126 assert_eq!(Duration::new(0, 1).checked_mul(2), Some(Duration::new(0, 2)));
127 assert_eq!(Duration::new(1, 1).checked_mul(3), Some(Duration::new(3, 3)));
128 assert_eq!(Duration::new(0, 500_000_001).checked_mul(4), Some(Duration::new(2, 4)));
129 assert_eq!(Duration::new(0, 500_000_001).checked_mul(4000), Some(Duration::new(2000, 4000)));
130 assert_eq!(Duration::new(::core::u64::MAX - 1, 0).checked_mul(2), None);
135 assert_eq!(Duration::new(0, 1) / 2, Duration::new(0, 0));
136 assert_eq!(Duration::new(1, 1) / 3, Duration::new(0, 333_333_333));
137 assert_eq!(Duration::new(99, 999_999_000) / 100, Duration::new(0, 999_999_990));
142 assert_eq!(Duration::new(2, 0).checked_div(2), Some(Duration::new(1, 0)));
143 assert_eq!(Duration::new(1, 0).checked_div(2), Some(Duration::new(0, 500_000_000)));
144 assert_eq!(Duration::new(2, 0).checked_div(0), None);
150 Duration::new(1, 999_999_999),
151 Duration::new(2, 999_999_999),
152 Duration::new(0, 999_999_999),
153 Duration::new(0, 999_999_999),
154 Duration::new(0, 999_999_999),
157 let sum = durations.iter().sum::<Duration>();
158 assert_eq!(sum, Duration::new(1 + 2 + 5 + 4, 1_000_000_000 - 5));
162 fn debug_formatting_extreme_values() {
164 format!("{:?}", Duration::new(18_446_744_073_709_551_615, 123_456_789)),
165 "18446744073709551615.123456789s"
170 fn debug_formatting_secs() {
171 assert_eq!(format!("{:?}", Duration::new(7, 000_000_000)), "7s");
172 assert_eq!(format!("{:?}", Duration::new(7, 100_000_000)), "7.1s");
173 assert_eq!(format!("{:?}", Duration::new(7, 000_010_000)), "7.00001s");
174 assert_eq!(format!("{:?}", Duration::new(7, 000_000_001)), "7.000000001s");
175 assert_eq!(format!("{:?}", Duration::new(7, 123_456_789)), "7.123456789s");
177 assert_eq!(format!("{:?}", Duration::new(88, 000_000_000)), "88s");
178 assert_eq!(format!("{:?}", Duration::new(88, 100_000_000)), "88.1s");
179 assert_eq!(format!("{:?}", Duration::new(88, 000_010_000)), "88.00001s");
180 assert_eq!(format!("{:?}", Duration::new(88, 000_000_001)), "88.000000001s");
181 assert_eq!(format!("{:?}", Duration::new(88, 123_456_789)), "88.123456789s");
183 assert_eq!(format!("{:?}", Duration::new(999, 000_000_000)), "999s");
184 assert_eq!(format!("{:?}", Duration::new(999, 100_000_000)), "999.1s");
185 assert_eq!(format!("{:?}", Duration::new(999, 000_010_000)), "999.00001s");
186 assert_eq!(format!("{:?}", Duration::new(999, 000_000_001)), "999.000000001s");
187 assert_eq!(format!("{:?}", Duration::new(999, 123_456_789)), "999.123456789s");
191 fn debug_formatting_millis() {
192 assert_eq!(format!("{:?}", Duration::new(0, 7_000_000)), "7ms");
193 assert_eq!(format!("{:?}", Duration::new(0, 7_100_000)), "7.1ms");
194 assert_eq!(format!("{:?}", Duration::new(0, 7_000_001)), "7.000001ms");
195 assert_eq!(format!("{:?}", Duration::new(0, 7_123_456)), "7.123456ms");
197 assert_eq!(format!("{:?}", Duration::new(0, 88_000_000)), "88ms");
198 assert_eq!(format!("{:?}", Duration::new(0, 88_100_000)), "88.1ms");
199 assert_eq!(format!("{:?}", Duration::new(0, 88_000_001)), "88.000001ms");
200 assert_eq!(format!("{:?}", Duration::new(0, 88_123_456)), "88.123456ms");
202 assert_eq!(format!("{:?}", Duration::new(0, 999_000_000)), "999ms");
203 assert_eq!(format!("{:?}", Duration::new(0, 999_100_000)), "999.1ms");
204 assert_eq!(format!("{:?}", Duration::new(0, 999_000_001)), "999.000001ms");
205 assert_eq!(format!("{:?}", Duration::new(0, 999_123_456)), "999.123456ms");
209 fn debug_formatting_micros() {
210 assert_eq!(format!("{:?}", Duration::new(0, 7_000)), "7µs");
211 assert_eq!(format!("{:?}", Duration::new(0, 7_100)), "7.1µs");
212 assert_eq!(format!("{:?}", Duration::new(0, 7_001)), "7.001µs");
213 assert_eq!(format!("{:?}", Duration::new(0, 7_123)), "7.123µs");
215 assert_eq!(format!("{:?}", Duration::new(0, 88_000)), "88µs");
216 assert_eq!(format!("{:?}", Duration::new(0, 88_100)), "88.1µs");
217 assert_eq!(format!("{:?}", Duration::new(0, 88_001)), "88.001µs");
218 assert_eq!(format!("{:?}", Duration::new(0, 88_123)), "88.123µs");
220 assert_eq!(format!("{:?}", Duration::new(0, 999_000)), "999µs");
221 assert_eq!(format!("{:?}", Duration::new(0, 999_100)), "999.1µs");
222 assert_eq!(format!("{:?}", Duration::new(0, 999_001)), "999.001µs");
223 assert_eq!(format!("{:?}", Duration::new(0, 999_123)), "999.123µs");
227 fn debug_formatting_nanos() {
228 assert_eq!(format!("{:?}", Duration::new(0, 0)), "0ns");
229 assert_eq!(format!("{:?}", Duration::new(0, 1)), "1ns");
230 assert_eq!(format!("{:?}", Duration::new(0, 88)), "88ns");
231 assert_eq!(format!("{:?}", Duration::new(0, 999)), "999ns");
235 fn debug_formatting_precision_zero() {
236 assert_eq!(format!("{:.0?}", Duration::new(0, 0)), "0ns");
237 assert_eq!(format!("{:.0?}", Duration::new(0, 123)), "123ns");
239 assert_eq!(format!("{:.0?}", Duration::new(0, 1_001)), "1µs");
240 assert_eq!(format!("{:.0?}", Duration::new(0, 1_499)), "1µs");
241 assert_eq!(format!("{:.0?}", Duration::new(0, 1_500)), "2µs");
242 assert_eq!(format!("{:.0?}", Duration::new(0, 1_999)), "2µs");
244 assert_eq!(format!("{:.0?}", Duration::new(0, 1_000_001)), "1ms");
245 assert_eq!(format!("{:.0?}", Duration::new(0, 1_499_999)), "1ms");
246 assert_eq!(format!("{:.0?}", Duration::new(0, 1_500_000)), "2ms");
247 assert_eq!(format!("{:.0?}", Duration::new(0, 1_999_999)), "2ms");
249 assert_eq!(format!("{:.0?}", Duration::new(1, 000_000_001)), "1s");
250 assert_eq!(format!("{:.0?}", Duration::new(1, 499_999_999)), "1s");
251 assert_eq!(format!("{:.0?}", Duration::new(1, 500_000_000)), "2s");
252 assert_eq!(format!("{:.0?}", Duration::new(1, 999_999_999)), "2s");
256 fn debug_formatting_precision_two() {
257 assert_eq!(format!("{:.2?}", Duration::new(0, 0)), "0.00ns");
258 assert_eq!(format!("{:.2?}", Duration::new(0, 123)), "123.00ns");
260 assert_eq!(format!("{:.2?}", Duration::new(0, 1_000)), "1.00µs");
261 assert_eq!(format!("{:.2?}", Duration::new(0, 7_001)), "7.00µs");
262 assert_eq!(format!("{:.2?}", Duration::new(0, 7_100)), "7.10µs");
263 assert_eq!(format!("{:.2?}", Duration::new(0, 7_109)), "7.11µs");
264 assert_eq!(format!("{:.2?}", Duration::new(0, 7_199)), "7.20µs");
265 assert_eq!(format!("{:.2?}", Duration::new(0, 1_999)), "2.00µs");
267 assert_eq!(format!("{:.2?}", Duration::new(0, 1_000_000)), "1.00ms");
268 assert_eq!(format!("{:.2?}", Duration::new(0, 3_001_000)), "3.00ms");
269 assert_eq!(format!("{:.2?}", Duration::new(0, 3_100_000)), "3.10ms");
270 assert_eq!(format!("{:.2?}", Duration::new(0, 1_999_999)), "2.00ms");
272 assert_eq!(format!("{:.2?}", Duration::new(1, 000_000_000)), "1.00s");
273 assert_eq!(format!("{:.2?}", Duration::new(4, 001_000_000)), "4.00s");
274 assert_eq!(format!("{:.2?}", Duration::new(2, 100_000_000)), "2.10s");
275 assert_eq!(format!("{:.2?}", Duration::new(2, 104_990_000)), "2.10s");
276 assert_eq!(format!("{:.2?}", Duration::new(2, 105_000_000)), "2.11s");
277 assert_eq!(format!("{:.2?}", Duration::new(8, 999_999_999)), "9.00s");
281 fn debug_formatting_precision_high() {
282 assert_eq!(format!("{:.5?}", Duration::new(0, 23_678)), "23.67800µs");
284 assert_eq!(format!("{:.9?}", Duration::new(1, 000_000_000)), "1.000000000s");
285 assert_eq!(format!("{:.10?}", Duration::new(4, 001_000_000)), "4.0010000000s");
286 assert_eq!(format!("{:.20?}", Duration::new(4, 001_000_000)), "4.00100000000000000000s");