httpcaddyfile: Support single-line matchers (#3263)

* httpcaddyfile: Support single-line matchers

* httpcaddyfile: Add single-line matcher test

* httpcaddyfile: Add a matcher syntax adapt test
This commit is contained in:
Francis Lavoie 2020-05-05 14:29:21 -04:00 committed by GitHub
parent 52305618df
commit 26e559662d
No known key found for this signature in database
GPG key ID: 4AEE18F83AFDEB23
3 changed files with 88 additions and 1 deletions

View file

@ -1001,7 +1001,7 @@ func parseMatcherDefinitions(d *caddyfile.Dispenser, matchers map[string]caddy.M
// handle more than one segment); otherwise, we'd overwrite other // handle more than one segment); otherwise, we'd overwrite other
// instances of the matcher in this set // instances of the matcher in this set
tokensByMatcherName := make(map[string][]caddyfile.Token) tokensByMatcherName := make(map[string][]caddyfile.Token)
for nesting := d.Nesting(); d.NextBlock(nesting); { for nesting := d.Nesting(); d.NextArg() || d.NextBlock(nesting); {
matcherName := d.Val() matcherName := d.Val()
tokensByMatcherName[matcherName] = append(tokensByMatcherName[matcherName], d.NextSegment()...) tokensByMatcherName[matcherName] = append(tokensByMatcherName[matcherName], d.NextSegment()...)
} }

View file

@ -50,6 +50,13 @@ func TestMatcherSyntax(t *testing.T) {
expectWarn: false, expectWarn: false,
expectError: false, expectError: false,
}, },
{
input: `http://localhost
@debug not path /somepath*
`,
expectWarn: false,
expectError: false,
},
} { } {
adapter := caddyfile.Adapter{ adapter := caddyfile.Adapter{

View file

@ -283,3 +283,83 @@ func TestHttpOnlyOnNonStandardPort(t *testing.T) {
} }
}`) }`)
} }
func TestMatcherSyntax(t *testing.T) {
caddytest.AssertAdapt(t, `
:80 {
@matcher {
method GET
}
respond @matcher "get"
@matcher2 method POST
respond @matcher2 "post"
@matcher3 not method PUT
respond @matcher3 "not put"
}
`, "caddyfile", `{
"apps": {
"http": {
"servers": {
"srv0": {
"listen": [
":80"
],
"routes": [
{
"match": [
{
"method": [
"GET"
]
}
],
"handle": [
{
"body": "get",
"handler": "static_response"
}
]
},
{
"match": [
{
"method": [
"POST"
]
}
],
"handle": [
{
"body": "post",
"handler": "static_response"
}
]
},
{
"match": [
{
"not": [
{
"method": [
"PUT"
]
}
]
}
],
"handle": [
{
"body": "not put",
"handler": "static_response"
}
]
}
]
}
}
}
}
}`)
}