亚洲乱码中文字幕综合,中国熟女仑乱hd,亚洲精品乱拍国产一区二区三区,一本大道卡一卡二卡三乱码全集资源,又粗又黄又硬又爽的免费视频

Go語言工程實(shí)踐單元測試基準(zhǔn)測試示例詳解

 更新時(shí)間:2023年02月05日 14:22:32   作者:啵啵腸  
這篇文章主要為大家介紹了Go語言工程實(shí)踐單元測試基準(zhǔn)測試示例詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪

背景

測試的出現(xiàn)是為了避免項(xiàng)目中出現(xiàn)重大事故

測試是避免事故的最后一道屏障

測試

單元測試的覆蓋率在一定程度上而言,決定了代碼的質(zhì)量

單元測試

通過測試單元的輸出與期望值進(jìn)行校對從而驗(yàn)證代碼的正確性,從而保證新舊代碼的互不影響與程序的正常運(yùn)行。

進(jìn)而單元測試較于編譯更易于在較短的周期內(nèi)發(fā)現(xiàn)和定位代碼中的錯(cuò)誤使損失最小化從而提升效率。所以寫單元測試是很有必要的。

Golang單元測試對文件名和方法名,參數(shù)都有很嚴(yán)格的要求。

  • 文件名必須以xx_test.go命名
  • 方法必須是Test[^a-z]開頭
  • 方法參數(shù)必須t *testing.T
  • 初始化邏輯放到TestMain中
  • 使用go test執(zhí)行單元測試

演示

通過第三方包assert演示單元測試

判斷函數(shù)測試值與期望值是否一致

import(
    "github.com/stretchr/testify/assert"
    "testing"
)
func TestHelloTom(t *testing.T) {
    output := HelloTom()
    expectOutput := "Tom"
    assert.Equal(t, expectOutput, output)
}
func HelloTom() string {
    return "Tom"
}

覆蓋率

覆蓋率出現(xiàn)的目的:

  • 衡量代碼是否經(jīng)過了足夠的測試
  • 評價(jià)項(xiàng)目的測試水準(zhǔn)
  • 評估項(xiàng)目是否達(dá)到了高水準(zhǔn)測試等級

通過go test命令測試函數(shù)的覆蓋率

// judgment.go
func JudgePassLine(score int16) bool {
    if score >= 60 {
        return true
    }
    else {
        return false
    }
}
// judgment_test.go
func TestJudgePassLineTrue(t *testing.T) {
    isPass := JudgeePassLine(70)
    assert.Equal(t, true, isPass)
}
func TestJudgePassLineFalse(t *testing.T) {
    isPass := JudgeePassLine(50)
    assert.Equal(t, false, isPass)
}
/*
 通過go test 命令測試覆蓋率
 go test judgment_test.go judgment.go --cover
*/

一般覆蓋率:50%~60%,較高覆蓋率:80%+

測試分支相互獨(dú)立、全面覆蓋

對于上述案例代碼而言

應(yīng)出現(xiàn)成績大于等于60 和小于60的測試用力

測試單元粒度足夠小,函數(shù)單一職責(zé)

依賴

  • 冪等:重復(fù)運(yùn)行同一個(gè)case,結(jié)果與之前一致
  • 穩(wěn)定:指單元測試相互隔離,可以獨(dú)立運(yùn)行

文件處理

當(dāng)測試文件被修改后,可能會(huì)導(dǎo)致測試失敗或錯(cuò)誤率增高

從而出現(xiàn)了Mock函數(shù)

func ReadFirstLine() string {
    open, err := os.Open("log") // 打開一個(gè)文件
    defer open.Close()
    if err != nil {
        return ""
    }
    scanner := bufio.NewScanner(open) // 對每行進(jìn)行遍歷
    for scanner.Scan() {
        return scanner.Text()
    }
    return ""
}
func ProcessFirstLine() string {
    line := ReadFirstLine()
    destLine := strings.ReplaceAll(line, "11", "00") // 替換11為00
    return destLine
}
func TestProcessFirstLine(t *testing.T) { // 執(zhí)行單元測試
    firstLine := ProcessFirstLine()
    assert.Equal(t, "line00", firstLine)
}

Mock

monkey: github.com/bouk/monkey 這是一個(gè)開源的mock測試庫,可以對method或者實(shí)例的方法進(jìn)行mock

Monkey Patch的作用域在Runtime, 運(yùn)行時(shí)通過Go的unsafe包能夠?qū)?nèi)存中函數(shù)的地址替換為運(yùn)行時(shí)函數(shù)的地址,將待打樁函數(shù)或方法的實(shí)現(xiàn)跳轉(zhuǎn)。

Mock函數(shù)不僅可以為一個(gè)函數(shù)打樁 也可以為一個(gè)方法打樁

