Skip to content

Commit

Permalink
fix(cx-api): docker bundling fails during tests on macOS
Browse files Browse the repository at this point in the history
When running unit tests `outdir` defaults to a temporary directory in
the system temp directory. On macOS `os.tmpdir()` is a symlink so
bundling in Docker fails.

Fix it by using `fs.realpathSync`.

Closes aws#10262
  • Loading branch information
jogold committed Oct 1, 2020
1 parent 9ac5f23 commit 70bf91e
Show file tree
Hide file tree
Showing 2 changed files with 8 additions and 2 deletions.
2 changes: 1 addition & 1 deletion packages/@aws-cdk/cx-api/lib/cloud-assembly.ts
Original file line number Diff line number Diff line change
Expand Up @@ -405,5 +405,5 @@ function ignore(_x: any) {
* Turn the given optional output directory into a fixed output directory
*/
function determineOutputDirectory(outdir?: string) {
return outdir ?? fs.mkdtempSync(path.join(os.tmpdir(), 'cdk.out'));
return outdir ?? fs.mkdtempSync(path.join(fs.realpathSync(os.tmpdir()), 'cdk.out'));
}
8 changes: 7 additions & 1 deletion packages/@aws-cdk/cx-api/test/cloud-assembly-builder.test.ts
Original file line number Diff line number Diff line change
Expand Up @@ -124,6 +124,12 @@ test('outdir must be a directory', () => {
expect(() => new cxapi.CloudAssemblyBuilder(__filename)).toThrow('must be a directory');
});

test('outdir defaults to a temporary directory', () => {
const assembly = new cxapi.CloudAssemblyBuilder();
const realTmpDir = fs.realpathSync(os.tmpdir());
expect(assembly.outdir).toMatch(new RegExp(`^${path.join(realTmpDir, 'cdk.out')}`));
});

test('duplicate missing values with the same key are only reported once', () => {
const outdir = fs.mkdtempSync(path.join(os.tmpdir(), 'cloud-assembly-builder-tests'));
const session = new cxapi.CloudAssemblyBuilder(outdir);
Expand Down Expand Up @@ -224,4 +230,4 @@ test('artifcats are written in topological order', () => {
expect(artifactsIds.indexOf('artifact-A')).toBeLessThan(artifactsIds.indexOf('artifact-C'));
expect(artifactsIds.indexOf('artifact-B')).toBeLessThan(artifactsIds.indexOf('artifact-C'));
expect(artifactsIds.indexOf('artifact-C')).toBeLessThan(artifactsIds.indexOf('artifact-D'));
});
});

0 comments on commit 70bf91e

Please sign in to comment.