返回

为什么 time.Now() 为不同的测试执行返回相同的时间?

发布时间:2022-07-23 23:51:17 187

(这个问题与操场本身无关,一位评论者要求一个操场,这就是为什么我提供了一个。这个问题是关于 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() 返回的时间总是代码编译的时间,或者类似的时间。任何人都可以证实这一点?

特别声明:以上内容(图片及文字)均为互联网收集或者用户上传发布,本站仅提供信息存储服务!如有侵权或有涉及法律问题请联系我们。
举报
评论区(0)
按点赞数排序
用户头像
相关帖子