为什么 time.Now() 为不同的测试执行返回相同的时间?
(这个问题与操场本身无关,一位评论者要求一个操场,这就是为什么我提供了一个。这个问题是关于 Go 的测试功能。)
我在单元测试中得到这样的时间:time.Now()
这是一些代码,显示了我如何使用 time.Now() 获取时间:
package main
import (
"log"
"testing"
"time"
)
// LastIndex returns the index of the last instance of x in list, or
// -1 if x is not present. The loop condition has a fault that
// causes some tests to fail. Change it to i >= 0 to see them pass.
func LastIndex(list []int, x int) int {
for i := len(list) - 1; i > 0; i-- {
if list[i] == x {
return i
}
}
return -1
}
func TestLastIndex(t *testing.T) {
tests := []struct {
list []int
x int
want int
mytime time.Time
}{
{list: []int{1}, x: 1, want: 0, mytime: time.Now()},
{list: []int{1, 1}, x: 1, want: 1, mytime: time.Now()},
{list: []int{2, 1}, x: 2, want: 0, mytime: time.Now()},
{list: []int{1, 2, 1, 1}, x: 2, want: 1, mytime: time.Now()},
{list: []int{1, 1, 1, 2, 2, 1}, x: 3, want: -1, mytime: time.Now()},
{list: []int{3, 1, 2, 2, 1, 1}, x: 3, want: 0, mytime: time.Now()},
}
for _, tt := range tests {
log.Println("Running test, mytime:", tt.mytime)
if got := LastIndex(tt.list, tt.x); got != tt.want {
t.Errorf("LastIndex(%v, %v) = %v, want %v", tt.list, tt.x, got, tt.want)
}
}
}
尽管多次调用测试,但间隔几秒钟,返回的“mytime”是完全相同的。为什么是这样?
(因为有些人误解了这个问题,所以编辑了输出)
看来你们很多人完全误解了这个问题。我将再次这样陈述,以便更容易理解我的意思:
执行测试并记下输出时间。
去喝杯咖啡。
再次执行测试,并查看时间。
步骤 1 和步骤 3 中的时间相同。
更新:似乎是一个可能的原因;time.Now() 返回的时间总是代码编译的时间,或者类似的时间。任何人都可以证实这一点?