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

Sm/new logger #876

Merged
merged 43 commits into from
Jul 27, 2023
Merged
Show file tree
Hide file tree
Changes from 33 commits
Commits
Show all changes
43 commits
Select commit Hold shift + click to select a range
1f52733
fix: bump jsforce
cristiand391 Jun 22, 2023
7b6565b
feat: pino logger
mshanemc Jun 27, 2023
ff88212
refactor: standardize file naming
mshanemc Jun 27, 2023
2dbaaf5
Merge remote-tracking branch 'origin/cd/fix-jwt-jsforce' into sm/new-…
mshanemc Jun 27, 2023
fcf0ec5
chore: add pino-abstract-transport
mshanemc Jun 27, 2023
f32e09e
chore: eslint cleanup
mshanemc Jun 27, 2023
5559f95
chore: windows ut jsdoc fail
mshanemc Jun 27, 2023
2af0bb9
feat: clean up week+ old log files
mshanemc Jun 27, 2023
789dcc4
refactor: use logger, not debug, for lifecycle
mshanemc Jun 27, 2023
e0d3124
refactor: test updates for Lifecycle change
mshanemc Jun 27, 2023
7e9e725
chore: eslint cleanup
mshanemc Jun 27, 2023
18608f4
Merge branch 'sm/perf-metrics' into sm/new-logger
mshanemc Jun 28, 2023
a8dd3bb
test: remove unused cache since autopush
mshanemc Jun 28, 2023
5f0f741
test: also build
mshanemc Jun 28, 2023
b927164
feat: parameterize log cleanup for test use
mshanemc Jun 28, 2023
ace491a
test: unwrap array ut
mshanemc Jun 28, 2023
bd83d3e
test: cleanup from test
mshanemc Jun 28, 2023
210f380
Merge remote-tracking branch 'origin/main' into sm/new-logger
mshanemc Jun 29, 2023
0ed3f61
chore: update cleanup odds and log a warning when cleanup fails
mshanemc Jun 29, 2023
4b0746b
refactor: 3x faster filters
mshanemc Jun 29, 2023
b64cc72
style: comments from self-review
mshanemc Jun 29, 2023
e37e172
chore: code cleanup for pr
mshanemc Jun 29, 2023
eaa03ef
refactor: deprecate Global prop
mshanemc Jul 3, 2023
70be1d0
test: output log destination
mshanemc Jul 3, 2023
aab1552
test: 1 external nut
mshanemc Jul 3, 2023
3f3b529
test: verify auth nuts
mshanemc Jul 3, 2023
96735d7
test: get more data for 3 windows nut failures
mshanemc Jul 5, 2023
52b2c86
test: avoid perf flaps, restore all extNuts
mshanemc Jul 5, 2023
17dd004
test: delay nuts for UT
mshanemc Jul 5, 2023
0b24b59
test: org with testkit for debug
mshanemc Jul 6, 2023
a742e1f
Merge remote-tracking branch 'origin/main' into sm/new-logger
mshanemc Jul 6, 2023
4c1a87d
test: re-add user, org plugins
mshanemc Jul 6, 2023
2d8191a
test: full extNut suite
mshanemc Jul 6, 2023
c52a29b
chore: breaking changes for Logger
mshanemc Jul 20, 2023
df0132a
Merge remote-tracking branch 'origin/main' into sm/new-logger
mshanemc Jul 20, 2023
6f9451a
docs: logger migration guide
mshanemc Jul 20, 2023
568e9e8
chore: new prerelease logic
iowillhoit Jul 20, 2023
bca0b5a
Merge pull request #897 from forcedotcom/ew/gha
iowillhoit Jul 20, 2023
06cf627
chore(release): 5.0.1-v5-beta.0 [skip ci]
svc-cli-bot Jul 20, 2023
cbe1090
refactor: log without JSON.stringify
mshanemc Jul 21, 2023
c6bbeb5
refactor: we can log objects now
mshanemc Jul 21, 2023
6959776
chore(release): 5.0.1-v5-beta.1 [skip ci]
svc-cli-bot Jul 24, 2023
039cc19
chore: pr comments
mshanemc Jul 26, 2023
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
2 changes: 1 addition & 1 deletion .github/workflows/test.yml
Original file line number Diff line number Diff line change
Expand Up @@ -15,7 +15,7 @@ jobs:
needs: linux-unit-tests
uses: salesforcecli/github-workflows/.github/workflows/unitTestsWindows.yml@main
nuts:
needs: linux-unit-tests
# needs: linux-unit-tests
mshanemc marked this conversation as resolved.
Show resolved Hide resolved
uses: salesforcecli/github-workflows/.github/workflows/externalNut.yml@main
strategy:
fail-fast: false
Expand Down
4,314 changes: 987 additions & 3,327 deletions CHANGELOG.md

