Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

fix(cdk-assets): context path not honored by Docker asset build #6957

Merged
merged 3 commits into from
Mar 24, 2020

Conversation

MrArnoldPalmer
Copy link
Contributor

@MrArnoldPalmer MrArnoldPalmer commented Mar 24, 2020

Commit Message

fix(cdk-assets): context path not honored by Docker asset build (#6957)

Prior v1.29.0, the context passed to the docker build command was always
the current working directory. In v1.29.0, this was changed to be the
directory the user passed when instantiating the asset. However, docker
doesn't respect the context passed to the build command when the
--file argument is also passed. This broke assets for users passing
the file prop when constructing a DockerImageAsset.

This is fixed by changing the current working directory of the docker build
command and passing that context as .. Then docker uses the current working
directory as the context and correctly finds the image definition file from the
file prop. An existing integration test in the framework covers this case,
but does not fail unless the stack is deployed fresh since the asset isn't
rebuilt when the hash is not changed.

Fix: #6954 #6814

End Commit Message


By submitting this pull request, I confirm that my contribution is made under the terms of the Apache-2.0 license

@MrArnoldPalmer MrArnoldPalmer requested review from rix0rrr, iliapolo and a team March 24, 2020 00:38
@mergify mergify bot added contribution/core This is a PR that came from AWS. labels Mar 24, 2020
@MrArnoldPalmer MrArnoldPalmer force-pushed the fix/docker-build-path branch from 0283d4b to ca318e3 Compare March 24, 2020 00:39
@aws-cdk-automation
Copy link
Collaborator

AWS CodeBuild CI Report

  • CodeBuild project: AutoBuildProject6AEA49D1-qxepHUsryhcu
  • Commit ID: 0283d4b
  • Result: FAILED
  • Build Logs (available for 30 days)

Powered by github-codebuild-logs, available on the AWS Serverless Application Repository

@aws-cdk-automation
Copy link
Collaborator

AWS CodeBuild CI Report

  • CodeBuild project: AutoBuildProject6AEA49D1-qxepHUsryhcu
  • Commit ID: ca318e3
  • Result: FAILED
  • Build Logs (available for 30 days)

Powered by github-codebuild-logs, available on the AWS Serverless Application Repository

@MrArnoldPalmer MrArnoldPalmer force-pushed the fix/docker-build-path branch from ca318e3 to 3d0247b Compare March 24, 2020 01:00
@aws-cdk-automation
Copy link
Collaborator

AWS CodeBuild CI Report

  • CodeBuild project: AutoBuildProject6AEA49D1-qxepHUsryhcu
  • Commit ID: 3d0247b
  • Result: SUCCEEDED
  • Build Logs (available for 30 days)

Powered by github-codebuild-logs, available on the AWS Serverless Application Repository

Prior v1.29.0, the context passed to the docker build command was always
the current working directory. In v1.29.0, this was changed to be the
directory the user passed when instantiating the asset. However, docker
doesn't respect the context passed to the build command when the
`--file` argument is also passed. This broke assets for users passing
the `file` prop when constructing a `DockerImageAsset`.

This is fixed by changing the current working directory of the `docker build`
command and passing that context as '.'. Then docker uses the current working
directory as the context and correctly finds the image definition file from the
`file` prop. An existing integration test in the framework covers this case,
but does not fail unless the stack is deployed fresh since the asset isn't
rebuilt when the hash is not changed.

Fix: aws#6954 aws#6814
@MrArnoldPalmer MrArnoldPalmer force-pushed the fix/docker-build-path branch from 3d0247b to 70f984e Compare March 24, 2020 02:11
@aws-cdk-automation
Copy link
Collaborator

AWS CodeBuild CI Report

  • CodeBuild project: AutoBuildProject6AEA49D1-qxepHUsryhcu
  • Commit ID: 70f984e
  • Result: SUCCEEDED
  • Build Logs (available for 30 days)

Powered by github-codebuild-logs, available on the AWS Serverless Application Repository

];
await this.execute(buildCommand);
await this.execute(buildCommand, { cwd: options.directory });
Copy link
Contributor

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

lgtm fwiw. The below alternative patch also worked for me if for some reason the reviewers wanted to avoid setting cwd (I don't know why that would be an issue):

--- cdk-assets/lib/private/handlers/container-images.js.orig    2020-03-24 06:03:56.670862836 +0000
+++ cdk-assets/lib/private/handlers/container-images.js 2020-03-24 05:58:01.971071483 +0000
@@ -51,7 +51,7 @@
             tag: this.localTagName,
             buildArgs: source.dockerBuildArgs,
             target: source.dockerBuildTarget,
-            file: source.dockerFile,
+            file: path.resolve(fullPath, source.dockerFile),
         });
     }
 }

Copy link
Contributor

@nija-at nija-at left a comment

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Fix the commit title to all lower case. For fixes, the commit title should summarize the issue it is fixing.
Remember to use mergify's '##Commit Message' in the description so mergify picks up the updated title.

