2020-06-07 15:19:09 +02:00
|
|
|
module time
|
|
|
|
|
|
|
|
fn assert_greater_time(ms int, t1 Time) {
|
2021-02-21 16:05:03 +01:00
|
|
|
wait(ms * millisecond)
|
2020-06-07 15:19:09 +02:00
|
|
|
t2 := now()
|
2021-01-05 11:43:34 +01:00
|
|
|
assert t2 > t1
|
2020-06-07 15:19:09 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
// Tests the now in all platform and the gt operator function with at least ms resolution
|
|
|
|
fn test_now_always_results_in_greater_time() {
|
|
|
|
t1 := now()
|
|
|
|
$if macos {
|
|
|
|
assert_greater_time(1, t1)
|
|
|
|
return
|
|
|
|
}
|
|
|
|
$if windows {
|
|
|
|
// Lower resolution of time for windows
|
|
|
|
assert_greater_time(15, t1)
|
|
|
|
return
|
|
|
|
}
|
|
|
|
$if linux {
|
|
|
|
assert_greater_time(1, t1)
|
|
|
|
return
|
|
|
|
}
|
|
|
|
$if solaris {
|
|
|
|
assert_greater_time(1, t1)
|
|
|
|
return
|
|
|
|
}
|
|
|
|
// other platforms may have more accurate resolution,
|
|
|
|
// but we do not know that ... so wait at least 1s:
|
|
|
|
assert_greater_time(1001, t1)
|
|
|
|
}
|
|
|
|
|
|
|
|
fn test_time1_should_be_same_as_time2() {
|
2020-12-06 15:19:39 +01:00
|
|
|
t1 := new_time(Time{
|
2020-06-07 15:19:09 +02:00
|
|
|
year: 2000
|
|
|
|
month: 5
|
|
|
|
day: 10
|
|
|
|
hour: 22
|
|
|
|
minute: 11
|
|
|
|
second: 3
|
|
|
|
microsecond: 100
|
|
|
|
})
|
2020-12-06 15:19:39 +01:00
|
|
|
t2 := new_time(Time{
|
2020-06-07 15:19:09 +02:00
|
|
|
year: 2000
|
|
|
|
month: 5
|
|
|
|
day: 10
|
|
|
|
hour: 22
|
|
|
|
minute: 11
|
|
|
|
second: 3
|
|
|
|
microsecond: 100
|
|
|
|
})
|
2021-01-05 11:43:34 +01:00
|
|
|
assert t1 == t2
|
2020-06-07 15:19:09 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
fn test_time1_should_not_be_same_as_time2() {
|
2020-12-06 15:19:39 +01:00
|
|
|
t1 := new_time(Time{
|
2020-06-07 15:19:09 +02:00
|
|
|
year: 2000
|
|
|
|
month: 5
|
|
|
|
day: 10
|
|
|
|
hour: 22
|
|
|
|
minute: 11
|
|
|
|
second: 3
|
|
|
|
microsecond: 100
|
|
|
|
})
|
|
|
|
// Difference is one microsecond
|
2020-12-06 15:19:39 +01:00
|
|
|
t2 := new_time(Time{
|
2020-06-07 15:19:09 +02:00
|
|
|
year: 2000
|
|
|
|
month: 5
|
|
|
|
day: 10
|
|
|
|
hour: 22
|
|
|
|
minute: 11
|
|
|
|
second: 3
|
|
|
|
microsecond: 101
|
|
|
|
})
|
2020-12-06 15:19:39 +01:00
|
|
|
t3 := new_time(Time{
|
2020-06-07 15:19:09 +02:00
|
|
|
year: 2000
|
|
|
|
month: 5
|
|
|
|
day: 10
|
|
|
|
hour: 22
|
|
|
|
minute: 11
|
|
|
|
second: 3
|
|
|
|
microsecond: 0
|
|
|
|
})
|
|
|
|
// Difference is one second
|
2020-12-06 15:19:39 +01:00
|
|
|
t4 := new_time(Time{
|
2020-06-07 15:19:09 +02:00
|
|
|
year: 2000
|
|
|
|
month: 5
|
|
|
|
day: 10
|
|
|
|
hour: 22
|
|
|
|
minute: 11
|
|
|
|
second: 4
|
|
|
|
microsecond: 0
|
|
|
|
})
|
2021-01-05 11:43:34 +01:00
|
|
|
assert t1 != t2
|
|
|
|
assert t3 != t4
|
2020-06-07 15:19:09 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
fn test_time1_should_be_greater_than_time2() {
|
2020-12-06 15:19:39 +01:00
|
|
|
t1 := new_time(Time{
|
2020-06-07 15:19:09 +02:00
|
|
|
year: 2000
|
|
|
|
month: 5
|
|
|
|
day: 10
|
|
|
|
hour: 22
|
|
|
|
minute: 11
|
|
|
|
second: 3
|
|
|
|
microsecond: 102
|
|
|
|
})
|
|
|
|
// Difference is one microsecond
|
2020-12-06 15:19:39 +01:00
|
|
|
t2 := new_time(Time{
|
2020-06-07 15:19:09 +02:00
|
|
|
year: 2000
|
|
|
|
month: 5
|
|
|
|
day: 10
|
|
|
|
hour: 22
|
|
|
|
minute: 11
|
|
|
|
second: 3
|
|
|
|
microsecond: 101
|
|
|
|
})
|
2020-12-06 15:19:39 +01:00
|
|
|
t3 := new_time(Time{
|
2020-06-07 15:19:09 +02:00
|
|
|
year: 2000
|
|
|
|
month: 5
|
|
|
|
day: 10
|
|
|
|
hour: 22
|
|
|
|
minute: 11
|
|
|
|
second: 5
|
|
|
|
microsecond: 0
|
|
|
|
})
|
|
|
|
// Difference is one second
|
2020-12-06 15:19:39 +01:00
|
|
|
t4 := new_time(Time{
|
2020-06-07 15:19:09 +02:00
|
|
|
year: 2000
|
|
|
|
month: 5
|
|
|
|
day: 10
|
|
|
|
hour: 22
|
|
|
|
minute: 11
|
|
|
|
second: 4
|
|
|
|
microsecond: 0
|
|
|
|
})
|
2021-01-05 11:43:34 +01:00
|
|
|
assert t1 > t2
|
|
|
|
assert t3 > t4
|
2020-06-07 15:19:09 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
fn test_time2_should_be_less_than_time1() {
|
2020-12-06 15:19:39 +01:00
|
|
|
t1 := new_time(Time{
|
2020-06-07 15:19:09 +02:00
|
|
|
year: 2000
|
|
|
|
month: 5
|
|
|
|
day: 10
|
|
|
|
hour: 22
|
|
|
|
minute: 11
|
|
|
|
second: 3
|
|
|
|
microsecond: 102
|
|
|
|
})
|
|
|
|
// Difference is one microsecond
|
2020-12-06 15:19:39 +01:00
|
|
|
t2 := new_time(Time{
|
2020-06-07 15:19:09 +02:00
|
|
|
year: 2000
|
|
|
|
month: 5
|
|
|
|
day: 10
|
|
|
|
hour: 22
|
|
|
|
minute: 11
|
|
|
|
second: 3
|
|
|
|
microsecond: 101
|
|
|
|
})
|
2020-12-06 15:19:39 +01:00
|
|
|
t3 := new_time(Time{
|
2020-06-07 15:19:09 +02:00
|
|
|
year: 2000
|
|
|
|
month: 5
|
|
|
|
day: 10
|
|
|
|
hour: 22
|
|
|
|
minute: 11
|
|
|
|
second: 3
|
|
|
|
microsecond: 0
|
|
|
|
})
|
|
|
|
// Difference is one second
|
2020-12-06 15:19:39 +01:00
|
|
|
t4 := new_time(Time{
|
2020-06-07 15:19:09 +02:00
|
|
|
year: 2000
|
|
|
|
month: 5
|
|
|
|
day: 10
|
|
|
|
hour: 22
|
|
|
|
minute: 11
|
|
|
|
second: 2
|
|
|
|
microsecond: 0
|
|
|
|
})
|
2021-01-05 11:43:34 +01:00
|
|
|
assert t2 < t1
|
|
|
|
assert t4 < t3
|
2020-06-07 15:19:09 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
fn test_time1_should_be_greater_or_equal_to_time2_when_gt() {
|
2020-12-06 15:19:39 +01:00
|
|
|
t1 := new_time(Time{
|
2020-06-07 15:19:09 +02:00
|
|
|
year: 2000
|
|
|
|
month: 5
|
|
|
|
day: 10
|
|
|
|
hour: 22
|
|
|
|
minute: 11
|
|
|
|
second: 3
|
|
|
|
microsecond: 102
|
|
|
|
})
|
|
|
|
// Difference is one microsecond
|
2020-12-06 15:19:39 +01:00
|
|
|
t2 := new_time(Time{
|
2020-06-07 15:19:09 +02:00
|
|
|
year: 2000
|
|
|
|
month: 5
|
|
|
|
day: 10
|
|
|
|
hour: 22
|
|
|
|
minute: 11
|
|
|
|
second: 3
|
|
|
|
microsecond: 101
|
|
|
|
})
|
2020-12-06 15:19:39 +01:00
|
|
|
t3 := new_time(Time{
|
2020-06-07 15:19:09 +02:00
|
|
|
year: 2000
|
|
|
|
month: 5
|
|
|
|
day: 10
|
|
|
|
hour: 22
|
|
|
|
minute: 11
|
|
|
|
second: 5
|
|
|
|
microsecond: 0
|
|
|
|
})
|
|
|
|
// Difference is one second
|
2020-12-06 15:19:39 +01:00
|
|
|
t4 := new_time(Time{
|
2020-06-07 15:19:09 +02:00
|
|
|
year: 2000
|
|
|
|
month: 5
|
|
|
|
day: 10
|
|
|
|
hour: 22
|
|
|
|
minute: 11
|
|
|
|
second: 4
|
|
|
|
microsecond: 0
|
|
|
|
})
|
2021-01-10 21:05:05 +01:00
|
|
|
assert t1 >= t2
|
|
|
|
assert t3 >= t4
|
2020-06-07 15:19:09 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
fn test_time1_should_be_greater_or_equal_to_time2_when_eq() {
|
2020-12-06 15:19:39 +01:00
|
|
|
t1 := new_time(Time{
|
2020-06-07 15:19:09 +02:00
|
|
|
year: 2000
|
|
|
|
month: 5
|
|
|
|
day: 10
|
|
|
|
hour: 22
|
|
|
|
minute: 11
|
|
|
|
second: 3
|
|
|
|
microsecond: 100
|
|
|
|
})
|
|
|
|
// Difference is one microsecond
|
2020-12-06 15:19:39 +01:00
|
|
|
t2 := new_time(Time{
|
2020-06-07 15:19:09 +02:00
|
|
|
year: 2000
|
|
|
|
month: 5
|
|
|
|
day: 10
|
|
|
|
hour: 22
|
|
|
|
minute: 11
|
|
|
|
second: 3
|
|
|
|
microsecond: 100
|
|
|
|
})
|
2020-12-06 15:19:39 +01:00
|
|
|
t3 := new_time(Time{
|
2020-06-07 15:19:09 +02:00
|
|
|
year: 2000
|
|
|
|
month: 5
|
|
|
|
day: 10
|
|
|
|
hour: 22
|
|
|
|
minute: 11
|
|
|
|
second: 3
|
|
|
|
microsecond: 0
|
|
|
|
})
|
|
|
|
// Difference is one second
|
2020-12-06 15:19:39 +01:00
|
|
|
t4 := new_time(Time{
|
2020-06-07 15:19:09 +02:00
|
|
|
year: 2000
|
|
|
|
month: 5
|
|
|
|
day: 10
|
|
|
|
hour: 22
|
|
|
|
minute: 11
|
|
|
|
second: 3
|
|
|
|
microsecond: 0
|
|
|
|
})
|
2021-01-10 21:05:05 +01:00
|
|
|
assert t1 >= t2
|
|
|
|
assert t3 >= t4
|
2020-06-07 15:19:09 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
fn test_time1_should_be_less_or_equal_to_time2_when_lt() {
|
2020-12-06 15:19:39 +01:00
|
|
|
t1 := new_time(Time{
|
2020-06-07 15:19:09 +02:00
|
|
|
year: 2000
|
|
|
|
month: 5
|
|
|
|
day: 10
|
|
|
|
hour: 22
|
|
|
|
minute: 11
|
|
|
|
second: 3
|
|
|
|
microsecond: 100
|
|
|
|
})
|
|
|
|
// Difference is one microsecond
|
2020-12-06 15:19:39 +01:00
|
|
|
t2 := new_time(Time{
|
2020-06-07 15:19:09 +02:00
|
|
|
year: 2000
|
|
|
|
month: 5
|
|
|
|
day: 10
|
|
|
|
hour: 22
|
|
|
|
minute: 11
|
|
|
|
second: 3
|
|
|
|
microsecond: 101
|
|
|
|
})
|
2020-12-06 15:19:39 +01:00
|
|
|
t3 := new_time(Time{
|
2020-06-07 15:19:09 +02:00
|
|
|
year: 2000
|
|
|
|
month: 5
|
|
|
|
day: 10
|
|
|
|
hour: 22
|
|
|
|
minute: 11
|
|
|
|
second: 3
|
|
|
|
microsecond: 0
|
|
|
|
})
|
|
|
|
// Difference is one second
|
2020-12-06 15:19:39 +01:00
|
|
|
t4 := new_time(Time{
|
2020-06-07 15:19:09 +02:00
|
|
|
year: 2000
|
|
|
|
month: 5
|
|
|
|
day: 10
|
|
|
|
hour: 22
|
|
|
|
minute: 11
|
|
|
|
second: 4
|
|
|
|
microsecond: 0
|
|
|
|
})
|
2021-01-10 21:05:05 +01:00
|
|
|
assert t1 <= t2
|
|
|
|
assert t3 <= t4
|
2020-06-07 15:19:09 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
fn test_time1_should_be_less_or_equal_to_time2_when_eq() {
|
2020-12-06 15:19:39 +01:00
|
|
|
t1 := new_time(Time{
|
2020-06-07 15:19:09 +02:00
|
|
|
year: 2000
|
|
|
|
month: 5
|
|
|
|
day: 10
|
|
|
|
hour: 22
|
|
|
|
minute: 11
|
|
|
|
second: 3
|
|
|
|
microsecond: 100
|
|
|
|
})
|
|
|
|
// Difference is one microsecond
|
2020-12-06 15:19:39 +01:00
|
|
|
t2 := new_time(Time{
|
2020-06-07 15:19:09 +02:00
|
|
|
year: 2000
|
|
|
|
month: 5
|
|
|
|
day: 10
|
|
|
|
hour: 22
|
|
|
|
minute: 11
|
|
|
|
second: 3
|
|
|
|
microsecond: 100
|
|
|
|
})
|
2020-12-06 15:19:39 +01:00
|
|
|
t3 := new_time(Time{
|
2020-06-07 15:19:09 +02:00
|
|
|
year: 2000
|
|
|
|
month: 5
|
|
|
|
day: 10
|
|
|
|
hour: 22
|
|
|
|
minute: 11
|
|
|
|
second: 3
|
|
|
|
microsecond: 0
|
|
|
|
})
|
|
|
|
// Difference is one second
|
2020-12-06 15:19:39 +01:00
|
|
|
t4 := new_time(Time{
|
2020-06-07 15:19:09 +02:00
|
|
|
year: 2000
|
|
|
|
month: 5
|
|
|
|
day: 10
|
|
|
|
hour: 22
|
|
|
|
minute: 11
|
|
|
|
second: 3
|
|
|
|
microsecond: 0
|
|
|
|
})
|
2021-01-10 21:05:05 +01:00
|
|
|
assert t1 <= t2
|
|
|
|
assert t3 <= t4
|
2020-06-07 15:19:09 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
fn test_time2_copied_from_time1_should_be_equal() {
|
2020-12-06 15:19:39 +01:00
|
|
|
t1 := new_time(Time{
|
2020-06-07 15:19:09 +02:00
|
|
|
year: 2000
|
|
|
|
month: 5
|
|
|
|
day: 10
|
|
|
|
hour: 22
|
|
|
|
minute: 11
|
|
|
|
second: 3
|
|
|
|
microsecond: 100
|
|
|
|
})
|
|
|
|
t2 := new_time(t1)
|
2021-01-05 11:43:34 +01:00
|
|
|
assert t2 == t1
|
2020-06-07 15:19:09 +02:00
|
|
|
}
|
2020-12-21 09:28:00 +01:00
|
|
|
|
|
|
|
fn test_subtract() {
|
|
|
|
d_seconds := 3
|
|
|
|
d_microseconds := 13
|
|
|
|
duration := d_seconds * second + d_microseconds * microsecond
|
|
|
|
t1 := new_time(Time{
|
|
|
|
year: 2000
|
|
|
|
month: 5
|
|
|
|
day: 10
|
|
|
|
hour: 22
|
|
|
|
minute: 11
|
|
|
|
second: 3
|
|
|
|
microsecond: 100
|
|
|
|
})
|
|
|
|
t2 := unix2(int(t1.unix) + d_seconds, t1.microsecond + d_microseconds)
|
|
|
|
d1 := t2 - t1
|
|
|
|
d2 := t1 - t2
|
|
|
|
assert d1 > 0
|
|
|
|
assert d1 == duration
|
|
|
|
assert d2 < 0
|
|
|
|
assert d2 == -duration
|
|
|
|
}
|