Merge pull request #1018 from tonistiigi/v0.8-compose-target-dot

[v0.8] bake: allow dot in target names for compose
pull/1022/head v0.8.1
Tõnis Tiigi 3 years ago committed by GitHub
commit 5fac64c2c4
No known key found for this signature in database
GPG Key ID: 4AEE18F83AFDEB23

@ -28,8 +28,10 @@ var (
httpPrefix = regexp.MustCompile(`^https?://`) httpPrefix = regexp.MustCompile(`^https?://`)
gitURLPathWithFragmentSuffix = regexp.MustCompile(`\.git(?:#.+)?$`) gitURLPathWithFragmentSuffix = regexp.MustCompile(`\.git(?:#.+)?$`)
validTargetNameChars = `[a-zA-Z0-9_-]+` validTargetNameChars = `[a-zA-Z0-9_-]+`
targetNamePattern = regexp.MustCompile(`^` + validTargetNameChars + `$`) validTargetNameCharsCompose = `[a-zA-Z0-9._-]+`
targetNamePattern = regexp.MustCompile(`^` + validTargetNameChars + `$`)
targetNamePatternCompose = regexp.MustCompile(`^` + validTargetNameCharsCompose + `$`)
) )
type File struct { type File struct {
@ -968,6 +970,13 @@ func validateTargetName(name string) error {
return nil return nil
} }
func validateTargetNameCompose(name string) error {
if !targetNamePatternCompose.MatchString(name) {
return errors.Errorf("only %q are allowed", validTargetNameCharsCompose)
}
return nil
}
func sliceEqual(s1, s2 []string) bool { func sliceEqual(s1, s2 []string) bool {
if len(s1) != len(s2) { if len(s1) != len(s2) {
return false return false

@ -60,7 +60,7 @@ func ParseCompose(dt []byte) (*Config, error) {
continue continue
} }
if err = validateTargetName(s.Name); err != nil { if err = validateTargetNameCompose(s.Name); err != nil {
return nil, errors.Wrapf(err, "invalid service name %q", s.Name) return nil, errors.Wrapf(err, "invalid service name %q", s.Name)
} }

@ -330,6 +330,10 @@ func TestServiceName(t *testing.T) {
}, },
{ {
svc: "a.b", svc: "a.b",
wantErr: false,
},
{
svc: "a?b",
wantErr: true, wantErr: true,
}, },
{ {

Loading…
Cancel
Save