Skip to content

Commit

Permalink
chore: tests and cleanup
Browse files Browse the repository at this point in the history
  • Loading branch information
mdonnalley committed Oct 17, 2024
1 parent f680c18 commit 273561e
Show file tree
Hide file tree
Showing 5 changed files with 56 additions and 89 deletions.
1 change: 1 addition & 0 deletions package.json
Original file line number Diff line number Diff line change
Expand Up @@ -86,6 +86,7 @@
"reformat": "prettier --config .prettierrc --write './*.{js,json,md}' './**/*.{ts,json,md}'",
"test": "wireit",
"test:nuts": "nyc mocha \"test/**/*.nut.ts\" --slow 4500 --timeout 600000 --parallel --jobs 20",
"test:nuts:alias": "nyc mocha \"test/**/alias/**/*.nut.ts\" --slow 4500 --timeout 600000 --parallel --jobs 20",
"test:nuts:config": "nyc mocha \"test/**/config/**/*.nut.ts\" --slow 4500 --timeout 600000 --parallel --jobs 20",
"test:only": "wireit",
"version": "oclif readme"
Expand Down
32 changes: 8 additions & 24 deletions src/alias.ts
Original file line number Diff line number Diff line change
Expand Up @@ -20,42 +20,26 @@ export type AliasResult = {

export type AliasResults = AliasResult[];

type AliasColumns = {
alias: { header: string };
value: { header: string };
success?: { header: string };
message?: { header: string };
};

export abstract class AliasCommand<T> extends SfCommand<T> {
protected output(title: string, results: AliasResults): void {
if (results.length === 0) {
this.log('No results');
return;
}

const columns: AliasColumns = {
alias: { header: 'Alias' },
value: { header: 'Value' },
};

if (title.includes('Set') || title.includes('Unset')) {
columns.success = { header: 'Success' };
}

// If any result contains an Error, add the header and grab the message off of Error
if (results.some((result) => result.error)) {
process.exitCode = 1;

columns.message = { header: 'Message' };

// results.map((r) => ({ ...r, message: r.error?.message }));
results.map((result) => (result.message = result.error?.message));
}

// this.table(results, columns, { title, 'no-truncate': true });
const data = results.map((result) => ({
alias: result.alias,
value: result.value,
...(title.includes('Set') || title.includes('Unset') ? { success: result.success } : {}),
...(result.error ? { message: result.error.message } : {}),
}));

this.table({
data: results,
data,
title,
});
}
Expand Down
29 changes: 18 additions & 11 deletions test/commands/alias/list.nut.ts
Original file line number Diff line number Diff line change
Expand Up @@ -38,7 +38,7 @@ describe('alias list NUTs', () => {
});

it('lists no aliases stdout', () => {
const res: string = execCmd('alias list').shellOutput;
const res = execCmd('alias list').shellOutput;
expect(res).to.include('No results');
});
});
Expand All @@ -60,10 +60,13 @@ describe('alias list NUTs', () => {
});

it('lists singular result correctly stdout', () => {
const res: string = execCmd('alias list', { ensureExitCode: 0 }).shellOutput;
expect(res).to.include('Alias List\n====='); // Table header
expect(res).to.include('Alias Value');
expect(res).to.include('DevHub [email protected]');
const res = execCmd('alias list', {
ensureExitCode: 0,
env: { ...process.env, SF_NO_TABLE_STYLE: 'true' },
}).shellOutput;
expect(res).to.include('Alias List'); // Table header
expect(res).to.include('alias value');
expect(res).to.include('DevHub [email protected]');
});
});

Expand Down Expand Up @@ -94,12 +97,16 @@ describe('alias list NUTs', () => {
});

it('lists multiple results correctly stdout', () => {
const res: string = execCmd('alias list', { ensureExitCode: 0 }).shellOutput;
expect(res).to.include('Alias List\n====='); // Table header
expect(res).to.include('Alias Value');
expect(res).to.include('DevHub [email protected]');
expect(res).to.include('Admin [email protected]');
expect(res).to.include('user [email protected]');
const res = execCmd('alias list', {
ensureExitCode: 0,
env: { ...process.env, SF_NO_TABLE_STYLE: 'true' },
}).shellOutput;

expect(res).to.include('Alias List'); // Table header
expect(res).to.include('alias value');
expect(res).to.include('DevHub [email protected]');
expect(res).to.include('Admin [email protected]');
expect(res).to.include('user [email protected]');
});
});
});
54 changes: 13 additions & 41 deletions test/commands/alias/set.nut.ts
Original file line number Diff line number Diff line change
Expand Up @@ -48,14 +48,15 @@ describe('alias set NUTs', () => {
});

