VSCode配置Golang单元测试实例

简介: 说到代码的健壮性,单元测试是少不了的,基本上所有语言都有自己的单元测试方案。工作这么多年,单元测试也没少写,像 Java、C++、Golang 都有过恶补单元测试的经历,为的就是应付各种 KPI,但是也不能说单元测试没有用,只是原始动力不是为了单元测试而单元测试,而是为了应付检查而单元测试。今天呢,就来说一说 Golang 语言的单元测试(这次真的是我自己主动要加的^_^)。

前言

说到代码的健壮性,单元测试是少不了的,基本上所有语言都有自己的单元测试方案。工作这么多年,单元测试也没少写,像 Java、C++、Golang 都有过恶补单元测试的经历,为的就是应付各种 KPI,但是也不能说单元测试没有用,只是原始动力不是为了单元测试而单元测试,而是为了应付检查而单元测试。今天呢,就来说一说 Golang 语言的单元测试(这次真的是我自己主动要加的^_^)。

正文

Golang 单元测试的工具包有很多,在 VSCode 插件超市里可以找到很多。今天我们主要介绍 Golang 内置的单元测试工具包—— testing。说实在的,用熟了之后,发现还是挺好用的。

单元测试规范

一、导入testing工具包

testing 是 Golang 内置的单元测试工具包,导入的时候非常方便,不需要引用 github 仓库地址的包。

实例代码:

packageutilsimport"testing"

二、单元测试文件命名规范

一般我们编写单元测试时,都会和原文件组合出现,以_test.go结尾。比如,原文件是xxx.go,那么它对应的单元测试文件就是 xxx_test.go。这是一种约定,所以我们在定义文件名时,不要轻易使用_test.go后缀。

结构示例图如下:

网络异常,图片无法展示
|

三、单元测试方法命名规范

单元测试一般都是针对单个方法进行单元测试的,所以,一般单元测试方法的命名也有一定的规则。如果我们测试的方法的名字是 aaa(),那么,单元测试方法的名字就是 Testaaa(t *Testing.T)。当然,单元测试方法可以自己手动写,也可以右键 VSCode 自动生成。

比如,我想测试一个压缩方法,单元测试方法实例代码:

funcTestZipFiles(t*testing.T) {
typeargsstruct {
filenamestringfiles    []stringoldFormstringnewFormstring    }
good :=args{
filename: "../example/resources/test.zip",
files:    []string{"../example/resources/test.txt"},
oldForm:  "",
newForm:  "",
    }
bad :=args{
filename: "../example/resources/test.zip",
files:    []string{"../example/resources/test.pdf"},
oldForm:  "",
newForm:  "",
    }
tests := []struct {
namestringargsargswantErrbool    }{
        {
name:    "good",
args:    good,
wantErr: false,
        },
        {
name:    "bad",
args:    bad,
wantErr: true,
        },
    }
t.Errorf("------------>begin")
for_, tt :=rangetests {
t.Run(tt.name, func(t*testing.T) {
iferr :=ZipFiles(tt.args.filename, tt.args.files, tt.args.oldForm, tt.args.newForm); (err!=nil) !=tt.wantErr {
t.Errorf("ZipFiles() error = %v, wantErr %v", err, tt.wantErr)
            }
        })
    }
t.Errorf("end<--------------")
}

在单元测试方法中,我们可以列出多个 case ,上面的例子中就包括一个可执行测试用例和一个不可执行测试用例。

四、执行单元测试

单元测试方法写完之后,怎么运行呢?也非常简单。

命令:

go test -v

结果实例:

网络异常,图片无法展示
|

结尾

好了,今天关于在 VSCode 中进行 Golang 单元测试的方法就介绍完了,感兴趣的小伙伴自己搞起来!晚安啦!我是 liuzhen007,欢迎关注,分享更多 Golang 知识。



作者简介:😄大家好,我是 Data-Mining(liuzhen007),是一位典型的音视频技术爱好者,前后就职于传统广电巨头和音视频互联网公司,具有丰富的音视频直播和点播相关经验,对 WebRTC、FFmpeg 和 Electron 有非常深入的了解,😄公众号:玩转音视频。同时也是 CSDN 博客专家、华为云享专家(共创编辑)、InfoQ 签约作者,欢迎关注我分享更多干货!😄

