golang代码规范和单元测试

代码规范

方便团队内部统一风格,提高代码可读性,统一性

命名规范

  1. 包名
    1. 尽量和目录名一致
    2. 采用有意义,简短
    3. 不要和标准库冲突
    4. 包名应该尽量全部小写
  1. 文件名
    1. 如果多个单词可以采用蛇形命名法
  1. 变量名
    1. 蛇形 不使用
    2. 驼峰 go un userName
    3. 专有名词全大写或者全小写
  1. 结构名
    1. 驼峰 首字母大写
  1. 接口命名
    1. 和结构体差不多
    2. 接口已er结尾
    3. IR
  1. 常量命名
    1. 全部大写,多个单词采用蛇形APP_VERSION

注释规范:

go提供两种注释:

  1. //适合单行注释
  2. 大段注释
  3. 变量后面加注释
  4. 包注释
  5. 接口注释
  6. 函数注释
  7. 代码逻辑注释

import注释

  1. go自带的包
  2. 第三方的包
  3. 自己内部的包

单元测试

单元测试命令:go test

go test命令是一个按照一定约定和组织的测试代码驱动程序。在包目录中,所有以_test.go为后缀的源码文件都会被go test运行

我们写的__test.go源码文件不用担心内容过多,因为go build命令不会将这些测试文件打包到最后的可执行文件

test文件有4类,Test开头的 功能测试

Benchmark开头的 性能测试

example 模糊测试

复制代码
func TestAdd(t *testing.T) {

}

跳过耗时单元测试

复制代码
func TestAdd2 (t *testing.T) {
	if testing.Short() {
		t.Skip("short 模式下跳过")
	}
	re := add(a:1,b:2)
	if re != 3 {
	t.Errorf("expect %d,actual %d")
}
}

go test -short

运行一个短的

基于表格的测试用例

复制代码
func TestAdd(t *Testing.T) {
	var dataset = []struct{
	a int
	b int
	out int
	}{
	{a:1,b:2,out:3}
	{a:1,b:2,out:3}
	{a:1,b:2,out:3}
	{a:1,b:2,out:3}
	{a:1,b:2,out:3}
	}
	for _,value := range dataset {
	re := add(value.a,value.b)
	if re != value.out {
	t.Errorf("expect:%d,actual:%d",value.out,re)
	}
	}
}

性能测试

核心函数

复制代码
func BenchmarAdd(bb *testing.B) {
	var a,b,c int
	a = 123
	b = 456
	c = 789
	
	for i:= 0;i< bb.N;i++ {
	 if actual := add(a,b);actual != c{
	fmt.Printf("%d+%d,except:%d,actual:%d",a,b,c,actual)
	}
	}
}
实例

对三种字符串的拼接方式进行性能测试

复制代码
package light_edit

import (
	"fmt"
	"strconv"
	"strings"
	"testing"
)

const numbers = 10000

func BenchmarkStringBuilder(b *testing.B) {
	b.ResetTimer()

	for i := 0; i < b.N; i++ {
		var builder strings.Builder
		for j := 0; j < numbers; j++ {
			builder.WriteString(strconv.Itoa(j))
		}
		_ = builder.String()
	}
	b.StopTimer()
}

func BenchmarkStringAdd(b *testing.B) {
	b.ResetTimer()

	for i := 0; i < b.N; i++ {
		var str string
		for j := 0; j < numbers; j++ {
			str = str + strconv.Itoa(j)
		}

	}
	b.StopTimer()

}

func BenchmarkStringSprintf(b *testing.B) {
	b.ResetTimer()

	for i := 0; i < b.N; i++ {
		var str string
		for j := 0; j < numbers; j++ {
			str = fmt.Sprintf("%s%d", str, j)
		}
	}
	b.StopTimer()
}
相关推荐
n***632711 小时前
Spring Boot 整合 log4j2 日志配置教程
spring boot·单元测试·log4j
代码or搬砖14 小时前
SpringMVC常用注解(二)
log4j
代码or搬砖15 小时前
SpringMVC常用注解
log4j
R***62311 天前
Spring Boot 整合 log4j2 日志配置教程
spring boot·单元测试·log4j
百花~6 天前
自动化测试概念篇~
selenium·log4j
k***3889 天前
SpringBoot Test详解
spring boot·后端·log4j
马达加斯加D9 天前
C# --- 如何写UT
前端·c#·log4j
秃了也弱了。9 天前
testng:Java界功能强大的单元测试框架
java·单元测试·log4j
q***420512 天前
Spring Boot 整合 log4j2 日志配置教程
spring boot·单元测试·log4j
m0_5656111317 天前
Java高级特性:单元测试、反射、注解、动态代理
java·单元测试·log4j