aws-cdk 2.172.0 → 2.173.0
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/build-info.json +2 -2
- package/db.json.gz +0 -0
- package/lib/api/aws-auth/awscli-compatible.js +2 -1
- package/lib/index.js +2 -2
- package/package.json +8 -8
- package/test/api/aws-auth/awscli-compatible.test.js +1 -32
- package/test/api/logs/cli-logging.test.js +135 -0
- package/test/api/logs/logs-monitor.test.js +15 -7
- package/test/logging.test.js +0 -131
- /package/test/{logging.test.d.ts → api/logs/cli-logging.test.d.ts} +0 -0
package/package.json
CHANGED
|
@@ -1,7 +1,7 @@
|
|
|
1
1
|
{
|
|
2
2
|
"name": "aws-cdk",
|
|
3
3
|
"description": "CDK Toolkit, the command line tool for CDK apps",
|
|
4
|
-
"version": "2.
|
|
4
|
+
"version": "2.173.0",
|
|
5
5
|
"bin": {
|
|
6
6
|
"cdk": "bin/cdk"
|
|
7
7
|
},
|
|
@@ -67,9 +67,9 @@
|
|
|
67
67
|
},
|
|
68
68
|
"license": "Apache-2.0",
|
|
69
69
|
"devDependencies": {
|
|
70
|
-
"@aws-cdk/cdk-build-tools": "2.
|
|
71
|
-
"@aws-cdk/pkglint": "2.
|
|
72
|
-
"@aws-cdk/yargs-gen": "2.
|
|
70
|
+
"@aws-cdk/cdk-build-tools": "2.173.0-alpha.0",
|
|
71
|
+
"@aws-cdk/pkglint": "2.173.0-alpha.0",
|
|
72
|
+
"@aws-cdk/yargs-gen": "2.173.0-alpha.0",
|
|
73
73
|
"@octokit/rest": "^18.12.0",
|
|
74
74
|
"@types/archiver": "^5.3.4",
|
|
75
75
|
"@types/fs-extra": "^9.0.13",
|
|
@@ -84,7 +84,7 @@
|
|
|
84
84
|
"@types/uuid": "^8.3.4",
|
|
85
85
|
"@types/wrap-ansi": "^3.0.0",
|
|
86
86
|
"@types/yargs": "^15.0.19",
|
|
87
|
-
"aws-cdk-lib": "2.
|
|
87
|
+
"aws-cdk-lib": "2.173.0",
|
|
88
88
|
"aws-sdk-client-mock": "^4.0.1",
|
|
89
89
|
"aws-sdk-client-mock-jest": "^4.0.1",
|
|
90
90
|
"axios": "^1.7.7",
|
|
@@ -100,9 +100,9 @@
|
|
|
100
100
|
"ts-mock-imports": "^1.3.16",
|
|
101
101
|
"xml-js": "^1.6.11",
|
|
102
102
|
"@aws-cdk/cloud-assembly-schema": "^38.0.0",
|
|
103
|
-
"@aws-cdk/cloudformation-diff": "2.
|
|
104
|
-
"@aws-cdk/cx-api": "2.
|
|
105
|
-
"@aws-cdk/region-info": "2.
|
|
103
|
+
"@aws-cdk/cloudformation-diff": "2.173.0",
|
|
104
|
+
"@aws-cdk/cx-api": "2.173.0",
|
|
105
|
+
"@aws-cdk/region-info": "2.173.0",
|
|
106
106
|
"@aws-sdk/client-appsync": "3.699.0",
|
|
107
107
|
"@aws-sdk/client-cloudformation": "3.699.0",
|
|
108
108
|
"@aws-sdk/client-cloudwatch-logs": "3.699.0",
|
|
@@ -211,35 +211,4 @@ describe('Session token', () => {
|
|
|
211
211
|
expect(process.env.AWS_SESSION_TOKEN).toEqual('aaa');
|
|
212
212
|
});
|
|
213
213
|
});
|
|
214
|
-
describe('Session token', () => {
|
|
215
|
-
beforeEach(() => {
|
|
216
|
-
process.env.AWS_ACCESS_KEY_ID = 'foo';
|
|
217
|
-
process.env.AWS_SECRET_ACCESS_KEY = 'bar';
|
|
218
|
-
});
|
|
219
|
-
test('does not mess up with session token env variables if they are undefined', async () => {
|
|
220
|
-
// Making sure these variables are not defined
|
|
221
|
-
delete process.env.AWS_SESSION_TOKEN;
|
|
222
|
-
delete process.env.AMAZON_SESSION_TOKEN;
|
|
223
|
-
await awscli_compatible_1.AwsCliCompatible.credentialChainBuilder();
|
|
224
|
-
expect(process.env.AWS_SESSION_TOKEN).toBeUndefined();
|
|
225
|
-
});
|
|
226
|
-
test('preserves AWS_SESSION_TOKEN if it is defined', async () => {
|
|
227
|
-
process.env.AWS_SESSION_TOKEN = 'aaa';
|
|
228
|
-
delete process.env.AMAZON_SESSION_TOKEN;
|
|
229
|
-
await awscli_compatible_1.AwsCliCompatible.credentialChainBuilder();
|
|
230
|
-
expect(process.env.AWS_SESSION_TOKEN).toEqual('aaa');
|
|
231
|
-
});
|
|
232
|
-
test('assigns AWS_SESSION_TOKEN if it is not defined but AMAZON_SESSION_TOKEN is', async () => {
|
|
233
|
-
delete process.env.AWS_SESSION_TOKEN;
|
|
234
|
-
process.env.AMAZON_SESSION_TOKEN = 'aaa';
|
|
235
|
-
await awscli_compatible_1.AwsCliCompatible.credentialChainBuilder();
|
|
236
|
-
expect(process.env.AWS_SESSION_TOKEN).toEqual('aaa');
|
|
237
|
-
});
|
|
238
|
-
test('preserves AWS_SESSION_TOKEN if both are defined', async () => {
|
|
239
|
-
process.env.AWS_SESSION_TOKEN = 'aaa';
|
|
240
|
-
process.env.AMAZON_SESSION_TOKEN = 'bbb';
|
|
241
|
-
await awscli_compatible_1.AwsCliCompatible.credentialChainBuilder();
|
|
242
|
-
expect(process.env.AWS_SESSION_TOKEN).toEqual('aaa');
|
|
243
|
-
});
|
|
244
|
-
});
|
|
245
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"awscli-compatible.test.js","sourceRoot":"","sources":["awscli-compatible.test.ts"],"names":[],"mappings":"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","sourcesContent":["import * as os from 'os';\nimport * as path from 'path';\nimport * as fs from 'fs-extra';\nimport { AwsCliCompatible } from '../../../lib/api/aws-auth/awscli-compatible';\n\ndescribe('AwsCliCompatible.region', () => {\n\n  beforeEach(() => {\n\n    // make sure we don't mistakenly point to an unrelated file\n    process.env.AWS_CONFIG_FILE = '/dev/null';\n    process.env.AWS_SHARED_CREDENTIALS_FILE = '/dev/null';\n\n    // these take precedence over the ini files so we need to disable them for\n    // the test to invoke the right function\n    delete process.env.AWS_REGION;\n    delete process.env.AMAZON_REGION;\n    delete process.env.AWS_DEFAULT_REGION;\n    delete process.env.AMAZON_DEFAULT_REGION;\n\n  });\n\n  test('default region can be specified in config', async () => {\n\n    const config = `\n  [default]\n  region=region-in-config\n  `;\n\n    await expect(region({ configFile: config })).resolves.toBe('region-in-config');\n  });\n\n  test('default region can be specified in credentials', async () => {\n\n    const creds = `\n  [default]\n  region=region-in-credentials\n  `;\n\n    await expect(region({ credentialsFile: creds })).resolves.toBe('region-in-credentials');\n\n  });\n\n  test('profile region can be specified in config', async () => {\n\n    const config = `\n  [profile user1]\n  region=region-in-config\n  `;\n\n    await expect(region({ configFile: config, profile: 'user1' })).resolves.toBe('region-in-config');\n\n  });\n\n  test('profile region can be specified in credentials', async () => {\n\n    const creds = `\n  [user1]\n  region=region-in-credentials\n  `;\n\n    await expect(region({ credentialsFile: creds, profile: 'user1' })).resolves.toBe('region-in-credentials');\n\n  });\n\n  test('with profile | profile-region-in-credentials is priority 1', async () => {\n\n    const config = `\n  [default]\n  region=default-region-in-config\n\n  [profile user]\n  region=profile-region-in-config\n\n  `;\n\n    const creds = `\n  [default]\n  region=default-region-in-credentials\n\n  [user]\n  region=profile-region-in-credentials\n  `;\n\n    await expect(region({ credentialsFile: creds, configFile: config, profile: 'user' })).resolves.toBe('profile-region-in-credentials');\n  });\n\n  test('with profile | profile-region-in-config is priority 2', async () => {\n\n    const config = `\n  [default]\n  region=default-region-in-config\n\n  [profile user]\n  region=profile-region-in-config\n\n  `;\n\n    const creds = `\n  [default]\n  region=default-region-in-credentials\n\n  [user]\n  `;\n\n    await expect(region({ credentialsFile: creds, configFile: config, profile: 'user' })).resolves.toBe('profile-region-in-config');\n  });\n\n  test('with profile | default-region-in-credentials is priority 3', async () => {\n\n    const config = `\n  [default]\n  region=default-region-in-config\n\n  [profile user]\n\n  `;\n\n    const creds = `\n  [default]\n  region=default-region-in-credentials\n\n  [user]\n  `;\n\n    await expect(region({ credentialsFile: creds, configFile: config, profile: 'user' })).resolves.toBe('default-region-in-credentials');\n  });\n\n  test('with profile | default-region-in-config is priority 4', async () => {\n\n    const config = `\n  [default]\n  region=default-region-in-config\n\n  [profile user]\n\n  `;\n\n    const creds = `\n  [default]\n\n  [user]\n  `;\n\n    await expect(region({ credentialsFile: creds, configFile: config, profile: 'user' })).resolves.toBe('default-region-in-config');\n  });\n\n  test('with profile | us-east-1 is priority 5', async () => {\n\n    const config = `\n  [default]\n\n  [profile user]\n\n  `;\n\n    const creds = `\n  [default]\n\n  [user]\n  `;\n\n    await expect(region({ credentialsFile: creds, configFile: config, profile: 'user' })).resolves.toBe('us-east-1');\n  });\n\n  test('without profile | default-region-in-credentials is priority 1', async () => {\n\n    const config = `\n  [default]\n  region=default-region-in-config\n\n  `;\n\n    const creds = `\n  [default]\n  region=default-region-in-credentials\n\n  `;\n\n    await expect(region({ credentialsFile: creds, configFile: config })).resolves.toBe('default-region-in-credentials');\n  });\n\n  test('without profile | default-region-in-config is priority 2', async () => {\n\n    const config = `\n  [default]\n  region=default-region-in-config\n\n  `;\n\n    const creds = `\n  [default]\n\n  `;\n\n    await expect(region({ credentialsFile: creds, configFile: config })).resolves.toBe('default-region-in-config');\n  });\n\n  test('without profile | us-east-1 is priority 3', async () => {\n\n    const config = `\n  [default]\n\n  `;\n\n    const creds = `\n  [default]\n\n  `;\n\n    await expect(region({ credentialsFile: creds, configFile: config })).resolves.toBe('us-east-1');\n  });\n\n});\n\nasync function region(opts: {\n  readonly configFile?: string;\n  readonly credentialsFile?: string;\n  readonly profile?: string;\n}) {\n\n  const workdir = fs.mkdtempSync(path.join(os.tmpdir(), 'awscli-compatible.test'));\n\n  try {\n\n    if (opts.configFile) {\n      const configPath = path.join(workdir, 'config');\n      fs.writeFileSync(configPath, opts.configFile);\n      process.env.AWS_CONFIG_FILE = configPath;\n    }\n\n    if (opts.credentialsFile) {\n      const credentialsPath = path.join(workdir, 'credentials');\n      fs.writeFileSync(credentialsPath, opts.credentialsFile);\n      process.env.AWS_SHARED_CREDENTIALS_FILE = credentialsPath;\n    }\n\n    return await AwsCliCompatible.region(opts.profile);\n\n  } finally {\n    fs.removeSync(workdir);\n  }\n}\n\ndescribe('Session token', () => {\n  beforeEach(() => {\n    process.env.AWS_ACCESS_KEY_ID = 'foo';\n    process.env.AWS_SECRET_ACCESS_KEY = 'bar';\n  });\n\n  test('does not mess up with session token env variables if they are undefined', async () => {\n    // Making sure these variables are not defined\n    delete process.env.AWS_SESSION_TOKEN;\n    delete process.env.AMAZON_SESSION_TOKEN;\n\n    await AwsCliCompatible.credentialChainBuilder();\n\n    expect(process.env.AWS_SESSION_TOKEN).toBeUndefined();\n  });\n\n  test('preserves AWS_SESSION_TOKEN if it is defined', async () => {\n    process.env.AWS_SESSION_TOKEN = 'aaa';\n    delete process.env.AMAZON_SESSION_TOKEN;\n\n    await AwsCliCompatible.credentialChainBuilder();\n\n    expect(process.env.AWS_SESSION_TOKEN).toEqual('aaa');\n  });\n\n  test('assigns AWS_SESSION_TOKEN if it is not defined but AMAZON_SESSION_TOKEN is', async () => {\n    delete process.env.AWS_SESSION_TOKEN;\n    process.env.AMAZON_SESSION_TOKEN = 'aaa';\n\n    await AwsCliCompatible.credentialChainBuilder();\n\n    expect(process.env.AWS_SESSION_TOKEN).toEqual('aaa');\n  });\n\n  test('preserves AWS_SESSION_TOKEN if both are defined', async () => {\n    process.env.AWS_SESSION_TOKEN = 'aaa';\n    process.env.AMAZON_SESSION_TOKEN = 'bbb';\n\n    await AwsCliCompatible.credentialChainBuilder();\n\n    expect(process.env.AWS_SESSION_TOKEN).toEqual('aaa');\n  });\n});\n\ndescribe('Session token', () => {\n  beforeEach(() => {\n    process.env.AWS_ACCESS_KEY_ID = 'foo';\n    process.env.AWS_SECRET_ACCESS_KEY = 'bar';\n  });\n\n  test('does not mess up with session token env variables if they are undefined', async () => {\n    // Making sure these variables are not defined\n    delete process.env.AWS_SESSION_TOKEN;\n    delete process.env.AMAZON_SESSION_TOKEN;\n\n    await AwsCliCompatible.credentialChainBuilder();\n\n    expect(process.env.AWS_SESSION_TOKEN).toBeUndefined();\n  });\n\n  test('preserves AWS_SESSION_TOKEN if it is defined', async () => {\n    process.env.AWS_SESSION_TOKEN = 'aaa';\n    delete process.env.AMAZON_SESSION_TOKEN;\n\n    await AwsCliCompatible.credentialChainBuilder();\n\n    expect(process.env.AWS_SESSION_TOKEN).toEqual('aaa');\n  });\n\n  test('assigns AWS_SESSION_TOKEN if it is not defined but AMAZON_SESSION_TOKEN is', async () => {\n    delete process.env.AWS_SESSION_TOKEN;\n    process.env.AMAZON_SESSION_TOKEN = 'aaa';\n\n    await AwsCliCompatible.credentialChainBuilder();\n\n    expect(process.env.AWS_SESSION_TOKEN).toEqual('aaa');\n  });\n\n  test('preserves AWS_SESSION_TOKEN if both are defined', async () => {\n    process.env.AWS_SESSION_TOKEN = 'aaa';\n    process.env.AMAZON_SESSION_TOKEN = 'bbb';\n\n    await AwsCliCompatible.credentialChainBuilder();\n\n    expect(process.env.AWS_SESSION_TOKEN).toEqual('aaa');\n  });\n});\n"]}
|
|
214
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"awscli-compatible.test.js","sourceRoot":"","sources":["awscli-compatible.test.ts"],"names":[],"mappings":"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","sourcesContent":["import * as os from 'os';\nimport * as path from 'path';\nimport * as fs from 'fs-extra';\nimport { AwsCliCompatible } from '../../../lib/api/aws-auth/awscli-compatible';\n\ndescribe('AwsCliCompatible.region', () => {\n\n  beforeEach(() => {\n\n    // make sure we don't mistakenly point to an unrelated file\n    process.env.AWS_CONFIG_FILE = '/dev/null';\n    process.env.AWS_SHARED_CREDENTIALS_FILE = '/dev/null';\n\n    // these take precedence over the ini files so we need to disable them for\n    // the test to invoke the right function\n    delete process.env.AWS_REGION;\n    delete process.env.AMAZON_REGION;\n    delete process.env.AWS_DEFAULT_REGION;\n    delete process.env.AMAZON_DEFAULT_REGION;\n\n  });\n\n  test('default region can be specified in config', async () => {\n\n    const config = `\n  [default]\n  region=region-in-config\n  `;\n\n    await expect(region({ configFile: config })).resolves.toBe('region-in-config');\n  });\n\n  test('default region can be specified in credentials', async () => {\n\n    const creds = `\n  [default]\n  region=region-in-credentials\n  `;\n\n    await expect(region({ credentialsFile: creds })).resolves.toBe('region-in-credentials');\n\n  });\n\n  test('profile region can be specified in config', async () => {\n\n    const config = `\n  [profile user1]\n  region=region-in-config\n  `;\n\n    await expect(region({ configFile: config, profile: 'user1' })).resolves.toBe('region-in-config');\n\n  });\n\n  test('profile region can be specified in credentials', async () => {\n\n    const creds = `\n  [user1]\n  region=region-in-credentials\n  `;\n\n    await expect(region({ credentialsFile: creds, profile: 'user1' })).resolves.toBe('region-in-credentials');\n\n  });\n\n  test('with profile | profile-region-in-credentials is priority 1', async () => {\n\n    const config = `\n  [default]\n  region=default-region-in-config\n\n  [profile user]\n  region=profile-region-in-config\n\n  `;\n\n    const creds = `\n  [default]\n  region=default-region-in-credentials\n\n  [user]\n  region=profile-region-in-credentials\n  `;\n\n    await expect(region({ credentialsFile: creds, configFile: config, profile: 'user' })).resolves.toBe('profile-region-in-credentials');\n  });\n\n  test('with profile | profile-region-in-config is priority 2', async () => {\n\n    const config = `\n  [default]\n  region=default-region-in-config\n\n  [profile user]\n  region=profile-region-in-config\n\n  `;\n\n    const creds = `\n  [default]\n  region=default-region-in-credentials\n\n  [user]\n  `;\n\n    await expect(region({ credentialsFile: creds, configFile: config, profile: 'user' })).resolves.toBe('profile-region-in-config');\n  });\n\n  test('with profile | default-region-in-credentials is priority 3', async () => {\n\n    const config = `\n  [default]\n  region=default-region-in-config\n\n  [profile user]\n\n  `;\n\n    const creds = `\n  [default]\n  region=default-region-in-credentials\n\n  [user]\n  `;\n\n    await expect(region({ credentialsFile: creds, configFile: config, profile: 'user' })).resolves.toBe('default-region-in-credentials');\n  });\n\n  test('with profile | default-region-in-config is priority 4', async () => {\n\n    const config = `\n  [default]\n  region=default-region-in-config\n\n  [profile user]\n\n  `;\n\n    const creds = `\n  [default]\n\n  [user]\n  `;\n\n    await expect(region({ credentialsFile: creds, configFile: config, profile: 'user' })).resolves.toBe('default-region-in-config');\n  });\n\n  test('with profile | us-east-1 is priority 5', async () => {\n\n    const config = `\n  [default]\n\n  [profile user]\n\n  `;\n\n    const creds = `\n  [default]\n\n  [user]\n  `;\n\n    await expect(region({ credentialsFile: creds, configFile: config, profile: 'user' })).resolves.toBe('us-east-1');\n  });\n\n  test('without profile | default-region-in-credentials is priority 1', async () => {\n\n    const config = `\n  [default]\n  region=default-region-in-config\n\n  `;\n\n    const creds = `\n  [default]\n  region=default-region-in-credentials\n\n  `;\n\n    await expect(region({ credentialsFile: creds, configFile: config })).resolves.toBe('default-region-in-credentials');\n  });\n\n  test('without profile | default-region-in-config is priority 2', async () => {\n\n    const config = `\n  [default]\n  region=default-region-in-config\n\n  `;\n\n    const creds = `\n  [default]\n\n  `;\n\n    await expect(region({ credentialsFile: creds, configFile: config })).resolves.toBe('default-region-in-config');\n  });\n\n  test('without profile | us-east-1 is priority 3', async () => {\n\n    const config = `\n  [default]\n\n  `;\n\n    const creds = `\n  [default]\n\n  `;\n\n    await expect(region({ credentialsFile: creds, configFile: config })).resolves.toBe('us-east-1');\n  });\n\n});\n\nasync function region(opts: {\n  readonly configFile?: string;\n  readonly credentialsFile?: string;\n  readonly profile?: string;\n}) {\n\n  const workdir = fs.mkdtempSync(path.join(os.tmpdir(), 'awscli-compatible.test'));\n\n  try {\n\n    if (opts.configFile) {\n      const configPath = path.join(workdir, 'config');\n      fs.writeFileSync(configPath, opts.configFile);\n      process.env.AWS_CONFIG_FILE = configPath;\n    }\n\n    if (opts.credentialsFile) {\n      const credentialsPath = path.join(workdir, 'credentials');\n      fs.writeFileSync(credentialsPath, opts.credentialsFile);\n      process.env.AWS_SHARED_CREDENTIALS_FILE = credentialsPath;\n    }\n\n    return await AwsCliCompatible.region(opts.profile);\n\n  } finally {\n    fs.removeSync(workdir);\n  }\n}\n\ndescribe('Session token', () => {\n  beforeEach(() => {\n    process.env.AWS_ACCESS_KEY_ID = 'foo';\n    process.env.AWS_SECRET_ACCESS_KEY = 'bar';\n  });\n\n  test('does not mess up with session token env variables if they are undefined', async () => {\n    // Making sure these variables are not defined\n    delete process.env.AWS_SESSION_TOKEN;\n    delete process.env.AMAZON_SESSION_TOKEN;\n\n    await AwsCliCompatible.credentialChainBuilder();\n\n    expect(process.env.AWS_SESSION_TOKEN).toBeUndefined();\n  });\n\n  test('preserves AWS_SESSION_TOKEN if it is defined', async () => {\n    process.env.AWS_SESSION_TOKEN = 'aaa';\n    delete process.env.AMAZON_SESSION_TOKEN;\n\n    await AwsCliCompatible.credentialChainBuilder();\n\n    expect(process.env.AWS_SESSION_TOKEN).toEqual('aaa');\n  });\n\n  test('assigns AWS_SESSION_TOKEN if it is not defined but AMAZON_SESSION_TOKEN is', async () => {\n    delete process.env.AWS_SESSION_TOKEN;\n    process.env.AMAZON_SESSION_TOKEN = 'aaa';\n\n    await AwsCliCompatible.credentialChainBuilder();\n\n    expect(process.env.AWS_SESSION_TOKEN).toEqual('aaa');\n  });\n\n  test('preserves AWS_SESSION_TOKEN if both are defined', async () => {\n    process.env.AWS_SESSION_TOKEN = 'aaa';\n    process.env.AMAZON_SESSION_TOKEN = 'bbb';\n\n    await AwsCliCompatible.credentialChainBuilder();\n\n    expect(process.env.AWS_SESSION_TOKEN).toEqual('aaa');\n  });\n});\n"]}
|
|
@@ -0,0 +1,135 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
const logging_1 = require("../../../lib/logging");
|
|
4
|
+
describe('logging', () => {
|
|
5
|
+
// Mock streams to capture output
|
|
6
|
+
let mockStdout;
|
|
7
|
+
let mockStderr;
|
|
8
|
+
// Helper function to strip ANSI codes
|
|
9
|
+
const stripAnsi = (str) => {
|
|
10
|
+
const ansiRegex = /\u001b\[[0-9;]*[a-zA-Z]/g;
|
|
11
|
+
return str.replace(ansiRegex, '');
|
|
12
|
+
};
|
|
13
|
+
beforeEach(() => {
|
|
14
|
+
// Reset log level before each test
|
|
15
|
+
(0, logging_1.setLogLevel)(logging_1.LogLevel.INFO);
|
|
16
|
+
(0, logging_1.setCI)(false);
|
|
17
|
+
// Create mock functions to capture output
|
|
18
|
+
mockStdout = jest.fn();
|
|
19
|
+
mockStderr = jest.fn();
|
|
20
|
+
// Mock the write methods directly and strip ANSI codes
|
|
21
|
+
jest.spyOn(process.stdout, 'write').mockImplementation((chunk) => {
|
|
22
|
+
mockStdout(stripAnsi(chunk.toString()));
|
|
23
|
+
return true;
|
|
24
|
+
});
|
|
25
|
+
jest.spyOn(process.stderr, 'write').mockImplementation((chunk) => {
|
|
26
|
+
mockStderr(stripAnsi(chunk.toString()));
|
|
27
|
+
return true;
|
|
28
|
+
});
|
|
29
|
+
});
|
|
30
|
+
afterEach(() => {
|
|
31
|
+
jest.restoreAllMocks();
|
|
32
|
+
});
|
|
33
|
+
describe('stream selection', () => {
|
|
34
|
+
test('data() always writes to stdout', () => {
|
|
35
|
+
(0, logging_1.data)('test message');
|
|
36
|
+
expect(mockStdout).toHaveBeenCalledWith('test message\n');
|
|
37
|
+
expect(mockStderr).not.toHaveBeenCalled();
|
|
38
|
+
});
|
|
39
|
+
test('error() always writes to stderr', () => {
|
|
40
|
+
(0, logging_1.error)('test error');
|
|
41
|
+
expect(mockStderr).toHaveBeenCalledWith('test error\n');
|
|
42
|
+
expect(mockStdout).not.toHaveBeenCalled();
|
|
43
|
+
});
|
|
44
|
+
test('print() writes to stderr by default', () => {
|
|
45
|
+
(0, logging_1.print)('test print');
|
|
46
|
+
expect(mockStderr).toHaveBeenCalledWith('test print\n');
|
|
47
|
+
expect(mockStdout).not.toHaveBeenCalled();
|
|
48
|
+
});
|
|
49
|
+
test('print() writes to stdout in CI mode', () => {
|
|
50
|
+
(0, logging_1.setCI)(true);
|
|
51
|
+
(0, logging_1.print)('test print');
|
|
52
|
+
expect(mockStdout).toHaveBeenCalledWith('test print\n');
|
|
53
|
+
expect(mockStderr).not.toHaveBeenCalled();
|
|
54
|
+
});
|
|
55
|
+
});
|
|
56
|
+
describe('log levels', () => {
|
|
57
|
+
test('respects log level settings', () => {
|
|
58
|
+
(0, logging_1.setLogLevel)(logging_1.LogLevel.ERROR);
|
|
59
|
+
(0, logging_1.error)('error message');
|
|
60
|
+
(0, logging_1.warning)('warning message');
|
|
61
|
+
(0, logging_1.print)('print message');
|
|
62
|
+
expect(mockStderr).toHaveBeenCalledWith('error message\n');
|
|
63
|
+
expect(mockStderr).not.toHaveBeenCalledWith('warning message\n');
|
|
64
|
+
expect(mockStderr).not.toHaveBeenCalledWith('print message\n');
|
|
65
|
+
});
|
|
66
|
+
test('debug messages only show at debug level', () => {
|
|
67
|
+
(0, logging_1.setLogLevel)(logging_1.LogLevel.INFO);
|
|
68
|
+
(0, logging_1.debug)('debug message');
|
|
69
|
+
expect(mockStderr).not.toHaveBeenCalled();
|
|
70
|
+
(0, logging_1.setLogLevel)(logging_1.LogLevel.DEBUG);
|
|
71
|
+
(0, logging_1.debug)('debug message');
|
|
72
|
+
expect(mockStderr).toHaveBeenCalledWith('debug message\n');
|
|
73
|
+
});
|
|
74
|
+
test('trace messages only show at trace level', () => {
|
|
75
|
+
(0, logging_1.setLogLevel)(logging_1.LogLevel.DEBUG);
|
|
76
|
+
(0, logging_1.trace)('trace message');
|
|
77
|
+
expect(mockStderr).not.toHaveBeenCalled();
|
|
78
|
+
(0, logging_1.setLogLevel)(logging_1.LogLevel.TRACE);
|
|
79
|
+
(0, logging_1.trace)('trace message');
|
|
80
|
+
expect(mockStderr).toHaveBeenCalledWith('trace message\n');
|
|
81
|
+
});
|
|
82
|
+
});
|
|
83
|
+
describe('message formatting', () => {
|
|
84
|
+
test('formats messages with multiple arguments', () => {
|
|
85
|
+
(0, logging_1.print)('Value: %d, String: %s', 42, 'test');
|
|
86
|
+
expect(mockStderr).toHaveBeenCalledWith('Value: 42, String: test\n');
|
|
87
|
+
});
|
|
88
|
+
test('handles prefix correctly', () => {
|
|
89
|
+
const prefixedLog = (0, logging_1.prefix)('PREFIX');
|
|
90
|
+
prefixedLog('test message');
|
|
91
|
+
expect(mockStderr).toHaveBeenCalledWith('PREFIX test message\n');
|
|
92
|
+
});
|
|
93
|
+
test('handles custom styles', () => {
|
|
94
|
+
(0, logging_1.success)('success message');
|
|
95
|
+
expect(mockStderr).toHaveBeenCalledWith('success message\n');
|
|
96
|
+
});
|
|
97
|
+
});
|
|
98
|
+
describe('corked logging', () => {
|
|
99
|
+
test('buffers messages when corked', async () => {
|
|
100
|
+
await (0, logging_1.withCorkedLogging)(async () => {
|
|
101
|
+
(0, logging_1.print)('message 1');
|
|
102
|
+
(0, logging_1.print)('message 2');
|
|
103
|
+
expect(mockStderr).not.toHaveBeenCalled();
|
|
104
|
+
});
|
|
105
|
+
expect(mockStderr).toHaveBeenCalledWith('message 1\n');
|
|
106
|
+
expect(mockStderr).toHaveBeenCalledWith('message 2\n');
|
|
107
|
+
});
|
|
108
|
+
test('handles nested corking correctly', async () => {
|
|
109
|
+
await (0, logging_1.withCorkedLogging)(async () => {
|
|
110
|
+
(0, logging_1.print)('outer 1');
|
|
111
|
+
await (0, logging_1.withCorkedLogging)(async () => {
|
|
112
|
+
(0, logging_1.print)('inner');
|
|
113
|
+
});
|
|
114
|
+
(0, logging_1.print)('outer 2');
|
|
115
|
+
expect(mockStderr).not.toHaveBeenCalled();
|
|
116
|
+
});
|
|
117
|
+
expect(mockStderr).toHaveBeenCalledTimes(3);
|
|
118
|
+
expect(mockStderr).toHaveBeenCalledWith('outer 1\n');
|
|
119
|
+
expect(mockStderr).toHaveBeenCalledWith('inner\n');
|
|
120
|
+
expect(mockStderr).toHaveBeenCalledWith('outer 2\n');
|
|
121
|
+
});
|
|
122
|
+
});
|
|
123
|
+
describe('timestamp and prefix handling', () => {
|
|
124
|
+
test('combines timestamp and prefix correctly', () => {
|
|
125
|
+
(0, logging_1.log)({
|
|
126
|
+
level: logging_1.LogLevel.INFO,
|
|
127
|
+
message: 'test message',
|
|
128
|
+
timestamp: true,
|
|
129
|
+
prefix: 'PREFIX',
|
|
130
|
+
});
|
|
131
|
+
expect(mockStderr).toHaveBeenCalledWith(expect.stringMatching(/^PREFIX \[\d{2}:\d{2}:\d{2}\] test message\n$/));
|
|
132
|
+
});
|
|
133
|
+
});
|
|
134
|
+
});
|
|
135
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"cli-logging.test.js","sourceRoot":"","sources":["cli-logging.test.ts"],"names":[],"mappings":"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","sourcesContent":["import { LogLevel, log, setLogLevel, setCI, data, print, error, warning, success, debug, trace, prefix, withCorkedLogging } from '../../../lib/logging';\n\ndescribe('logging', () => {\n  // Mock streams to capture output\n  let mockStdout: jest.Mock;\n  let mockStderr: jest.Mock;\n\n  // Helper function to strip ANSI codes\n  const stripAnsi = (str: string): string => {\n    const ansiRegex = /\\u001b\\[[0-9;]*[a-zA-Z]/g;\n    return str.replace(ansiRegex, '');\n  };\n\n  beforeEach(() => {\n    // Reset log level before each test\n    setLogLevel(LogLevel.INFO);\n    setCI(false);\n\n    // Create mock functions to capture output\n    mockStdout = jest.fn();\n    mockStderr = jest.fn();\n\n    // Mock the write methods directly and strip ANSI codes\n    jest.spyOn(process.stdout, 'write').mockImplementation((chunk: any) => {\n      mockStdout(stripAnsi(chunk.toString()));\n      return true;\n    });\n\n    jest.spyOn(process.stderr, 'write').mockImplementation((chunk: any) => {\n      mockStderr(stripAnsi(chunk.toString()));\n      return true;\n    });\n  });\n\n  afterEach(() => {\n    jest.restoreAllMocks();\n  });\n\n  describe('stream selection', () => {\n    test('data() always writes to stdout', () => {\n      data('test message');\n      expect(mockStdout).toHaveBeenCalledWith('test message\\n');\n      expect(mockStderr).not.toHaveBeenCalled();\n    });\n\n    test('error() always writes to stderr', () => {\n      error('test error');\n      expect(mockStderr).toHaveBeenCalledWith('test error\\n');\n      expect(mockStdout).not.toHaveBeenCalled();\n    });\n\n    test('print() writes to stderr by default', () => {\n      print('test print');\n      expect(mockStderr).toHaveBeenCalledWith('test print\\n');\n      expect(mockStdout).not.toHaveBeenCalled();\n    });\n\n    test('print() writes to stdout in CI mode', () => {\n      setCI(true);\n      print('test print');\n      expect(mockStdout).toHaveBeenCalledWith('test print\\n');\n      expect(mockStderr).not.toHaveBeenCalled();\n    });\n  });\n\n  describe('log levels', () => {\n    test('respects log level settings', () => {\n      setLogLevel(LogLevel.ERROR);\n      error('error message');\n      warning('warning message');\n      print('print message');\n      expect(mockStderr).toHaveBeenCalledWith('error message\\n');\n      expect(mockStderr).not.toHaveBeenCalledWith('warning message\\n');\n      expect(mockStderr).not.toHaveBeenCalledWith('print message\\n');\n    });\n\n    test('debug messages only show at debug level', () => {\n      setLogLevel(LogLevel.INFO);\n      debug('debug message');\n      expect(mockStderr).not.toHaveBeenCalled();\n\n      setLogLevel(LogLevel.DEBUG);\n      debug('debug message');\n      expect(mockStderr).toHaveBeenCalledWith('debug message\\n');\n    });\n\n    test('trace messages only show at trace level', () => {\n      setLogLevel(LogLevel.DEBUG);\n      trace('trace message');\n      expect(mockStderr).not.toHaveBeenCalled();\n\n      setLogLevel(LogLevel.TRACE);\n      trace('trace message');\n      expect(mockStderr).toHaveBeenCalledWith('trace message\\n');\n    });\n  });\n\n  describe('message formatting', () => {\n    test('formats messages with multiple arguments', () => {\n      print('Value: %d, String: %s', 42, 'test');\n      expect(mockStderr).toHaveBeenCalledWith('Value: 42, String: test\\n');\n    });\n\n    test('handles prefix correctly', () => {\n      const prefixedLog = prefix('PREFIX');\n      prefixedLog('test message');\n      expect(mockStderr).toHaveBeenCalledWith('PREFIX test message\\n');\n    });\n\n    test('handles custom styles', () => {\n      success('success message');\n      expect(mockStderr).toHaveBeenCalledWith('success message\\n');\n    });\n  });\n\n  describe('corked logging', () => {\n    test('buffers messages when corked', async () => {\n      await withCorkedLogging(async () => {\n        print('message 1');\n        print('message 2');\n        expect(mockStderr).not.toHaveBeenCalled();\n      });\n\n      expect(mockStderr).toHaveBeenCalledWith('message 1\\n');\n      expect(mockStderr).toHaveBeenCalledWith('message 2\\n');\n    });\n\n    test('handles nested corking correctly', async () => {\n      await withCorkedLogging(async () => {\n        print('outer 1');\n        await withCorkedLogging(async () => {\n          print('inner');\n        });\n        print('outer 2');\n        expect(mockStderr).not.toHaveBeenCalled();\n      });\n\n      expect(mockStderr).toHaveBeenCalledTimes(3);\n      expect(mockStderr).toHaveBeenCalledWith('outer 1\\n');\n      expect(mockStderr).toHaveBeenCalledWith('inner\\n');\n      expect(mockStderr).toHaveBeenCalledWith('outer 2\\n');\n    });\n  });\n\n  describe('timestamp and prefix handling', () => {\n    test('combines timestamp and prefix correctly', () => {\n      log({\n        level: LogLevel.INFO,\n        message: 'test message',\n        timestamp: true,\n        prefix: 'PREFIX',\n      });\n      expect(mockStderr).toHaveBeenCalledWith(\n        expect.stringMatching(/^PREFIX \\[\\d{2}:\\d{2}:\\d{2}\\] test message\\n$/),\n      );\n    });\n  });\n});\n"]}
|
|
@@ -1,17 +1,25 @@
|
|
|
1
1
|
"use strict";
|
|
2
2
|
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
3
|
const client_cloudwatch_logs_1 = require("@aws-sdk/client-cloudwatch-logs");
|
|
4
|
-
const chalk_1 = require("chalk");
|
|
5
4
|
const logs_monitor_1 = require("../../../lib/api/logs/logs-monitor");
|
|
6
5
|
const util_1 = require("../../util");
|
|
7
6
|
const mock_sdk_1 = require("../../util/mock-sdk");
|
|
7
|
+
// Helper function to strip ANSI codes
|
|
8
|
+
const stripAnsi = (str) => {
|
|
9
|
+
const ansiRegex = /\u001b\[[0-9;]*[a-zA-Z]/g;
|
|
10
|
+
return str.replace(ansiRegex, '');
|
|
11
|
+
};
|
|
8
12
|
let sdk;
|
|
9
13
|
let stderrMock;
|
|
10
14
|
let monitor;
|
|
11
15
|
beforeEach(() => {
|
|
12
16
|
monitor = new logs_monitor_1.CloudWatchLogEventMonitor(new Date(T100));
|
|
13
|
-
stderrMock = jest.spyOn(process.stderr, 'write').mockImplementation(() => {
|
|
14
|
-
|
|
17
|
+
stderrMock = jest.spyOn(process.stderr, 'write').mockImplementation((chunk) => {
|
|
18
|
+
// Strip ANSI codes when capturing output
|
|
19
|
+
if (typeof chunk === 'string') {
|
|
20
|
+
return stripAnsi(chunk);
|
|
21
|
+
}
|
|
22
|
+
return stripAnsi(chunk.toString());
|
|
15
23
|
});
|
|
16
24
|
sdk = new mock_sdk_1.MockSdk();
|
|
17
25
|
});
|
|
@@ -37,7 +45,7 @@ test('process events', async () => {
|
|
|
37
45
|
// THEN
|
|
38
46
|
const expectedLocaleTimeString = eventDate.toLocaleTimeString();
|
|
39
47
|
expect(stderrMock).toHaveBeenCalledTimes(1);
|
|
40
|
-
expect(stderrMock.mock.calls[0][0]).toContain(`[
|
|
48
|
+
expect(stripAnsi(stderrMock.mock.calls[0][0])).toContain(`[loggroup] ${expectedLocaleTimeString} message`);
|
|
41
49
|
});
|
|
42
50
|
test('process truncated events', async () => {
|
|
43
51
|
// GIVEN
|
|
@@ -62,8 +70,8 @@ test('process truncated events', async () => {
|
|
|
62
70
|
// THEN
|
|
63
71
|
const expectedLocaleTimeString = eventDate.toLocaleTimeString();
|
|
64
72
|
expect(stderrMock).toHaveBeenCalledTimes(101);
|
|
65
|
-
expect(stderrMock.mock.calls[0][0]).toContain(`[
|
|
66
|
-
expect(stderrMock.mock.calls[100][0]).toContain(`[
|
|
73
|
+
expect(stripAnsi(stderrMock.mock.calls[0][0])).toContain(`[loggroup] ${expectedLocaleTimeString} message0`);
|
|
74
|
+
expect(stripAnsi(stderrMock.mock.calls[100][0])).toContain(`[loggroup] ${expectedLocaleTimeString} >>> \`watch\` shows only the first 100 log messages - the rest have been truncated...`);
|
|
67
75
|
});
|
|
68
76
|
const T0 = 1597837230504;
|
|
69
77
|
const T100 = T0 + 100 * 1000;
|
|
@@ -75,4 +83,4 @@ function event(nr, message, timestamp) {
|
|
|
75
83
|
ingestionTime: timestamp.getTime(),
|
|
76
84
|
};
|
|
77
85
|
}
|
|
78
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
86
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"logs-monitor.test.js","sourceRoot":"","sources":["logs-monitor.test.ts"],"names":[],"mappings":"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","sourcesContent":["import { FilterLogEventsCommand, type FilteredLogEvent } from '@aws-sdk/client-cloudwatch-logs';\nimport { CloudWatchLogEventMonitor } from '../../../lib/api/logs/logs-monitor';\nimport { sleep } from '../../util';\nimport { MockSdk, mockCloudWatchClient } from '../../util/mock-sdk';\n\n// Helper function to strip ANSI codes\nconst stripAnsi = (str: string): string => {\n  const ansiRegex = /\\u001b\\[[0-9;]*[a-zA-Z]/g;\n  return str.replace(ansiRegex, '');\n};\n\nlet sdk: MockSdk;\nlet stderrMock: jest.SpyInstance;\nlet monitor: CloudWatchLogEventMonitor;\nbeforeEach(() => {\n  monitor = new CloudWatchLogEventMonitor(new Date(T100));\n  stderrMock = jest.spyOn(process.stderr, 'write').mockImplementation((chunk: any) => {\n    // Strip ANSI codes when capturing output\n    if (typeof chunk === 'string') {\n      return stripAnsi(chunk) as unknown as boolean;\n    }\n    return stripAnsi(chunk.toString()) as unknown as boolean;\n  });\n  sdk = new MockSdk();\n});\n\nafterEach(() => {\n  stderrMock.mockRestore();\n  monitor.deactivate();\n});\n\ntest('process events', async () => {\n  // GIVEN\n  const eventDate = new Date(T0 + 102 * 1000);\n  mockCloudWatchClient.on(FilterLogEventsCommand).resolves({\n    events: [event(102, 'message', eventDate)],\n  });\n\n  monitor.addLogGroups(\n    {\n      name: 'name',\n      account: '11111111111',\n      region: 'us-east-1',\n    },\n    sdk,\n    ['loggroup'],\n  );\n  // WHEN\n  monitor.activate();\n  // need time for the log processing to occur\n  await sleep(1000);\n\n  // THEN\n  const expectedLocaleTimeString = eventDate.toLocaleTimeString();\n  expect(stderrMock).toHaveBeenCalledTimes(1);\n  expect(stripAnsi(stderrMock.mock.calls[0][0])).toContain(`[loggroup] ${expectedLocaleTimeString} message`);\n});\n\ntest('process truncated events', async () => {\n  // GIVEN\n  const eventDate = new Date(T0 + 102 * 1000);\n  const events: FilteredLogEvent[] = [];\n  for (let i = 0; i < 100; i++) {\n    events.push(event(102 + i, 'message' + i, eventDate));\n  }\n\n  mockCloudWatchClient.on(FilterLogEventsCommand).resolves({\n    events,\n    nextToken: 'some-token',\n  });\n  monitor.addLogGroups(\n    {\n      name: 'name',\n      account: '11111111111',\n      region: 'us-east-1',\n    },\n    sdk,\n    ['loggroup'],\n  );\n  // WHEN\n  monitor.activate();\n  // need time for the log processing to occur\n  await sleep(1000);\n\n  // THEN\n  const expectedLocaleTimeString = eventDate.toLocaleTimeString();\n  expect(stderrMock).toHaveBeenCalledTimes(101);\n  expect(stripAnsi(stderrMock.mock.calls[0][0])).toContain(`[loggroup] ${expectedLocaleTimeString} message0`);\n  expect(stripAnsi(stderrMock.mock.calls[100][0])).toContain(\n    `[loggroup] ${expectedLocaleTimeString} >>> \\`watch\\` shows only the first 100 log messages - the rest have been truncated...`,\n  );\n});\n\nconst T0 = 1597837230504;\nconst T100 = T0 + 100 * 1000;\nfunction event(nr: number, message: string, timestamp: Date): FilteredLogEvent {\n  return {\n    eventId: `${nr}`,\n    message,\n    timestamp: timestamp.getTime(),\n    ingestionTime: timestamp.getTime(),\n  };\n}\n"]}
|
package/test/logging.test.js
DELETED
|
@@ -1,131 +0,0 @@
|
|
|
1
|
-
"use strict";
|
|
2
|
-
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
-
const logging_1 = require("../lib/logging");
|
|
4
|
-
describe('logging', () => {
|
|
5
|
-
// Mock streams to capture output
|
|
6
|
-
let mockStdout;
|
|
7
|
-
let mockStderr;
|
|
8
|
-
beforeEach(() => {
|
|
9
|
-
// Reset log level before each test
|
|
10
|
-
(0, logging_1.setLogLevel)(logging_1.LogLevel.INFO);
|
|
11
|
-
(0, logging_1.setCI)(false);
|
|
12
|
-
// Create mock functions to capture output
|
|
13
|
-
mockStdout = jest.fn();
|
|
14
|
-
mockStderr = jest.fn();
|
|
15
|
-
// Mock the write methods directly
|
|
16
|
-
jest.spyOn(process.stdout, 'write').mockImplementation((chunk) => {
|
|
17
|
-
mockStdout(chunk.toString());
|
|
18
|
-
return true;
|
|
19
|
-
});
|
|
20
|
-
jest.spyOn(process.stderr, 'write').mockImplementation((chunk) => {
|
|
21
|
-
mockStderr(chunk.toString());
|
|
22
|
-
return true;
|
|
23
|
-
});
|
|
24
|
-
});
|
|
25
|
-
afterEach(() => {
|
|
26
|
-
jest.restoreAllMocks();
|
|
27
|
-
});
|
|
28
|
-
describe('stream selection', () => {
|
|
29
|
-
test('data() always writes to stdout', () => {
|
|
30
|
-
(0, logging_1.data)('test message');
|
|
31
|
-
expect(mockStdout).toHaveBeenCalledWith(expect.stringContaining('test message\n'));
|
|
32
|
-
expect(mockStderr).not.toHaveBeenCalled();
|
|
33
|
-
});
|
|
34
|
-
test('error() always writes to stderr', () => {
|
|
35
|
-
(0, logging_1.error)('test error');
|
|
36
|
-
expect(mockStderr).toHaveBeenCalledWith(expect.stringContaining('test error\n'));
|
|
37
|
-
expect(mockStdout).not.toHaveBeenCalled();
|
|
38
|
-
});
|
|
39
|
-
test('print() writes to stderr by default', () => {
|
|
40
|
-
(0, logging_1.print)('test print');
|
|
41
|
-
expect(mockStderr).toHaveBeenCalledWith(expect.stringContaining('test print\n'));
|
|
42
|
-
expect(mockStdout).not.toHaveBeenCalled();
|
|
43
|
-
});
|
|
44
|
-
test('print() writes to stdout in CI mode', () => {
|
|
45
|
-
(0, logging_1.setCI)(true);
|
|
46
|
-
(0, logging_1.print)('test print');
|
|
47
|
-
expect(mockStdout).toHaveBeenCalledWith(expect.stringContaining('test print\n'));
|
|
48
|
-
expect(mockStderr).not.toHaveBeenCalled();
|
|
49
|
-
});
|
|
50
|
-
});
|
|
51
|
-
describe('log levels', () => {
|
|
52
|
-
test('respects log level settings', () => {
|
|
53
|
-
(0, logging_1.setLogLevel)(logging_1.LogLevel.ERROR);
|
|
54
|
-
(0, logging_1.error)('error message');
|
|
55
|
-
(0, logging_1.warning)('warning message');
|
|
56
|
-
(0, logging_1.print)('print message');
|
|
57
|
-
expect(mockStderr).toHaveBeenCalledWith(expect.stringContaining('error message\n'));
|
|
58
|
-
expect(mockStderr).not.toHaveBeenCalledWith(expect.stringContaining('warning message\n'));
|
|
59
|
-
expect(mockStderr).not.toHaveBeenCalledWith(expect.stringContaining('print message\n'));
|
|
60
|
-
});
|
|
61
|
-
test('debug messages only show at debug level', () => {
|
|
62
|
-
(0, logging_1.setLogLevel)(logging_1.LogLevel.INFO);
|
|
63
|
-
(0, logging_1.debug)('debug message');
|
|
64
|
-
expect(mockStderr).not.toHaveBeenCalled();
|
|
65
|
-
(0, logging_1.setLogLevel)(logging_1.LogLevel.DEBUG);
|
|
66
|
-
(0, logging_1.debug)('debug message');
|
|
67
|
-
expect(mockStderr).toHaveBeenCalledWith(expect.stringContaining('debug message\n'));
|
|
68
|
-
});
|
|
69
|
-
test('trace messages only show at trace level', () => {
|
|
70
|
-
(0, logging_1.setLogLevel)(logging_1.LogLevel.DEBUG);
|
|
71
|
-
(0, logging_1.trace)('trace message');
|
|
72
|
-
expect(mockStderr).not.toHaveBeenCalled();
|
|
73
|
-
(0, logging_1.setLogLevel)(logging_1.LogLevel.TRACE);
|
|
74
|
-
(0, logging_1.trace)('trace message');
|
|
75
|
-
expect(mockStderr).toHaveBeenCalledWith(expect.stringContaining('trace message\n'));
|
|
76
|
-
});
|
|
77
|
-
});
|
|
78
|
-
describe('message formatting', () => {
|
|
79
|
-
test('formats messages with multiple arguments', () => {
|
|
80
|
-
(0, logging_1.print)('Value: %d, String: %s', 42, 'test');
|
|
81
|
-
expect(mockStderr).toHaveBeenCalledWith(expect.stringContaining('Value: 42, String: test\n'));
|
|
82
|
-
});
|
|
83
|
-
test('handles prefix correctly', () => {
|
|
84
|
-
const prefixedLog = (0, logging_1.prefix)('PREFIX');
|
|
85
|
-
prefixedLog('test message');
|
|
86
|
-
expect(mockStderr).toHaveBeenCalledWith(expect.stringContaining('PREFIX test message\n'));
|
|
87
|
-
});
|
|
88
|
-
test('handles custom styles', () => {
|
|
89
|
-
(0, logging_1.success)('success message');
|
|
90
|
-
// Note: actual styling will depend on chalk, but we can verify the message is there
|
|
91
|
-
expect(mockStderr).toHaveBeenCalledWith(expect.stringContaining('success message\n'));
|
|
92
|
-
});
|
|
93
|
-
});
|
|
94
|
-
describe('corked logging', () => {
|
|
95
|
-
test('buffers messages when corked', async () => {
|
|
96
|
-
await (0, logging_1.withCorkedLogging)(async () => {
|
|
97
|
-
(0, logging_1.print)('message 1');
|
|
98
|
-
(0, logging_1.print)('message 2');
|
|
99
|
-
expect(mockStderr).not.toHaveBeenCalled();
|
|
100
|
-
});
|
|
101
|
-
expect(mockStderr).toHaveBeenCalledWith(expect.stringContaining('message 1\n'));
|
|
102
|
-
expect(mockStderr).toHaveBeenCalledWith(expect.stringContaining('message 2\n'));
|
|
103
|
-
});
|
|
104
|
-
test('handles nested corking correctly', async () => {
|
|
105
|
-
await (0, logging_1.withCorkedLogging)(async () => {
|
|
106
|
-
(0, logging_1.print)('outer 1');
|
|
107
|
-
await (0, logging_1.withCorkedLogging)(async () => {
|
|
108
|
-
(0, logging_1.print)('inner');
|
|
109
|
-
});
|
|
110
|
-
(0, logging_1.print)('outer 2');
|
|
111
|
-
expect(mockStderr).not.toHaveBeenCalled();
|
|
112
|
-
});
|
|
113
|
-
expect(mockStderr).toHaveBeenCalledTimes(3);
|
|
114
|
-
expect(mockStderr).toHaveBeenCalledWith(expect.stringContaining('outer 1\n'));
|
|
115
|
-
expect(mockStderr).toHaveBeenCalledWith(expect.stringContaining('inner\n'));
|
|
116
|
-
expect(mockStderr).toHaveBeenCalledWith(expect.stringContaining('outer 2\n'));
|
|
117
|
-
});
|
|
118
|
-
});
|
|
119
|
-
describe('timestamp and prefix handling', () => {
|
|
120
|
-
test('combines timestamp and prefix correctly', () => {
|
|
121
|
-
(0, logging_1.log)({
|
|
122
|
-
level: logging_1.LogLevel.INFO,
|
|
123
|
-
message: 'test message',
|
|
124
|
-
timestamp: true,
|
|
125
|
-
prefix: 'PREFIX',
|
|
126
|
-
});
|
|
127
|
-
expect(mockStderr).toHaveBeenCalledWith(expect.stringMatching(/PREFIX \[\d{2}:\d{2}:\d{2}\] test message\n/));
|
|
128
|
-
});
|
|
129
|
-
});
|
|
130
|
-
});
|
|
131
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"logging.test.js","sourceRoot":"","sources":["logging.test.ts"],"names":[],"mappings":"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","sourcesContent":["import { LogLevel, log, setLogLevel, setCI, data, print, error, warning, success, debug, trace, prefix, withCorkedLogging } from '../lib/logging';\n\ndescribe('logging', () => {\n  // Mock streams to capture output\n  let mockStdout: jest.Mock;\n  let mockStderr: jest.Mock;\n\n  beforeEach(() => {\n    // Reset log level before each test\n    setLogLevel(LogLevel.INFO);\n    setCI(false);\n\n    // Create mock functions to capture output\n    mockStdout = jest.fn();\n    mockStderr = jest.fn();\n\n    // Mock the write methods directly\n    jest.spyOn(process.stdout, 'write').mockImplementation((chunk: any) => {\n      mockStdout(chunk.toString());\n      return true;\n    });\n\n    jest.spyOn(process.stderr, 'write').mockImplementation((chunk: any) => {\n      mockStderr(chunk.toString());\n      return true;\n    });\n  });\n\n  afterEach(() => {\n    jest.restoreAllMocks();\n  });\n  describe('stream selection', () => {\n    test('data() always writes to stdout', () => {\n      data('test message');\n      expect(mockStdout).toHaveBeenCalledWith(expect.stringContaining('test message\\n'));\n      expect(mockStderr).not.toHaveBeenCalled();\n    });\n\n    test('error() always writes to stderr', () => {\n      error('test error');\n      expect(mockStderr).toHaveBeenCalledWith(expect.stringContaining('test error\\n'));\n      expect(mockStdout).not.toHaveBeenCalled();\n    });\n\n    test('print() writes to stderr by default', () => {\n      print('test print');\n      expect(mockStderr).toHaveBeenCalledWith(expect.stringContaining('test print\\n'));\n      expect(mockStdout).not.toHaveBeenCalled();\n    });\n\n    test('print() writes to stdout in CI mode', () => {\n      setCI(true);\n      print('test print');\n      expect(mockStdout).toHaveBeenCalledWith(expect.stringContaining('test print\\n'));\n      expect(mockStderr).not.toHaveBeenCalled();\n    });\n  });\n\n  describe('log levels', () => {\n    test('respects log level settings', () => {\n      setLogLevel(LogLevel.ERROR);\n      error('error message');\n      warning('warning message');\n      print('print message');\n      expect(mockStderr).toHaveBeenCalledWith(expect.stringContaining('error message\\n'));\n      expect(mockStderr).not.toHaveBeenCalledWith(expect.stringContaining('warning message\\n'));\n      expect(mockStderr).not.toHaveBeenCalledWith(expect.stringContaining('print message\\n'));\n    });\n\n    test('debug messages only show at debug level', () => {\n      setLogLevel(LogLevel.INFO);\n      debug('debug message');\n      expect(mockStderr).not.toHaveBeenCalled();\n\n      setLogLevel(LogLevel.DEBUG);\n      debug('debug message');\n      expect(mockStderr).toHaveBeenCalledWith(expect.stringContaining('debug message\\n'));\n    });\n\n    test('trace messages only show at trace level', () => {\n      setLogLevel(LogLevel.DEBUG);\n      trace('trace message');\n      expect(mockStderr).not.toHaveBeenCalled();\n\n      setLogLevel(LogLevel.TRACE);\n      trace('trace message');\n      expect(mockStderr).toHaveBeenCalledWith(expect.stringContaining('trace message\\n'));\n    });\n  });\n\n  describe('message formatting', () => {\n    test('formats messages with multiple arguments', () => {\n      print('Value: %d, String: %s', 42, 'test');\n      expect(mockStderr).toHaveBeenCalledWith(expect.stringContaining('Value: 42, String: test\\n'));\n    });\n\n    test('handles prefix correctly', () => {\n      const prefixedLog = prefix('PREFIX');\n      prefixedLog('test message');\n      expect(mockStderr).toHaveBeenCalledWith(expect.stringContaining('PREFIX test message\\n'));\n    });\n\n    test('handles custom styles', () => {\n      success('success message');\n      // Note: actual styling will depend on chalk, but we can verify the message is there\n      expect(mockStderr).toHaveBeenCalledWith(expect.stringContaining('success message\\n'));\n    });\n  });\n\n  describe('corked logging', () => {\n    test('buffers messages when corked', async () => {\n      await withCorkedLogging(async () => {\n        print('message 1');\n        print('message 2');\n        expect(mockStderr).not.toHaveBeenCalled();\n      });\n\n      expect(mockStderr).toHaveBeenCalledWith(expect.stringContaining('message 1\\n'));\n      expect(mockStderr).toHaveBeenCalledWith(expect.stringContaining('message 2\\n'));\n    });\n\n    test('handles nested corking correctly', async () => {\n      await withCorkedLogging(async () => {\n        print('outer 1');\n        await withCorkedLogging(async () => {\n          print('inner');\n        });\n        print('outer 2');\n        expect(mockStderr).not.toHaveBeenCalled();\n      });\n\n      expect(mockStderr).toHaveBeenCalledTimes(3);\n      expect(mockStderr).toHaveBeenCalledWith(expect.stringContaining('outer 1\\n'));\n      expect(mockStderr).toHaveBeenCalledWith(expect.stringContaining('inner\\n'));\n      expect(mockStderr).toHaveBeenCalledWith(expect.stringContaining('outer 2\\n'));\n    });\n  });\n\n  describe('timestamp and prefix handling', () => {\n    test('combines timestamp and prefix correctly', () => {\n      log({\n        level: LogLevel.INFO,\n        message: 'test message',\n        timestamp: true,\n        prefix: 'PREFIX',\n      });\n      expect(mockStderr).toHaveBeenCalledWith(\n        expect.stringMatching(/PREFIX \\[\\d{2}:\\d{2}:\\d{2}\\] test message\\n/),\n      );\n    });\n  });\n});\n"]}
|
|
File without changes
|