|
| 1 | +package postfix |
| 2 | + |
| 3 | +import ( |
| 4 | + "io/ioutil" |
| 5 | + "os" |
| 6 | + "path" |
| 7 | + "testing" |
| 8 | + "time" |
| 9 | + |
| 10 | + "github.com/influxdata/telegraf/testutil" |
| 11 | + "github.com/stretchr/testify/assert" |
| 12 | + "github.com/stretchr/testify/require" |
| 13 | +) |
| 14 | + |
| 15 | +func TestGather(t *testing.T) { |
| 16 | + td, err := ioutil.TempDir("", "") |
| 17 | + require.NoError(t, err) |
| 18 | + defer os.RemoveAll(td) |
| 19 | + |
| 20 | + for _, q := range []string{"active", "hold", "incoming", "maildrop", "deferred"} { |
| 21 | + require.NoError(t, os.Mkdir(path.Join(td, q), 0755)) |
| 22 | + } |
| 23 | + for _, q := range []string{"0", "1", "2", "3", "4", "5", "6", "7", "8", "9", "A", "B", "C", "D", "F"} { // "E" deliberately left off |
| 24 | + require.NoError(t, os.Mkdir(path.Join(td, "deferred", q), 0755)) |
| 25 | + } |
| 26 | + |
| 27 | + require.NoError(t, ioutil.WriteFile(path.Join(td, "active", "01"), []byte("abc"), 0644)) |
| 28 | + require.NoError(t, ioutil.WriteFile(path.Join(td, "active", "02"), []byte("defg"), 0644)) |
| 29 | + require.NoError(t, os.Chtimes(path.Join(td, "active", "02"), time.Now(), time.Now().Add(-time.Hour))) |
| 30 | + require.NoError(t, ioutil.WriteFile(path.Join(td, "hold", "01"), []byte("abc"), 0644)) |
| 31 | + require.NoError(t, ioutil.WriteFile(path.Join(td, "incoming", "01"), []byte("abcd"), 0644)) |
| 32 | + require.NoError(t, ioutil.WriteFile(path.Join(td, "deferred", "0", "01"), []byte("abc"), 0644)) |
| 33 | + require.NoError(t, ioutil.WriteFile(path.Join(td, "deferred", "F", "F1"), []byte("abc"), 0644)) |
| 34 | + |
| 35 | + p := Postfix{ |
| 36 | + QueueDirectory: td, |
| 37 | + } |
| 38 | + |
| 39 | + var acc testutil.Accumulator |
| 40 | + require.NoError(t, p.Gather(&acc)) |
| 41 | + |
| 42 | + metrics := map[string]*testutil.Metric{} |
| 43 | + for _, m := range acc.Metrics { |
| 44 | + metrics[m.Tags["queue"]] = m |
| 45 | + } |
| 46 | + |
| 47 | + assert.Equal(t, int64(2), metrics["active"].Fields["length"]) |
| 48 | + assert.Equal(t, int64(7), metrics["active"].Fields["size"]) |
| 49 | + assert.InDelta(t, int64(time.Hour/time.Second), metrics["active"].Fields["age"], 10) |
| 50 | + |
| 51 | + assert.Equal(t, int64(1), metrics["hold"].Fields["length"]) |
| 52 | + assert.Equal(t, int64(3), metrics["hold"].Fields["size"]) |
| 53 | + |
| 54 | + assert.Equal(t, int64(1), metrics["incoming"].Fields["length"]) |
| 55 | + assert.Equal(t, int64(4), metrics["incoming"].Fields["size"]) |
| 56 | + |
| 57 | + assert.Equal(t, int64(0), metrics["maildrop"].Fields["length"]) |
| 58 | + assert.Equal(t, int64(0), metrics["maildrop"].Fields["size"]) |
| 59 | + assert.Equal(t, int64(0), metrics["maildrop"].Fields["age"]) |
| 60 | + |
| 61 | + assert.Equal(t, int64(2), metrics["deferred"].Fields["length"]) |
| 62 | + assert.Equal(t, int64(6), metrics["deferred"].Fields["size"]) |
| 63 | +} |
0 commit comments