diff options
| author | Tomas Aschan <[email protected]> | 2025-05-15 08:34:45 +0200 |
|---|---|---|
| committer | GitHub <[email protected]> | 2025-05-15 08:34:45 +0200 |
| commit | 196624cc28da007ab68e13213b7fb6447211ad31 (patch) | |
| tree | 3f0a00c49539532d92fdb83775999d9a948bb16c /text_test.go | |
| parent | 7322552c7c20c512a8b5bedeb1ad4a9504fcee00 (diff) | |
| parent | 011db0c1163722ac2fa4452be8be8123768dc912 (diff) | |
Merge pull request #418 from hujun-open/master
add support equivalent to golang flag.TextVar(), also fixes the test failure as described in #368
Diffstat (limited to 'text_test.go')
| -rw-r--r-- | text_test.go | 56 |
1 files changed, 56 insertions, 0 deletions
diff --git a/text_test.go b/text_test.go new file mode 100644 index 0000000..e60c136 --- /dev/null +++ b/text_test.go @@ -0,0 +1,56 @@ +package pflag + +import ( + "fmt" + "os" + "testing" + "time" +) + +func setUpTime(t *time.Time) *FlagSet { + f := NewFlagSet("test", ContinueOnError) + f.TextVar(t, "time", time.Now(), "time stamp") + return f +} + +func TestText(t *testing.T) { + testCases := []struct { + input string + success bool + expected time.Time + }{ + {"2003-01-02T15:04:05Z", true, time.Date(2003, 1, 2, 15, 04, 05, 0, time.UTC)}, + {"2003-01-02 15:05:01", false, time.Time{}}, //negative case, invalid layout + {"2024-11-22T03:01:02Z", true, time.Date(2024, 11, 22, 3, 1, 02, 0, time.UTC)}, + {"2006-01-02T15:04:05+07:00", true, time.Date(2006, 1, 2, 15, 4, 5, 0, time.FixedZone("UTC+7", 7*60*60))}, + } + + devnull, _ := os.Open(os.DevNull) + os.Stderr = devnull + for i := range testCases { + var ts time.Time + f := setUpTime(&ts) + tc := &testCases[i] + arg := fmt.Sprintf("--time=%s", tc.input) + err := f.Parse([]string{arg}) + if err != nil { + if tc.success { + t.Errorf("expected parsing to succeed, but got %q", err) + } + continue + } + if !tc.success { + t.Errorf("expected parsing failure, but parsing succeeded") + continue + } + parsedT := new(time.Time) + err = f.GetText("time", parsedT) + if err != nil { + t.Errorf("Got error trying to fetch the time flag: %v", err) + } + if !parsedT.Equal(tc.expected) { + t.Errorf("expected %q, got %q", tc.expected, parsedT) + } + + } +} |
