Skip to content

Commit

Permalink
Merge pull request #747 from salesforcecli/sm/retrieve-warnings
Browse files Browse the repository at this point in the history
fix: show retrieve warnings in a table
  • Loading branch information
shetzel authored Sep 8, 2023
2 parents 26769ca + 3f34340 commit 0da02d2
Showing 1 changed file with 24 additions and 13 deletions.
37 changes: 24 additions & 13 deletions src/formatters/retrieveResultFormatter.ts
Original file line number Diff line number Diff line change
Expand Up @@ -6,8 +6,9 @@
*/
import * as path from 'path';
import { Ux } from '@salesforce/sf-plugins-core';
import { FileResponse, RetrieveResult } from '@salesforce/source-deploy-retrieve';
import { FileResponse, RetrieveMessage, RetrieveResult } from '@salesforce/source-deploy-retrieve';
import { NamedPackageDir, SfProject } from '@salesforce/core';
import { ensureArray } from '@salesforce/kit';
import { Formatter, isSdrSuccess, RetrieveResultJson } from '../utils/types';
import { sortFileResponses, asRelativePaths, tableHeader, getFileResponseSuccessProps } from '../utils/output';

Expand Down Expand Up @@ -44,20 +45,28 @@ export class RetrieveResultFormatter implements Formatter<RetrieveResultJson> {
// a retrieve didn't happen, probably because everything was ignored or there were no remote changes to retrieve
this.ux.log('Nothing retrieved');
}
return;
}
} else {
const columns = {
state: { header: 'State' },
fullName: { header: 'Name' },
type: { header: 'Type' },
filePath: { header: 'Path' },
};
const options = { title: tableHeader('Retrieved Source'), 'no-truncate': true };
this.ux.log();

const columns = {
state: { header: 'State' },
fullName: { header: 'Name' },
type: { header: 'Type' },
filePath: { header: 'Path' },
};
const title = 'Retrieved Source';
const options = { title: tableHeader(title), 'no-truncate': true };
this.ux.log();
this.ux.table(getFileResponseSuccessProps(successes), columns, options);
}

this.ux.table(getFileResponseSuccessProps(successes), columns, options);
const warnings = getWarnings(this.result);
if (warnings.length) {
this.ux.log();
this.ux.table(
warnings,
{ fileName: { header: 'File' }, problem: { header: 'Problem' } },
{ 'no-truncate': true, title: tableHeader('Warnings') }
);
}
}

private async displayPackages(): Promise<void> {
Expand All @@ -82,3 +91,5 @@ export class RetrieveResultFormatter implements Formatter<RetrieveResultJson> {
});
}
}

const getWarnings = (result: RetrieveResult): RetrieveMessage[] => ensureArray(result?.response?.messages ?? []);

0 comments on commit 0da02d2

Please sign in to comment.