如何在Go 中對命令列標誌進行單元測試
簡介:
單元測試是對於確保程式碼的可靠性和正確性至關重要,包括命令列標誌處理。標誌解析是 Go 應用程式中的常見任務,驗證標誌是否正確驗證至關重要。本文將探討如何在 Go 中對命令列標誌進行單元測試。
設定單元測試:
為了單元測試標誌驗證,我們將建立一個自訂檢查標誌值是否在預期枚舉範圍內的標誌類型。考慮以下範例程式碼:
<code class="go">var formatType string const ( text = "text" json = "json" hash = "hash" ) func init() { const ( defaultFormat = "text" formatUsage = "desired output format" ) flag.StringVar(&formatType, "format", defaultFormat, formatUsage) flag.StringVar(&formatType, "f", defaultFormat, formatUsage+" (shorthand)") }</code>
自訂標誌驗證:
我們可以定義自訂標誌。值類型來驗證格式標誌:
<code class="go">type formatType string func (f *formatType) String() string { return fmt.Sprint(*f) } func (f *formatType) Set(value string) error { if len(*f) > 0 && *f != "text" { return errors.New("format flag already set") } if value != "text" && value != "json" && value != "hash" { return errors.New("Invalid Format Type") } *f = formatType(value) return nil }</code>
建立單元測試:
現在,讓我們寫一個驗證自訂標誌驗證的單元測試:
<code class="go">func TestValidateFormatFlag(t *testing.T) { testCases := []struct { input string expected error }{ {"text", nil}, {"json", nil}, {"hash", nil}, {"invalid", errors.New("Invalid Format Type")}, } for _, tc := range testCases { args := []string{"-format", tc.input} os.Args = args typeFlag = "text" flag.CommandLine = flag.NewFlagSet("test", flag.ContinueOnError) flag.Var(&typeFlag, "format", "Format type. Must be \"text\", \"json\" or \"hash\". Defaults to \"text\".") if err := flag.CommandLine.Parse(args[1:]); err != nil { t.Errorf("Error parsing flags: %v", err) } if tc.expected != nil && err == nil { t.Errorf("Expected error: %v, got nil", tc.expected) } else if tc.expected == nil && err != nil { t.Errorf("Unexpected error: %v", err) } } }</code>
在此測試中,我們設定一系列具有不同輸入和預期錯誤的測試案例。我們使用 os.Args 模擬命令列參數,並使用自訂 FlagSet 解析標誌。透過將每個測試案例的實際錯誤與預期錯誤進行比較,我們確保標誌驗證按預期工作。
執行標誌測試的提示:
結論:
透過實作自訂標誌類型和編寫單元測試,您可以有效地驗證 Go 中的命令列標誌。這種做法有助於保持應用程式的可靠性和穩健性。
以上是如何在 Go 中對命令列標誌驗證進行單元測試?的詳細內容。更多資訊請關注PHP中文網其他相關文章!