cdk-lambda-subminute 2.0.545 → 2.0.547

Sign up to get free protection for your applications and to get access to all the features.
package/.jsii CHANGED
@@ -3889,7 +3889,7 @@
3889
3889
  "stability": "stable"
3890
3890
  },
3891
3891
  "homepage": "https://github.com/HsiehShuJeng/cdk-lambda-subminute.git",
3892
- "jsiiVersion": "5.4.43 (build 160ec70)",
3892
+ "jsiiVersion": "5.4.44 (build 419233e)",
3893
3893
  "keywords": [
3894
3894
  "aws-cloudwatch-events",
3895
3895
  "aws-lambda",
@@ -4359,6 +4359,6 @@
4359
4359
  "symbolId": "src/cdk-lambda-subminute:SubminuteStateMachineProps"
4360
4360
  }
4361
4361
  },
4362
- "version": "2.0.545",
4363
- "fingerprint": "rkbae0jSKM2gozPANTjkn78Qgdvss8vn176j/9ry4OE="
4362
+ "version": "2.0.547",
4363
+ "fingerprint": "Lsq5TGOePwA7ayQntYK/fmr3JcQIFmm+EEV9Os9EAA0="
4364
4364
  }
@@ -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.545" };
48
+ LambdaSubminute[_a] = { fqn: "cdk-lambda-subminute.LambdaSubminute", version: "2.0.547" };
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.545" };
88
+ IteratorLambda[_b] = { fqn: "cdk-lambda-subminute.IteratorLambda", version: "2.0.547" };
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.545" };
163
+ SubminuteStateMachine[_c] = { fqn: "cdk-lambda-subminute.SubminuteStateMachine", version: "2.0.547" };
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}"]}
@@ -5,6 +5,20 @@ 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
+ ## [v1.1.0](https://github.com/inspect-js/has-proto/compare/v1.0.3...v1.1.0) - 2024-12-01
9
+
10
+ ### Commits
11
+
12
+ - [New] add `accessor` and `mutator` endpoints [`144f6a9`](https://github.com/inspect-js/has-proto/commit/144f6a9c2a3925f25058d5d5ea7eab3be57767d9)
13
+ - [types] use shared config [`8b597cf`](https://github.com/inspect-js/has-proto/commit/8b597cff2b09f0351bc357cac0e0c7b0c8bb7e70)
14
+ - [Refactor] cache result at module level [`88418bd`](https://github.com/inspect-js/has-proto/commit/88418bde7e0c37c7d9aa6cc79150e774004c01d8)
15
+ - [Dev Deps] update `@ljharb/eslint-config`, `auto-changelog`, `tape` [`d246200`](https://github.com/inspect-js/has-proto/commit/d246200bae6ceceebb495df7f8eb0f27a017b63f)
16
+ - [Deps] update `gopd`, `reflect.getprototypeof` [`6f72364`](https://github.com/inspect-js/has-proto/commit/6f723645da9b5bef0aaae4a1aa66c07a1fed179f)
17
+ - [Tests] add `@arethetypeswrong/cli` [`8194e1a`](https://github.com/inspect-js/has-proto/commit/8194e1a607233f63c5bd0b91112c0423b3296ac9)
18
+ - [Tests] replace `aud` with `npm audit` [`fd7ad11`](https://github.com/inspect-js/has-proto/commit/fd7ad111dc35488b3200a763204dba0f6087defc)
19
+ - [Dev Deps] update `@types/tape` [`2695808`](https://github.com/inspect-js/has-proto/commit/26958086aec0b1cbfdddd4f10e54d2de1facf85c)
20
+ - [Dev Deps] add missing peer dep [`fa4b2f7`](https://github.com/inspect-js/has-proto/commit/fa4b2f77f7c0071e1c06b5590c9bada8e6b2edce)
21
+
8
22
  ## [v1.0.3](https://github.com/inspect-js/has-proto/compare/v1.0.2...v1.0.3) - 2024-02-19
9
23
 
10
24
  ### Commits
@@ -16,6 +16,25 @@ var hasProto = require('has-proto');
16
16
  var assert = require('assert');
17
17
 
18
18
  assert.equal(typeof hasProto(), 'boolean');
19
+
20
+ var hasProtoAccessor = require('has-proto/accessor')();
21
+ if (hasProtoAccessor) {
22
+ assert.equal([].__proto__, Array.prototype);
23
+ } else {
24
+ assert(!('__proto__' in Object.prototype));
25
+ }
26
+
27
+ var hasProtoMutator = require('has-proto/mutator');
28
+ var obj = {};
29
+ assert('toString' in obj);
30
+
31
+ obj.__proto__ = null;
32
+ if (hasProtoMutator) {
33
+ assert(!('toString' in obj));
34
+ } else {
35
+ assert('toString' in obj);
36
+ assert.equal(obj.__proto__, null);
37
+ }
19
38
  ```
20
39
 
21
40
  ## Tests
@@ -0,0 +1,3 @@
1
+ declare function accessor(): boolean;
2
+
3
+ export = accessor;
@@ -0,0 +1,20 @@
1
+ 'use strict';
2
+
3
+ var result = require('./')();
4
+
5
+ var test = {
6
+ __proto__: null,
7
+ foo: {}
8
+ };
9
+
10
+ /** @type {import('./accessor')} */
11
+ module.exports = function hasAccessor() {
12
+ /* eslint no-proto: 0 */
13
+ return result
14
+ && !('toString' in test)
15
+ // eslint-disable-next-line no-extra-parens
16
+ && /** @type {{ __proto__?: typeof Object.prototype }} */ ({}).__proto__ === Object.prototype
17
+ // eslint-disable-next-line no-extra-parens
18
+ && /** @type {ReadonlyArray<never> & { __proto__?: typeof Array.prototype }} */ (
19
+ []).__proto__ === Array.prototype;
20
+ };
@@ -0,0 +1,12 @@
1
+ 'use strict';
2
+
3
+ var callBind = require('call-bind');
4
+ var gOPD = require('gopd');
5
+
6
+ // eslint-disable-next-line no-extra-parens, no-proto
7
+ var hasProto = /** @type {{ __proto__?: typeof Array.prototype }} */ ([]).__proto__ === Array.prototype;
8
+
9
+ // eslint-disable-next-line no-extra-parens
10
+ var dunderGetter = hasProto && gOPD && gOPD(Object.prototype, /** @type {keyof typeof Object.prototype} */ ('__proto__'));
11
+
12
+ module.exports = dunderGetter && dunderGetter.get && callBind(dunderGetter.get);
@@ -0,0 +1,9 @@
1
+ 'use strict';
2
+
3
+ var callBind = require('call-bind');
4
+ var gOPD = require('gopd');
5
+
6
+ // @ts-expect-error TS can't handle dunder proto
7
+ var desc = gOPD && gOPD(Object.prototype, '__proto__');
8
+
9
+ module.exports = !!desc && !!desc.set && callBind(desc.set);
@@ -1,3 +1,3 @@
1
1
  declare function hasProto(): boolean;
2
2
 
3
- export = hasProto;
3
+ export = hasProto;
@@ -5,11 +5,11 @@ var test = {
5
5
  foo: {}
6
6
  };
7
7
 
8
- var $Object = Object;
8
+ // @ts-expect-error: TS errors on an inherited property for some reason
9
+ var result = { __proto__: test }.foo === test.foo
10
+ && !(test instanceof Object);
9
11
 
10
12
  /** @type {import('.')} */
11
13
  module.exports = function hasProto() {
12
- // @ts-expect-error: TS errors on an inherited property for some reason
13
- return { __proto__: test }.foo === test.foo
14
- && !(test instanceof $Object);
14
+ return result;
15
15
  };
@@ -0,0 +1,3 @@
1
+ declare function mutator(): boolean;
2
+
3
+ export = mutator;
@@ -0,0 +1,33 @@
1
+ 'use strict';
2
+
3
+ var result = require('./')();
4
+
5
+ var test = {
6
+ __proto__: null,
7
+ foo: {}
8
+ };
9
+
10
+ var setter = require('./helpers/setDunder');
11
+
12
+ /** @type {import('./mutator')} */
13
+ module.exports = function hasMutator() {
14
+ if (!result) {
15
+ return false;
16
+ }
17
+
18
+ var obj = { __proto__: test };
19
+ // @ts-expect-error: TS errors on an inherited property for some reason
20
+ if (obj.foo !== test.foo) {
21
+ return false;
22
+ }
23
+
24
+ if (!setter) {
25
+ return false;
26
+ }
27
+
28
+ setter(obj, null);
29
+ if ('foo' in obj || 'toString' in obj) {
30
+ return false;
31
+ }
32
+ return true;
33
+ };
@@ -1,10 +1,12 @@
1
1
  {
2
2
  "name": "has-proto",
3
- "version": "1.0.3",
3
+ "version": "1.1.0",
4
4
  "description": "Does this environment have the ability to get the [[Prototype]] of an object on creation with `__proto__`?",
5
5
  "main": "index.js",
6
6
  "exports": {
7
7
  ".": "./index.js",
8
+ "./accessor": "./accessor.js",
9
+ "./mutator": "./mutator.js",
8
10
  "./package.json": "./package.json"
9
11
  },
10
12
  "sideEffects": false,
@@ -12,12 +14,13 @@
12
14
  "prepack": "npmignore --auto --commentLines=autogenerated",
13
15
  "prepublishOnly": "safe-publish-latest",
14
16
  "prepublish": "not-in-publish || npm run prepublishOnly",
17
+ "prelint": "evalmd README.md",
15
18
  "lint": "eslint --ext=js,mjs .",
16
- "postlint": "tsc -p .",
19
+ "postlint": "tsc -p . && attw -P",
17
20
  "pretest": "npm run lint",
18
21
  "tests-only": "tape 'test/**/*.js'",
19
22
  "test": "npm run tests-only",
20
- "posttest": "aud --production",
23
+ "posttest": "npx npm@'>=10.2' audit --production",
21
24
  "version": "auto-changelog && git add CHANGELOG.md",
22
25
  "postversion": "auto-changelog && git add CHANGELOG.md && git commit --no-edit --amend && git tag -f \"v$(node -e \"console.log(require('./package.json').version)\")\""
23
26
  },
@@ -48,15 +51,22 @@
48
51
  "files": "test/index.js"
49
52
  },
50
53
  "devDependencies": {
51
- "@ljharb/eslint-config": "^21.1.0",
52
- "@types/tape": "^5.6.4",
53
- "aud": "^2.0.4",
54
- "auto-changelog": "^2.4.0",
54
+ "@arethetypeswrong/cli": "^0.17.0",
55
+ "@ljharb/eslint-config": "^21.1.1",
56
+ "@ljharb/tsconfig": "^0.2.0",
57
+ "@types/call-bind": "^1.0.5",
58
+ "@types/gopd": "^1.0.3",
59
+ "@types/tape": "^5.6.5",
60
+ "auto-changelog": "^2.5.0",
61
+ "encoding": "^0.1.13",
55
62
  "eslint": "=8.8.0",
63
+ "evalmd": "^0.0.19",
64
+ "gopd": "^1.1.0",
56
65
  "in-publish": "^2.0.1",
57
66
  "npmignore": "^0.3.1",
67
+ "reflect.getprototypeof": "^1.0.7",
58
68
  "safe-publish-latest": "^2.0.0",
59
- "tape": "^5.7.5",
69
+ "tape": "^5.9.0",
60
70
  "typescript": "next"
61
71
  },
62
72
  "engines": {
@@ -72,7 +82,11 @@
72
82
  },
73
83
  "publishConfig": {
74
84
  "ignore": [
75
- ".github/workflows"
85
+ ".github/workflows",
86
+ "types"
76
87
  ]
88
+ },
89
+ "dependencies": {
90
+ "call-bind": "^1.0.7"
77
91
  }
78
92
  }
@@ -0,0 +1,34 @@
1
+ 'use strict';
2
+
3
+ var test = require('tape');
4
+ var gPO = require('reflect.getprototypeof/polyfill')();
5
+ var gOPD = require('gopd');
6
+
7
+ var hasProto = require('../');
8
+ var hasProtoAccessor = require('../accessor');
9
+
10
+ var getter = require('../helpers/getDunder');
11
+
12
+ test('hasProtoAccessor', function (t) {
13
+ var result = hasProtoAccessor();
14
+ t.equal(typeof result, 'boolean', 'returns a boolean (' + result + ')');
15
+
16
+ var obj = { __proto__: null };
17
+ if (result) {
18
+ t.notOk('toString' in obj, 'null object lacks toString');
19
+ t.equal(gPO(obj), null);
20
+ if (gOPD && getter) {
21
+ t.equal(getter(obj), null);
22
+ }
23
+ } else if (hasProto()) {
24
+ t.notOk('toString' in obj, 'null object lacks toString');
25
+ if (gOPD && getter) {
26
+ t.equal(getter(obj), null);
27
+ }
28
+ } else {
29
+ t.ok('toString' in obj, 'without proto, null object has toString');
30
+ t.equal(gPO(obj), Object.prototype);
31
+ }
32
+
33
+ t.end();
34
+ });
@@ -1,8 +1,13 @@
1
1
  'use strict';
2
2
 
3
3
  var test = require('tape');
4
+ var gPO = require('reflect.getprototypeof/polyfill')();
5
+ var gOPD = require('gopd');
6
+
4
7
  var hasProto = require('../');
5
8
 
9
+ var getter = require('../helpers/getDunder');
10
+
6
11
  test('hasProto', function (t) {
7
12
  var result = hasProto();
8
13
  t.equal(typeof result, 'boolean', 'returns a boolean (' + result + ')');
@@ -10,10 +15,14 @@ test('hasProto', function (t) {
10
15
  var obj = { __proto__: null };
11
16
  if (result) {
12
17
  t.notOk('toString' in obj, 'null object lacks toString');
18
+ if (gOPD && getter) {
19
+ t.equal(getter(obj), null);
20
+ }
13
21
  } else {
14
22
  t.ok('toString' in obj, 'without proto, null object has toString');
15
- t.equal(obj.__proto__, null); // eslint-disable-line no-proto
23
+ t.equal(gPO(obj), Object.prototype);
16
24
  }
17
25
 
18
26
  t.end();
19
27
  });
28
+
@@ -0,0 +1,34 @@
1
+ 'use strict';
2
+
3
+ var test = require('tape');
4
+ var gPO = require('reflect.getprototypeof/polyfill')();
5
+ var gOPD = require('gopd');
6
+
7
+ var hasProto = require('../');
8
+ var hasProtoMutator = require('../mutator');
9
+
10
+ var getter = require('../helpers/getDunder');
11
+
12
+ test('hasProtoMutator', function (t) {
13
+ var result = hasProtoMutator();
14
+ t.equal(typeof result, 'boolean', 'returns a boolean (' + result + ')');
15
+
16
+ var obj = { __proto__: null };
17
+ if (result) {
18
+ t.notOk('toString' in obj, 'null object lacks toString');
19
+ t.equal(gPO(obj), null);
20
+ if (gOPD && getter) {
21
+ t.equal(getter(obj), null);
22
+ }
23
+ } else if (hasProto()) {
24
+ t.notOk('toString' in obj, 'null object lacks toString');
25
+ if (gOPD && getter) {
26
+ t.equal(getter(obj), null);
27
+ }
28
+ } else {
29
+ t.ok('toString' in obj, 'without proto, null object has toString');
30
+ t.equal(gPO(obj), Object.prototype);
31
+ }
32
+
33
+ t.end();
34
+ });
@@ -1,49 +1,11 @@
1
1
  {
2
- "compilerOptions": {
3
- /* Visit https://aka.ms/tsconfig to read more about this file */
4
-
5
- /* Projects */
6
-
7
- /* Language and Environment */
8
- "target": "ESNext", /* Set the JavaScript language version for emitted JavaScript and include compatible library declarations. */
9
- // "lib": [], /* Specify a set of bundled library declaration files that describe the target runtime environment. */
10
- // "noLib": true, /* Disable including any library files, including the default lib.d.ts. */
11
- "useDefineForClassFields": true, /* Emit ECMAScript-standard-compliant class fields. */
12
- // "moduleDetection": "auto", /* Control what method is used to detect module-format JS files. */
13
-
14
- /* Modules */
15
- "module": "commonjs", /* Specify what module code is generated. */
16
- // "rootDir": "./", /* Specify the root folder within your source files. */
17
- // "moduleResolution": "node10", /* Specify how TypeScript looks up a file from a given module specifier. */
18
- // "baseUrl": "./", /* Specify the base directory to resolve non-relative module names. */
19
- // "paths": {}, /* Specify a set of entries that re-map imports to additional lookup locations. */
20
- // "rootDirs": [], /* Allow multiple folders to be treated as one when resolving modules. */
21
- "typeRoots": ["types"], /* Specify multiple folders that act like './node_modules/@types'. */
22
- "resolveJsonModule": true, /* Enable importing .json files. */
23
- // "allowArbitraryExtensions": true, /* Enable importing files with any extension, provided a declaration file is present. */
24
-
25
- /* JavaScript Support */
26
- "allowJs": true, /* Allow JavaScript files to be a part of your program. Use the 'checkJS' option to get errors from these files. */
27
- "checkJs": true, /* Enable error reporting in type-checked JavaScript files. */
28
- "maxNodeModuleJsDepth": 0, /* Specify the maximum folder depth used for checking JavaScript files from 'node_modules'. Only applicable with 'allowJs'. */
29
-
30
- /* Emit */
31
- "declaration": true, /* Generate .d.ts files from TypeScript and JavaScript files in your project. */
32
- "declarationMap": true, /* Create sourcemaps for d.ts files. */
33
- "noEmit": true, /* Disable emitting files from a compilation. */
34
-
35
- /* Interop Constraints */
36
- "allowSyntheticDefaultImports": true, /* Allow 'import x from y' when a module doesn't have a default export. */
37
- "esModuleInterop": true, /* Emit additional JavaScript to ease support for importing CommonJS modules. This enables 'allowSyntheticDefaultImports' for type compatibility. */
38
- "forceConsistentCasingInFileNames": true, /* Ensure that casing is correct in imports. */
39
-
40
- /* Type Checking */
41
- "strict": true, /* Enable all strict type-checking options. */
42
-
43
- /* Completeness */
44
- //"skipLibCheck": true /* Skip type checking all .d.ts files. */
45
- },
46
- "exclude": [
47
- "coverage"
48
- ]
2
+ "extends": "@ljharb/tsconfig",
3
+ "exclude": [
4
+ "coverage",
5
+ ],
6
+ "compilerOptions": {
7
+ "typeRoots": [
8
+ "types",
9
+ ],
10
+ },
49
11
  }
@@ -5,6 +5,22 @@ 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
+ ## [v1.1.0](https://github.com/inspect-js/has-symbols/compare/v1.0.3...v1.1.0) - 2024-12-02
9
+
10
+ ### Commits
11
+
12
+ - [actions] update workflows [`548c0bf`](https://github.com/inspect-js/has-symbols/commit/548c0bf8c9b1235458df7a1c0490b0064647a282)
13
+ - [actions] further shard; update action deps [`bec56bb`](https://github.com/inspect-js/has-symbols/commit/bec56bb0fb44b43a786686b944875a3175cf3ff3)
14
+ - [meta] use `npmignore` to autogenerate an npmignore file [`ac81032`](https://github.com/inspect-js/has-symbols/commit/ac81032809157e0a079e5264e9ce9b6f1275777e)
15
+ - [New] add types [`6469cbf`](https://github.com/inspect-js/has-symbols/commit/6469cbff1866cfe367b2b3d181d9296ec14b2a3d)
16
+ - [actions] update rebase action to use reusable workflow [`9c9d4d0`](https://github.com/inspect-js/has-symbols/commit/9c9d4d0d8938e4b267acdf8e421f4e92d1716d72)
17
+ - [Dev Deps] update `eslint`, `@ljharb/eslint-config`, `aud`, `tape` [`adb5887`](https://github.com/inspect-js/has-symbols/commit/adb5887ca9444849b08beb5caaa9e1d42320cdfb)
18
+ - [Dev Deps] update `@ljharb/eslint-config`, `aud`, `tape` [`13ec198`](https://github.com/inspect-js/has-symbols/commit/13ec198ec80f1993a87710af1606a1970b22c7cb)
19
+ - [Dev Deps] update `auto-changelog`, `core-js`, `tape` [`941be52`](https://github.com/inspect-js/has-symbols/commit/941be5248387cab1da72509b22acf3fdb223f057)
20
+ - [Tests] replace `aud` with `npm audit` [`74f49e9`](https://github.com/inspect-js/has-symbols/commit/74f49e9a9d17a443020784234a1c53ce765b3559)
21
+ - [Dev Deps] update `npmignore` [`9c0ac04`](https://github.com/inspect-js/has-symbols/commit/9c0ac0452a834f4c2a4b54044f2d6a89f17e9a70)
22
+ - [Dev Deps] add missing peer dep [`52337a5`](https://github.com/inspect-js/has-symbols/commit/52337a5621cced61f846f2afdab7707a8132cc12)
23
+
8
24
  ## [v1.0.3](https://github.com/inspect-js/has-symbols/compare/v1.0.2...v1.0.3) - 2022-03-01
9
25
 
10
26
  ### Commits
@@ -0,0 +1,3 @@
1
+ declare function hasNativeSymbols(): boolean;
2
+
3
+ export = hasNativeSymbols;
@@ -3,6 +3,7 @@
3
3
  var origSymbol = typeof Symbol !== 'undefined' && Symbol;
4
4
  var hasSymbolSham = require('./shams');
5
5
 
6
+ /** @type {import('.')} */
6
7
  module.exports = function hasNativeSymbols() {
7
8
  if (typeof origSymbol !== 'function') { return false; }
8
9
  if (typeof Symbol !== 'function') { return false; }
@@ -1,21 +1,23 @@
1
1
  {
2
2
  "name": "has-symbols",
3
- "version": "1.0.3",
3
+ "version": "1.1.0",
4
4
  "description": "Determine if the JS environment has Symbol support. Supports spec, or shams.",
5
5
  "main": "index.js",
6
6
  "scripts": {
7
+ "prepack": "npmignore --auto --commentLines=autogenerated",
7
8
  "prepublishOnly": "safe-publish-latest",
8
9
  "prepublish": "not-in-publish || npm run prepublishOnly",
9
10
  "pretest": "npm run --silent lint",
10
11
  "test": "npm run tests-only",
11
- "posttest": "aud --production",
12
- "tests-only": "npm run test:stock && npm run test:staging && npm run test:shams",
12
+ "posttest": "npx npm@'>=10.2' audit --production",
13
+ "tests-only": "npm run test:stock && npm run test:shams",
13
14
  "test:stock": "nyc node test",
14
15
  "test:staging": "nyc node --harmony --es-staging test",
15
16
  "test:shams": "npm run --silent test:shams:getownpropertysymbols && npm run --silent test:shams:corejs",
16
17
  "test:shams:corejs": "nyc node test/shams/core-js.js",
17
18
  "test:shams:getownpropertysymbols": "nyc node test/shams/get-own-property-symbols.js",
18
19
  "lint": "eslint --ext=js,mjs .",
20
+ "postlint": "tsc -p . && attw -P",
19
21
  "version": "auto-changelog && git add CHANGELOG.md",
20
22
  "postversion": "auto-changelog && git add CHANGELOG.md && git commit --no-edit --amend && git tag -f \"v$(node -e \"console.log(require('./package.json').version)\")\""
21
23
  },
@@ -54,15 +56,22 @@
54
56
  },
55
57
  "homepage": "https://github.com/ljharb/has-symbols#readme",
56
58
  "devDependencies": {
57
- "@ljharb/eslint-config": "^20.2.3",
58
- "aud": "^2.0.0",
59
- "auto-changelog": "^2.4.0",
59
+ "@arethetypeswrong/cli": "^0.17.0",
60
+ "@ljharb/eslint-config": "^21.1.1",
61
+ "@ljharb/tsconfig": "^0.2.0",
62
+ "@types/core-js": "^2.5.8",
63
+ "@types/tape": "^5.6.5",
64
+ "auto-changelog": "^2.5.0",
60
65
  "core-js": "^2.6.12",
66
+ "encoding": "^0.1.13",
61
67
  "eslint": "=8.8.0",
62
68
  "get-own-property-symbols": "^0.9.5",
69
+ "in-publish": "^2.0.1",
70
+ "npmignore": "^0.3.1",
63
71
  "nyc": "^10.3.2",
64
72
  "safe-publish-latest": "^2.0.0",
65
- "tape": "^5.5.2"
73
+ "tape": "^5.9.0",
74
+ "typescript": "next"
66
75
  },
67
76
  "testling": {
68
77
  "files": "test/index.js",
@@ -93,9 +102,10 @@
93
102
  "backfillLimit": false,
94
103
  "hideCredit": true
95
104
  },
96
- "greenkeeper": {
105
+ "publishConfig": {
97
106
  "ignore": [
98
- "core-js"
107
+ ".github/workflows",
108
+ "types"
99
109
  ]
100
110
  }
101
111
  }
@@ -0,0 +1,3 @@
1
+ declare function hasSymbolShams(): boolean;
2
+
3
+ export = hasSymbolShams;
@@ -1,10 +1,12 @@
1
1
  'use strict';
2
2
 
3
+ /** @type {import('./shams')} */
3
4
  /* eslint complexity: [2, 18], max-statements: [2, 33] */
4
5
  module.exports = function hasSymbols() {
5
6
  if (typeof Symbol !== 'function' || typeof Object.getOwnPropertySymbols !== 'function') { return false; }
6
7
  if (typeof Symbol.iterator === 'symbol') { return true; }
7
8
 
9
+ /** @type {{ [k in symbol]?: unknown }} */
8
10
  var obj = {};
9
11
  var sym = Symbol('test');
10
12
  var symObj = Object(sym);
@@ -23,7 +25,7 @@ module.exports = function hasSymbols() {
23
25
 
24
26
  var symVal = 42;
25
27
  obj[sym] = symVal;
26
- for (sym in obj) { return false; } // eslint-disable-line no-restricted-syntax, no-unreachable-loop
28
+ for (var _ in obj) { return false; } // eslint-disable-line no-restricted-syntax, no-unreachable-loop
27
29
  if (typeof Object.keys === 'function' && Object.keys(obj).length !== 0) { return false; }
28
30
 
29
31
  if (typeof Object.getOwnPropertyNames === 'function' && Object.getOwnPropertyNames(obj).length !== 0) { return false; }
@@ -34,7 +36,8 @@ module.exports = function hasSymbols() {
34
36
  if (!Object.prototype.propertyIsEnumerable.call(obj, sym)) { return false; }
35
37
 
36
38
  if (typeof Object.getOwnPropertyDescriptor === 'function') {
37
- var descriptor = Object.getOwnPropertyDescriptor(obj, sym);
39
+ // eslint-disable-next-line no-extra-parens
40
+ var descriptor = /** @type {PropertyDescriptor} */ (Object.getOwnPropertyDescriptor(obj, sym));
38
41
  if (descriptor.value !== symVal || descriptor.enumerable !== true) { return false; }
39
42
  }
40
43
 
@@ -8,6 +8,7 @@ if (typeof Symbol === 'function' && typeof Symbol() === 'symbol') {
8
8
  t.equal(typeof Symbol(), 'symbol');
9
9
  t.end();
10
10
  });
11
+ // @ts-expect-error TS is stupid and doesn't know about top level return
11
12
  return;
12
13
  }
13
14
 
@@ -8,6 +8,7 @@ if (typeof Symbol === 'function' && typeof Symbol() === 'symbol') {
8
8
  t.equal(typeof Symbol(), 'symbol');
9
9
  t.end();
10
10
  });
11
+ // @ts-expect-error TS is stupid and doesn't know about top level return
11
12
  return;
12
13
  }
13
14
 
@@ -1,5 +1,6 @@
1
1
  'use strict';
2
2
 
3
+ /** @type {(t: import('tape').Test) => false | void} */
3
4
  // eslint-disable-next-line consistent-return
4
5
  module.exports = function runSymbolTests(t) {
5
6
  t.equal(typeof Symbol, 'function', 'global Symbol is a function');
@@ -31,6 +32,7 @@ module.exports = function runSymbolTests(t) {
31
32
 
32
33
  t.equal(typeof Object.getOwnPropertySymbols, 'function', 'Object.getOwnPropertySymbols is a function');
33
34
 
35
+ /** @type {{ [k in symbol]?: unknown }} */
34
36
  var obj = {};
35
37
  var sym = Symbol('test');
36
38
  var symObj = Object(sym);
@@ -40,8 +42,8 @@ module.exports = function runSymbolTests(t) {
40
42
 
41
43
  var symVal = 42;
42
44
  obj[sym] = symVal;
43
- // eslint-disable-next-line no-restricted-syntax
44
- for (sym in obj) { t.fail('symbol property key was found in for..in of object'); }
45
+ // eslint-disable-next-line no-restricted-syntax, no-unused-vars
46
+ for (var _ in obj) { t.fail('symbol property key was found in for..in of object'); }
45
47
 
46
48
  t.deepEqual(Object.keys(obj), [], 'no enumerable own keys on symbol-valued object');
47
49
  t.deepEqual(Object.getOwnPropertyNames(obj), [], 'no own names on symbol-valued object');
@@ -0,0 +1,10 @@
1
+ {
2
+ "extends": "@ljharb/tsconfig",
3
+ "compilerOptions": {
4
+ "target": "ES2021",
5
+ "maxNodeModuleJsDepth": 0,
6
+ },
7
+ "exclude": [
8
+ "coverage"
9
+ ]
10
+ }
package/package.json CHANGED
@@ -57,7 +57,7 @@
57
57
  "jsii-docgen": "^10.5.0",
58
58
  "jsii-pacmak": "^1.105.0",
59
59
  "jsii-rosetta": "5.4.x",
60
- "projen": "^0.90.5",
60
+ "projen": "^0.90.6",
61
61
  "source-map-support": "^0.5.21",
62
62
  "ts-jest": "^27",
63
63
  "typescript": "^4.9.5"
@@ -91,7 +91,7 @@
91
91
  "publishConfig": {
92
92
  "access": "public"
93
93
  },
94
- "version": "2.0.545",
94
+ "version": "2.0.547",
95
95
  "jest": {
96
96
  "coverageProvider": "v8",
97
97
  "testMatch": [