// 用函數(shù)A去替換函數(shù)B,B就是原函數(shù),A就是打樁函數(shù)
func Patch(target, replacement interface{}) *PatchGuard {
    // target就是原函數(shù),replacement就是打樁函數(shù)
    t := reflect.ValueOf(target)
    r := reflect.ValueOf(replacement)
    patchValue(t, r)
    return &PatchGuard{t, r}
}
func Unpatch(target interface{}) bool {
    // 保證了在測試結(jié)束之后需要把這個(gè)包卸載掉
    return unpatchValue(reflect.ValueOf(target))
}
func TestProcessFirstLineWithMock(t *testing.T) {
    monkey.Patch(ReadFirstLine, func() string {
        return "line110"
    })
    defer monkey.Unpatch(ReadFirstLine)
    line := ProcessFirstLine()
    assert.Equal(t, "line000", line)
}
// 通過patch對ReadFirstLine進(jìn)行打樁mock,默認(rèn)返回line110,通過defer卸載mock
// 這樣整個(gè)測試函數(shù)就擺脫了本地文件的束縛和依賴

基準(zhǔn)測試

基準(zhǔn)測試是指測試一段程序的性能及耗費(fèi)CPU的程度;

在實(shí)際的項(xiàng)目開發(fā)中,經(jīng)常會(huì)遇到代碼性能瓶頸,為了定位問題,經(jīng)常要對代碼做性能分;

這時(shí)就用到了基準(zhǔn)測試,其使用方法與單元測試類似。

  • 優(yōu)化代碼,需要對當(dāng)前代碼分析
  • 內(nèi)置的測試框架提供了基準(zhǔn)測試的能力

小結(jié)

對于今日課程而言,我將其劃分成測試的重要性與分類。 當(dāng)前課程余下部分為項(xiàng)目實(shí)戰(zhàn),該部分內(nèi)容選擇了放置于項(xiàng)目筆記。 如果筆記中有錯(cuò)誤的地方也希望掘友們可以及時(shí)的提出糾正,更多關(guān)于Go語言單元測試基準(zhǔn)測的資料請關(guān)注腳本之家其它相關(guān)文章!

相關(guān)文章

  • go流程控制代碼詳解

    go流程控制代碼詳解

    這篇文章主要介紹了go流程控制,本文通過實(shí)例代碼給大家介紹的非常詳細(xì),具有一定的參考借鑒價(jià)值 ,需要的朋友可以參考下
    2019-05-05
  • 基于golang uint8、int8與byte的區(qū)別說明

    基于golang uint8、int8與byte的區(qū)別說明

    這篇文章主要介紹了基于golang uint8、int8與byte的區(qū)別說明,具有很好的參考價(jià)值,希望對大家有所幫助。一起跟隨小編過來看看吧
    2021-03-03
  • Go語言學(xué)習(xí)otns示例分析

    Go語言學(xué)習(xí)otns示例分析

    這篇文章主要為大家介紹了Go語言學(xué)習(xí)otns示例分析詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪
    2023-04-04
  • 一篇文章搞懂Go語言中的Context

    一篇文章搞懂Go語言中的Context

    這篇文章主要介紹了一篇文章搞懂Go語言中的Context,Context攜帶一個(gè)截止日期、一個(gè)取消信號和其他跨越API邊界的值。上下文的方法可以被多個(gè)gor例程同時(shí)調(diào)用
    2022-07-07
  • Go語言中你所不知道的位操作用法

    Go語言中你所不知道的位操作用法

    位運(yùn)算可能在平常的編程中使用的并不多,但涉及到底層優(yōu)化,一些算法及源碼可能會(huì)經(jīng)常遇見。下面這篇文章主要給大家介紹了關(guān)于Go語言中你所不知道的位操作用法的相關(guān)資料,文中通過示例代碼介紹的非常詳細(xì),需要的朋友可以參考下。
    2017-12-12
  • go語言中的json與map相互轉(zhuǎn)換實(shí)現(xiàn)

    go語言中的json與map相互轉(zhuǎn)換實(shí)現(xiàn)

    本文主要介紹了go語言中的json與map相互轉(zhuǎn)換實(shí)現(xiàn),文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2022-08-08
  • Golang?websocket協(xié)議使用淺析

    Golang?websocket協(xié)議使用淺析

    這篇文章主要介紹了Golang?websocket協(xié)議的使用,WebSocket是一種新型的網(wǎng)絡(luò)通信協(xié)議,可以在Web應(yīng)用程序中實(shí)現(xiàn)雙向通信,感興趣想要詳細(xì)了解可以參考下文
    2023-05-05
  • Golang?依賴注入經(jīng)典解決方案uber/fx理論解析

    Golang?依賴注入經(jīng)典解決方案uber/fx理論解析

    這篇文章主要為大家介紹了Golang依賴注入經(jīng)典解決方案uber/fx理論解析,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪
    2023-05-05
  • Golang中常見加密算法的總結(jié)

    Golang中常見加密算法的總結(jié)

    這篇文章主要為大家詳細(xì)介紹了Golang中常見的一些加密算法的實(shí)現(xiàn),文中的示例代碼講解詳細(xì),具有一定的學(xué)習(xí)價(jià)值,感興趣的小伙伴可以了解一下
    2023-03-03
  • Go語言操作mysql數(shù)據(jù)庫簡單例子

    Go語言操作mysql數(shù)據(jù)庫簡單例子

    這篇文章主要介紹了Go語言操作mysql數(shù)據(jù)庫簡單例子,本文包含插入數(shù)據(jù)和查詢代碼實(shí)例,需要的朋友可以參考下
    2014-10-10

最新評論