【go语言开发】编写单元测试

这篇具有很好参考价值的文章主要介绍了【go语言开发】编写单元测试。希望对大家有所帮助。如果存在错误或未考虑完全的地方,请大家不吝赐教,您也可以点击"举报违法"按钮提交疑问。

本文主要介绍使用go语言编写单元测试用例,首先介绍如何编写单元测试,然后介绍基本命令的使用,最后给出demo示例

前言

在go语言中编写单元测试时,使用说明

  1. 测试文件命名:在 Go 语言中,测试文件的命名应与被测试的源代码文件相同,但以 “_test” 结尾。例如,如果你的源代码文件名为 example.go,则测试文件名应为 example_test.go。

  2. 导入 testing 包:在测试文件的开头,导入 testing 包,这是 Go 语言内置的用于编写单元测试的包。

  3. 编写测试函数:测试函数的命名应以 “Test” 开头,后面跟着被测试的函数名,并接收一个参数 t *testing.T。例如,如果要测试名为 Add 的函数,测试函数名应为 TestAdd(t *testing.T)。

  4. 使用 t.Error 或 t.Errorf 进行断言:在测试函数中,你可以使用 t.Error 或 t.Errorf 方法来判断测试是否通过。如果断言条件为假,则测试失败。例如,t.Error(“错误信息”) 表示测试失败并输出错误信息,而 t.Errorf(“格式化错误信息”, 参数列表…) 允许你使用类似 fmt.Printf 的格式化字符串。

  5. 运行测试命令:在项目的根目录下,使用 go test 命令来执行单元测试。Go 语言会自动找到并运行所有的测试文件。你还可以使用 -v 参数来获取更详细的输出。

  6. 测试覆盖率报告:你可以使用 -cover 参数来生成测试覆盖率报告。例如,go test -cover 将显示每个被测试的函数的覆盖率百分比。

  7. 子测试:你可以在单个测试函数中定义多个子测试,以便更好地组织和管理测试代码。使用 t.Run 方法来运行子测试。

命令

测试用例文件使用go test指令来执行,不需要 main() 作为函数入口

Go 语言的测试工具提供了许多命令和选项来帮助你编写和运行测试。以下是一些常见的 go test 命令和选项:

  • go test: 在项目的根目录下,使用此命令来运行所有的测试文件并输出测试结果。
  • go test : 运行特定包中的所有测试文件,并输出测试结果。例如,go test calc 将运行 calc 包中的所有测试文件。
  • go test -v: 输出更详细的测试结果信息,包括测试名称、测试运行时间、测试覆盖率等。
  • go test -run : 仅运行名称匹配给定模式的测试函数。例如,go test -run TestAdd 将仅运行名称为 TestAdd 的测试函数。
  • go test -cover: 生成测试覆盖率报告,显示每个被测试的函数的覆盖率百分比。
  • go test -coverprofile : 生成覆盖率文件,并将其写入指定文件。例如,go test -coverprofile cover.out 将生成一个名为 cover.out 的文件,其中包含测试覆盖率数据。
  • go tool cover -html : 使用 HTML 格式显示覆盖率报告。例如,go tool cover -html=cover.out 将使用浏览器显示 cover.out 文件的测试覆盖率报告。

示例

package test

import "testing"

func Add(a, b int) int {
	return a + b
}

func TestAdd(t *testing.T) {
	result := Add(4, 5)
	if result != 9 {
		t.Errorf("Add(4,5)=%d fail\n", result)
	}
}

点击红圈地方,可以直接运行单元测试用例
【go语言开发】编写单元测试,go,golang,单元测试,log4j
控制台输出结果:
【go语言开发】编写单元测试,go,golang,单元测试,log4j

命令行运行:文章来源地址https://www.toymoban.com/news/detail-759541.html

  • go test
    【go语言开发】编写单元测试,go,golang,单元测试,log4j
    go test -v
    【go语言开发】编写单元测试,go,golang,单元测试,log4j

到了这里,关于【go语言开发】编写单元测试的文章就介绍完了。如果您还想了解更多内容,请在右上角搜索TOY模板网以前的文章或继续浏览下面的相关文章,希望大家以后多多支持TOY模板网!

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处: 如若内容造成侵权/违法违规/事实不符,请点击违法举报进行投诉反馈,一经查实,立即删除!

领支付宝红包 赞助服务器费用

