2014-08-06 15:08:17 -07:00
|
|
|
package acl
|
|
|
|
|
|
|
|
import (
|
|
|
|
"reflect"
|
|
|
|
"testing"
|
|
|
|
)
|
|
|
|
|
|
|
|
func TestParse(t *testing.T) {
|
|
|
|
inp := `
|
|
|
|
key "" {
|
|
|
|
policy = "read"
|
|
|
|
}
|
|
|
|
key "foo/" {
|
|
|
|
policy = "write"
|
|
|
|
}
|
|
|
|
key "foo/bar/" {
|
|
|
|
policy = "read"
|
|
|
|
}
|
|
|
|
key "foo/bar/baz" {
|
2014-08-08 15:25:11 -07:00
|
|
|
policy = "deny"
|
2014-08-06 15:08:17 -07:00
|
|
|
}
|
|
|
|
`
|
|
|
|
exp := &Policy{
|
|
|
|
Keys: []*KeyPolicy{
|
|
|
|
&KeyPolicy{
|
|
|
|
Prefix: "",
|
|
|
|
Policy: KeyPolicyRead,
|
|
|
|
},
|
|
|
|
&KeyPolicy{
|
|
|
|
Prefix: "foo/",
|
|
|
|
Policy: KeyPolicyWrite,
|
|
|
|
},
|
|
|
|
&KeyPolicy{
|
|
|
|
Prefix: "foo/bar/",
|
|
|
|
Policy: KeyPolicyRead,
|
|
|
|
},
|
|
|
|
&KeyPolicy{
|
|
|
|
Prefix: "foo/bar/baz",
|
|
|
|
Policy: KeyPolicyDeny,
|
|
|
|
},
|
|
|
|
},
|
|
|
|
}
|
|
|
|
|
|
|
|
out, err := Parse(inp)
|
|
|
|
if err != nil {
|
|
|
|
t.Fatalf("err: %v", err)
|
|
|
|
}
|
|
|
|
|
2014-08-08 15:57:28 -07:00
|
|
|
if !reflect.DeepEqual(out, exp) {
|
|
|
|
t.Fatalf("bad: %#v %#v", out, exp)
|
2014-08-06 15:08:17 -07:00
|
|
|
}
|
|
|
|
}
|