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 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75
|
package aini
import (
"testing"
"github.com/stretchr/testify/assert"
)
func TestListAncestorsOrdered(t *testing.T) {
v := parseString(t, `
host1
[notMyGroup3]
[myGroup2]
[myGroup1]
host1
[myGroup2:children]
myGroup1
[notMyGroup3:children]
myGroup2
`)
host1 := v.Hosts["host1"]
assert.NotNil(t, host1)
assert.Len(t, host1.Groups, 4)
groups := host1.ListGroupsOrdered()
assert.Len(t, groups, 4)
assert.Equal(t, groups[0].Name, "myGroup1")
assert.Equal(t, groups[1].Name, "myGroup2")
assert.Equal(t, groups[2].Name, "notMyGroup3")
assert.Equal(t, groups[3].Name, "all")
group1 := v.Groups["myGroup1"]
assert.NotNil(t, group1)
groups = group1.ListParentGroupsOrdered()
assert.NotNil(t, groups)
assert.Len(t, groups, 3)
assert.Equal(t, groups[0].Name, "myGroup2")
assert.Equal(t, groups[1].Name, "notMyGroup3")
assert.Equal(t, groups[2].Name, "all")
}
func TestMatchGroupsOrdered(t *testing.T) {
v := parseString(t, `
host1
[notMyGroup3]
[myGroup2]
[myGroup1]
host1
[myGroup2:children]
myGroup1
[notMyGroup3:children]
myGroup2
`)
host1 := v.Hosts["host1"]
assert.NotNil(t, host1)
assert.Len(t, host1.Groups, 4)
groups, err := host1.MatchGroupsOrdered("my*")
assert.Nil(t, err)
assert.Len(t, groups, 2)
assert.Equal(t, groups[0].Name, "myGroup1")
assert.Equal(t, groups[1].Name, "myGroup2")
group1 := v.Groups["myGroup1"]
assert.NotNil(t, group1)
groups, err = group1.MatchGroupsOrdered("my*")
assert.Nil(t, err)
assert.NotNil(t, groups)
assert.Len(t, groups, 1)
assert.Equal(t, groups[0].Name, "myGroup2")
}
|