真实的国产乱ⅩXXX66竹夫人,五月香六月婷婷激情综合,亚洲日本VA一区二区三区,亚洲精品一区二区三区麻豆

成都創(chuàng)新互聯(lián)網站制作重慶分公司

使用go優(yōu)雅地撰寫單元測試的方法-創(chuàng)新互聯(lián)

小編給大家分享一下使用go優(yōu)雅地撰寫單元測試的方法,希望大家閱讀完這篇文章后大所收獲,下面讓我們一起去探討吧!

成都創(chuàng)新互聯(lián)公司是一家專注于成都網站設計、成都網站制作與策劃設計,普安網站建設哪家好?成都創(chuàng)新互聯(lián)公司做網站,專注于網站建設十載,網設計領域的專業(yè)建站公司;建站業(yè)務涵蓋:普安等地區(qū)。普安做網站價格咨詢:18982081108

                                                       

背景

剛剛加入一個年輕的小組,代碼中的單元測試還沒有來得及寫,leader希望我通過單元測試來熟悉項目的業(yè)務邏輯。但是,代碼量實在有點多,高效的完成單元測試成為首要目標。

實現(xiàn)原理

單元測試測用的是testify的測試框架,使用起來非常方便,具體的基礎使用方法可以參考中文testify博客以及官方文檔。

項目中的應用

初始化單元測試

在一個復雜的Web項目中,測試某一模塊的功能往往需要先對這一模塊所使用到的服務進行初始化,我們將初始化函數以及初始化函數所使用到的參數都放在同一個單元測試包下,例如對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()}

我們在另一個contant包下存放對應的參數:

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進行初始化,Register函數可以傳入四個參數fun1,fun2,fun3,fun4
fun1:在該測試文件中的最開始執(zhí)行一次。
fun2:在每個單元測試前都執(zhí)行一次。
fun3:在每個單元測試后都執(zhí)行一次。
fun4:在該測試文件中的最終執(zhí)行一次。
根據需求,我們需要在所有單元測試開始前執(zhí)行一次初始化數據庫操作,以及在最后關閉數據庫。

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)//創(chuàng)建測試的數據記錄
    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)//創(chuàng)建測試的數據記錄
    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優(yōu)雅地撰寫單元測試的方法有了一定的了解,想了解更多相關知識,歡迎關注創(chuàng)新互聯(lián)-成都網站建設公司行業(yè)資訊頻道,感謝各位的閱讀!


網站題目:使用go優(yōu)雅地撰寫單元測試的方法-創(chuàng)新互聯(lián)
文章出自:http://weahome.cn/article/jgegg.html

其他資訊

在線咨詢

微信咨詢

電話咨詢

028-86922220(工作日)

18980820575(7×24)

提交需求

返回頂部