Large diffs are not rendered by default.

8 changes: 4 additions & 4 deletions package.json
Original file line number Diff line number Diff line change
Expand Up @@ -39,20 +39,21 @@
"messageTransformer/messageTransformer.ts"
],
"dependencies": {
"@salesforce/bunyan": "^2.0.0",
"@salesforce/kit": "^3.0.3",
"@salesforce/schemas": "^1.5.1",
"@salesforce/ts-types": "^2.0.2",
"@types/semver": "^7.5.0",
"ajv": "^8.12.0",
"change-case": "^4.1.2",
"debug": "^3.2.7",
"faye": "^1.4.0",
"form-data": "^4.0.0",
"js2xmlparser": "^4.0.1",
"jsforce": "^2.0.0-beta.27",
"jsonwebtoken": "9.0.0",
"jszip": "3.10.1",
"pino": "^8.14.1",
"pino-abstract-transport": "^1.0.0",
"pino-pretty": "^10.0.0",
"proper-lockfile": "^4.1.2",
"ts-retry-promise": "^0.7.0"
},
Expand All @@ -63,7 +64,6 @@
"@salesforce/ts-sinon": "^1.4.8",
"@types/benchmark": "^2.1.2",
"@types/chai-string": "^1.4.2",
"@types/debug": "0.0.31",
"@types/jsonwebtoken": "9.0.2",
"@types/lodash": "^4.14.195",
"@types/proper-lockfile": "^4.1.2",
Expand Down Expand Up @@ -174,4 +174,4 @@
]
}
}
}
}
2 changes: 1 addition & 1 deletion src/config/config.ts
Original file line number Diff line number Diff line change
Expand Up @@ -10,7 +10,7 @@ import * as fs from 'fs';
import { keyBy, parseJsonMap, set } from '@salesforce/kit';
import { Dictionary, ensure, isString, JsonPrimitive, Nullable } from '@salesforce/ts-types';
import { Global } from '../global';
import { Logger } from '../logger';
import { Logger } from '../logger/logger';
import { Messages } from '../messages';
import { validateApiVersion } from '../util/sfdc';
import { SfdcUrl } from '../util/sfdcUrl';
Expand Down
2 changes: 1 addition & 1 deletion src/config/configFile.ts
Original file line number Diff line number Diff line change
Expand Up @@ -12,7 +12,7 @@ import { dirname as pathDirname, join as pathJoin } from 'path';
import { isPlainObject } from '@salesforce/ts-types';
import { parseJsonMap } from '@salesforce/kit';
import { Global } from '../global';
import { Logger } from '../logger';
import { Logger } from '../logger/logger';
import { SfError } from '../sfError';
import { resolveProjectPath, resolveProjectPathSync } from '../util/internal';
import { BaseConfigStore, ConfigContents } from './configStore';
Expand Down
2 changes: 1 addition & 1 deletion src/crypto/crypto.ts
Original file line number Diff line number Diff line change
Expand Up @@ -11,7 +11,7 @@ import * as os from 'os';
import { join as pathJoin } from 'path';
import { ensure, Nullable, Optional } from '@salesforce/ts-types';
import { AsyncOptionalCreatable, env } from '@salesforce/kit';
import { Logger } from '../logger';
import { Logger } from '../logger/logger';
import { Messages } from '../messages';
import { Cache } from '../util/cache';
import { Global } from '../global';
Expand Down
2 changes: 1 addition & 1 deletion src/crypto/keyChain.ts
Original file line number Diff line number Diff line change
Expand Up @@ -6,7 +6,7 @@
*/

