go单元格测试

编写单元测试(Unit Test)是一种测试方法,用于验证代码中的单个功能单元(通常是函数或方法)是否按照预期工作。以下是编写单元测试的一般步骤:

  1. 创建测试文件:在项目的测试目录中创建一个新的测试文件,文件名通常以 _test.go 结尾,例如 mycode_test.go

  2. 导入测试所需的包:在测试文件的开头,导入所需的包,包括 testing 包和待测试代码的包。 3. 编写测试函数:在测试文件中,使用 func TestXxx(t *testing.T) 的格式编写测试函数。其中 Xxx 是要测试的函数名或方法名。

  3. 编写测试用例:在测试函数中,编写一系列测试用例,每个测试用例都是一个独立的函数调用,用于验证待测试函数的不同方面和边界条件。

  4. 运行测试:在终端或命令行中,使用 go test 命令运行测试。系统将自动查找并执行测试文件中的所有测试函数。

  5. 检查测试结果:运行完成后,系统将显示每个测试用例的执行结果,包括通过的用例和失败的用例。如果有失败的用例,系统将显示详细的错误信息。

  6. 分析和修复问题:根据测试结果,分析失败的用例,并修复代码中的问题。然后重新运行测试,直到所有用例都通过为止。 这是一个简单的示例:

    package mycode

    import "testing"

    func TestAdd(t *testing.T) {
    result := Add(2, 3)
    expected := 5
    if result != expected {
    t.Errorf("Add(2, 3) returned %d, expected %d", result, expected)
    }
    }

    func TestSubtract(t *testing.T) {
    result := Subtract(5, 2)
    expected := 3
    if result != expected {
    t.Errorf("Subtract(5, 2) returned %d, expected %d", result, expected)
    }
    }

    go test -run TestFun

在上述代码中,"t" 是一个 *testing.T 类型的参数,它用于表示测试对象。在 Go 语言中, *testing.T 是一个测试对象的指针,用于执行断言和记录测试结果。 在单元测试中,我们使用 t 参数来调用断言方法,例如 assert.Empty(t, result)assert.Equal(t, expected, result) 。这些断言方法用于验证测试结果是否符合预期,并在测试失败时生成相应的错误消息。 所以,在上述代码中,"t" 代表测试对象,用于执行断言并记录测试结果。

初始化

在Go语言中,当声明一个变量时,如果没有显式赋值,那么变量将被赋予其类型的默认零值。 对于数值类型(如 intfloat64 等),默认零值是0。对于布尔类型,默认零值是 false 。对于字符串类型,默认零值是空字符串 "" 。对于引用类型(如 mapslicestruct 等),默认零值是 nil 。 因此,在声明 int 等字段时,它们会被自动初始化为其类型的默认零值。您无需显式进行初始化操作。

在Go语言中,没有名为 string[struct] 的数据类型。然而,你可以使用 map[string]struct{} 来实现一个类似的结构,其中 string 作为键, struct{} 作为值。这样可以创建一个映射,将字符串与空结构关联起来。

type EmptyStruct struct{}

func main() {
	data := make(map[string]EmptyStruct)

	// 添加键值对
	data["key1"] = EmptyStruct{}
	data["key2"] = EmptyStruct{}

	// 检查键是否存在
	if _, ok := data["key1"]; ok {
		fmt.Println("key1存在")
	}

	// 删除键值对
	delete(data, "key2")
}
相关推荐
2501_903238653 天前
Log4j在Spring项目中的应用与实践
java·spring·log4j·个人开发
大雄野比3 天前
Maven 项⽬⽣命周期
java·log4j·maven
綦枫Maple4 天前
Spring Boot(8)深入理解 @Autowired 注解:使用场景与实战示例
spring boot·后端·log4j
李豆豆喵5 天前
第36天:安全开发-JavaEE应用&第三方组件&Log4j日志&FastJson序列化&JNDI注入
安全·java-ee·log4j
豆浆两块钱6 天前
【SpringBoot3.x+】slf4j-log4j12依赖引入打印日志报错的两种解决方法
log4j·maven
2501_903238658 天前
SLF4J与Spring集成实战:替代JCL并绑定Log4j
spring·单元测试·log4j·个人开发
斯曦巍峨9 天前
Log4j定制JSON格式日志输出
log4j·json
XiaoyuEr_668810 天前
log4j2日志配置文件
log4j
胡图蛋.11 天前
深入学习反射
学习·log4j