@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 CHANGED
@@ -1,25 +1,22 @@
1
- import { ClientContext, CognitoIdentity, Context } from "aws-lambda";
2
-
3
- //#region src/index.d.ts
1
+ import { ClientContext, CognitoIdentity, Context } from 'aws-lambda';
4
2
  type Options = {
5
- region?: string;
6
- account?: string;
7
- alias?: string;
8
- functionName?: string;
9
- functionVersion?: string;
10
- memoryLimitInMB?: string;
11
- identity?: CognitoIdentity | undefined;
12
- clientContext?: ClientContext | undefined;
13
- tenantId?: string | undefined;
14
- timeout?: number;
15
- handleTimeout?: boolean;
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
- Promise: Promise<any>;
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
- //#endregion
24
- export { mockContext as default, resetGlobalOptions, setGlobalOptions };
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
- const defer = () => {
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
- const lambdaTimeout = (context, timeout) => {
17
+ var lambdaTimeout = (context, timeout) => {
18
18
  return setTimeout(() => {
19
- if (Math.round(context.getRemainingTimeInMillis() / 1e3) === 0) context.fail(/* @__PURE__ */ new Error(`Task timed out after ${timeout}.00 seconds`));
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
- let globalOptions = {};
23
- const setGlobalOptions = (options) => {
22
+ var globalOptions = {};
23
+ var setGlobalOptions = (options) => {
24
24
  Object.assign(globalOptions, options);
25
25
  return globalOptions;
26
26
  };
27
- const resetGlobalOptions = () => {
27
+ var resetGlobalOptions = () => {
28
28
  globalOptions = {};
29
29
  };
30
- const getStrictKeys = (object) => Object.keys(object);
31
- const removeUndefinedValues = (options) => {
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
- const mockContext = (options, overrides) => {
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 = /* @__PURE__ */ new Date();
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,MAAM,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,MAAM,iBAAiB,SAAsB,YAAoC;AAC/E,QAAO,iBAAiB;AACtB,MAAI,KAAK,MAAM,QAAQ,0BAA0B,GAAG,IAAK,KAAK,EAC5D,SAAQ,qBAAK,IAAI,MAAM,wBAAwB,QAAQ,aAAa,CAAC;IAEtE,UAAU,IAAK;;AAGpB,IAAI,gBAAyB,EAAE;AAE/B,MAAM,oBAAoB,YAA8B;AACtD,QAAO,OAAO,eAAe,QAAQ;AACrC,QAAO;;AAGT,MAAM,2BAAiC;AACrC,iBAAgB,EAAE;;AAGpB,MAAM,iBAAgD,WAA2B,OAAO,KAAK,OAAO;AAEpG,MAAM,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,MAAM,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,oBAAI,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"}
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.4.0",
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.9",
39
+ "@biomejs/biome": "2.4.13",
40
40
  "@types/aws-lambda": "8.10.161",
41
- "@types/node": "24.12.0",
42
- "@typescript/native-preview": "7.0.0-dev.20260324.1",
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
- "rolldown": "1.0.0-rc.12",
46
- "rolldown-plugin-dts": "0.23.2",
47
- "vite": "8.0.3",
48
- "vite-tsconfig-paths": "6.1.1",
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": "rolldown -c",
50
+ "build": "vite build",
53
51
  "lint": "biome check --write .",
54
- "check": "tsgo",
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",