it('alias set multiple values stdout', () => {
const res: string = execCmd('alias set [email protected] [email protected]', {
const res = execCmd('alias set [email protected] [email protected]', {
ensureExitCode: 0,
env: { ...process.env, SF_NO_TABLE_STYLE: 'true' },
}).shellOutput;

expect(res).to.include('Alias Set\n====='); // Table header
expect(res).to.include('Alias Value');
expect(res).to.include('DevHub [email protected]');
expect(res).to.include('Admin [email protected]');
expect(res).to.include('Alias Set'); // Table header
expect(res).to.include('alias value success');
expect(res).to.include('DevHub [email protected] true');
expect(res).to.include('Admin [email protected] true');
});

it('alias set with spaces in value', () => {
Expand Down Expand Up @@ -101,36 +102,6 @@ describe('alias set NUTs', () => {

expect(res).to.include('Found duplicate argument');
});

// this behavior is now allowed to allow plugin-settings in sfdx
it.skip('alias set DevHub= shows error message to use alias unset command', () => {
const res = execCmd('alias set DevHub=', {
ensureExitCode: 1,
}).shellOutput;

expect(res).to.include('Alias Set\n====='); // Table header
expect(res).to.include('Alias Value Success Message');
expect(res).to.include(`DevHub false ${messages.getMessages('error.ValueRequired')}`);
});

it.skip('alias set DevHub= shows error to use alias unset command (json)', () => {
const result = execCmd('alias set DevHub= --json', {
ensureExitCode: 1,
}).jsonOutput?.result;

expect(result).to.deep.equal([
{
alias: 'DevHub',
success: false,
error: {
name: 'ValueRequiredError',
exitCode: 1,
},
message:
'You must provide a value when setting an alias. Use `sf alias unset my-alias-name` to remove existing aliases.',
},
]);
});
});

describe('alias set overwrites existing entry', () => {
Expand All @@ -151,14 +122,15 @@ describe('alias set NUTs', () => {
});

it('alias set overwrites entry correctly stdout', () => {
const res: string = execCmd('alias set [email protected] [email protected]', {
const res = execCmd('alias set [email protected] [email protected]', {
ensureExitCode: 0,
env: { ...process.env, SF_NO_TABLE_STYLE: 'true' },
}).shellOutput;

expect(res).to.include('Alias Set\n====='); // Table header
expect(res).to.include('Alias Value');
expect(res).to.include('DevHub [email protected]');
expect(res).to.include('Admin [email protected]');
expect(res).to.include('Alias Set'); // Table header
expect(res).to.include('alias value success');
expect(res).to.include('DevHub [email protected] true');
expect(res).to.include('Admin [email protected] true');
});
});

Expand All @@ -174,7 +146,7 @@ describe('alias set NUTs', () => {
});

it('alias set without varargs stdout', () => {
const res: string = execCmd('alias set', {
const res = execCmd('alias set', {
ensureExitCode: 1,
}).shellOutput.stderr;

Expand Down
29 changes: 16 additions & 13 deletions test/commands/alias/unset.nut.ts
Original file line number Diff line number Diff line change
Expand Up @@ -40,13 +40,14 @@ describe('alias unset NUTs', () => {
});

it('unsetting non-existent key is a success (stdout)', () => {
const res: string = execCmd('alias unset noAlias', {
const res = execCmd('alias unset noAlias', {
ensureExitCode: 0,
env: { ...process.env, SF_NO_TABLE_STYLE: 'true' },
}).shellOutput;

expect(res).to.include('Alias Unset\n====='); // Table header
expect(res).to.include('Alias Value Success');
expect(res).to.include('noAlias true');
expect(res).to.include('Alias Unset'); // Table header
expect(res).to.include('alias value success');
expect(res).to.include('noAlias true');
});
});

Expand Down Expand Up @@ -82,13 +83,14 @@ describe('alias unset NUTs', () => {
});

it('alias unset DevHub', () => {
const res: string = execCmd('alias unset DevHub', {
const res = execCmd('alias unset DevHub', {
ensureExitCode: 0,
env: { ...process.env, SF_NO_TABLE_STYLE: 'true' },
}).shellOutput;

expect(res).to.include('Alias Unset\n====='); // Table header
expect(res).to.include('Alias Value Success');
expect(res).to.include('DevHub [email protected] true');
expect(res).to.include('Alias Unset'); // Table header
expect(res).to.include('alias value success');
expect(res).to.include('DevHub [email protected] true');
});
});

Expand Down Expand Up @@ -143,14 +145,15 @@ describe('alias unset NUTs', () => {
});

it('alias unset DevHub user', () => {
const res: string = execCmd('alias unset DevHub user', {
const res = execCmd('alias unset DevHub user', {
ensureExitCode: 0,
env: { ...process.env, SF_NO_TABLE_STYLE: 'true' },
}).shellOutput;

expect(res).to.include('Alias Unset\n====='); // Table header
expect(res).to.include('Alias Value Success');
expect(res).to.include('DevHub [email protected] true');
expect(res).to.include('user [email protected] true');
expect(res).to.include('Alias Unset'); // Table header
expect(res).to.include('alias value success');
expect(res).to.include('DevHub [email protected] true');
expect(res).to.include('user [email protected] true');
});

it('removes all aliases when passing --all', () => {
Expand Down

0 comments on commit 273561e

Please sign in to comment.