@gahojin-inc/aws-lambda-mock-context 2026.4.0 → 2026.5.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/dist/index.d.ts +15 -18
- package/dist/index.js +10 -10
- package/dist/index.js.map +1 -1
- package/package.json +10 -12
package/dist/index.d.ts
CHANGED
|
@@ -1,25 +1,22 @@
|
|
|
1
|
-
import { ClientContext, CognitoIdentity, Context } from
|
|
2
|
-
|
|
3
|
-
//#region src/index.d.ts
|
|
1
|
+
import { ClientContext, CognitoIdentity, Context } from 'aws-lambda';
|
|
4
2
|
type Options = {
|
|
5
|
-
|
|
6
|
-
|
|
7
|
-
|
|
8
|
-
|
|
9
|
-
|
|
10
|
-
|
|
11
|
-
|
|
12
|
-
|
|
13
|
-
|
|
14
|
-
|
|
15
|
-
|
|
3
|
+
region?: string;
|
|
4
|
+
account?: string;
|
|
5
|
+
alias?: string;
|
|
6
|
+
functionName?: string;
|
|
7
|
+
functionVersion?: string;
|
|
8
|
+
memoryLimitInMB?: string;
|
|
9
|
+
identity?: CognitoIdentity | undefined;
|
|
10
|
+
clientContext?: ClientContext | undefined;
|
|
11
|
+
tenantId?: string | undefined;
|
|
12
|
+
timeout?: number;
|
|
13
|
+
handleTimeout?: boolean;
|
|
16
14
|
};
|
|
17
15
|
interface MockContext extends Context {
|
|
18
|
-
|
|
16
|
+
Promise: Promise<any>;
|
|
19
17
|
}
|
|
20
18
|
declare const setGlobalOptions: (options: Options) => Options;
|
|
21
19
|
declare const resetGlobalOptions: () => void;
|
|
22
20
|
declare const mockContext: <E = Record<string, any>>(options?: Options, overrides?: E) => MockContext & E;
|
|
23
|
-
|
|
24
|
-
export
|
|
25
|
-
//# sourceMappingURL=index.d.ts.map
|
|
21
|
+
export { resetGlobalOptions, setGlobalOptions };
|
|
22
|
+
export default mockContext;
|
package/dist/index.js
CHANGED
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
import { randomUUID } from "node:crypto";
|
|
2
2
|
//#region src/index.ts
|
|
3
|
-
|
|
3
|
+
var defer = () => {
|
|
4
4
|
const deferred = {};
|
|
5
5
|
const promise = new Promise((resolve, reject) => {
|
|
6
6
|
deferred.resolve = resolve;
|
|
@@ -14,26 +14,26 @@ const defer = () => {
|
|
|
14
14
|
reject: deferred.reject
|
|
15
15
|
};
|
|
16
16
|
};
|
|
17
|
-
|
|
17
|
+
var lambdaTimeout = (context, timeout) => {
|
|
18
18
|
return setTimeout(() => {
|
|
19
|
-
if (Math.round(context.getRemainingTimeInMillis() / 1e3) === 0) context.fail(
|
|
19
|
+
if (Math.round(context.getRemainingTimeInMillis() / 1e3) === 0) context.fail(new Error(`Task timed out after ${timeout}.00 seconds`));
|
|
20
20
|
}, timeout * 1e3);
|
|
21
21
|
};
|
|
22
|
-
|
|
23
|
-
|
|
22
|
+
var globalOptions = {};
|
|
23
|
+
var setGlobalOptions = (options) => {
|
|
24
24
|
Object.assign(globalOptions, options);
|
|
25
25
|
return globalOptions;
|
|
26
26
|
};
|
|
27
|
-
|
|
27
|
+
var resetGlobalOptions = () => {
|
|
28
28
|
globalOptions = {};
|
|
29
29
|
};
|
|
30
|
-
|
|
31
|
-
|
|
30
|
+
var getStrictKeys = (object) => Object.keys(object);
|
|
31
|
+
var removeUndefinedValues = (options) => {
|
|
32
32
|
if (!options) return {};
|
|
33
33
|
for (const key of getStrictKeys(options)) options[key] === void 0 && delete options[key];
|
|
34
34
|
return options;
|
|
35
35
|
};
|
|
36
|
-
|
|
36
|
+
var mockContext = (options, overrides) => {
|
|
37
37
|
const requestId = randomUUID();
|
|
38
38
|
const logStream = requestId.replace(/-/g, "");
|
|
39
39
|
const opts = Object.assign({
|
|
@@ -46,7 +46,7 @@ const mockContext = (options, overrides) => {
|
|
|
46
46
|
handleTimeout: false
|
|
47
47
|
}, removeUndefinedValues(globalOptions), removeUndefinedValues(options));
|
|
48
48
|
const deferred = defer();
|
|
49
|
-
const d =
|
|
49
|
+
const d = new Date();
|
|
50
50
|
const logDate = [
|
|
51
51
|
d.getFullYear(),
|
|
52
52
|
`0${d.getMonth() + 1}`.slice(-2),
|
package/dist/index.js.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"index.js","names":[],"sources":["../src/index.ts"],"sourcesContent":["import { randomUUID } from 'node:crypto'\nimport type { ClientContext, CognitoIdentity, Context } from 'aws-lambda'\n\ntype Options = {\n region?: string\n account?: string\n alias?: string\n functionName?: string\n functionVersion?: string\n memoryLimitInMB?: string\n identity?: CognitoIdentity | undefined\n clientContext?: ClientContext | undefined\n tenantId?: string | undefined\n timeout?: number\n handleTimeout?: boolean\n}\n\ninterface MockContext extends Context {\n Promise: Promise<any>\n}\n\ntype Deferred = {\n promise: Promise<unknown>\n resolve: (value: unknown) => void\n reject: (reason?: any) => void\n}\n\nconst defer = (): Deferred => {\n const deferred: Partial<Deferred> = {}\n const promise = new Promise((resolve, reject) => {\n deferred.resolve = resolve\n deferred.reject = reject\n })\n assert(deferred.resolve)\n assert(deferred.reject)\n return {\n promise,\n resolve: deferred.resolve,\n reject: deferred.reject,\n }\n}\n\nconst lambdaTimeout = (context: MockContext, timeout: number): NodeJS.Timeout => {\n return setTimeout(() => {\n if (Math.round(context.getRemainingTimeInMillis() / 1000) === 0) {\n context.fail(new Error(`Task timed out after ${timeout}.00 seconds`))\n }\n }, timeout * 1000)\n}\n\nlet globalOptions: Options = {}\n\nconst setGlobalOptions = (options: Options): Options => {\n Object.assign(globalOptions, options)\n return globalOptions\n}\n\nconst resetGlobalOptions = (): void => {\n globalOptions = {}\n}\n\nconst getStrictKeys = <T extends Record<string, any>>(object: T): (keyof T)[] => Object.keys(object)\n\nconst removeUndefinedValues = (options?: Options): Options => {\n if (!options) {\n return {}\n }\n for (const key of getStrictKeys(options)) {\n options[key] === undefined && delete options[key]\n }\n return options\n}\n\nconst mockContext = <E = Record<string, any>>(options?: Options, overrides?: E): MockContext & E => {\n const requestId = randomUUID()\n const logStream = requestId.replace(/-/g, '')\n\n const opts = Object.assign(\n {\n region: 'us-west-1',\n account: '123456789012',\n functionName: 'aws-lambda-mock-context',\n functionVersion: '$LATEST',\n memoryLimitInMB: '128',\n timeout: 3,\n handleTimeout: false,\n },\n removeUndefinedValues(globalOptions),\n removeUndefinedValues(options),\n )\n\n const deferred = defer()\n\n const d = new Date()\n const logDate = [d.getFullYear(), `0${d.getMonth() + 1}`.slice(-2), `0${d.getDate()}`.slice(-2)].join('/')\n const start = d.getTime()\n let end: number | null = null\n let timeout: NodeJS.Timeout | null = null\n\n // https://docs.aws.amazon.com/ja_jp/lambda/latest/dg/nodejs-context.html\n const context: MockContext = {\n callbackWaitsForEmptyEventLoop: true,\n functionName: opts.functionName,\n functionVersion: opts.functionVersion,\n invokedFunctionArn: `arn:aws:lambda:${opts.region}:${opts.account}:function:${opts.functionName}:${opts.alias || opts.functionVersion}`,\n memoryLimitInMB: opts.memoryLimitInMB,\n awsRequestId: requestId,\n logGroupName: `/aws/lambda/${opts.functionName}`,\n logStreamName: `${logDate}/[${opts.functionVersion}]/${logStream}`,\n identity: opts.identity,\n clientContext: opts.clientContext,\n tenantId: opts.tenantId,\n getRemainingTimeInMillis: () => {\n const endTime = end || Date.now()\n const remainingTime = opts.timeout * 1000 - (endTime - start)\n\n return Math.max(0, remainingTime)\n },\n succeed: (messageOrObject) => {\n end = Date.now()\n\n deferred.resolve(messageOrObject)\n },\n fail: (error) => {\n end = Date.now()\n\n deferred.reject(typeof error === 'string' ? new Error(error) : error)\n },\n done: (error, result) => {\n if (timeout) {\n clearTimeout(timeout)\n }\n\n if (error) {\n context.fail(error)\n return\n }\n\n context.succeed(result)\n },\n Promise: deferred.promise,\n }\n\n // Lambda Timeout\n if (opts.handleTimeout && opts.timeout > 0) {\n timeout = lambdaTimeout(context, opts.timeout)\n }\n\n return Object.assign(context, overrides)\n}\n\nexport { resetGlobalOptions, setGlobalOptions }\nexport default mockContext\n"],"mappings":";;AA2BA,
|
|
1
|
+
{"version":3,"file":"index.js","names":[],"sources":["../src/index.ts"],"sourcesContent":["import { randomUUID } from 'node:crypto'\nimport type { ClientContext, CognitoIdentity, Context } from 'aws-lambda'\n\ntype Options = {\n region?: string\n account?: string\n alias?: string\n functionName?: string\n functionVersion?: string\n memoryLimitInMB?: string\n identity?: CognitoIdentity | undefined\n clientContext?: ClientContext | undefined\n tenantId?: string | undefined\n timeout?: number\n handleTimeout?: boolean\n}\n\ninterface MockContext extends Context {\n Promise: Promise<any>\n}\n\ntype Deferred = {\n promise: Promise<unknown>\n resolve: (value: unknown) => void\n reject: (reason?: any) => void\n}\n\nconst defer = (): Deferred => {\n const deferred: Partial<Deferred> = {}\n const promise = new Promise((resolve, reject) => {\n deferred.resolve = resolve\n deferred.reject = reject\n })\n assert(deferred.resolve)\n assert(deferred.reject)\n return {\n promise,\n resolve: deferred.resolve,\n reject: deferred.reject,\n }\n}\n\nconst lambdaTimeout = (context: MockContext, timeout: number): NodeJS.Timeout => {\n return setTimeout(() => {\n if (Math.round(context.getRemainingTimeInMillis() / 1000) === 0) {\n context.fail(new Error(`Task timed out after ${timeout}.00 seconds`))\n }\n }, timeout * 1000)\n}\n\nlet globalOptions: Options = {}\n\nconst setGlobalOptions = (options: Options): Options => {\n Object.assign(globalOptions, options)\n return globalOptions\n}\n\nconst resetGlobalOptions = (): void => {\n globalOptions = {}\n}\n\nconst getStrictKeys = <T extends Record<string, any>>(object: T): (keyof T)[] => Object.keys(object)\n\nconst removeUndefinedValues = (options?: Options): Options => {\n if (!options) {\n return {}\n }\n for (const key of getStrictKeys(options)) {\n options[key] === undefined && delete options[key]\n }\n return options\n}\n\nconst mockContext = <E = Record<string, any>>(options?: Options, overrides?: E): MockContext & E => {\n const requestId = randomUUID()\n const logStream = requestId.replace(/-/g, '')\n\n const opts = Object.assign(\n {\n region: 'us-west-1',\n account: '123456789012',\n functionName: 'aws-lambda-mock-context',\n functionVersion: '$LATEST',\n memoryLimitInMB: '128',\n timeout: 3,\n handleTimeout: false,\n },\n removeUndefinedValues(globalOptions),\n removeUndefinedValues(options),\n )\n\n const deferred = defer()\n\n const d = new Date()\n const logDate = [d.getFullYear(), `0${d.getMonth() + 1}`.slice(-2), `0${d.getDate()}`.slice(-2)].join('/')\n const start = d.getTime()\n let end: number | null = null\n let timeout: NodeJS.Timeout | null = null\n\n // https://docs.aws.amazon.com/ja_jp/lambda/latest/dg/nodejs-context.html\n const context: MockContext = {\n callbackWaitsForEmptyEventLoop: true,\n functionName: opts.functionName,\n functionVersion: opts.functionVersion,\n invokedFunctionArn: `arn:aws:lambda:${opts.region}:${opts.account}:function:${opts.functionName}:${opts.alias || opts.functionVersion}`,\n memoryLimitInMB: opts.memoryLimitInMB,\n awsRequestId: requestId,\n logGroupName: `/aws/lambda/${opts.functionName}`,\n logStreamName: `${logDate}/[${opts.functionVersion}]/${logStream}`,\n identity: opts.identity,\n clientContext: opts.clientContext,\n tenantId: opts.tenantId,\n getRemainingTimeInMillis: () => {\n const endTime = end || Date.now()\n const remainingTime = opts.timeout * 1000 - (endTime - start)\n\n return Math.max(0, remainingTime)\n },\n succeed: (messageOrObject) => {\n end = Date.now()\n\n deferred.resolve(messageOrObject)\n },\n fail: (error) => {\n end = Date.now()\n\n deferred.reject(typeof error === 'string' ? new Error(error) : error)\n },\n done: (error, result) => {\n if (timeout) {\n clearTimeout(timeout)\n }\n\n if (error) {\n context.fail(error)\n return\n }\n\n context.succeed(result)\n },\n Promise: deferred.promise,\n }\n\n // Lambda Timeout\n if (opts.handleTimeout && opts.timeout > 0) {\n timeout = lambdaTimeout(context, opts.timeout)\n }\n\n return Object.assign(context, overrides)\n}\n\nexport { resetGlobalOptions, setGlobalOptions }\nexport default mockContext\n"],"mappings":";;AA2BA,IAAM,cAAwB;CAC5B,MAAM,WAA8B,EAAE;CACtC,MAAM,UAAU,IAAI,SAAS,SAAS,WAAW;AAC/C,WAAS,UAAU;AACnB,WAAS,SAAS;GAClB;AACF,QAAO,SAAS,QAAQ;AACxB,QAAO,SAAS,OAAO;AACvB,QAAO;EACL;EACA,SAAS,SAAS;EAClB,QAAQ,SAAS;EAClB;;AAGH,IAAM,iBAAiB,SAAsB,YAAoC;AAC/E,QAAO,iBAAiB;AACtB,MAAI,KAAK,MAAM,QAAQ,0BAA0B,GAAG,IAAK,KAAK,EAC5D,SAAQ,KAAK,IAAI,MAAM,wBAAwB,QAAQ,aAAa,CAAC;IAEtE,UAAU,IAAK;;AAGpB,IAAI,gBAAyB,EAAE;AAE/B,IAAM,oBAAoB,YAA8B;AACtD,QAAO,OAAO,eAAe,QAAQ;AACrC,QAAO;;AAGT,IAAM,2BAAiC;AACrC,iBAAgB,EAAE;;AAGpB,IAAM,iBAAgD,WAA2B,OAAO,KAAK,OAAO;AAEpG,IAAM,yBAAyB,YAA+B;AAC5D,KAAI,CAAC,QACH,QAAO,EAAE;AAEX,MAAK,MAAM,OAAO,cAAc,QAAQ,CACtC,SAAQ,SAAS,KAAA,KAAa,OAAO,QAAQ;AAE/C,QAAO;;AAGT,IAAM,eAAwC,SAAmB,cAAmC;CAClG,MAAM,YAAY,YAAY;CAC9B,MAAM,YAAY,UAAU,QAAQ,MAAM,GAAG;CAE7C,MAAM,OAAO,OAAO,OAClB;EACE,QAAQ;EACR,SAAS;EACT,cAAc;EACd,iBAAiB;EACjB,iBAAiB;EACjB,SAAS;EACT,eAAe;EAChB,EACD,sBAAsB,cAAc,EACpC,sBAAsB,QAAQ,CAC/B;CAED,MAAM,WAAW,OAAO;CAExB,MAAM,IAAI,IAAI,MAAM;CACpB,MAAM,UAAU;EAAC,EAAE,aAAa;EAAE,IAAI,EAAE,UAAU,GAAG,IAAI,MAAM,GAAG;EAAE,IAAI,EAAE,SAAS,GAAG,MAAM,GAAG;EAAC,CAAC,KAAK,IAAI;CAC1G,MAAM,QAAQ,EAAE,SAAS;CACzB,IAAI,MAAqB;CACzB,IAAI,UAAiC;CAGrC,MAAM,UAAuB;EAC3B,gCAAgC;EAChC,cAAc,KAAK;EACnB,iBAAiB,KAAK;EACtB,oBAAoB,kBAAkB,KAAK,OAAO,GAAG,KAAK,QAAQ,YAAY,KAAK,aAAa,GAAG,KAAK,SAAS,KAAK;EACtH,iBAAiB,KAAK;EACtB,cAAc;EACd,cAAc,eAAe,KAAK;EAClC,eAAe,GAAG,QAAQ,IAAI,KAAK,gBAAgB,IAAI;EACvD,UAAU,KAAK;EACf,eAAe,KAAK;EACpB,UAAU,KAAK;EACf,gCAAgC;GAC9B,MAAM,UAAU,OAAO,KAAK,KAAK;GACjC,MAAM,gBAAgB,KAAK,UAAU,OAAQ,UAAU;AAEvD,UAAO,KAAK,IAAI,GAAG,cAAc;;EAEnC,UAAU,oBAAoB;AAC5B,SAAM,KAAK,KAAK;AAEhB,YAAS,QAAQ,gBAAgB;;EAEnC,OAAO,UAAU;AACf,SAAM,KAAK,KAAK;AAEhB,YAAS,OAAO,OAAO,UAAU,WAAW,IAAI,MAAM,MAAM,GAAG,MAAM;;EAEvE,OAAO,OAAO,WAAW;AACvB,OAAI,QACF,cAAa,QAAQ;AAGvB,OAAI,OAAO;AACT,YAAQ,KAAK,MAAM;AACnB;;AAGF,WAAQ,QAAQ,OAAO;;EAEzB,SAAS,SAAS;EACnB;AAGD,KAAI,KAAK,iBAAiB,KAAK,UAAU,EACvC,WAAU,cAAc,SAAS,KAAK,QAAQ;AAGhD,QAAO,OAAO,OAAO,SAAS,UAAU"}
|
package/package.json
CHANGED
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
{
|
|
2
2
|
"name": "@gahojin-inc/aws-lambda-mock-context",
|
|
3
|
-
"version": "2026.
|
|
3
|
+
"version": "2026.5.0",
|
|
4
4
|
"description": "AWS Lambda mock context object",
|
|
5
5
|
"author": "GAHOJIN, Inc.",
|
|
6
6
|
"license": "Apache-2.0",
|
|
@@ -36,22 +36,20 @@
|
|
|
36
36
|
},
|
|
37
37
|
"devDependencies": {
|
|
38
38
|
"@arethetypeswrong/cli": "0.18.2",
|
|
39
|
-
"@biomejs/biome": "2.4.
|
|
39
|
+
"@biomejs/biome": "2.4.13",
|
|
40
40
|
"@types/aws-lambda": "8.10.161",
|
|
41
|
-
"@types/node": "24.12.
|
|
42
|
-
"@
|
|
43
|
-
"@vitest/coverage-v8": "4.1.2",
|
|
41
|
+
"@types/node": "24.12.2",
|
|
42
|
+
"@vitest/coverage-v8": "4.1.5",
|
|
44
43
|
"jest-extended": "7.0.0",
|
|
45
|
-
"
|
|
46
|
-
"
|
|
47
|
-
"vite": "8.0.
|
|
48
|
-
"
|
|
49
|
-
"vitest": "4.1.2"
|
|
44
|
+
"typescript": "6.0.3",
|
|
45
|
+
"unplugin-dts": "1.0.0",
|
|
46
|
+
"vite": "8.0.10",
|
|
47
|
+
"vitest": "4.1.5"
|
|
50
48
|
},
|
|
51
49
|
"scripts": {
|
|
52
|
-
"build": "
|
|
50
|
+
"build": "vite build",
|
|
53
51
|
"lint": "biome check --write .",
|
|
54
|
-
"check": "
|
|
52
|
+
"check": "tsc",
|
|
55
53
|
"check:packagejson": "attw --pack --profile esm-only .",
|
|
56
54
|
"test": "vitest --watch",
|
|
57
55
|
"test:unit": "vitest --passWithNoTests --run --coverage",
|