>백엔드 개발 >Golang >go를 사용하여 단위 테스트를 우아하게 작성하는 방법

go를 사용하여 단위 테스트를 우아하게 작성하는 방법

藏色散人
藏色散人앞으로
2020-09-07 09:16:501988검색

Background

go를 사용하여 단위 테스트를 우아하게 작성하는 방법 저는 이제 막 젊은 팀에 합류했고, 아직 코드에 유닛 테스트를 작성할 시간이 없었습니다. 리더는 제가 유닛을 통해 프로젝트의 비즈니스 로직에 익숙해질 수 있기를 바랍니다. 테스트. 하지만 코드의 양이 정말 너무 많아서 효율적으로 단위 테스트를 완료하는 것이 주요 목표가 됩니다.

구현 원리

단위 테스트는 testify의 테스트 프레임워크를 사용하므로 사용이 매우 편리합니다. 구체적인 기본 사용 방법은 중국어 testify 블로그 및 공식 문서를 참조하세요.

프로젝트 내 애플리케이션

초기화 단위 테스트복잡한 웹 프로젝트에서 특정 모듈의 기능을 테스트하려면 이 모듈에서 사용하는 서비스를 초기화해야 하는 경우가 많습니다. 초기화 기능은 동일한 단위 테스트 패키지에 배치됩니다. 예를 들어 MySQL의 초기화는 다음과 같습니다.

package unitTestfunc InitMySQL() error{
    return db.Init(constant.MySQLDSN,
    constant.MaxIdleConns,
    constant.MaxOpenConns, 
    time.Duration(constant.ConnMaxLifetime)*time.Second,
    constant.EnableSqlLog)//其他包中已经封装了初始化函数,在测试包的初始化函数中调用即可}func CloseDB() error{
    return db.Close()}

해당 매개변수를 다른 콘텐츠 패키지에 저장합니다.
package constantconstant(
    MySQLDSN = "username:password@addresss/db?timeout=5000ms&readTimeout=5s&charset=utf8mb4"
    MaxIdleConns = 20
    MaxOpenConns = 20
    ConnMaxLifetime = 60
    EnableSqlLog = true
    MerchantID = 6666
    SheetID = "SZSWIMTEST"
    Operator = "XXXX@XXXX")

단위 테스트용

다음은 다음과 같습니다. 예를 들어 데이터베이스 작동

단위 테스트는 주로 세 부분으로 구성됩니다.

첫 번째 부분은 고정된 쓰기 방법입니다
type ActionLogRepo struct {
    basetest.BaseSuite}
두 번째 부분은 레지스터를 초기화하는 것입니다. Register 함수는 fun1, fun2, fun3, fun4

fun1: 테스트 파일 시작 부분에서 한 번 실행합니다.

fun2: 각 단위 테스트 전에 한 번 실행합니다.
fun3: 각 단위 테스트 후에 한 번씩 실행합니다.
fun4: 이 테스트 파일의 최종 실행입니다.

요구 사항에 따라 모든 단위 테스트가 시작되기 전에 데이터베이스 초기화 작업을 수행하고 마지막에 데이터베이스를 닫아야 합니다.

func TestActionLogRepo(t *testing.T) {
    AgentSuite := new(ActionLogRepo)
    var err error
    AgentSuite.Register(
        func() {
            err = unitTest.InitMySQL()
        },
        nil,
        nil,
        func() {
            err = unitTest.CloseDB()
        })
    assert.Nil(t,err)
    suite.Run(t, AgentSuite)}

세 번째 부분은 먼저 데이터베이스에 해당 데이터를 생성한 다음 해당 데이터에 대해 작동하기 위해 단위 테스트가 필요한 함수를 호출한 다음 Assert를 사용하여 결과를 확인하는 것입니다. 단위 테스트 기록.
func (suite *ActionLogRepo) TestActionLog() {
    repo := repository.NewRepository()//获取数据库
    actionLog := &model.ActionLogTab{XXXXXX}
    err := CreateActionLog(actionLog)//创建测试的数据记录
    assert.Nil(suite.T(),err)
    logs,count,err := FetchActionLogs(repo,repo.MerchantID,actionLog.SheetID,actionLog.SheetType,1,1)//需要测试的函数
    assert.Nil(suite.T(),err)
    assert.Equal(suite.T(),logs[0].OperationTime,actionLog.OperationTime)//验证函数的正确性

    err = repo.MerchantDB().Delete(actionLog).Error//删除掉测试的数据库记录
    assert.Nil(suite.T(),err)}

최종 테스트 파일 구조는 다음과 같습니다.
package testtype ActionLogRepo struct {
    basetest.BaseSuite}func TestActionLogRepo(t *testing.T) {
    AgentSuite := new(ActionLogRepo)
    var err error
    AgentSuite.Register(
        func() {
            err = unitTest.InitMySQL()
        },
        nil,
        nil,
        func() {
            err = unitTest.CloseDB()
        })
    assert.Nil(t,err)
    suite.Run(t, AgentSuite)}func (suite *ActionLogRepo) TestActionLog() {
    repo := repository.NewRepository()//获取数据库
    actionLog := &model.ActionLogTab{XXXXXX}
    err := CreateActionLog(actionLog)//创建测试的数据记录
    assert.Nil(suite.T(),err)
    logs,count,err := FetchActionLogs(repo,repo.MerchantID,actionLog.SheetID,actionLog.SheetType,1,1)//需要测试的函数
    assert.Nil(suite.T(),err)
    assert.Equal(suite.T(),logs[0].OperationTime,actionLog.OperationTime)//验证函数的正确性

    err = repo.MerchantDB().Delete(actionLog).Error//删除掉测试的数据库记录
    assert.Nil(suite.T(),err)}

위 내용은 go를 사용하여 단위 테스트를 우아하게 작성하는 방법의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

성명:
이 기사는 learnku.com에서 복제됩니다. 침해가 있는 경우 admin@php.cn으로 문의하시기 바랍니다. 삭제