cdk-lambda-subminute 2.0.610 → 2.0.612
Sign up to get free protection for your applications and to get access to all the features.
- package/.jsii +3 -3
- package/lib/cdk-lambda-subminute.js +3 -3
- package/node_modules/for-each/.eslintrc +2 -0
- package/node_modules/for-each/CHANGELOG.md +6 -0
- package/node_modules/for-each/index.d.ts +35 -0
- package/node_modules/for-each/index.js +11 -4
- package/node_modules/for-each/package.json +8 -2
- package/node_modules/for-each/test/test.js +53 -10
- package/node_modules/for-each/tsconfig.json +8 -0
- package/package.json +1 -1
package/.jsii
CHANGED
@@ -3941,7 +3941,7 @@
|
|
3941
3941
|
"stability": "stable"
|
3942
3942
|
},
|
3943
3943
|
"homepage": "https://github.com/HsiehShuJeng/cdk-lambda-subminute.git",
|
3944
|
-
"jsiiVersion": "5.4.
|
3944
|
+
"jsiiVersion": "5.4.51 (build 3d3c6ce)",
|
3945
3945
|
"keywords": [
|
3946
3946
|
"aws-cloudwatch-events",
|
3947
3947
|
"aws-lambda",
|
@@ -4411,6 +4411,6 @@
|
|
4411
4411
|
"symbolId": "src/cdk-lambda-subminute:SubminuteStateMachineProps"
|
4412
4412
|
}
|
4413
4413
|
},
|
4414
|
-
"version": "2.0.
|
4415
|
-
"fingerprint": "
|
4414
|
+
"version": "2.0.612",
|
4415
|
+
"fingerprint": "fKRROhFroGMCRy6btkfKECIwbZWXaMbu71hBRbYQuow="
|
4416
4416
|
}
|
@@ -45,7 +45,7 @@ class LambdaSubminute extends constructs_1.Construct {
|
|
45
45
|
}
|
46
46
|
exports.LambdaSubminute = LambdaSubminute;
|
47
47
|
_a = JSII_RTTI_SYMBOL_1;
|
48
|
-
LambdaSubminute[_a] = { fqn: "cdk-lambda-subminute.LambdaSubminute", version: "2.0.
|
48
|
+
LambdaSubminute[_a] = { fqn: "cdk-lambda-subminute.LambdaSubminute", version: "2.0.612" };
|
49
49
|
class IteratorLambda extends constructs_1.Construct {
|
50
50
|
constructor(scope, name, props) {
|
51
51
|
super(scope, name);
|
@@ -85,7 +85,7 @@ class IteratorLambda extends constructs_1.Construct {
|
|
85
85
|
}
|
86
86
|
exports.IteratorLambda = IteratorLambda;
|
87
87
|
_b = JSII_RTTI_SYMBOL_1;
|
88
|
-
IteratorLambda[_b] = { fqn: "cdk-lambda-subminute.IteratorLambda", version: "2.0.
|
88
|
+
IteratorLambda[_b] = { fqn: "cdk-lambda-subminute.IteratorLambda", version: "2.0.612" };
|
89
89
|
class SubminuteStateMachine extends constructs_1.Construct {
|
90
90
|
constructor(scope, id, props) {
|
91
91
|
super(scope, id);
|
@@ -160,5 +160,5 @@ class SubminuteStateMachine extends constructs_1.Construct {
|
|
160
160
|
}
|
161
161
|
exports.SubminuteStateMachine = SubminuteStateMachine;
|
162
162
|
_c = JSII_RTTI_SYMBOL_1;
|
163
|
-
SubminuteStateMachine[_c] = { fqn: "cdk-lambda-subminute.SubminuteStateMachine", version: "2.0.
|
163
|
+
SubminuteStateMachine[_c] = { fqn: "cdk-lambda-subminute.SubminuteStateMachine", version: "2.0.612" };
|
164
164
|
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"cdk-lambda-subminute.js","sourceRoot":"","sources":["../src/cdk-lambda-subminute.ts"],"names":[],"mappings":"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","sourcesContent":["import * as fs from 'fs';\nimport * as path from 'path';\nimport * as cdk from 'aws-cdk-lib';\nimport events = require('aws-cdk-lib/aws-events');\nimport targets = require('aws-cdk-lib/aws-events-targets');\nimport * as iam from 'aws-cdk-lib/aws-iam';\n\nimport { IFunction, Runtime, Tracing } from 'aws-cdk-lib/aws-lambda';\nimport { NodejsFunction } from 'aws-cdk-lib/aws-lambda-nodejs';\nimport { RetentionDays } from 'aws-cdk-lib/aws-logs';\nimport * as sfn from 'aws-cdk-lib/aws-stepfunctions';\nimport * as tasks from 'aws-cdk-lib/aws-stepfunctions-tasks';\nimport { Construct } from 'constructs';\n\nexport interface LambdaSubminuteProps {\n  /**\n   * The Lambda function that is going to be executed per time unit less than one minute.\n   */\n  readonly targetFunction: IFunction;\n  /**\n   * A pattern you want this statemachine to be executed.\n   * @see https://docs.aws.amazon.com/AmazonCloudWatch/latest/events/ScheduledEvents.html\n   *\n   * @default cron(50/1 15-17 ? * * *) UTC+0 being run every minute starting from 15:00 PM to 17:00 PM.\n   */\n  readonly cronjobExpression?: string;\n  /**\n   * How many times you intent to execute in a minute.\n   *\n   * @default 6\n   */\n  readonly frequency?: number;\n  /**\n   * Seconds for an interval, the product of `frequency` and `intervalTime` should be approximagely 1 minute.\n   *\n   * @default 10\n   */\n  readonly intervalTime?: number;\n}\n\nexport class LambdaSubminute extends Construct {\n  /**\n   * The Lambda function that plays the role of the iterator.\n   */\n  readonly iteratorFunction: IFunction;\n  /**\n   * The ARN of the state machine that executes the target Lambda function per time unit less than one minute.\n   */\n  readonly stateMachineArn: string;\n  constructor(parent: Construct, name: string, props: LambdaSubminuteProps) {\n    super(parent, name);\n    const iterator = new IteratorLambda(this, 'IteratorLambda', { targetFunction: props.targetFunction });\n    this.iteratorFunction = iterator.function;\n    const subminuteStateMachine = new SubminuteStateMachine(this, 'SubminuteStateMachine', {\n      stateMachineName: 'lambda-subminute-statemachine',\n      targetFunction: props.targetFunction,\n      iteratorFunction: this.iteratorFunction,\n      intervalTime: props.intervalTime ?? 10,\n      frequency: props.frequency ?? 6,\n    });\n    this.stateMachineArn = subminuteStateMachine.stateMachine.stateMachineArn;\n\n    const startRule = new events.Rule(this, 'StartSubminuteStateMachine', {\n      schedule: events.Schedule.expression(props.cronjobExpression ?? 'cron(50/1 15-17 ? * * *)'),\n      ruleName: 'subminute-statemachine-lambda-rule',\n      description: `A rule to run the subminute state machine, i.e. ${subminuteStateMachine.stateMachine.stateMachineName}`,\n    });\n    startRule.addTarget(new targets.SfnStateMachine(\n      subminuteStateMachine.stateMachine, {\n        input: events.RuleTargetInput.fromObject({\n          iterator: {\n            index: 0,\n            count: 6,\n          },\n        }),\n      }));\n  }\n}\n\nexport interface IteratorLambdaProps {\n  /**\n     * The Lambda function that is going to be executed per time unit less than one minute.\n     */\n  readonly targetFunction: IFunction;\n}\n\nexport class IteratorLambda extends Construct {\n  /**\n     * A Lambda function that plays the role of the iterator.\n     */\n  readonly function: IFunction;\n  constructor(scope: Construct, name: string, props: IteratorLambdaProps) {\n    super(scope, name);\n    const iteratorLambdaRole = new iam.Role(this, 'IteratorLambdaRole', {\n      assumedBy: new iam.CompositePrincipal(\n        new iam.ServicePrincipal('lambda.amazonaws.com'),\n      ),\n      description: 'An execution role for a Lambda function to invoke a target Lambda Function per time unit less than one minute',\n      managedPolicies: [\n        iam.ManagedPolicy.fromAwsManagedPolicyName('service-role/AWSLambdaBasicExecutionRole'),\n        iam.ManagedPolicy.fromAwsManagedPolicyName('AWSXRayDaemonWriteAccess'),\n        iam.ManagedPolicy.fromAwsManagedPolicyName('service-role/AWSLambdaVPCAccessExecutionRole'),\n      ],\n      roleName: 'Lambda-Iterator-Role',\n    });\n    cdk.DockerVolumeConsistency.CONSISTENT;\n\n\n    iteratorLambdaRole.addToPolicy(new iam.PolicyStatement({\n      sid: 'TargetLambdaPermission',\n      effect: iam.Effect.ALLOW,\n      actions: ['lambda:InvokeFunction'],\n      resources: [props.targetFunction.functionArn],\n    }));\n\n    this.function = new NodejsFunction(this, 'Iterator', {\n      functionName: 'lambda-subminute-iterator',\n      description: 'A function for breaking the limit of 1 minute with the CloudWatch Rules.',\n      logRetention: RetentionDays.THREE_MONTHS,\n      runtime: Runtime.NODEJS_18_X,\n      entry: fs.existsSync(path.join(__dirname, 'resources/iterator/iterator_agent.ts')) ? path.join(__dirname, 'resources/iterator/iterator_agent.ts') : path.join(__dirname, 'resources/iterator/iterator_agent.js'),\n      handler: 'lambdaHandler',\n      environment: {\n        TARGET_FN_NAME: props.targetFunction.functionName,\n      },\n      memorySize: 128,\n      role: iteratorLambdaRole,\n      timeout: cdk.Duration.seconds(58), // 1 min\n      tracing: Tracing.ACTIVE,\n    });\n  }\n}\n\nexport interface SubminuteStateMachineProps {\n  /**\n   * the name of the state machine.\n   */\n  readonly stateMachineName: string;\n  /**\n   * the Lambda function that executes your intention.\n   */\n  readonly targetFunction: IFunction;\n  /**\n   * the iterator Lambda function for the target Lambda function.\n   */\n  readonly iteratorFunction: IFunction;\n  /**\n   * Seconds for an interval, the product of `frequency` and `intervalTime` should be approximagely 1 minute.\n   *\n   * @default 10\n   */\n  readonly intervalTime: number;\n  /**\n   * How many times you intent to execute in a minute.\n   *\n   * @default 6\n   */\n  readonly frequency: number;\n}\n\nexport class SubminuteStateMachine extends Construct {\n  readonly stateMachine: sfn.StateMachine;\n  constructor(scope: Construct, id: string, props: SubminuteStateMachineProps) {\n    super(scope, id);\n    const stateMachineRole = this._createWorkFlowRole(\n      props.targetFunction.functionArn, props.iteratorFunction.functionArn);\n    const jobDefinition = this.createJobDefinition(props.iteratorFunction, props.intervalTime, props.frequency);\n    const stateMachine = new sfn.StateMachine(this, 'StateMachine', {\n      stateMachineName: props.stateMachineName,\n      definition: jobDefinition,\n      role: stateMachineRole,\n    });\n    this.stateMachine = stateMachine;\n  }\n\n  /**\n   * Creates a state machine for breaking the limit of 1 minute with the CloudWatch Rules.\n   *\n   * @param iteratorFunction The iterator Lambda function for the target Labmda funciton.\n   * @param intervalTime Seconds for an interval, the product of `frequency` and `intervalTime` should be approximagely 1 minute.\n   * @param frequency How many times you intent to execute in a minute.\n   * @returns THe job definition for the state machine.\n   */\n  private createJobDefinition = (\n    iteratorFunction: IFunction, intervalTime: number, frequency: number): sfn.Chain => {\n    const configureCount = new sfn.Pass(this, 'ConfigureCount', {\n      result: sfn.Result.fromObject({\n        index: 0,\n        count: frequency,\n      }),\n      resultPath: '$.iterator',\n    });\n    const iterator = new tasks.LambdaInvoke(this, 'Iterator', {\n      lambdaFunction: iteratorFunction,\n      resultPath: '$.iterator',\n      resultSelector: {\n        'index.$': '$.Payload.index',\n        'count.$': '$.Payload.count',\n        'continue.$': '$.Payload.continue',\n      },\n    });\n    const wait = new sfn.Wait(this, 'Wait for the target Lambda function finished', {\n      time: sfn.WaitTime.duration(cdk.Duration.seconds(intervalTime)),\n    });\n    wait.next(iterator);\n    const done = new sfn.Pass(this, 'Done');\n\n    const isCountReached = new sfn.Choice(this, 'IsCountReached');\n    isCountReached.when(sfn.Condition.booleanEquals('$.iterator.continue', true), wait);\n    isCountReached.otherwise(done);\n    const jobDefinition = configureCount.next(iterator).next(isCountReached);\n    return jobDefinition;\n  };\n\n  /**\n   * Creates a role and corresponding policies for the subminute state machine.\n   *\n   * @param targetFunctionArn the ARN of the Lambda function that executes your intention.\n   * @param iteratorFunctionArn the ARN of the iterator Lambda function for the target Lambda function.\n   * @returns the role as the documentation indicates.\n   */\n  private _createWorkFlowRole = (targetFunctionArn: string, iteratorFunctionArn: string) => {\n    const workFlowExecutionRole = new iam.Role(this, 'StepFunctionExecutionRole', {\n      assumedBy: new iam.ServicePrincipal('states.amazonaws.com'),\n      description: 'Execute a workflow related to executing a Lambda function per time unit less than 1 minute.',\n    });\n    workFlowExecutionRole.addToPolicy(new iam.PolicyStatement({\n      sid: 'LambdaInvokePermissions',\n      effect: iam.Effect.ALLOW,\n      actions: ['lambda:InvokeFunction'],\n      resources: [\n        targetFunctionArn,\n        iteratorFunctionArn,\n      ],\n    }));\n    return workFlowExecutionRole;\n  };\n}"]}
|
@@ -6,10 +6,12 @@
|
|
6
6
|
"rules": {
|
7
7
|
"eqeqeq": [2, "allow-null"],
|
8
8
|
"func-name-matching": 0,
|
9
|
+
"func-style": 0,
|
9
10
|
"indent": [2, 4],
|
10
11
|
"max-nested-callbacks": [2, 3],
|
11
12
|
"max-params": [2, 3],
|
12
13
|
"max-statements": [2, 14],
|
14
|
+
"no-extra-parens": 0,
|
13
15
|
"no-invalid-this": 1,
|
14
16
|
"no-restricted-syntax": [2, "BreakStatement", "ContinueStatement", "DebuggerStatement", "LabeledStatement", "WithStatement"],
|
15
17
|
},
|
@@ -5,6 +5,12 @@ All notable changes to this project will be documented in this file.
|
|
5
5
|
The format is based on [Keep a Changelog](https://keepachangelog.com/en/1.0.0/)
|
6
6
|
and this project adheres to [Semantic Versioning](https://semver.org/spec/v2.0.0.html).
|
7
7
|
|
8
|
+
## [v0.3.5](https://github.com/ljharb/for-each/compare/v0.3.4...v0.3.5) - 2025-02-10
|
9
|
+
|
10
|
+
### Commits
|
11
|
+
|
12
|
+
- [New] add types [`6483c1e`](https://github.com/ljharb/for-each/commit/6483c1e9b6177e5ca9ba506188300c5a25de26c2)
|
13
|
+
|
8
14
|
## [v0.3.4](https://github.com/ljharb/for-each/compare/v0.3.3...v0.3.4) - 2025-01-24
|
9
15
|
|
10
16
|
### Commits
|
@@ -0,0 +1,35 @@
|
|
1
|
+
declare function forEach<O extends readonly unknown[], This = undefined>(
|
2
|
+
arr: O,
|
3
|
+
callback: (this: This | void, value: O[number], index: number, array: O) => void,
|
4
|
+
thisArg?: This,
|
5
|
+
): void;
|
6
|
+
|
7
|
+
declare function forEach<O extends ArrayLike<unknown>, This = undefined>(
|
8
|
+
arr: O,
|
9
|
+
callback: (this: This | void, value: O[number], index: number, array: O) => void,
|
10
|
+
thisArg?: This,
|
11
|
+
): void;
|
12
|
+
|
13
|
+
declare function forEach<O extends object, This = undefined>(
|
14
|
+
obj: O,
|
15
|
+
callback: (this: This | void, value: O[keyof O], key: keyof O, obj: O) => void,
|
16
|
+
thisArg?: This,
|
17
|
+
): void;
|
18
|
+
|
19
|
+
declare function forEach<O extends string, This = undefined>(
|
20
|
+
str: O,
|
21
|
+
callback: (this: This | void, value: O[number], index: number, str: O) => void,
|
22
|
+
thisArg: This,
|
23
|
+
): void;
|
24
|
+
|
25
|
+
export = forEach;
|
26
|
+
|
27
|
+
declare function forEachInternal<O, C extends (this: This | void, value: unknown, index: PropertyKey, obj: O) => void, This = undefined>(
|
28
|
+
value: O,
|
29
|
+
callback: C,
|
30
|
+
thisArg?: This,
|
31
|
+
): void;
|
32
|
+
|
33
|
+
declare namespace forEach {
|
34
|
+
export type _internal = typeof forEachInternal;
|
35
|
+
}
|
@@ -5,6 +5,7 @@ var isCallable = require('is-callable');
|
|
5
5
|
var toStr = Object.prototype.toString;
|
6
6
|
var hasOwnProperty = Object.prototype.hasOwnProperty;
|
7
7
|
|
8
|
+
/** @type {<This, A extends readonly unknown[]>(arr: A, iterator: (this: This | void, value: A[number], index: number, arr: A) => void, receiver: This | undefined) => void} */
|
8
9
|
var forEachArray = function forEachArray(array, iterator, receiver) {
|
9
10
|
for (var i = 0, len = array.length; i < len; i++) {
|
10
11
|
if (hasOwnProperty.call(array, i)) {
|
@@ -17,6 +18,7 @@ var forEachArray = function forEachArray(array, iterator, receiver) {
|
|
17
18
|
}
|
18
19
|
};
|
19
20
|
|
21
|
+
/** @type {<This, S extends string>(string: S, iterator: (this: This | void, value: S[number], index: number, string: S) => void, receiver: This | undefined) => void} */
|
20
22
|
var forEachString = function forEachString(string, iterator, receiver) {
|
21
23
|
for (var i = 0, len = string.length; i < len; i++) {
|
22
24
|
// no such thing as a sparse string.
|
@@ -28,6 +30,7 @@ var forEachString = function forEachString(string, iterator, receiver) {
|
|
28
30
|
}
|
29
31
|
};
|
30
32
|
|
33
|
+
/** @type {<This, O>(obj: O, iterator: (this: This | void, value: O[keyof O], index: keyof O, obj: O) => void, receiver: This | undefined) => void} */
|
31
34
|
var forEachObject = function forEachObject(object, iterator, receiver) {
|
32
35
|
for (var k in object) {
|
33
36
|
if (hasOwnProperty.call(object, k)) {
|
@@ -40,7 +43,13 @@ var forEachObject = function forEachObject(object, iterator, receiver) {
|
|
40
43
|
}
|
41
44
|
};
|
42
45
|
|
43
|
-
|
46
|
+
/** @type {(x: unknown) => x is readonly unknown[]} */
|
47
|
+
function isArray(x) {
|
48
|
+
return toStr.call(x) === '[object Array]';
|
49
|
+
}
|
50
|
+
|
51
|
+
/** @type {import('.')._internal} */
|
52
|
+
module.exports = function forEach(list, iterator, thisArg) {
|
44
53
|
if (!isCallable(iterator)) {
|
45
54
|
throw new TypeError('iterator must be a function');
|
46
55
|
}
|
@@ -50,7 +59,7 @@ var forEach = function forEach(list, iterator, thisArg) {
|
|
50
59
|
receiver = thisArg;
|
51
60
|
}
|
52
61
|
|
53
|
-
if (
|
62
|
+
if (isArray(list)) {
|
54
63
|
forEachArray(list, iterator, receiver);
|
55
64
|
} else if (typeof list === 'string') {
|
56
65
|
forEachString(list, iterator, receiver);
|
@@ -58,5 +67,3 @@ var forEach = function forEach(list, iterator, thisArg) {
|
|
58
67
|
forEachObject(list, iterator, receiver);
|
59
68
|
}
|
60
69
|
};
|
61
|
-
|
62
|
-
module.exports = forEach;
|
@@ -1,6 +1,6 @@
|
|
1
1
|
{
|
2
2
|
"name": "for-each",
|
3
|
-
"version": "0.3.
|
3
|
+
"version": "0.3.5",
|
4
4
|
"description": "A better forEach",
|
5
5
|
"keywords": [],
|
6
6
|
"author": "Raynos <raynos2@gmail.com>",
|
@@ -34,6 +34,7 @@
|
|
34
34
|
"tests-only": "nyc tape 'test/*.js'",
|
35
35
|
"posttest": "npx npm@\">= 10.2\" audit --production",
|
36
36
|
"lint": "eslint --ext=js,mjs .",
|
37
|
+
"postlint": "tsc && attw -P",
|
37
38
|
"version": "auto-changelog && git add CHANGELOG.md",
|
38
39
|
"postversion": "auto-changelog && git add CHANGELOG.md && git commit --no-edit --amend && git tag -f \"v$(node -e \"console.log(require('./package.json').version)\")\""
|
39
40
|
},
|
@@ -41,12 +42,17 @@
|
|
41
42
|
"is-callable": "^1.2.7"
|
42
43
|
},
|
43
44
|
"devDependencies": {
|
45
|
+
"@arethetypeswrong/cli": "^0.17.3",
|
44
46
|
"@ljharb/eslint-config": "^21.1.1",
|
47
|
+
"@ljharb/tsconfig": "^0.2.3",
|
48
|
+
"@types/is-callable": "^1.1.2",
|
49
|
+
"@types/tape": "^5.8.1",
|
45
50
|
"auto-changelog": "^2.5.0",
|
46
51
|
"eslint": "=8.8.0",
|
47
52
|
"npmignore": "^0.3.1",
|
48
53
|
"nyc": "^10.3.2",
|
49
|
-
"tape": "^5.9.0"
|
54
|
+
"tape": "^5.9.0",
|
55
|
+
"typescript": "next"
|
50
56
|
},
|
51
57
|
"testling": {
|
52
58
|
"files": "test/test.js"
|
@@ -6,6 +6,7 @@ var forEach = require('../');
|
|
6
6
|
test('forEach calls each iterator', function (t) {
|
7
7
|
var count = 0;
|
8
8
|
t.plan(4);
|
9
|
+
|
9
10
|
forEach({ a: 1, b: 2 }, function (value, key) {
|
10
11
|
if (count === 0) {
|
11
12
|
t.equal(value, 1);
|
@@ -29,26 +30,40 @@ test('forEach calls iterator with correct this value', function (t) {
|
|
29
30
|
});
|
30
31
|
|
31
32
|
test('second argument: iterator', function (t) {
|
33
|
+
/** @type {unknown[]} */
|
32
34
|
var arr = [];
|
35
|
+
|
36
|
+
// @ts-expect-error
|
33
37
|
t['throws'](function () { forEach(arr); }, TypeError, 'undefined is not a function');
|
38
|
+
// @ts-expect-error
|
34
39
|
t['throws'](function () { forEach(arr, null); }, TypeError, 'null is not a function');
|
40
|
+
// @ts-expect-error
|
35
41
|
t['throws'](function () { forEach(arr, ''); }, TypeError, 'string is not a function');
|
42
|
+
// @ts-expect-error
|
36
43
|
t['throws'](function () { forEach(arr, /a/); }, TypeError, 'regex is not a function');
|
44
|
+
// @ts-expect-error
|
37
45
|
t['throws'](function () { forEach(arr, true); }, TypeError, 'true is not a function');
|
46
|
+
// @ts-expect-error
|
38
47
|
t['throws'](function () { forEach(arr, false); }, TypeError, 'false is not a function');
|
48
|
+
// @ts-expect-error
|
39
49
|
t['throws'](function () { forEach(arr, NaN); }, TypeError, 'NaN is not a function');
|
50
|
+
// @ts-expect-error
|
40
51
|
t['throws'](function () { forEach(arr, 42); }, TypeError, '42 is not a function');
|
52
|
+
|
41
53
|
t.doesNotThrow(function () { forEach(arr, function () {}); }, 'function is a function');
|
54
|
+
// @ts-expect-error TODO fixme
|
42
55
|
t.doesNotThrow(function () { forEach(arr, setTimeout); }, 'setTimeout is a function');
|
56
|
+
|
43
57
|
/* eslint-env browser */
|
44
58
|
if (typeof window !== 'undefined') {
|
45
59
|
t.doesNotThrow(function () { forEach(arr, window.alert); }, 'alert is a function');
|
46
60
|
}
|
61
|
+
|
47
62
|
t.end();
|
48
63
|
});
|
49
64
|
|
50
65
|
test('array', function (t) {
|
51
|
-
var arr = [1, 2, 3];
|
66
|
+
var arr = /** @type {const} */ ([1, 2, 3]);
|
52
67
|
|
53
68
|
t.test('iterates over every item', function (st) {
|
54
69
|
var index = 0;
|
@@ -60,36 +75,44 @@ test('array', function (t) {
|
|
60
75
|
t.test('first iterator argument', function (st) {
|
61
76
|
var index = 0;
|
62
77
|
st.plan(arr.length);
|
78
|
+
|
63
79
|
forEach(arr, function (item) {
|
64
80
|
st.equal(arr[index], item, 'item ' + index + ' is passed as first argument');
|
65
81
|
index += 1;
|
66
82
|
});
|
83
|
+
|
67
84
|
st.end();
|
68
85
|
});
|
69
86
|
|
70
87
|
t.test('second iterator argument', function (st) {
|
71
88
|
var counter = 0;
|
72
89
|
st.plan(arr.length);
|
73
|
-
|
90
|
+
|
91
|
+
forEach(arr, function (_item, index) {
|
74
92
|
st.equal(counter, index, 'index ' + index + ' is passed as second argument');
|
75
93
|
counter += 1;
|
76
94
|
});
|
95
|
+
|
77
96
|
st.end();
|
78
97
|
});
|
79
98
|
|
80
99
|
t.test('third iterator argument', function (st) {
|
81
100
|
st.plan(arr.length);
|
82
|
-
|
101
|
+
|
102
|
+
forEach(arr, function (_item, _index, array) {
|
83
103
|
st.deepEqual(arr, array, 'array is passed as third argument');
|
84
104
|
});
|
105
|
+
|
85
106
|
st.end();
|
86
107
|
});
|
87
108
|
|
88
109
|
t.test('context argument', function (st) {
|
89
110
|
var context = {};
|
111
|
+
|
90
112
|
forEach([], function () {
|
91
113
|
st.equal(this, context, '"this" is the passed context');
|
92
114
|
}, context);
|
115
|
+
|
93
116
|
st.end();
|
94
117
|
});
|
95
118
|
|
@@ -102,62 +125,77 @@ test('object', function (t) {
|
|
102
125
|
b: 2,
|
103
126
|
c: 3
|
104
127
|
};
|
105
|
-
var keys = ['a', 'b', 'c'];
|
128
|
+
var keys = /** @type {const} */ (['a', 'b', 'c']);
|
106
129
|
|
107
|
-
|
130
|
+
/** @constructor */
|
131
|
+
function F() {
|
108
132
|
this.a = 1;
|
109
133
|
this.b = 2;
|
110
|
-
}
|
134
|
+
}
|
111
135
|
F.prototype.c = 3;
|
112
|
-
var fKeys = ['a', 'b'];
|
136
|
+
var fKeys = /** @type {const} */ (['a', 'b']);
|
113
137
|
|
114
138
|
t.test('iterates over every object literal key', function (st) {
|
115
139
|
var counter = 0;
|
140
|
+
|
116
141
|
forEach(obj, function () { counter += 1; });
|
142
|
+
|
117
143
|
st.equal(counter, keys.length, 'iterated ' + counter + ' times');
|
144
|
+
|
118
145
|
st.end();
|
119
146
|
});
|
120
147
|
|
121
148
|
t.test('iterates only over own keys', function (st) {
|
122
149
|
var counter = 0;
|
150
|
+
|
123
151
|
forEach(new F(), function () { counter += 1; });
|
152
|
+
|
124
153
|
st.equal(counter, fKeys.length, 'iterated ' + fKeys.length + ' times');
|
154
|
+
|
125
155
|
st.end();
|
126
156
|
});
|
127
157
|
|
128
158
|
t.test('first iterator argument', function (st) {
|
129
159
|
var index = 0;
|
130
160
|
st.plan(keys.length);
|
161
|
+
|
131
162
|
forEach(obj, function (item) {
|
132
163
|
st.equal(obj[keys[index]], item, 'item at key ' + keys[index] + ' is passed as first argument');
|
133
164
|
index += 1;
|
134
165
|
});
|
166
|
+
|
135
167
|
st.end();
|
136
168
|
});
|
137
169
|
|
138
170
|
t.test('second iterator argument', function (st) {
|
139
171
|
var counter = 0;
|
140
172
|
st.plan(keys.length);
|
141
|
-
|
173
|
+
|
174
|
+
forEach(obj, function (_item, key) {
|
142
175
|
st.equal(keys[counter], key, 'key ' + key + ' is passed as second argument');
|
143
176
|
counter += 1;
|
144
177
|
});
|
178
|
+
|
145
179
|
st.end();
|
146
180
|
});
|
147
181
|
|
148
182
|
t.test('third iterator argument', function (st) {
|
149
183
|
st.plan(keys.length);
|
150
|
-
|
184
|
+
|
185
|
+
forEach(obj, function (_item, _key, object) {
|
151
186
|
st.deepEqual(obj, object, 'object is passed as third argument');
|
152
187
|
});
|
188
|
+
|
153
189
|
st.end();
|
154
190
|
});
|
155
191
|
|
156
192
|
t.test('context argument', function (st) {
|
157
193
|
var context = {};
|
194
|
+
|
158
195
|
forEach({}, function () {
|
159
196
|
st.equal(this, context, '"this" is the passed context');
|
160
197
|
}, context);
|
198
|
+
|
161
199
|
st.end();
|
162
200
|
});
|
163
201
|
|
@@ -165,17 +203,22 @@ test('object', function (t) {
|
|
165
203
|
});
|
166
204
|
|
167
205
|
test('string', function (t) {
|
168
|
-
var str = 'str';
|
206
|
+
var str = /** @type {const} */ ('str');
|
207
|
+
|
169
208
|
t.test('second iterator argument', function (st) {
|
170
209
|
var counter = 0;
|
171
210
|
st.plan((str.length * 2) + 1);
|
211
|
+
|
172
212
|
forEach(str, function (item, index) {
|
173
213
|
st.equal(counter, index, 'index ' + index + ' is passed as second argument');
|
174
214
|
st.equal(str.charAt(index), item);
|
175
215
|
counter += 1;
|
176
216
|
});
|
217
|
+
|
177
218
|
st.equal(counter, str.length, 'iterates ' + str.length + ' times');
|
219
|
+
|
178
220
|
st.end();
|
179
221
|
});
|
222
|
+
|
180
223
|
t.end();
|
181
224
|
});
|