相关文章

  • 36-代码测试(上):如何编写Go语言单元测试和性能测试用例?

    每种语言通常都有自己的测试包/模块,Go语言也不例外。在Go中,我们可以通过 testing 包对代码进行单元测试和性能测试。  Go语言有自带的测试框架 testing ,可以用来实现单元测试(T类型)和性能测试(B类型),通过 go test 命令来执行单元测试和性能测试。 go test 执行测试

    2024年04月11日
    浏览(40)
  • 036-安全开发-JavaEE应用&第三方组件&Log4j日志&FastJson序列化&JNDI注入

    1、JavaEE-组件安全-Log4j 2、JavaEE-组件安全-Fastjson 3、JavaEE-基本了解-JNDI-API 演示案例: ➢Java-三方组件-Log4JJNDI ➢Java-三方组件-FastJson反射 Jar仓库: https://mvnrepository.com/ Maven配置: https://www.jb51.net/article/259780.htm JNDI相关概念: 1、JNDI是一个接口,在这个接口下会有多种目录系统

    2024年02月21日
    浏览(42)
  • 安全学习_开发相关_Java第三方组件Log4j&FastJSON及相关安全问题简介

    Java Naming and Directory Interface (Java 命名和目录接口 ),JNDI 提供统一的客户端 API,通过不同的服务供应接口(SPI)的实现,由管理者将 JNDI API 映射为特定的命名服务和目录服务,使得 JAVA 应用程可以通过 JNDI 实现和这些命名服务和目录服务之间的交互。 Log4J: Apache的一个开源项目

    2024年02月05日
    浏览(47)
  • elasticsearch-7.13.3 升级log4j 到log4j-2.17.1

    1、升级原因 log4j低版本存在严重漏洞,根据需要升级到安全版本,不一定是最新。 log4j-2.17.1 jar包下载地址https://archive.apache.org/dist/logging/log4j/2.17.1/ 2、下载后解压apache-log4j-2.17.1-bin.tar.gz 升级需要用到截图中四个jar包 3、升级 删除旧版本log4j 进入elasticsearch-7.13.3目录 $ rm -rf l

    2024年02月12日
    浏览(42)
  • Java中的Log4j是什么?如何使用Log4j进行日志管理

    Log4j是一个Java日志管理工具,它可以帮助开发者在应用程序中记录日志。它是由Apache软件基金会开发和维护的,已经成为Java开发中最流行的日志管理框架之一。 Log4j可以通过多种方式记录日志,包括控制台输出、文件输出、数据库存储等。此外,Log4j还提供了多种日志级别,

    2024年02月04日
    浏览(45)
  • Log4J

    为什么要用日志? -- 方便调试代码 什么时候用?什么时候不用? ​ 出错调试代码时候用 生产环境下就不需要,就需要删除 怎么用? -- 输出语句 ​ log4j是Apache的一个开放源代码的项目,通过使用log4j,我们可以控制日志信息输送的目的地是控制台、文件、GUI组件、甚至是套接口服

    2024年02月08日
    浏览(35)
  • log4j漏洞详解

    log4j全名就是(log for java),就是apache的一个开源的日志记录组件 ,它在Java项目中使用的比较广泛。 使用方法:                 1.pom引入依赖                 2.获取logger实例                 3.logger.info() debug() error() warn()... 优点:功能丰富,易于集成

    2024年02月16日
    浏览(34)
  • 【日志加载 log4j】

    2.编写配置 3.获取日志对象 4.1 Loggers 记录器 4.2 Appenders 输出源 4.3 Layouts 布局 5. 配置文件 log4j.properties

    2024年02月11日
    浏览(83)
  • Log4j源码解析

    Log4j源码解析 主要流程 Logger logger = Logger.getLogger(Main.class); 1、通过Logger.getLogger(Class clazz) 或 Logger.getLogger(String name)进入。 2、加载LogManager进jvm, 执行静态代码块执行初始化, 创建出RepositorySelector实例及LoggerRepository实例(Hierarchy)。 3、调用OptionConverter.selectAndConfigure(URL url, String

    2024年02月15日
    浏览(37)
  • log4j警告之log4j:WARN No appenders could be found for logger

    目录 1. 警告信息  2. 错误解读  3.解决办法   错误输出信息: log4j:WARN No appenders could be found for logger (org.apache.flink.api.java.utils.PlanGenerator). log4j:WARN Please initialize the log4j system properly. log4j:WARN See http://logging.apache.org/log4j/1.2/faq.html#noconfig for more info. 如果找不到默认配置文件log4j

    2024年02月14日
    浏览(47)

觉得文章有用就打赏一下文章作者

支付宝扫一扫打赏

博客赞助

微信扫一扫打赏

请作者喝杯咖啡吧~博客赞助

支付宝扫一扫领取红包,优惠每天领

二维码1

领取红包

二维码2

领红包