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

feat(core): add volumes-from option to docker run command for bundling #22829

Merged
merged 30 commits into from
Dec 12, 2022
Merged
Show file tree
Hide file tree
Changes from 29 commits
Commits
Show all changes
30 commits
Select commit Hold shift + click to select a range
9a18004
WIP add volumesFrom
webratz Aug 9, 2022
020b825
WIP add volumesFrom
webratz Aug 9, 2022
6bcb4ee
adding tests and usage instruction
webratz Aug 18, 2022
8473d45
disable failing test for now
webratz Sep 13, 2022
abdb9b5
add missing type
webratz Sep 13, 2022
658e1dd
Merge branch 'main' into master
mergify[bot] Oct 2, 2022
a7fc600
Merge branch 'aws:main' into master
webratz Oct 4, 2022
74aae68
cleanup
webratz Oct 4, 2022
2ee951b
re-add adjusted test
webratz Oct 5, 2022
9dbbd18
test variant to allow the call to fail
webratz Oct 5, 2022
1fb4ada
remove failing test
webratz Oct 5, 2022
96c5614
whitespace cleanup
webratz Oct 5, 2022
d6b0bd4
Merge branch 'main' into master
webratz Nov 2, 2022
18073db
adding fixed test
webratz Nov 8, 2022
c287929
Merge branch 'aws:main' into master
webratz Nov 8, 2022
1f5c667
add integration test
webratz Nov 8, 2022
f5e5ea0
Merge branch 'master' of https://github.com/webratz/aws-cdk
webratz Nov 8, 2022
08fd008
check if adding helper container works
webratz Nov 8, 2022
aa528ca
update integration tests
webratz Nov 9, 2022
13c7e8b
test sync spawn of docker container
webratz Nov 9, 2022
bce18f2
Merge branch 'main' into master
webratz Nov 9, 2022
e032d03
Merge branch 'main' into master
webratz Nov 11, 2022
f1d9a16
Merge branch 'main' into master
webratz Nov 11, 2022
5a5d3f7
Apply suggestions from code review
webratz Dec 9, 2022
89bb614
WIP allow multiple volumes to be defined
webratz Dec 9, 2022
2ed997a
add full integration test for all steps
webratz Dec 9, 2022
9754f03
remove of integration tests and additional options
webratz Dec 12, 2022
af81272
remove integration for python
webratz Dec 12, 2022
c637016
remove empty line
webratz Dec 12, 2022
6c21217
Merge branch 'main' into master
webratz Dec 12, 2022
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
1 change: 1 addition & 0 deletions packages/@aws-cdk/core/lib/asset-staging.ts
Original file line number Diff line number Diff line change
Expand Up @@ -469,6 +469,7 @@ export class AssetStaging extends Construct {
entrypoint: options.entrypoint,
workingDirectory: options.workingDirectory ?? AssetStaging.BUNDLING_INPUT_DIR,
securityOpt: options.securityOpt ?? '',
volumesFrom: options.volumesFrom,
});
}
} catch (err) {
Expand Down
17 changes: 17 additions & 0 deletions packages/@aws-cdk/core/lib/bundling.ts
Original file line number Diff line number Diff line change
Expand Up @@ -43,6 +43,13 @@ export interface BundlingOptions {
*/
readonly volumes?: DockerVolume[];

/**
* Where to mount the specified volumes from
* @see https://docs.docker.com/engine/reference/commandline/run/#mount-volumes-from-container---volumes-from
* @default - no containers are specified to mount volumes from
*/
readonly volumesFrom?: string[];

/**
* The environment variables to pass to the Docker container.
*
Expand Down Expand Up @@ -210,6 +217,9 @@ export class BundlingDockerImage {
...options.user
? ['-u', options.user]
: [],
...options.volumesFrom
? flatten(options.volumesFrom.map(v => ['--volumes-from', v]))
: [],
...flatten(volumes.map(v => ['-v', `${v.hostPath}:${v.containerPath}:${isSeLinux() ? 'z,' : ''}${v.consistency ?? DockerVolumeConsistency.DELEGATED}`])),
...flatten(Object.entries(environment).map(([k, v]) => ['--env', `${k}=${v}`])),
...options.workingDirectory
Expand Down Expand Up @@ -441,6 +451,13 @@ export interface DockerRunOptions {
*/
readonly volumes?: DockerVolume[];

/**
* Where to mount the specified volumes from
* @see https://docs.docker.com/engine/reference/commandline/run/#mount-volumes-from-container---volumes-from
* @default - no containers are specified to mount volumes from
*/
readonly volumesFrom?: string[];

/**
* The environment variables to pass to the container.
*
Expand Down
38 changes: 38 additions & 0 deletions packages/@aws-cdk/core/test/bundling.test.ts
Original file line number Diff line number Diff line change
Expand Up @@ -438,6 +438,44 @@ describe('bundling', () => {
], { stdio: ['ignore', process.stderr, 'inherit'] })).toEqual(true);
});

test('adding user provided docker volume options', () => {
// GIVEN
sinon.stub(process, 'platform').value('darwin');
const spawnSyncStub = sinon.stub(child_process, 'spawnSync').returns({
status: 1,
stderr: Buffer.from('stderr'),
stdout: Buffer.from('stdout'),
pid: 123,
output: ['stdout', 'stderr'],
signal: null,
});
const image = DockerImage.fromRegistry('alpine');

try {
image.run({
command: ['cool', 'command'],
volumesFrom: ['foo', 'bar'],
volumes: [{ hostPath: '/host-path', containerPath: '/container-path' }],
workingDirectory: '/working-directory',
user: 'user:group',
});
} catch (e) {
// We expect this to fail as the test environment will not have the required docker setup for the command to exit successfully
// nevertheless what we want to check here is that the command was built correctly and triggered
};

expect(spawnSyncStub.calledWith('docker', [
'run', '--rm',
'-u', 'user:group',
'--volumes-from', 'foo',
'--volumes-from', 'bar',
'-v', '/host-path:/container-path:delegated',
'-w', '/working-directory',
'alpine',
'cool', 'command',
], { stdio: ['ignore', process.stderr, 'inherit'] })).toEqual(true);
});

test('ensure selinux docker mount', () => {
// GIVEN
sinon.stub(process, 'platform').value('linux');
Expand Down