bake: support compose build tags

Signed-off-by: CrazyMax <crazy-max@users.noreply.github.com>
pull/1153/head
CrazyMax 3 years ago
parent e0350f671a
commit 6cb1b85d7b
No known key found for this signature in database
GPG Key ID: 3248E46B6BB8C7F7

@ -89,6 +89,7 @@ func ParseCompose(dt []byte) (*Config, error) {
Name: s.Name, Name: s.Name,
Context: contextPathP, Context: contextPathP,
Dockerfile: dockerfilePathP, Dockerfile: dockerfilePathP,
Tags: s.Build.Tags,
Labels: s.Build.Labels, Labels: s.Build.Labels,
Args: flatten(s.Build.Args.Resolve(func(val string) (string, bool) { Args: flatten(s.Build.Args.Resolve(func(val string) (string, bool) {
if val, ok := s.Environment[val]; ok && val != nil { if val, ok := s.Environment[val]; ok && val != nil {

@ -47,6 +47,7 @@ secrets:
}) })
require.Equal(t, "db", c.Targets[0].Name) require.Equal(t, "db", c.Targets[0].Name)
require.Equal(t, "./db", *c.Targets[0].Context) require.Equal(t, "./db", *c.Targets[0].Context)
require.Equal(t, []string{"docker.io/tonistiigi/db"}, c.Targets[0].Tags)
require.Equal(t, "webapp", c.Targets[1].Name) require.Equal(t, "webapp", c.Targets[1].Name)
require.Equal(t, "./dir", *c.Targets[1].Context) require.Equal(t, "./dir", *c.Targets[1].Context)
@ -194,6 +195,24 @@ networks:
require.NoError(t, err) require.NoError(t, err)
} }
func TestTags(t *testing.T) {
var dt = []byte(`
services:
example:
image: example
build:
context: .
dockerfile: Dockerfile
tags:
- foo
- bar
`)
c, err := ParseCompose(dt)
require.NoError(t, err)
require.Equal(t, c.Targets[0].Tags, []string{"foo", "bar"})
}
func TestDependsOnList(t *testing.T) { func TestDependsOnList(t *testing.T) {
var dt = []byte(` var dt = []byte(`
version: "3.8" version: "3.8"
@ -240,6 +259,8 @@ services:
dockerfile: ./Dockerfile dockerfile: ./Dockerfile
cache_from: cache_from:
- user/app:cache - user/app:cache
tags:
- ct-addon:baz
args: args:
CT_ECR: foo CT_ECR: foo
CT_TAG: bar CT_TAG: bar
@ -279,7 +300,7 @@ services:
return c.Targets[i].Name < c.Targets[j].Name return c.Targets[i].Name < c.Targets[j].Name
}) })
require.Equal(t, c.Targets[0].Args, map[string]string{"CT_ECR": "foo", "CT_TAG": "bar"}) require.Equal(t, c.Targets[0].Args, map[string]string{"CT_ECR": "foo", "CT_TAG": "bar"})
require.Equal(t, c.Targets[0].Tags, []string{"ct-addon:foo", "ct-addon:alp"}) require.Equal(t, c.Targets[0].Tags, []string{"ct-addon:baz", "ct-addon:foo", "ct-addon:alp"})
require.Equal(t, c.Targets[0].Platforms, []string{"linux/amd64", "linux/arm64"}) require.Equal(t, c.Targets[0].Platforms, []string{"linux/amd64", "linux/arm64"})
require.Equal(t, c.Targets[0].CacheFrom, []string{"type=local,src=path/to/cache"}) require.Equal(t, c.Targets[0].CacheFrom, []string{"type=local,src=path/to/cache"})
require.Equal(t, c.Targets[0].CacheTo, []string{"local,dest=path/to/cache"}) require.Equal(t, c.Targets[0].CacheTo, []string{"local,dest=path/to/cache"})

Loading…
Cancel
Save