reqon-dsl 0.2.0 → 0.4.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/CHANGELOG.md +7 -0
- package/README.md +45 -3
- package/dist/ast/nodes.d.ts +91 -4
- package/dist/ast/nodes.js +14 -0
- package/dist/auth/circuit-breaker.d.ts +11 -0
- package/dist/auth/circuit-breaker.js +90 -18
- package/dist/auth/credentials.d.ts +6 -1
- package/dist/auth/credentials.js +12 -4
- package/dist/auth/oauth2-provider.js +13 -3
- package/dist/auth/rate-limiter.d.ts +12 -1
- package/dist/auth/rate-limiter.js +39 -26
- package/dist/auth/token-store.js +8 -1
- package/dist/cli.d.ts +24 -1
- package/dist/cli.js +149 -10
- package/dist/config/constants.d.ts +152 -0
- package/dist/config/constants.js +139 -0
- package/dist/config/index.d.ts +4 -0
- package/dist/config/index.js +4 -0
- package/dist/control/index.d.ts +2 -0
- package/dist/control/index.js +1 -0
- package/dist/control/server.d.ts +105 -0
- package/dist/control/server.js +315 -0
- package/dist/control/types.d.ts +61 -0
- package/dist/control/types.js +7 -0
- package/dist/debug/cli-debugger.d.ts +17 -0
- package/dist/debug/cli-debugger.js +185 -0
- package/dist/debug/controller.d.ts +94 -0
- package/dist/debug/controller.js +45 -0
- package/dist/debug/index.d.ts +6 -0
- package/dist/debug/index.js +5 -0
- package/dist/errors/index.d.ts +67 -0
- package/dist/errors/index.js +89 -1
- package/dist/execution/index.d.ts +1 -1
- package/dist/execution/state.d.ts +24 -0
- package/dist/execution/store.js +2 -2
- package/dist/execution-log/events.d.ts +125 -0
- package/dist/execution-log/events.js +17 -0
- package/dist/execution-log/fold.d.ts +38 -0
- package/dist/execution-log/fold.js +54 -0
- package/dist/execution-log/index.d.ts +18 -0
- package/dist/execution-log/index.js +6 -0
- package/dist/execution-log/postgres-store.d.ts +36 -0
- package/dist/execution-log/postgres-store.js +108 -0
- package/dist/execution-log/resume.d.ts +11 -0
- package/dist/execution-log/resume.js +5 -0
- package/dist/execution-log/sqlite-store.d.ts +16 -0
- package/dist/execution-log/sqlite-store.js +101 -0
- package/dist/execution-log/store.d.ts +72 -0
- package/dist/execution-log/store.js +182 -0
- package/dist/index.d.ts +23 -2
- package/dist/index.js +35 -3
- package/dist/interpreter/context.d.ts +29 -0
- package/dist/interpreter/context.js +18 -0
- package/dist/interpreter/evaluator.d.ts +63 -1
- package/dist/interpreter/evaluator.js +219 -42
- package/dist/interpreter/executor.d.ts +132 -14
- package/dist/interpreter/executor.js +883 -178
- package/dist/interpreter/fetch-handler.d.ts +48 -1
- package/dist/interpreter/fetch-handler.js +216 -38
- package/dist/interpreter/http.d.ts +34 -0
- package/dist/interpreter/http.js +203 -28
- package/dist/interpreter/index.d.ts +5 -3
- package/dist/interpreter/index.js +4 -2
- package/dist/interpreter/pagination.d.ts +12 -3
- package/dist/interpreter/pagination.js +102 -32
- package/dist/interpreter/signals.d.ts +8 -0
- package/dist/interpreter/signals.js +12 -0
- package/dist/interpreter/source-manager.d.ts +75 -0
- package/dist/interpreter/source-manager.js +157 -0
- package/dist/interpreter/step-handlers/apply-handler.d.ts +29 -0
- package/dist/interpreter/step-handlers/apply-handler.js +79 -0
- package/dist/interpreter/step-handlers/for-handler.d.ts +16 -0
- package/dist/interpreter/step-handlers/for-handler.js +89 -7
- package/dist/interpreter/step-handlers/index.d.ts +4 -2
- package/dist/interpreter/step-handlers/index.js +4 -2
- package/dist/interpreter/step-handlers/match-handler.d.ts +9 -0
- package/dist/interpreter/step-handlers/match-handler.js +47 -17
- package/dist/interpreter/step-handlers/pause-handler.d.ts +52 -0
- package/dist/interpreter/step-handlers/pause-handler.js +87 -0
- package/dist/interpreter/step-handlers/store-handler.d.ts +17 -1
- package/dist/interpreter/step-handlers/store-handler.js +61 -20
- package/dist/interpreter/step-handlers/types.d.ts +3 -0
- package/dist/interpreter/step-handlers/validate-handler.d.ts +2 -1
- package/dist/interpreter/step-handlers/validate-handler.js +7 -2
- package/dist/interpreter/step-handlers/webhook-handler.d.ts +4 -0
- package/dist/interpreter/step-handlers/webhook-handler.js +31 -5
- package/dist/interpreter/store-manager.d.ts +46 -0
- package/dist/interpreter/store-manager.js +70 -0
- package/dist/lexer/index.d.ts +11 -4
- package/dist/lexer/index.js +11 -4
- package/dist/lexer/tokens.d.ts +17 -1
- package/dist/lexer/tokens.js +36 -0
- package/dist/loader/index.js +5 -8
- package/dist/mcp/index.d.ts +11 -0
- package/dist/mcp/index.js +11 -0
- package/dist/mcp/sandbox.d.ts +41 -0
- package/dist/mcp/sandbox.js +76 -0
- package/dist/mcp/server.d.ts +17 -0
- package/dist/mcp/server.js +504 -0
- package/dist/oas/index.d.ts +2 -0
- package/dist/oas/index.js +1 -0
- package/dist/oas/loader.d.ts +13 -1
- package/dist/oas/loader.js +25 -3
- package/dist/oas/mock-generator.d.ts +12 -0
- package/dist/oas/mock-generator.js +196 -0
- package/dist/oas/validator.js +45 -5
- package/dist/observability/events.d.ts +248 -0
- package/dist/observability/events.js +85 -0
- package/dist/observability/index.d.ts +15 -0
- package/dist/observability/index.js +12 -0
- package/dist/observability/logger.d.ts +106 -0
- package/dist/observability/logger.js +266 -0
- package/dist/observability/otel.d.ts +143 -0
- package/dist/observability/otel.js +421 -0
- package/dist/parser/action-parser.d.ts +105 -0
- package/dist/parser/action-parser.js +645 -0
- package/dist/parser/base.d.ts +7 -0
- package/dist/parser/base.js +11 -0
- package/dist/parser/expressions.d.ts +14 -0
- package/dist/parser/expressions.js +89 -6
- package/dist/parser/fetch-parser.d.ts +27 -0
- package/dist/parser/fetch-parser.js +280 -0
- package/dist/parser/index.d.ts +17 -0
- package/dist/parser/index.js +17 -0
- package/dist/parser/parser.d.ts +44 -46
- package/dist/parser/parser.js +122 -1070
- package/dist/parser/pipeline-parser.d.ts +12 -0
- package/dist/parser/pipeline-parser.js +52 -0
- package/dist/parser/schedule-parser.d.ts +7 -0
- package/dist/parser/schedule-parser.js +137 -0
- package/dist/parser/source-parser.d.ts +9 -0
- package/dist/parser/source-parser.js +151 -0
- package/dist/pause/index.d.ts +15 -0
- package/dist/pause/index.js +12 -0
- package/dist/pause/log-store.d.ts +33 -0
- package/dist/pause/log-store.js +98 -0
- package/dist/pause/manager.d.ts +130 -0
- package/dist/pause/manager.js +294 -0
- package/dist/pause/state.d.ts +93 -0
- package/dist/pause/state.js +103 -0
- package/dist/pause/store.d.ts +61 -0
- package/dist/pause/store.js +158 -0
- package/dist/plugin.d.ts +9 -12
- package/dist/plugin.js +10 -13
- package/dist/scheduler/cron-parser.d.ts +10 -3
- package/dist/scheduler/cron-parser.js +227 -48
- package/dist/scheduler/scheduler.js +56 -22
- package/dist/stores/factory.d.ts +7 -1
- package/dist/stores/factory.js +14 -3
- package/dist/stores/file.d.ts +26 -0
- package/dist/stores/file.js +67 -21
- package/dist/stores/index.d.ts +16 -1
- package/dist/stores/index.js +16 -1
- package/dist/stores/memory.d.ts +4 -0
- package/dist/stores/memory.js +8 -6
- package/dist/stores/postgrest.d.ts +28 -0
- package/dist/stores/postgrest.js +84 -37
- package/dist/stores/types.d.ts +17 -0
- package/dist/stores/types.js +12 -0
- package/dist/sync/index.d.ts +3 -2
- package/dist/sync/index.js +2 -1
- package/dist/sync/log-store.d.ts +30 -0
- package/dist/sync/log-store.js +45 -0
- package/dist/sync/store.js +1 -1
- package/dist/trace/index.d.ts +18 -0
- package/dist/trace/index.js +13 -0
- package/dist/trace/log-view.d.ts +57 -0
- package/dist/trace/log-view.js +76 -0
- package/dist/trace/recorder.d.ts +75 -0
- package/dist/trace/recorder.js +157 -0
- package/dist/trace/replay.d.ts +132 -0
- package/dist/trace/replay.js +264 -0
- package/dist/trace/state.d.ts +102 -0
- package/dist/trace/state.js +86 -0
- package/dist/trace/store.d.ts +75 -0
- package/dist/trace/store.js +250 -0
- package/dist/utils/deep-merge.d.ts +10 -0
- package/dist/utils/deep-merge.js +23 -0
- package/dist/utils/file.d.ts +13 -4
- package/dist/utils/file.js +70 -12
- package/dist/utils/index.d.ts +2 -1
- package/dist/utils/index.js +2 -1
- package/dist/utils/long-timeout.d.ts +19 -0
- package/dist/utils/long-timeout.js +33 -0
- package/dist/utils/path.d.ts +22 -1
- package/dist/utils/path.js +46 -1
- package/dist/utils/redact.d.ts +22 -0
- package/dist/utils/redact.js +42 -0
- package/dist/utils/type-guards.d.ts +58 -0
- package/dist/utils/type-guards.js +92 -0
- package/dist/webhook/server.d.ts +9 -0
- package/dist/webhook/server.js +122 -36
- package/dist/webhook/types.d.ts +9 -1
- package/package.json +76 -9
- package/.claude/settings.local.json +0 -31
- package/.claude/skills/api-integration.md +0 -125
- package/.claude/skills/database-schema.md +0 -51
- package/.claude/skills/dsl-design.md +0 -80
- package/.claude/skills/property-testing.md +0 -143
- package/.claude/skills/reqon/SKILL.md +0 -44
- package/.claude/skills/reqon/references/examples.md +0 -206
- package/.claude/skills/reqon/references/syntax.md +0 -263
- package/.claude/skills/vscode-extension.md +0 -113
- package/.github/dependabot.yml +0 -32
- package/.github/pull_request_template.md +0 -21
- package/.github/workflows/ci.yml +0 -174
- package/.github/workflows/release.yml +0 -73
- package/CLAUDE.md +0 -72
- package/CONTRIBUTING.md +0 -161
- package/TODO.md +0 -51
- package/dist/auth/auth.test.d.ts +0 -1
- package/dist/auth/auth.test.js +0 -255
- package/dist/errors/errors.test.d.ts +0 -1
- package/dist/errors/errors.test.js +0 -165
- package/dist/execution/execution.test.d.ts +0 -1
- package/dist/execution/execution.test.js +0 -246
- package/dist/integration.test.d.ts +0 -1
- package/dist/integration.test.js +0 -168
- package/dist/interpreter/evaluator.test.d.ts +0 -1
- package/dist/interpreter/evaluator.test.js +0 -512
- package/dist/interpreter/http.test.d.ts +0 -1
- package/dist/interpreter/http.test.js +0 -299
- package/dist/interpreter/progress.test.d.ts +0 -1
- package/dist/interpreter/progress.test.js +0 -216
- package/dist/interpreter/schema-matcher.test.d.ts +0 -1
- package/dist/interpreter/schema-matcher.test.js +0 -122
- package/dist/lexer/lexer.d.ts +0 -24
- package/dist/lexer/lexer.js +0 -264
- package/dist/lexer/lexer.test.d.ts +0 -1
- package/dist/lexer/lexer.test.js +0 -259
- package/dist/loader/loader.test.d.ts +0 -1
- package/dist/loader/loader.test.js +0 -287
- package/dist/oas/oas.test.d.ts +0 -1
- package/dist/oas/oas.test.js +0 -218
- package/dist/parser/expressions.test.d.ts +0 -1
- package/dist/parser/expressions.test.js +0 -378
- package/dist/parser/match.test.d.ts +0 -1
- package/dist/parser/match.test.js +0 -254
- package/dist/parser/parser.test.d.ts +0 -1
- package/dist/parser/parser.test.js +0 -333
- package/dist/parser/schedule.test.d.ts +0 -1
- package/dist/parser/schedule.test.js +0 -241
- package/dist/scheduler/cron-parser.test.d.ts +0 -1
- package/dist/scheduler/cron-parser.test.js +0 -188
- package/dist/stores/file.test.d.ts +0 -1
- package/dist/stores/file.test.js +0 -165
- package/dist/stores/memory.test.d.ts +0 -1
- package/dist/stores/memory.test.js +0 -157
- package/dist/stores/stores.test.d.ts +0 -1
- package/dist/stores/stores.test.js +0 -158
- package/dist/sync/sync.test.d.ts +0 -1
- package/dist/sync/sync.test.js +0 -221
- package/docusaurus/README.md +0 -41
- package/docusaurus/docs/advanced/execution-state.md +0 -283
- package/docusaurus/docs/advanced/extending-reqon.md +0 -388
- package/docusaurus/docs/advanced/multi-file-missions.md +0 -250
- package/docusaurus/docs/advanced/parallel-execution.md +0 -353
- package/docusaurus/docs/api-reference.md +0 -443
- package/docusaurus/docs/authentication/api-key.md +0 -339
- package/docusaurus/docs/authentication/basic.md +0 -276
- package/docusaurus/docs/authentication/bearer.md +0 -282
- package/docusaurus/docs/authentication/oauth2.md +0 -317
- package/docusaurus/docs/authentication/overview.md +0 -251
- package/docusaurus/docs/cli.md +0 -229
- package/docusaurus/docs/core-concepts/actions.md +0 -286
- package/docusaurus/docs/core-concepts/missions.md +0 -264
- package/docusaurus/docs/core-concepts/schemas.md +0 -353
- package/docusaurus/docs/core-concepts/sources.md +0 -339
- package/docusaurus/docs/core-concepts/stores.md +0 -332
- package/docusaurus/docs/dsl-syntax/expressions.md +0 -361
- package/docusaurus/docs/dsl-syntax/fetch.md +0 -293
- package/docusaurus/docs/dsl-syntax/for-loops.md +0 -324
- package/docusaurus/docs/dsl-syntax/map.md +0 -345
- package/docusaurus/docs/dsl-syntax/match.md +0 -387
- package/docusaurus/docs/dsl-syntax/pipelines.md +0 -397
- package/docusaurus/docs/dsl-syntax/validate.md +0 -401
- package/docusaurus/docs/error-handling/dead-letter-queues.md +0 -399
- package/docusaurus/docs/error-handling/flow-control.md +0 -337
- package/docusaurus/docs/error-handling/retry-strategies.md +0 -368
- package/docusaurus/docs/examples.md +0 -488
- package/docusaurus/docs/getting-started.md +0 -256
- package/docusaurus/docs/http/circuit-breaker.md +0 -401
- package/docusaurus/docs/http/incremental-sync.md +0 -394
- package/docusaurus/docs/http/pagination.md +0 -361
- package/docusaurus/docs/http/rate-limiting.md +0 -383
- package/docusaurus/docs/http/requests.md +0 -328
- package/docusaurus/docs/http/retry.md +0 -402
- package/docusaurus/docs/intro.md +0 -90
- package/docusaurus/docs/openapi/loading-specs.md +0 -305
- package/docusaurus/docs/openapi/operation-calls.md +0 -314
- package/docusaurus/docs/openapi/overview.md +0 -212
- package/docusaurus/docs/openapi/response-validation.md +0 -344
- package/docusaurus/docs/scheduling/cron.md +0 -305
- package/docusaurus/docs/scheduling/daemon-mode.md +0 -317
- package/docusaurus/docs/scheduling/intervals.md +0 -289
- package/docusaurus/docs/scheduling/overview.md +0 -231
- package/docusaurus/docs/stores/custom-adapters.md +0 -376
- package/docusaurus/docs/stores/file.md +0 -236
- package/docusaurus/docs/stores/memory.md +0 -193
- package/docusaurus/docs/stores/overview.md +0 -274
- package/docusaurus/docs/stores/postgrest.md +0 -316
- package/docusaurus/docusaurus.config.ts +0 -148
- package/docusaurus/package-lock.json +0 -18029
- package/docusaurus/package.json +0 -47
- package/docusaurus/sidebars.ts +0 -155
- package/docusaurus/src/components/HomepageFeatures/index.tsx +0 -105
- package/docusaurus/src/components/HomepageFeatures/styles.module.css +0 -12
- package/docusaurus/src/css/custom.css +0 -169
- package/docusaurus/src/pages/index.module.css +0 -48
- package/docusaurus/src/pages/index.tsx +0 -110
- package/docusaurus/src/pages/markdown-page.md +0 -7
- package/docusaurus/static/.nojekyll +0 -0
- package/docusaurus/static/img/docusaurus-social-card.jpg +0 -0
- package/docusaurus/static/img/docusaurus.png +0 -0
- package/docusaurus/static/img/favicon.ico +0 -0
- package/docusaurus/static/img/logo.svg +0 -10
- package/docusaurus/static/img/undraw_docusaurus_mountain.svg +0 -171
- package/docusaurus/static/img/undraw_docusaurus_react.svg +0 -170
- package/docusaurus/static/img/undraw_docusaurus_tree.svg +0 -40
- package/docusaurus/tsconfig.json +0 -8
- package/examples/README.md +0 -112
- package/examples/error-handling/README.md +0 -150
- package/examples/error-handling/payment-processor.vague +0 -287
- package/examples/github-sync/README.md +0 -74
- package/examples/github-sync/fetch-issues.vague +0 -47
- package/examples/github-sync/fetch-prs.vague +0 -40
- package/examples/github-sync/mission.vague +0 -101
- package/examples/github-sync/normalize.vague +0 -70
- package/examples/jsonplaceholder/README.md +0 -28
- package/examples/jsonplaceholder/posts.vague +0 -48
- package/examples/petstore/README.md +0 -35
- package/examples/petstore/openapi.yaml +0 -97
- package/examples/petstore/sync.vague +0 -52
- package/examples/temporal-comparison/README.md +0 -297
- package/examples/temporal-comparison/reconciliation.vague +0 -355
- package/examples/temporal-comparison/temporal/activities/index.ts +0 -8
- package/examples/temporal-comparison/temporal/activities/shipstation.ts +0 -225
- package/examples/temporal-comparison/temporal/activities/shopify.ts +0 -257
- package/examples/temporal-comparison/temporal/activities/storage.ts +0 -198
- package/examples/temporal-comparison/temporal/activities/stripe.ts +0 -169
- package/examples/temporal-comparison/temporal/activities/validation.ts +0 -205
- package/examples/temporal-comparison/temporal/client/schedule.ts +0 -218
- package/examples/temporal-comparison/temporal/config/retry.ts +0 -63
- package/examples/temporal-comparison/temporal/types/index.ts +0 -129
- package/examples/temporal-comparison/temporal/workers/main.ts +0 -130
- package/examples/temporal-comparison/temporal/workflows/orderReconciliation.ts +0 -262
- package/examples/xero/README.md +0 -88
- package/examples/xero/invoices.vague +0 -189
- package/src/api-integration.test.ts +0 -954
- package/src/ast/index.ts +0 -1
- package/src/ast/nodes.ts +0 -310
- package/src/auth/auth.test.ts +0 -326
- package/src/auth/circuit-breaker.test.ts +0 -390
- package/src/auth/circuit-breaker.ts +0 -379
- package/src/auth/credentials.test.ts +0 -273
- package/src/auth/credentials.ts +0 -246
- package/src/auth/index.ts +0 -40
- package/src/auth/oauth2-provider.ts +0 -177
- package/src/auth/rate-limiter.ts +0 -459
- package/src/auth/token-store.ts +0 -177
- package/src/auth/types.ts +0 -159
- package/src/benchmark/e2e.bench.ts +0 -288
- package/src/benchmark/evaluator.bench.ts +0 -331
- package/src/benchmark/fixtures.ts +0 -295
- package/src/benchmark/index.ts +0 -108
- package/src/benchmark/lexer.bench.ts +0 -69
- package/src/benchmark/parser.bench.ts +0 -103
- package/src/benchmark/resilience.bench.ts +0 -193
- package/src/benchmark/store.bench.ts +0 -147
- package/src/benchmark/utils.ts +0 -230
- package/src/cli.ts +0 -313
- package/src/errors/errors.test.ts +0 -234
- package/src/errors/index.ts +0 -223
- package/src/execution/execution.test.ts +0 -307
- package/src/execution/index.ts +0 -21
- package/src/execution/state.ts +0 -207
- package/src/execution/store.ts +0 -188
- package/src/index.ts +0 -169
- package/src/integration.test.ts +0 -192
- package/src/interpreter/context.ts +0 -57
- package/src/interpreter/evaluator.test.ts +0 -796
- package/src/interpreter/evaluator.ts +0 -245
- package/src/interpreter/executor.ts +0 -946
- package/src/interpreter/fetch-handler.ts +0 -302
- package/src/interpreter/http.test.ts +0 -423
- package/src/interpreter/http.ts +0 -308
- package/src/interpreter/index.ts +0 -32
- package/src/interpreter/pagination.ts +0 -207
- package/src/interpreter/progress.test.ts +0 -276
- package/src/interpreter/schema-matcher.test.ts +0 -160
- package/src/interpreter/schema-matcher.ts +0 -168
- package/src/interpreter/signals.ts +0 -73
- package/src/interpreter/step-handlers/for-handler.ts +0 -65
- package/src/interpreter/step-handlers/index.ts +0 -17
- package/src/interpreter/step-handlers/map-handler.ts +0 -24
- package/src/interpreter/step-handlers/match-handler.ts +0 -101
- package/src/interpreter/step-handlers/store-handler.ts +0 -78
- package/src/interpreter/step-handlers/types.ts +0 -17
- package/src/interpreter/step-handlers/validate-handler.ts +0 -30
- package/src/interpreter/step-handlers/webhook-handler.ts +0 -142
- package/src/lexer/index.ts +0 -18
- package/src/lexer/lexer.test.ts +0 -316
- package/src/lexer/tokens.ts +0 -179
- package/src/loader/index.ts +0 -288
- package/src/loader/loader.test.ts +0 -360
- package/src/oas/index.ts +0 -4
- package/src/oas/loader.ts +0 -126
- package/src/oas/oas.test.ts +0 -254
- package/src/oas/validator.ts +0 -299
- package/src/parser/base.ts +0 -124
- package/src/parser/expressions.test.ts +0 -525
- package/src/parser/expressions.ts +0 -314
- package/src/parser/index.ts +0 -3
- package/src/parser/match.test.ts +0 -296
- package/src/parser/parser.test.ts +0 -739
- package/src/parser/parser.ts +0 -1469
- package/src/parser/schedule.test.ts +0 -287
- package/src/parser/webhook.test.ts +0 -248
- package/src/plugin.ts +0 -83
- package/src/scheduler/cron-parser.test.ts +0 -236
- package/src/scheduler/cron-parser.ts +0 -236
- package/src/scheduler/index.ts +0 -10
- package/src/scheduler/scheduler.ts +0 -443
- package/src/scheduler/types.ts +0 -71
- package/src/stores/factory.ts +0 -104
- package/src/stores/file.test.ts +0 -276
- package/src/stores/file.ts +0 -211
- package/src/stores/index.ts +0 -6
- package/src/stores/memory.test.ts +0 -238
- package/src/stores/memory.ts +0 -63
- package/src/stores/postgrest.test.ts +0 -488
- package/src/stores/postgrest.ts +0 -263
- package/src/stores/stores.test.ts +0 -197
- package/src/stores/types.ts +0 -58
- package/src/sync/index.ts +0 -16
- package/src/sync/state.ts +0 -126
- package/src/sync/store.ts +0 -139
- package/src/sync/sync.test.ts +0 -271
- package/src/utils/async.ts +0 -10
- package/src/utils/file.ts +0 -106
- package/src/utils/index.ts +0 -14
- package/src/utils/logger.ts +0 -53
- package/src/utils/path.ts +0 -47
- package/src/webhook/index.ts +0 -15
- package/src/webhook/server.test.ts +0 -253
- package/src/webhook/server.ts +0 -389
- package/src/webhook/store.ts +0 -239
- package/src/webhook/types.ts +0 -93
- package/tsconfig.json +0 -17
- package/vitest.config.ts +0 -39
package/src/benchmark/index.ts
DELETED
|
@@ -1,108 +0,0 @@
|
|
|
1
|
-
/**
|
|
2
|
-
* Benchmark suite for Reqon
|
|
3
|
-
*
|
|
4
|
-
* Run all benchmarks: npx tsx src/benchmark/index.ts
|
|
5
|
-
* Run specific suite: npx tsx src/benchmark/index.ts --suite lexer
|
|
6
|
-
*/
|
|
7
|
-
|
|
8
|
-
import { runLexerBenchmarks } from './lexer.bench.js';
|
|
9
|
-
import { runParserBenchmarks } from './parser.bench.js';
|
|
10
|
-
import { runEvaluatorBenchmarks } from './evaluator.bench.js';
|
|
11
|
-
import { runStoreBenchmarks } from './store.bench.js';
|
|
12
|
-
import { runResilienceBenchmarks } from './resilience.bench.js';
|
|
13
|
-
import { runE2EBenchmarks } from './e2e.bench.js';
|
|
14
|
-
|
|
15
|
-
const SUITES: Record<string, () => Promise<void>> = {
|
|
16
|
-
lexer: runLexerBenchmarks,
|
|
17
|
-
parser: runParserBenchmarks,
|
|
18
|
-
evaluator: runEvaluatorBenchmarks,
|
|
19
|
-
store: runStoreBenchmarks,
|
|
20
|
-
resilience: runResilienceBenchmarks,
|
|
21
|
-
e2e: runE2EBenchmarks,
|
|
22
|
-
};
|
|
23
|
-
|
|
24
|
-
function printUsage(): void {
|
|
25
|
-
console.log(`
|
|
26
|
-
Reqon Benchmark Suite
|
|
27
|
-
=====================
|
|
28
|
-
|
|
29
|
-
Usage:
|
|
30
|
-
npx tsx src/benchmark/index.ts [options]
|
|
31
|
-
|
|
32
|
-
Options:
|
|
33
|
-
--suite <name> Run a specific benchmark suite
|
|
34
|
-
--list List available benchmark suites
|
|
35
|
-
--help Show this help message
|
|
36
|
-
|
|
37
|
-
Available Suites:
|
|
38
|
-
lexer - Tokenization benchmarks
|
|
39
|
-
parser - Parsing benchmarks
|
|
40
|
-
evaluator - Expression evaluation benchmarks
|
|
41
|
-
store - Store adapter benchmarks
|
|
42
|
-
resilience - Circuit breaker and rate limiter benchmarks
|
|
43
|
-
e2e - End-to-end execution benchmarks
|
|
44
|
-
all - Run all benchmarks (default)
|
|
45
|
-
|
|
46
|
-
Examples:
|
|
47
|
-
npx tsx src/benchmark/index.ts # Run all benchmarks
|
|
48
|
-
npx tsx src/benchmark/index.ts --suite lexer # Run only lexer benchmarks
|
|
49
|
-
npx tsx src/benchmark/index.ts --suite parser # Run only parser benchmarks
|
|
50
|
-
`);
|
|
51
|
-
}
|
|
52
|
-
|
|
53
|
-
async function main(): Promise<void> {
|
|
54
|
-
const args = process.argv.slice(2);
|
|
55
|
-
|
|
56
|
-
// Parse arguments
|
|
57
|
-
let suiteName = 'all';
|
|
58
|
-
for (let i = 0; i < args.length; i++) {
|
|
59
|
-
if (args[i] === '--help' || args[i] === '-h') {
|
|
60
|
-
printUsage();
|
|
61
|
-
process.exit(0);
|
|
62
|
-
}
|
|
63
|
-
if (args[i] === '--list') {
|
|
64
|
-
console.log('\nAvailable benchmark suites:');
|
|
65
|
-
for (const name of Object.keys(SUITES)) {
|
|
66
|
-
console.log(` - ${name}`);
|
|
67
|
-
}
|
|
68
|
-
console.log(' - all (runs all suites)');
|
|
69
|
-
process.exit(0);
|
|
70
|
-
}
|
|
71
|
-
if (args[i] === '--suite' || args[i] === '-s') {
|
|
72
|
-
suiteName = args[++i];
|
|
73
|
-
}
|
|
74
|
-
}
|
|
75
|
-
|
|
76
|
-
console.log(`
|
|
77
|
-
╔═══════════════════════════════════════════════════════════════╗
|
|
78
|
-
║ REQON BENCHMARK SUITE ║
|
|
79
|
-
╚═══════════════════════════════════════════════════════════════╝
|
|
80
|
-
`);
|
|
81
|
-
|
|
82
|
-
const startTime = Date.now();
|
|
83
|
-
|
|
84
|
-
if (suiteName === 'all') {
|
|
85
|
-
console.log('Running all benchmark suites...\n');
|
|
86
|
-
for (const [name, runFn] of Object.entries(SUITES)) {
|
|
87
|
-
console.log(`\n>>> Running ${name} benchmarks...`);
|
|
88
|
-
await runFn();
|
|
89
|
-
}
|
|
90
|
-
} else if (SUITES[suiteName]) {
|
|
91
|
-
console.log(`Running ${suiteName} benchmarks...\n`);
|
|
92
|
-
await SUITES[suiteName]();
|
|
93
|
-
} else {
|
|
94
|
-
console.error(`Unknown suite: ${suiteName}`);
|
|
95
|
-
console.error(`Available suites: ${Object.keys(SUITES).join(', ')}, all`);
|
|
96
|
-
process.exit(1);
|
|
97
|
-
}
|
|
98
|
-
|
|
99
|
-
const totalTime = ((Date.now() - startTime) / 1000).toFixed(2);
|
|
100
|
-
console.log(`\n${'═'.repeat(60)}`);
|
|
101
|
-
console.log(`Benchmarks completed in ${totalTime}s`);
|
|
102
|
-
console.log(`${'═'.repeat(60)}`);
|
|
103
|
-
}
|
|
104
|
-
|
|
105
|
-
main().catch((err) => {
|
|
106
|
-
console.error('Benchmark failed:', err);
|
|
107
|
-
process.exit(1);
|
|
108
|
-
});
|
|
@@ -1,69 +0,0 @@
|
|
|
1
|
-
/**
|
|
2
|
-
* Lexer benchmarks
|
|
3
|
-
*/
|
|
4
|
-
|
|
5
|
-
import { ReqonLexer } from '../lexer/lexer.js';
|
|
6
|
-
import { BenchmarkSuite } from './utils.js';
|
|
7
|
-
import {
|
|
8
|
-
SIMPLE_DSL,
|
|
9
|
-
MEDIUM_DSL,
|
|
10
|
-
COMPLEX_DSL,
|
|
11
|
-
EXPRESSION_HEAVY_DSL,
|
|
12
|
-
generateLargeDSL,
|
|
13
|
-
} from './fixtures.js';
|
|
14
|
-
|
|
15
|
-
export async function runLexerBenchmarks(): Promise<void> {
|
|
16
|
-
const suite = new BenchmarkSuite('Lexer');
|
|
17
|
-
|
|
18
|
-
// Simple DSL tokenization
|
|
19
|
-
suite.addSync('simple-dsl', () => {
|
|
20
|
-
const lexer = new ReqonLexer(SIMPLE_DSL);
|
|
21
|
-
return lexer.tokenize();
|
|
22
|
-
});
|
|
23
|
-
|
|
24
|
-
// Medium complexity DSL
|
|
25
|
-
suite.addSync('medium-dsl', () => {
|
|
26
|
-
const lexer = new ReqonLexer(MEDIUM_DSL);
|
|
27
|
-
return lexer.tokenize();
|
|
28
|
-
});
|
|
29
|
-
|
|
30
|
-
// Complex DSL
|
|
31
|
-
suite.addSync('complex-dsl', () => {
|
|
32
|
-
const lexer = new ReqonLexer(COMPLEX_DSL);
|
|
33
|
-
return lexer.tokenize();
|
|
34
|
-
});
|
|
35
|
-
|
|
36
|
-
// Expression-heavy DSL
|
|
37
|
-
suite.addSync('expression-heavy', () => {
|
|
38
|
-
const lexer = new ReqonLexer(EXPRESSION_HEAVY_DSL);
|
|
39
|
-
return lexer.tokenize();
|
|
40
|
-
});
|
|
41
|
-
|
|
42
|
-
// Large generated DSL (10 actions)
|
|
43
|
-
const largeDsl10 = generateLargeDSL(10);
|
|
44
|
-
suite.addSync('large-10-actions', () => {
|
|
45
|
-
const lexer = new ReqonLexer(largeDsl10);
|
|
46
|
-
return lexer.tokenize();
|
|
47
|
-
});
|
|
48
|
-
|
|
49
|
-
// Large generated DSL (50 actions)
|
|
50
|
-
const largeDsl50 = generateLargeDSL(50);
|
|
51
|
-
suite.addSync('large-50-actions', () => {
|
|
52
|
-
const lexer = new ReqonLexer(largeDsl50);
|
|
53
|
-
return lexer.tokenize();
|
|
54
|
-
}, { iterations: 500 });
|
|
55
|
-
|
|
56
|
-
// Large generated DSL (100 actions) - stress test
|
|
57
|
-
const largeDsl100 = generateLargeDSL(100);
|
|
58
|
-
suite.addSync('large-100-actions', () => {
|
|
59
|
-
const lexer = new ReqonLexer(largeDsl100);
|
|
60
|
-
return lexer.tokenize();
|
|
61
|
-
}, { iterations: 100, warmupIterations: 10 });
|
|
62
|
-
|
|
63
|
-
suite.print();
|
|
64
|
-
}
|
|
65
|
-
|
|
66
|
-
// Run if executed directly
|
|
67
|
-
if (import.meta.url === `file://${process.argv[1]}`) {
|
|
68
|
-
runLexerBenchmarks().catch(console.error);
|
|
69
|
-
}
|
|
@@ -1,103 +0,0 @@
|
|
|
1
|
-
/**
|
|
2
|
-
* Parser benchmarks
|
|
3
|
-
*/
|
|
4
|
-
|
|
5
|
-
import { ReqonLexer } from '../lexer/lexer.js';
|
|
6
|
-
import { ReqonParser } from '../parser/parser.js';
|
|
7
|
-
import { BenchmarkSuite } from './utils.js';
|
|
8
|
-
import {
|
|
9
|
-
SIMPLE_DSL,
|
|
10
|
-
MEDIUM_DSL,
|
|
11
|
-
COMPLEX_DSL,
|
|
12
|
-
EXPRESSION_HEAVY_DSL,
|
|
13
|
-
MATCH_HEAVY_DSL,
|
|
14
|
-
generateLargeDSL,
|
|
15
|
-
} from './fixtures.js';
|
|
16
|
-
|
|
17
|
-
// Pre-tokenize for parser-only benchmarks
|
|
18
|
-
function preTokenize(source: string) {
|
|
19
|
-
const lexer = new ReqonLexer(source);
|
|
20
|
-
return lexer.tokenize();
|
|
21
|
-
}
|
|
22
|
-
|
|
23
|
-
export async function runParserBenchmarks(): Promise<void> {
|
|
24
|
-
const suite = new BenchmarkSuite('Parser');
|
|
25
|
-
|
|
26
|
-
// Pre-tokenize all fixtures
|
|
27
|
-
const simpleTokens = preTokenize(SIMPLE_DSL);
|
|
28
|
-
const mediumTokens = preTokenize(MEDIUM_DSL);
|
|
29
|
-
const complexTokens = preTokenize(COMPLEX_DSL);
|
|
30
|
-
const expressionTokens = preTokenize(EXPRESSION_HEAVY_DSL);
|
|
31
|
-
const matchTokens = preTokenize(MATCH_HEAVY_DSL);
|
|
32
|
-
const large10Tokens = preTokenize(generateLargeDSL(10));
|
|
33
|
-
const large50Tokens = preTokenize(generateLargeDSL(50));
|
|
34
|
-
|
|
35
|
-
// Parser-only benchmarks (with pre-tokenized input)
|
|
36
|
-
suite.addSync('simple-dsl', () => {
|
|
37
|
-
const parser = new ReqonParser([...simpleTokens]);
|
|
38
|
-
return parser.parse();
|
|
39
|
-
});
|
|
40
|
-
|
|
41
|
-
suite.addSync('medium-dsl', () => {
|
|
42
|
-
const parser = new ReqonParser([...mediumTokens]);
|
|
43
|
-
return parser.parse();
|
|
44
|
-
});
|
|
45
|
-
|
|
46
|
-
suite.addSync('complex-dsl', () => {
|
|
47
|
-
const parser = new ReqonParser([...complexTokens]);
|
|
48
|
-
return parser.parse();
|
|
49
|
-
});
|
|
50
|
-
|
|
51
|
-
suite.addSync('expression-heavy', () => {
|
|
52
|
-
const parser = new ReqonParser([...expressionTokens]);
|
|
53
|
-
return parser.parse();
|
|
54
|
-
});
|
|
55
|
-
|
|
56
|
-
suite.addSync('match-heavy', () => {
|
|
57
|
-
const parser = new ReqonParser([...matchTokens]);
|
|
58
|
-
return parser.parse();
|
|
59
|
-
});
|
|
60
|
-
|
|
61
|
-
suite.addSync('large-10-actions', () => {
|
|
62
|
-
const parser = new ReqonParser([...large10Tokens]);
|
|
63
|
-
return parser.parse();
|
|
64
|
-
});
|
|
65
|
-
|
|
66
|
-
suite.addSync('large-50-actions', () => {
|
|
67
|
-
const parser = new ReqonParser([...large50Tokens]);
|
|
68
|
-
return parser.parse();
|
|
69
|
-
}, { iterations: 500 });
|
|
70
|
-
|
|
71
|
-
suite.print();
|
|
72
|
-
|
|
73
|
-
// Full pipeline benchmarks (lexer + parser)
|
|
74
|
-
const pipelineSuite = new BenchmarkSuite('Lexer + Parser Pipeline');
|
|
75
|
-
|
|
76
|
-
pipelineSuite.addSync('simple-full', () => {
|
|
77
|
-
const lexer = new ReqonLexer(SIMPLE_DSL);
|
|
78
|
-
const tokens = lexer.tokenize();
|
|
79
|
-
const parser = new ReqonParser(tokens);
|
|
80
|
-
return parser.parse();
|
|
81
|
-
});
|
|
82
|
-
|
|
83
|
-
pipelineSuite.addSync('medium-full', () => {
|
|
84
|
-
const lexer = new ReqonLexer(MEDIUM_DSL);
|
|
85
|
-
const tokens = lexer.tokenize();
|
|
86
|
-
const parser = new ReqonParser(tokens);
|
|
87
|
-
return parser.parse();
|
|
88
|
-
});
|
|
89
|
-
|
|
90
|
-
pipelineSuite.addSync('complex-full', () => {
|
|
91
|
-
const lexer = new ReqonLexer(COMPLEX_DSL);
|
|
92
|
-
const tokens = lexer.tokenize();
|
|
93
|
-
const parser = new ReqonParser(tokens);
|
|
94
|
-
return parser.parse();
|
|
95
|
-
});
|
|
96
|
-
|
|
97
|
-
pipelineSuite.print();
|
|
98
|
-
}
|
|
99
|
-
|
|
100
|
-
// Run if executed directly
|
|
101
|
-
if (import.meta.url === `file://${process.argv[1]}`) {
|
|
102
|
-
runParserBenchmarks().catch(console.error);
|
|
103
|
-
}
|
|
@@ -1,193 +0,0 @@
|
|
|
1
|
-
/**
|
|
2
|
-
* Resilience component benchmarks (Circuit Breaker and Rate Limiter)
|
|
3
|
-
*/
|
|
4
|
-
|
|
5
|
-
import { CircuitBreaker } from '../auth/circuit-breaker.js';
|
|
6
|
-
import { AdaptiveRateLimiter } from '../auth/rate-limiter.js';
|
|
7
|
-
import { BenchmarkSuite } from './utils.js';
|
|
8
|
-
|
|
9
|
-
export async function runResilienceBenchmarks(): Promise<void> {
|
|
10
|
-
// Circuit Breaker benchmarks
|
|
11
|
-
const cbSuite = new BenchmarkSuite('CircuitBreaker');
|
|
12
|
-
|
|
13
|
-
// Basic operations in closed state
|
|
14
|
-
const closedBreaker = new CircuitBreaker();
|
|
15
|
-
|
|
16
|
-
cbSuite.addSync('canProceed-closed', () => {
|
|
17
|
-
return closedBreaker.canProceed('test-source', '/endpoint');
|
|
18
|
-
});
|
|
19
|
-
|
|
20
|
-
cbSuite.addSync('ensureCanProceed-closed', () => {
|
|
21
|
-
closedBreaker.ensureCanProceed('test-source', '/endpoint');
|
|
22
|
-
});
|
|
23
|
-
|
|
24
|
-
cbSuite.addSync('recordSuccess-closed', () => {
|
|
25
|
-
closedBreaker.recordSuccess('test-source', '/endpoint');
|
|
26
|
-
});
|
|
27
|
-
|
|
28
|
-
cbSuite.addSync('recordFailure-closed', () => {
|
|
29
|
-
const breaker = new CircuitBreaker({ failureThreshold: 1000 }); // High threshold to stay closed
|
|
30
|
-
breaker.recordFailure('test-source', '/endpoint');
|
|
31
|
-
});
|
|
32
|
-
|
|
33
|
-
// Configure operation
|
|
34
|
-
cbSuite.addSync('configure', () => {
|
|
35
|
-
const breaker = new CircuitBreaker();
|
|
36
|
-
breaker.configure('new-source', {
|
|
37
|
-
failureThreshold: 10,
|
|
38
|
-
resetTimeout: 60000,
|
|
39
|
-
});
|
|
40
|
-
});
|
|
41
|
-
|
|
42
|
-
// State transition to open
|
|
43
|
-
cbSuite.addSync('transition-to-open', () => {
|
|
44
|
-
const breaker = new CircuitBreaker({ failureThreshold: 3 });
|
|
45
|
-
breaker.recordFailure('source', '/ep');
|
|
46
|
-
breaker.recordFailure('source', '/ep');
|
|
47
|
-
breaker.recordFailure('source', '/ep');
|
|
48
|
-
return breaker.getStatus('source', '/ep');
|
|
49
|
-
});
|
|
50
|
-
|
|
51
|
-
// Multiple sources/endpoints
|
|
52
|
-
cbSuite.addSync('multi-source-check', () => {
|
|
53
|
-
const breaker = new CircuitBreaker();
|
|
54
|
-
for (let i = 0; i < 10; i++) {
|
|
55
|
-
breaker.canProceed(`source-${i}`, `/endpoint-${i}`);
|
|
56
|
-
}
|
|
57
|
-
});
|
|
58
|
-
|
|
59
|
-
// Simulate realistic request pattern
|
|
60
|
-
cbSuite.addSync('realistic-request-pattern', () => {
|
|
61
|
-
const breaker = new CircuitBreaker({ failureThreshold: 5 });
|
|
62
|
-
// 80% success, 20% failure
|
|
63
|
-
for (let i = 0; i < 100; i++) {
|
|
64
|
-
breaker.ensureCanProceed('api', '/data');
|
|
65
|
-
if (Math.random() > 0.2) {
|
|
66
|
-
breaker.recordSuccess('api', '/data');
|
|
67
|
-
} else {
|
|
68
|
-
breaker.recordFailure('api', '/data');
|
|
69
|
-
}
|
|
70
|
-
}
|
|
71
|
-
}, { iterations: 100 });
|
|
72
|
-
|
|
73
|
-
cbSuite.print();
|
|
74
|
-
|
|
75
|
-
// Rate Limiter benchmarks
|
|
76
|
-
const rlSuite = new BenchmarkSuite('AdaptiveRateLimiter');
|
|
77
|
-
|
|
78
|
-
const limiter = new AdaptiveRateLimiter();
|
|
79
|
-
|
|
80
|
-
await rlSuite.addAsync('canProceed-fresh', async () => {
|
|
81
|
-
const rl = new AdaptiveRateLimiter();
|
|
82
|
-
return await rl.canProceed('api', '/endpoint');
|
|
83
|
-
});
|
|
84
|
-
|
|
85
|
-
await rlSuite.addAsync('canProceed-existing', async () => {
|
|
86
|
-
return await limiter.canProceed('test-api', '/test-endpoint');
|
|
87
|
-
});
|
|
88
|
-
|
|
89
|
-
// Configure operation
|
|
90
|
-
rlSuite.addSync('configure', () => {
|
|
91
|
-
const rl = new AdaptiveRateLimiter();
|
|
92
|
-
rl.configure('api', {
|
|
93
|
-
strategy: 'pause',
|
|
94
|
-
maxWait: 60,
|
|
95
|
-
notifyAt: 5,
|
|
96
|
-
fallbackRpm: 100,
|
|
97
|
-
});
|
|
98
|
-
});
|
|
99
|
-
|
|
100
|
-
// Record response with rate limit info
|
|
101
|
-
await rlSuite.addAsync('recordResponse-with-headers', async () => {
|
|
102
|
-
const rl = new AdaptiveRateLimiter();
|
|
103
|
-
rl.recordResponse('api', {
|
|
104
|
-
remaining: 50,
|
|
105
|
-
limit: 100,
|
|
106
|
-
resetAt: new Date(Date.now() + 3600000),
|
|
107
|
-
}, '/endpoint');
|
|
108
|
-
});
|
|
109
|
-
|
|
110
|
-
// Record response without rate limit info
|
|
111
|
-
await rlSuite.addAsync('recordResponse-no-headers', async () => {
|
|
112
|
-
const rl = new AdaptiveRateLimiter();
|
|
113
|
-
rl.recordResponse('api', {}, '/endpoint');
|
|
114
|
-
});
|
|
115
|
-
|
|
116
|
-
// Record 429 response with retry-after
|
|
117
|
-
await rlSuite.addAsync('recordResponse-429', async () => {
|
|
118
|
-
const rl = new AdaptiveRateLimiter();
|
|
119
|
-
rl.recordResponse('api', {
|
|
120
|
-
retryAfter: 60,
|
|
121
|
-
}, '/endpoint');
|
|
122
|
-
});
|
|
123
|
-
|
|
124
|
-
// getStatus operation
|
|
125
|
-
await rlSuite.addAsync('getStatus', async () => {
|
|
126
|
-
return limiter.getStatus('test-api', '/test-endpoint');
|
|
127
|
-
});
|
|
128
|
-
|
|
129
|
-
// Multiple endpoints check
|
|
130
|
-
await rlSuite.addAsync('multi-endpoint-check', async () => {
|
|
131
|
-
const rl = new AdaptiveRateLimiter();
|
|
132
|
-
for (let i = 0; i < 10; i++) {
|
|
133
|
-
await rl.canProceed(`source-${i}`, `/endpoint-${i}`);
|
|
134
|
-
}
|
|
135
|
-
});
|
|
136
|
-
|
|
137
|
-
// Simulate realistic request pattern
|
|
138
|
-
await rlSuite.addAsync('realistic-request-pattern', async () => {
|
|
139
|
-
const rl = new AdaptiveRateLimiter();
|
|
140
|
-
|
|
141
|
-
for (let i = 0; i < 20; i++) {
|
|
142
|
-
await rl.canProceed('api', '/data');
|
|
143
|
-
rl.recordResponse('api', {
|
|
144
|
-
remaining: 95 - i,
|
|
145
|
-
limit: 100,
|
|
146
|
-
resetAt: new Date(Date.now() + 60000),
|
|
147
|
-
}, '/data');
|
|
148
|
-
}
|
|
149
|
-
}, { iterations: 100 });
|
|
150
|
-
|
|
151
|
-
rlSuite.print();
|
|
152
|
-
|
|
153
|
-
// Combined resilience pattern
|
|
154
|
-
const combinedSuite = new BenchmarkSuite('Combined Resilience Pattern');
|
|
155
|
-
|
|
156
|
-
await combinedSuite.addAsync('circuit-breaker-plus-rate-limiter', async () => {
|
|
157
|
-
const cb = new CircuitBreaker({ failureThreshold: 5 });
|
|
158
|
-
const rl = new AdaptiveRateLimiter();
|
|
159
|
-
|
|
160
|
-
// Simulate 50 requests
|
|
161
|
-
for (let i = 0; i < 50; i++) {
|
|
162
|
-
// Check circuit breaker
|
|
163
|
-
try {
|
|
164
|
-
cb.ensureCanProceed('api', '/data');
|
|
165
|
-
} catch {
|
|
166
|
-
continue;
|
|
167
|
-
}
|
|
168
|
-
|
|
169
|
-
// Check rate limiter
|
|
170
|
-
if (!(await rl.canProceed('api', '/data'))) {
|
|
171
|
-
continue;
|
|
172
|
-
}
|
|
173
|
-
|
|
174
|
-
// Simulate response
|
|
175
|
-
const success = Math.random() > 0.1;
|
|
176
|
-
if (success) {
|
|
177
|
-
cb.recordSuccess('api', '/data');
|
|
178
|
-
rl.recordResponse('api', {
|
|
179
|
-
remaining: 50,
|
|
180
|
-
}, '/data');
|
|
181
|
-
} else {
|
|
182
|
-
cb.recordFailure('api', '/data');
|
|
183
|
-
}
|
|
184
|
-
}
|
|
185
|
-
}, { iterations: 100 });
|
|
186
|
-
|
|
187
|
-
combinedSuite.print();
|
|
188
|
-
}
|
|
189
|
-
|
|
190
|
-
// Run if executed directly
|
|
191
|
-
if (import.meta.url === `file://${process.argv[1]}`) {
|
|
192
|
-
runResilienceBenchmarks().catch(console.error);
|
|
193
|
-
}
|
|
@@ -1,147 +0,0 @@
|
|
|
1
|
-
/**
|
|
2
|
-
* Store adapter benchmarks
|
|
3
|
-
*/
|
|
4
|
-
|
|
5
|
-
import { MemoryStore } from '../stores/memory.js';
|
|
6
|
-
import { applyStoreFilter } from '../stores/types.js';
|
|
7
|
-
import { BenchmarkSuite, generateRecords } from './utils.js';
|
|
8
|
-
|
|
9
|
-
export async function runStoreBenchmarks(): Promise<void> {
|
|
10
|
-
const suite = new BenchmarkSuite('MemoryStore Operations');
|
|
11
|
-
|
|
12
|
-
// Prepare test data
|
|
13
|
-
const smallRecords = generateRecords(100);
|
|
14
|
-
const mediumRecords = generateRecords(1000);
|
|
15
|
-
const largeRecords = generateRecords(10000);
|
|
16
|
-
|
|
17
|
-
// Individual set operations
|
|
18
|
-
await suite.addAsync('set-single', async () => {
|
|
19
|
-
const store = new MemoryStore('test');
|
|
20
|
-
await store.set('key-1', { id: '1', value: 42 });
|
|
21
|
-
});
|
|
22
|
-
|
|
23
|
-
// Batch set operations
|
|
24
|
-
await suite.addAsync('set-100-records', async () => {
|
|
25
|
-
const store = new MemoryStore('test');
|
|
26
|
-
for (const record of smallRecords) {
|
|
27
|
-
await store.set(record.id as string, record);
|
|
28
|
-
}
|
|
29
|
-
}, { iterations: 100 });
|
|
30
|
-
|
|
31
|
-
await suite.addAsync('set-1000-records', async () => {
|
|
32
|
-
const store = new MemoryStore('test');
|
|
33
|
-
for (const record of mediumRecords) {
|
|
34
|
-
await store.set(record.id as string, record);
|
|
35
|
-
}
|
|
36
|
-
}, { iterations: 50, warmupIterations: 5 });
|
|
37
|
-
|
|
38
|
-
// Get operations (pre-populate store)
|
|
39
|
-
const prePopulatedStore = new MemoryStore('prepopulated');
|
|
40
|
-
for (const record of mediumRecords) {
|
|
41
|
-
await prePopulatedStore.set(record.id as string, record);
|
|
42
|
-
}
|
|
43
|
-
|
|
44
|
-
await suite.addAsync('get-existing', async () => {
|
|
45
|
-
await prePopulatedStore.get('record-500');
|
|
46
|
-
});
|
|
47
|
-
|
|
48
|
-
await suite.addAsync('get-nonexistent', async () => {
|
|
49
|
-
await prePopulatedStore.get('nonexistent-key');
|
|
50
|
-
});
|
|
51
|
-
|
|
52
|
-
await suite.addAsync('get-100-sequential', async () => {
|
|
53
|
-
for (let i = 0; i < 100; i++) {
|
|
54
|
-
await prePopulatedStore.get(`record-${i}`);
|
|
55
|
-
}
|
|
56
|
-
}, { iterations: 100 });
|
|
57
|
-
|
|
58
|
-
// Update operations
|
|
59
|
-
await suite.addAsync('update-existing', async () => {
|
|
60
|
-
await prePopulatedStore.update('record-500', { updated: true });
|
|
61
|
-
});
|
|
62
|
-
|
|
63
|
-
await suite.addAsync('update-100-records', async () => {
|
|
64
|
-
for (let i = 0; i < 100; i++) {
|
|
65
|
-
await prePopulatedStore.update(`record-${i}`, { updated: true });
|
|
66
|
-
}
|
|
67
|
-
}, { iterations: 100 });
|
|
68
|
-
|
|
69
|
-
// List operations
|
|
70
|
-
await suite.addAsync('list-all-1000', async () => {
|
|
71
|
-
await prePopulatedStore.list();
|
|
72
|
-
}, { iterations: 100 });
|
|
73
|
-
|
|
74
|
-
// Large store for list benchmarks
|
|
75
|
-
const largeStore = new MemoryStore('large');
|
|
76
|
-
for (const record of largeRecords) {
|
|
77
|
-
await largeStore.set(record.id as string, record);
|
|
78
|
-
}
|
|
79
|
-
|
|
80
|
-
await suite.addAsync('list-all-10000', async () => {
|
|
81
|
-
await largeStore.list();
|
|
82
|
-
}, { iterations: 20, warmupIterations: 5 });
|
|
83
|
-
|
|
84
|
-
// List with filters
|
|
85
|
-
await suite.addAsync('list-with-limit-100', async () => {
|
|
86
|
-
await largeStore.list({ limit: 100 });
|
|
87
|
-
}, { iterations: 100 });
|
|
88
|
-
|
|
89
|
-
await suite.addAsync('list-with-offset-and-limit', async () => {
|
|
90
|
-
await largeStore.list({ offset: 5000, limit: 100 });
|
|
91
|
-
}, { iterations: 100 });
|
|
92
|
-
|
|
93
|
-
await suite.addAsync('list-with-where-clause', async () => {
|
|
94
|
-
await largeStore.list({ where: { active: true } });
|
|
95
|
-
}, { iterations: 50, warmupIterations: 5 });
|
|
96
|
-
|
|
97
|
-
// Delete operations
|
|
98
|
-
await suite.addAsync('delete-single', async () => {
|
|
99
|
-
const store = new MemoryStore('test');
|
|
100
|
-
await store.set('key-1', { id: '1' });
|
|
101
|
-
await store.delete('key-1');
|
|
102
|
-
});
|
|
103
|
-
|
|
104
|
-
suite.print();
|
|
105
|
-
|
|
106
|
-
// Filter function benchmarks
|
|
107
|
-
const filterSuite = new BenchmarkSuite('applyStoreFilter');
|
|
108
|
-
|
|
109
|
-
filterSuite.addSync('no-filter-1000', () => {
|
|
110
|
-
return applyStoreFilter(mediumRecords);
|
|
111
|
-
});
|
|
112
|
-
|
|
113
|
-
filterSuite.addSync('no-filter-10000', () => {
|
|
114
|
-
return applyStoreFilter(largeRecords);
|
|
115
|
-
}, { iterations: 100 });
|
|
116
|
-
|
|
117
|
-
filterSuite.addSync('limit-only-1000', () => {
|
|
118
|
-
return applyStoreFilter(mediumRecords, { limit: 100 });
|
|
119
|
-
});
|
|
120
|
-
|
|
121
|
-
filterSuite.addSync('offset-limit-1000', () => {
|
|
122
|
-
return applyStoreFilter(mediumRecords, { offset: 500, limit: 100 });
|
|
123
|
-
});
|
|
124
|
-
|
|
125
|
-
filterSuite.addSync('where-simple-1000', () => {
|
|
126
|
-
return applyStoreFilter(mediumRecords, { where: { active: true } });
|
|
127
|
-
});
|
|
128
|
-
|
|
129
|
-
filterSuite.addSync('where-simple-10000', () => {
|
|
130
|
-
return applyStoreFilter(largeRecords, { where: { active: true } });
|
|
131
|
-
}, { iterations: 100 });
|
|
132
|
-
|
|
133
|
-
filterSuite.addSync('where-multiple-conditions', () => {
|
|
134
|
-
return applyStoreFilter(largeRecords, {
|
|
135
|
-
where: { active: true },
|
|
136
|
-
offset: 100,
|
|
137
|
-
limit: 50,
|
|
138
|
-
});
|
|
139
|
-
}, { iterations: 100 });
|
|
140
|
-
|
|
141
|
-
filterSuite.print();
|
|
142
|
-
}
|
|
143
|
-
|
|
144
|
-
// Run if executed directly
|
|
145
|
-
if (import.meta.url === `file://${process.argv[1]}`) {
|
|
146
|
-
runStoreBenchmarks().catch(console.error);
|
|
147
|
-
}
|