目录
相关文章
|
11月前
|
Python
在VScode环境下配置Python环境的方法
经过上述步骤,你的VSCode环境就已经配置好了。请尽情享受这扇你为自己开启的知识之窗。如同你在冒险世界中前行,你的探索之路只有越走越广,你获得的知识只会越来越丰富,你的能力只会越来越强。
1025 37
|
数据采集 自然语言处理 数据库
深入体验阿里云通义灵码:测试与实例展示
阿里云通义灵码是一款强大的代码生成工具,支持自然语言描述需求,快速生成高质量代码。它在测试、代码质量和用户体验方面表现出色,能够高效地生成 Python 和 Java 等语言的代码,助力开发者提升开发效率和代码质量。无论是新手还是资深开发者,都能从中受益匪浅。
深入体验阿里云通义灵码:测试与实例展示
|
机器学习/深度学习 JSON 算法
实例分割笔记(一): 使用YOLOv5-Seg对图像进行分割检测完整版(从自定义数据集到测试验证的完整流程)
本文详细介绍了使用YOLOv5-Seg模型进行图像分割的完整流程,包括图像分割的基础知识、YOLOv5-Seg模型的特点、环境搭建、数据集准备、模型训练、验证、测试以及评价指标。通过实例代码,指导读者从自定义数据集开始,直至模型的测试验证,适合深度学习领域的研究者和开发者参考。
6599 3
实例分割笔记(一): 使用YOLOv5-Seg对图像进行分割检测完整版(从自定义数据集到测试验证的完整流程)
|
JavaScript 前端开发 开发者
如何在 Visual Studio Code (VSCode) 中使用 ESLint 和 Prettier 检查代码规范并自动格式化 Vue.js 代码,包括安装插件、配置 ESLint 和 Prettier 以及 VSCode 设置的具体步骤
随着前端开发技术的快速发展,代码规范和格式化工具变得尤为重要。本文介绍了如何在 Visual Studio Code (VSCode) 中使用 ESLint 和 Prettier 检查代码规范并自动格式化 Vue.js 代码,包括安装插件、配置 ESLint 和 Prettier 以及 VSCode 设置的具体步骤。通过这些工具,可以显著提升编码效率和代码质量。
2687 4
|
JavaScript 前端开发 编译器
TypeScript教程(一)在vscode中的配置TypeScript环境
本文是一篇TypeScript入门教程,介绍了在VS Code中配置TypeScript环境的步骤,包括安装Node.js、使用npm安装TypeScript、配置npm镜像源、安装VS Code的TypeScript扩展,以及创建和运行一个简单的TypeScript "Hello World"程序。
TypeScript教程(一)在vscode中的配置TypeScript环境
|
Ubuntu Linux 编译器
Linux/Ubuntu下使用VS Code配置C/C++项目环境调用OpenCV
通过以上步骤,您已经成功在Ubuntu系统下的VS Code中配置了C/C++项目环境,并能够调用OpenCV库进行开发。请确保每一步都按照您的系统实际情况进行适当调整。
2915 3
|
设计模式 SQL 安全
PHP中的设计模式:单例模式的深入探索与实践在PHP的编程实践中,设计模式是解决常见软件设计问题的最佳实践。单例模式作为设计模式中的一种,确保一个类只有一个实例,并提供全局访问点,广泛应用于配置管理、日志记录和测试框架等场景。本文将深入探讨单例模式的原理、实现方式及其在PHP中的应用,帮助开发者更好地理解和运用这一设计模式。
在PHP开发中,单例模式通过确保类仅有一个实例并提供一个全局访问点,有效管理和访问共享资源。本文详细介绍了单例模式的概念、PHP实现方式及应用场景,并通过具体代码示例展示如何在PHP中实现单例模式以及如何在实际项目中正确使用它来优化代码结构和性能。
279 2
|
JSON 数据格式
vscode配置latex
本文档介绍如何在VSCode中配置LaTeX环境。首先需安装texlive和VSCode,并提前安装SumatraPDF以查看PDF文件。配置包括设置自动编译、PDF预览程序及正反向搜索等。提供了详细的`settings.json`配置示例,涵盖不同操作系统下的编译选项与方案。此外,还介绍了如何配置SumatraPDF实现与VSCode的跳转功能,以及相关快捷键的使用方法。
|
Dart
Flutter笔记:手动配置VSCode中Dart代码自动格式化
Flutter笔记:手动配置VSCode中Dart代码自动格式化
2167 5
|
NoSQL 编译器 C语言
VSCode配置配置C++环境
VSCode配置配置C++环境
552 1

推荐镜像

更多