在Go中比较结构

问题描述

我有一个测试,用于比较两个指针与一个结构实例(MyStruct)的相等性。指针存储在其他结构(container1container2)中。这是我检查相等性方法

require.Equal(*container1.MyStruct,*container2.MyStruct)

Equals()方法来自Testify库:https://github.com/stretchr/testify/blob/master/require/require_forward.go#L128

当我在Mac上运行该测试时,该测试通过。但是,当我将更改推送到构建服务器(Linux)时,测试失败。错误消息是标准的Error: Not equal...消息,但是当我比较输出显示的期望值和实际值时,它们是完全相同的!

我以为Go可能以某种方式比较了指针的地址而不是内容,但是对require的注释使它看起来不太可能:

// Pointer variable equality is determined based on the equality of the referenced values (as opposed to the memory addresses)

你知道这里发生了什么吗? Go在Mac和Linux上的行为是否有所不同?

我无法在此处发布详细信息,因为这是我在工作中碰到的代码库中的一个问题。

解决方法

问题在于,当结构中包含Equal对象时,Time函数的“ expected ... real ...”打印逻辑的输出在结构中存在错误。这是错误输出的摘录:(我已经删除了该结构的无关字段):

        Error Trace:    my_test.go:388
                                    my_test.go:50
        Error:          Not equal:
                        expected: {
                          BuildStartDateUtc: 2020-08-17 22:43:05.330062876 +0000 UTC,actual  : {
                          BuildStartDateUtc: 2020-08-17 22:43:05.330062876 +0000 UTC,}
                         

字段看起来相同。但是,如果直接比较MyStruct.BuildStartDateUtc,我会得到:

expected: &time.Time{wall:0x389ccfe6,ext:63733398658,loc:(*time.Location)(0x101d4e0)}
actual : &time.Time{wall:0x389ccfe6,loc:(*time.Location)(nil)}

实际中缺少“ loc”字段。这就是导致比较失败的原因,但是,当我们比较包含Time的结构时,由于输出中显然没有包含“ loc”,因此我们会感到非常混乱的“ expected ... actual ...”输出,当实际/预期值不相等时,它们看起来完全相等。

当我同步被比较的Location中的Time时,测试通过了。

它可能与该“见证”问题有关:https://github.com/stretchr/testify/issues/984