2017-05-07 14:07:50 +02:00
|
|
|
package zfs
|
|
|
|
|
|
|
|
import (
|
|
|
|
"testing"
|
2019-03-22 19:41:12 +01:00
|
|
|
|
|
|
|
"github.com/stretchr/testify/assert"
|
2017-05-07 14:07:50 +02:00
|
|
|
)
|
|
|
|
|
|
|
|
func TestNewDatasetPathTree(t *testing.T) {
|
|
|
|
|
2017-08-05 21:15:37 +02:00
|
|
|
r := newDatasetPathTree(toDatasetPath("pool1/foo/bar").comps)
|
2017-05-07 14:07:50 +02:00
|
|
|
|
|
|
|
assert.Equal(t, "pool1", r.Component)
|
|
|
|
assert.True(t, len(r.Children) == 1)
|
|
|
|
cr := r.Children[0]
|
|
|
|
assert.Equal(t, "foo", cr.Component)
|
|
|
|
assert.True(t, len(cr.Children) == 1)
|
|
|
|
ccr := cr.Children[0]
|
|
|
|
assert.Equal(t, "bar", ccr.Component)
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
type visitRecorder struct {
|
|
|
|
visits []DatasetPathVisit
|
|
|
|
}
|
|
|
|
|
|
|
|
func makeVisitRecorder() (v DatasetPathsVisitor, rec *visitRecorder) {
|
|
|
|
rec = &visitRecorder{
|
|
|
|
visits: make([]DatasetPathVisit, 0),
|
|
|
|
}
|
2017-07-09 00:08:50 +02:00
|
|
|
v = func(v DatasetPathVisit) bool {
|
2017-05-07 14:07:50 +02:00
|
|
|
rec.visits = append(rec.visits, v)
|
2017-07-09 00:08:50 +02:00
|
|
|
return true
|
2017-05-07 14:07:50 +02:00
|
|
|
}
|
|
|
|
return
|
|
|
|
}
|
|
|
|
|
2017-08-06 13:04:29 +02:00
|
|
|
func buildForest(paths []*DatasetPath) (f *DatasetPathForest) {
|
2017-05-07 14:07:50 +02:00
|
|
|
f = NewDatasetPathForest()
|
|
|
|
for _, p := range paths {
|
|
|
|
f.Add(p)
|
|
|
|
}
|
|
|
|
return
|
|
|
|
}
|
|
|
|
|
|
|
|
func TestDatasetPathForestWalkTopDown(t *testing.T) {
|
|
|
|
|
2017-08-06 13:04:29 +02:00
|
|
|
paths := []*DatasetPath{
|
2017-05-07 14:07:50 +02:00
|
|
|
toDatasetPath("pool1"),
|
|
|
|
toDatasetPath("pool1/foo/bar"),
|
|
|
|
toDatasetPath("pool1/foo/bar/looloo"),
|
|
|
|
toDatasetPath("pool2/test/bar"),
|
|
|
|
}
|
|
|
|
|
|
|
|
v, rec := makeVisitRecorder()
|
|
|
|
|
|
|
|
buildForest(paths).WalkTopDown(v)
|
|
|
|
|
2020-02-23 23:24:12 +01:00
|
|
|
expectedVisits := []DatasetPathVisit{
|
2017-05-07 14:07:50 +02:00
|
|
|
{toDatasetPath("pool1"), false},
|
|
|
|
{toDatasetPath("pool1/foo"), true},
|
|
|
|
{toDatasetPath("pool1/foo/bar"), false},
|
|
|
|
{toDatasetPath("pool1/foo/bar/looloo"), false},
|
|
|
|
{toDatasetPath("pool2"), true},
|
|
|
|
{toDatasetPath("pool2/test"), true},
|
|
|
|
{toDatasetPath("pool2/test/bar"), false},
|
|
|
|
}
|
2020-02-23 23:24:12 +01:00
|
|
|
assert.Equal(t, expectedVisits, rec.visits)
|
2017-05-07 14:07:50 +02:00
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
func TestDatasetPathWalkTopDownWorksUnordered(t *testing.T) {
|
|
|
|
|
2017-08-06 13:04:29 +02:00
|
|
|
paths := []*DatasetPath{
|
2017-05-07 14:07:50 +02:00
|
|
|
toDatasetPath("pool1"),
|
|
|
|
toDatasetPath("pool1/foo/bar/looloo"),
|
|
|
|
toDatasetPath("pool1/foo/bar"),
|
|
|
|
toDatasetPath("pool1/bang/baz"),
|
|
|
|
}
|
|
|
|
|
|
|
|
v, rec := makeVisitRecorder()
|
|
|
|
|
|
|
|
buildForest(paths).WalkTopDown(v)
|
|
|
|
|
2020-02-23 23:24:12 +01:00
|
|
|
expectedVisits := []DatasetPathVisit{
|
2017-05-07 14:07:50 +02:00
|
|
|
{toDatasetPath("pool1"), false},
|
|
|
|
{toDatasetPath("pool1/foo"), true},
|
|
|
|
{toDatasetPath("pool1/foo/bar"), false},
|
|
|
|
{toDatasetPath("pool1/foo/bar/looloo"), false},
|
|
|
|
{toDatasetPath("pool1/bang"), true},
|
|
|
|
{toDatasetPath("pool1/bang/baz"), false},
|
|
|
|
}
|
|
|
|
|
2020-02-23 23:24:12 +01:00
|
|
|
assert.Equal(t, expectedVisits, rec.visits)
|
2017-05-07 14:07:50 +02:00
|
|
|
|
|
|
|
}
|