Skip to content

Commit

Permalink
fix(cli): 'cdk context --reset <number>' does not work
Browse files Browse the repository at this point in the history
  • Loading branch information
NetaNir authored and diesal11 committed Oct 7, 2020
1 parent 41f6de2 commit 1e88242
Show file tree
Hide file tree
Showing 2 changed files with 28 additions and 6 deletions.
11 changes: 5 additions & 6 deletions packages/aws-cdk/lib/commands/context.ts
Original file line number Diff line number Diff line change
Expand Up @@ -28,8 +28,6 @@ export function handler(args: yargs.Arguments) {
export async function realHandler(options: CommandOptions): Promise<number> {
const { configuration, args } = options;

const contextValues = configuration.context.all;

if (args.clear) {
configuration.context.clear();
await configuration.saveContext();
Expand All @@ -40,17 +38,18 @@ export async function realHandler(options: CommandOptions): Promise<number> {
} else {
// List -- support '--json' flag
if (args.json) {
const contextValues = configuration.context.all;
process.stdout.write(JSON.stringify(contextValues, undefined, 2));
} else {
listContext(contextValues);
listContext(configuration.context);
}
}
await version.displayVersionMessage();

return 0;
}

function listContext(context: any) {
function listContext(context: Context) {
const keys = contextKeys(context);

if (keys.length === 0) {
Expand All @@ -66,7 +65,7 @@ function listContext(context: any) {
// Print config by default
const data: any[] = [[colors.green('#'), colors.green('Key'), colors.green('Value')]];
for (const [i, key] of keys) {
const jsonWithoutNewlines = JSON.stringify(context[key], undefined, 2).replace(/\s+/g, ' ');
const jsonWithoutNewlines = JSON.stringify(context.all[key], undefined, 2).replace(/\s+/g, ' ');
data.push([i, key, jsonWithoutNewlines]);
}

Expand Down Expand Up @@ -94,7 +93,7 @@ function invalidateContext(context: Context, key: string) {
}
}

function keyByNumber(context: any, n: number) {
function keyByNumber(context: Context, n: number) {
for (const [i, key] of contextKeys(context)) {
if (n === i) {
return key;
Expand Down
23 changes: 23 additions & 0 deletions packages/aws-cdk/test/commands/context-command.test.ts
Original file line number Diff line number Diff line change
Expand Up @@ -39,3 +39,26 @@ test('context reset can remove a context key', async () => {
baz: 'quux',
});
});

test('context reset can remove a context key using number', async () => {
// GIVEN
const configuration = new Configuration();
configuration.context.set('foo', 'bar');
configuration.context.set('baz', 'quux');

expect(configuration.context.all).toEqual({
foo: 'bar',
baz: 'quux',
});

// WHEN
await realHandler({
configuration,
args: { reset: '1' },
} as any);

// THEN
expect(configuration.context.all).toEqual({
foo: 'bar',
});
});

0 comments on commit 1e88242

Please sign in to comment.