2017-07-06 13:03:44 +02:00
|
|
|
package cmd
|
2017-04-26 20:21:18 +02:00
|
|
|
|
|
|
|
import (
|
2017-04-26 20:25:53 +02:00
|
|
|
"testing"
|
2017-06-22 19:04:48 +02:00
|
|
|
"time"
|
2017-08-05 21:15:37 +02:00
|
|
|
|
|
|
|
"github.com/stretchr/testify/assert"
|
|
|
|
"github.com/zrepl/zrepl/util"
|
|
|
|
"github.com/zrepl/zrepl/zfs"
|
2017-04-26 20:21:18 +02:00
|
|
|
)
|
|
|
|
|
2017-09-10 16:13:05 +02:00
|
|
|
func TestSampleConfigsAreParsedWithoutErrors(t *testing.T) {
|
|
|
|
|
2017-09-11 15:45:10 +02:00
|
|
|
paths := []string{
|
2017-09-10 16:13:05 +02:00
|
|
|
"./sampleconf/localbackup/host1.yml",
|
|
|
|
"./sampleconf/pullbackup/backuphost.yml",
|
|
|
|
"./sampleconf/pullbackup/productionhost.yml",
|
2017-09-11 15:45:10 +02:00
|
|
|
"./sampleconf/random/debugging.yml",
|
2017-09-10 16:13:05 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
for _, p := range paths {
|
|
|
|
|
|
|
|
_, err := ParseConfig(p)
|
|
|
|
if err != nil {
|
|
|
|
t.Errorf("error parsing %s:\n%+v", p, err)
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2017-04-26 20:21:18 +02:00
|
|
|
}
|
2017-06-22 19:04:48 +02:00
|
|
|
|
|
|
|
func TestParseRetentionGridStringParsing(t *testing.T) {
|
|
|
|
|
2017-07-09 00:38:16 +02:00
|
|
|
intervals, err := parseRetentionGridIntervalsString("2x10m(keep=2) | 1x1h | 3x1w")
|
2017-06-22 19:04:48 +02:00
|
|
|
|
|
|
|
assert.Nil(t, err)
|
|
|
|
assert.Len(t, intervals, 6)
|
|
|
|
proto := util.RetentionInterval{
|
|
|
|
KeepCount: 2,
|
|
|
|
Length: 10 * time.Minute,
|
|
|
|
}
|
|
|
|
assert.EqualValues(t, proto, intervals[0])
|
|
|
|
assert.EqualValues(t, proto, intervals[1])
|
|
|
|
|
|
|
|
proto.KeepCount = 1
|
|
|
|
proto.Length = 1 * time.Hour
|
|
|
|
assert.EqualValues(t, proto, intervals[2])
|
|
|
|
|
|
|
|
proto.Length = 7 * 24 * time.Hour
|
|
|
|
assert.EqualValues(t, proto, intervals[3])
|
|
|
|
assert.EqualValues(t, proto, intervals[4])
|
|
|
|
assert.EqualValues(t, proto, intervals[5])
|
|
|
|
|
|
|
|
intervals, err = parseRetentionGridIntervalsString("|")
|
|
|
|
assert.Error(t, err)
|
2017-07-09 00:38:16 +02:00
|
|
|
intervals, err = parseRetentionGridIntervalsString("2x10m")
|
2017-06-22 19:04:48 +02:00
|
|
|
assert.NoError(t, err)
|
|
|
|
|
2017-07-09 00:38:16 +02:00
|
|
|
intervals, err = parseRetentionGridIntervalsString("1x10m(keep=all)")
|
2017-06-22 19:04:48 +02:00
|
|
|
assert.NoError(t, err)
|
|
|
|
assert.Len(t, intervals, 1)
|
|
|
|
assert.EqualValues(t, util.RetentionGridKeepCountAll, intervals[0].KeepCount)
|
|
|
|
|
|
|
|
}
|
2017-08-05 21:15:37 +02:00
|
|
|
|
|
|
|
func TestDatasetMapFilter(t *testing.T) {
|
|
|
|
|
|
|
|
expectMapping := func(m map[string]string, from, to string) {
|
|
|
|
dmf, err := parseDatasetMapFilter(m, false)
|
|
|
|
if err != nil {
|
|
|
|
t.Logf("expect test map to be valid: %s", err)
|
|
|
|
t.FailNow()
|
|
|
|
}
|
|
|
|
fromPath, err := zfs.NewDatasetPath(from)
|
|
|
|
if err != nil {
|
|
|
|
t.Logf("expect test from path to be valid: %s", err)
|
|
|
|
t.FailNow()
|
|
|
|
}
|
|
|
|
toPath, err := zfs.NewDatasetPath(to)
|
|
|
|
if err != nil {
|
|
|
|
t.Logf("expect test to path to be valid: %s", err)
|
|
|
|
t.FailNow()
|
|
|
|
}
|
|
|
|
|
|
|
|
res, err := dmf.Map(fromPath)
|
|
|
|
t.Logf("%s => %s", fromPath.ToString(), res.ToString())
|
|
|
|
assert.Nil(t, err)
|
|
|
|
assert.True(t, res.Equal(toPath))
|
|
|
|
}
|
|
|
|
|
|
|
|
expectFilter := func(m map[string]string, path string, pass bool) {
|
|
|
|
dmf, err := parseDatasetMapFilter(m, true)
|
|
|
|
if err != nil {
|
|
|
|
t.Logf("expect test filter to be valid: %s", err)
|
|
|
|
t.FailNow()
|
|
|
|
}
|
|
|
|
p, err := zfs.NewDatasetPath(path)
|
|
|
|
if err != nil {
|
|
|
|
t.Logf("expect test path to be valid: %s", err)
|
|
|
|
t.FailNow()
|
|
|
|
}
|
|
|
|
res, err := dmf.Filter(p)
|
|
|
|
assert.Nil(t, err)
|
|
|
|
assert.Equal(t, pass, res)
|
|
|
|
}
|
|
|
|
|
|
|
|
map1 := map[string]string{
|
|
|
|
"a/b/c<": "root1",
|
|
|
|
"a/b<": "root2",
|
|
|
|
"<": "root3/b/c",
|
|
|
|
"q<": "root4/1/2",
|
|
|
|
}
|
|
|
|
|
|
|
|
expectMapping(map1, "a/b/c", "root1")
|
|
|
|
expectMapping(map1, "a/b/c/d", "root1/d")
|
|
|
|
expectMapping(map1, "a/b/e", "root2/e")
|
|
|
|
expectMapping(map1, "a/b", "root2")
|
|
|
|
expectMapping(map1, "x", "root3/b/c")
|
|
|
|
expectMapping(map1, "x/y", "root3/b/c/y")
|
|
|
|
expectMapping(map1, "q", "root4/1/2")
|
|
|
|
expectMapping(map1, "q/r", "root4/1/2/r")
|
|
|
|
|
|
|
|
filter1 := map[string]string{
|
|
|
|
"<": "omit",
|
|
|
|
"a<": "ok",
|
|
|
|
"a/b<": "omit",
|
|
|
|
}
|
|
|
|
|
|
|
|
expectFilter(filter1, "b", false)
|
|
|
|
expectFilter(filter1, "a", true)
|
|
|
|
expectFilter(filter1, "a/d", true)
|
|
|
|
expectFilter(filter1, "a/b", false)
|
|
|
|
expectFilter(filter1, "a/b/c", false)
|
|
|
|
|
|
|
|
filter2 := map[string]string{}
|
|
|
|
expectFilter(filter2, "foo", false) // default to omit
|
|
|
|
|
|
|
|
}
|