An existing integration test in the framework covers this case,
but does not fail unless the stack is deployed fresh since the asset isn't
rebuilt when the hash is not changed.

Can we correct this test, or add a better one?

@RomainMuller RomainMuller changed the title fix(cdk-assets): Docker Build Context Path fix(cdk-assets): context path not honored by Docker asset build Mar 24, 2020
@shivlaks shivlaks changed the title fix(cdk-assets): context path not honored by Docker asset build fix(cdk-assets): context is not passed to docker build when the file property is used with DockerImageAsset Mar 24, 2020
@shivlaks shivlaks changed the title fix(cdk-assets): context is not passed to docker build when the file property is used with DockerImageAsset fix(cdk-assets): context path not honored by Docker asset build (#6957) Mar 24, 2020
@shivlaks shivlaks changed the title fix(cdk-assets): context path not honored by Docker asset build (#6957) fix(cdk-assets): context path not honored by Docker asset build Mar 24, 2020
@shivlaks
Copy link
Contributor

Fix the commit title to all lower case. For fixes, the commit title should summarize the issue it is fixing.
Remember to use mergify's '##Commit Message' in the description so mergify picks up the updated title.

done

Can we correct this test, or add a better one?

yep, it's currently failing right now, but I'll address it's flakiness in a follow-up PR once we've mitigated the p0

@aws-cdk-automation
Copy link
Collaborator

AWS CodeBuild CI Report

  • CodeBuild project: AutoBuildProject6AEA49D1-qxepHUsryhcu
  • Commit ID: eeeb8df
  • Result: SUCCEEDED
  • Build Logs (available for 30 days)

Powered by github-codebuild-logs, available on the AWS Serverless Application Repository

@iliapolo
Copy link
Contributor

iliapolo commented Mar 24, 2020

@MrArnoldPalmer wrote:

Prior v1.29.0, the context passed to the docker build command was always
the current working directory. In v1.29.0, this was changed to be the
directory the user passed when instantiating the asset.

Thats not accurate. To my understanding, in both 1.29.0 and 1.28.0, the context being passed is the asset directory, from the original issue:

in 1.28.0:

docker build --tag 942768376061.dkr.ecr.eu-central-1.amazonaws.com/aws-cdk/assets:xxx --target production --file cdk.out/asset.xxx/services/admin/Dockerfile cdk.out/asset.xxx

The context here is cdk.out/asset.xxx, which is the asset directory, relative to the cdk working directory (the app directory).

in 1.30.0:

docker build  --tag cdkasset-xxx --file services/backend/Dockerfile /Volumes/Projects/whatever/build/cdk/cdk.out/asset.xxx

The context here is /Volumes/Projects/whatever/build/cdk/cdk.out/asset.xxx, which is the same thing, except now its absolute.

This is ok, the problem is that in 1.28.0, the --file value was relative to the cdk working directory (cdk.out/asset.xxx/services/admin/Dockerfile), but in 1.30.0, its relative to the context path (services/backend/Dockerfile). Which would have been ok if docker would take the context path and append the --file path to it, which is what it claims it does:

From https://docs.docker.com/engine/reference/commandline/build/

If a relative path is specified then it is interpreted as relative to the root of the context.

this just doesn't seem to be true. Docker always looks up the --file under the current working directory, not the context path.

So the fix is basically to always have the context directory be the current working directory when running docker build

@aws-cdk-automation
Copy link
Collaborator

AWS CodeBuild CI Report

  • CodeBuild project: AutoBuildProject6AEA49D1-qxepHUsryhcu
  • Commit ID: 3e67579
  • Result: SUCCEEDED
  • Build Logs (available for 30 days)

Powered by github-codebuild-logs, available on the AWS Serverless Application Repository

@mergify
Copy link
Contributor

mergify bot commented Mar 24, 2020

Thank you for contributing! Your pull request will be updated from master and then merged automatically (do not update manually, and be sure to allow changes to be pushed to your fork).

@mergify mergify bot merged commit 1edd507 into aws:master Mar 24, 2020
shivlaks pushed a commit that referenced this pull request Mar 24, 2020
Prior v1.29.0, the context passed to the docker build command was always
the current working directory. In v1.29.0, this was changed to be the
directory the user passed when instantiating the asset. However, docker
doesn't respect the context passed to the build command when the
`--file` argument is also passed. This broke assets for users passing
the `file` prop when constructing a `DockerImageAsset`.

This is fixed by changing the current working directory of the `docker build`
command and passing that context as `.`. Then docker uses the current working
directory as the context and correctly finds the image definition file from the
`file` prop. An existing integration test in the framework covers this case,
but does not fail unless the stack is deployed fresh since the asset isn't
rebuilt when the hash is not changed.

Fix: #6954 #6814
@MrArnoldPalmer MrArnoldPalmer deleted the fix/docker-build-path branch April 26, 2023 21:48
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
contribution/core This is a PR that came from AWS.
Projects
None yet
Development

Successfully merging this pull request may close these issues.

‼️ NOTICE: DockerImageAsset and ContainerImage 'file' property breaks docker image building
7 participants