aboutsummaryrefslogtreecommitdiff
path: root/text_test.go
blob: 2a667abae8fb4706322b85ece9fe388d9d9d7679 (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
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.Date(2002, 1, 2, 15, 05, 05, 07, time.UTC)},
		{"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 && tc.success == true {
			t.Errorf("expected success, got %q", err)
			continue
		} else if err == nil && tc.success == false {
			t.Errorf("expected failure, but succeeded")
			continue
		} else if tc.success {
			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)
			}
		}
	}
}