import { env } from '@salesforce/kit';
import { Logger } from '../logger';
import { Logger } from '../logger/logger';
import { Messages } from '../messages';
import { KeyChain, keyChainImpl } from './keyChainImpl';

Expand Down
2 changes: 1 addition & 1 deletion src/deviceOauthService.ts
Original file line number Diff line number Diff line change
Expand Up @@ -12,7 +12,7 @@ import { AsyncCreatable, Duration, parseJsonMap } from '@salesforce/kit';
import { HttpRequest, OAuth2Config } from 'jsforce';
import { ensureString, JsonMap, Nullable } from '@salesforce/ts-types';
import * as FormData from 'form-data';
import { Logger } from './logger';
import { Logger } from './logger/logger';
import { AuthInfo, DEFAULT_CONNECTED_APP_INFO, SFDX_HTTP_HEADERS } from './org';
import { SfError } from './sfError';
import { Messages } from './messages';
Expand Down
2 changes: 1 addition & 1 deletion src/exported.ts
Original file line number Diff line number Diff line change
Expand Up @@ -63,7 +63,7 @@ export {
LoggerOptions,
LoggerStream,
Logger,
} from './logger';
} from './logger/logger';

export { Messages, StructuredMessage } from './messages';

Expand Down
2 changes: 2 additions & 0 deletions src/global.ts
Original file line number Diff line number Diff line change
Expand Up @@ -77,6 +77,8 @@ export class Global {

/**
* The full system path to the global log file.
*
* @deprecated. The log file path is now based on a datestamp an not static. This will return incorrect information if used.
*/
// member ordering conflicts with the TS use-before-declaration error
// eslint-disable-next-line @typescript-eslint/member-ordering
Expand Down
14 changes: 10 additions & 4 deletions src/lifecycleEvents.ts
Original file line number Diff line number Diff line change
Expand Up @@ -6,12 +6,12 @@
*/

import { AnyJson, Dictionary } from '@salesforce/ts-types';
import * as Debug from 'debug';
import { compare } from 'semver';
// needed for TS to not put everything inside /lib/src
// eslint-disable-next-line @typescript-eslint/ban-ts-comment
// @ts-ignore
import * as pjson from '../package.json';
import { Logger } from './logger/logger';
Copy link
Contributor Author

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

use Logger instead of debug for logging. this allows debug to be removed


// Data of any type can be passed to the callback. Can be cast to any type that is given in emit().
// eslint-disable-next-line @typescript-eslint/no-explicit-any
Expand Down Expand Up @@ -45,7 +45,7 @@ declare const global: {
export class Lifecycle {
public static readonly telemetryEventName = 'telemetry';
public static readonly warningEventName = 'warning';
private debug = Debug(`sfdx:${this.constructor.name}`);
private logger?: Logger;

private constructor(private readonly listeners: Dictionary<callback[]> = {}) {}

Expand Down Expand Up @@ -154,7 +154,10 @@ export class Lifecycle {
public on<T = AnyJson>(eventName: string, cb: (data: T) => Promise<void>): void {
const listeners = this.getListeners(eventName);
if (listeners.length !== 0) {
this.debug(
if (!this.logger) {
this.logger = Logger.childFromRoot('Lifecycle');
}
this.logger.debug(
`${
listeners.length + 1
} lifecycle events with the name ${eventName} have now been registered. When this event is emitted all ${
Expand Down Expand Up @@ -196,7 +199,10 @@ export class Lifecycle {
public async emit<T = AnyJson>(eventName: string, data: T): Promise<void> {
const listeners = this.getListeners(eventName);
if (listeners.length === 0 && eventName !== Lifecycle.warningEventName) {
this.debug(
if (!this.logger) {
this.logger = Logger.childFromRoot('Lifecycle');
}
this.logger.debug(
`A lifecycle event with the name ${eventName} does not exist. An event must be registered before it can be emitted.`
);
} else {
Expand Down
Loading