Revert "bake: fix incorrect dockerfile resolution against cwd:// context"

This reverts commit bc597e6b5e.

Signed-off-by: Justin Chadwell <me@jedevc.com>
pull/1930/head
Justin Chadwell 2 years ago
parent 1602b491f9
commit 5159571dfc

@ -1048,12 +1048,12 @@ func toBuildOpt(t *Target, inp *Input) (*build.Options, error) {
bi.DockerfileInline = *t.DockerfileInline bi.DockerfileInline = *t.DockerfileInline
} }
updateContext(&bi, inp) updateContext(&bi, inp)
if strings.HasPrefix(bi.ContextPath, "cwd://") {
bi.ContextPath = path.Clean(strings.TrimPrefix(bi.ContextPath, "cwd://"))
}
if !build.IsRemoteURL(bi.ContextPath) && bi.ContextState == nil && !path.IsAbs(bi.DockerfilePath) { if !build.IsRemoteURL(bi.ContextPath) && bi.ContextState == nil && !path.IsAbs(bi.DockerfilePath) {
bi.DockerfilePath = path.Join(bi.ContextPath, bi.DockerfilePath) bi.DockerfilePath = path.Join(bi.ContextPath, bi.DockerfilePath)
} }
if strings.HasPrefix(bi.ContextPath, "cwd://") {
bi.ContextPath = path.Clean(strings.TrimPrefix(bi.ContextPath, "cwd://"))
}
for k, v := range bi.NamedContexts { for k, v := range bi.NamedContexts {
if strings.HasPrefix(v.Path, "cwd://") { if strings.HasPrefix(v.Path, "cwd://") {
bi.NamedContexts[k] = build.NamedContext{Path: path.Clean(strings.TrimPrefix(v.Path, "cwd://"))} bi.NamedContexts[k] = build.NamedContext{Path: path.Clean(strings.TrimPrefix(v.Path, "cwd://"))}

@ -386,19 +386,18 @@ func TestHCLCwdPrefix(t *testing.T) {
m, g, err := ReadTargets(ctx, []File{fp}, []string{"app"}, nil, nil) m, g, err := ReadTargets(ctx, []File{fp}, []string{"app"}, nil, nil)
require.NoError(t, err) require.NoError(t, err)
bo, err := TargetsToBuildOpt(m, &Input{}) require.Equal(t, 1, len(m))
require.NoError(t, err) _, ok := m["app"]
require.True(t, ok)
require.Equal(t, 1, len(g)) _, err = TargetsToBuildOpt(m, &Input{})
require.Equal(t, []string{"app"}, g["default"].Targets) require.NoError(t, err)
require.Equal(t, 1, len(m))
require.Contains(t, m, "app")
require.Equal(t, "test", *m["app"].Dockerfile) require.Equal(t, "test", *m["app"].Dockerfile)
require.Equal(t, "foo", *m["app"].Context) require.Equal(t, "foo", *m["app"].Context)
require.Equal(t, "foo/test", bo["app"].Inputs.DockerfilePath) require.Equal(t, 1, len(g))
require.Equal(t, "foo", bo["app"].Inputs.ContextPath) require.Equal(t, []string{"app"}, g["default"].Targets)
} }
func TestOverrideMerge(t *testing.T) { func TestOverrideMerge(t *testing.T) {

Loading…
Cancel
Save