@geekmidas/constructs 0.0.1
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/README.md +614 -0
- package/dist/AWSLambdaFunction-CpHFE2m6.d.mts +27 -0
- package/dist/AWSLambdaFunction-CwagvPG3.d.cts +27 -0
- package/dist/AWSLambdaFunction-DWIZYsCy.mjs +79 -0
- package/dist/AWSLambdaFunction-DWIZYsCy.mjs.map +1 -0
- package/dist/AWSLambdaFunction-qA5LqPsv.cjs +85 -0
- package/dist/AWSLambdaFunction-qA5LqPsv.cjs.map +1 -0
- package/dist/AWSLambdaSubscriberAdaptor-C1wQuucQ.d.mts +32 -0
- package/dist/AWSLambdaSubscriberAdaptor-CmPZ10JF.cjs +138 -0
- package/dist/AWSLambdaSubscriberAdaptor-CmPZ10JF.cjs.map +1 -0
- package/dist/AWSLambdaSubscriberAdaptor-G8y3YkWj.mjs +132 -0
- package/dist/AWSLambdaSubscriberAdaptor-G8y3YkWj.mjs.map +1 -0
- package/dist/AWSLambdaSubscriberAdaptor-QKVxR6qh.d.cts +32 -0
- package/dist/AmazonApiGatewayEndpointAdaptor-BoBh7vvD.d.mts +61 -0
- package/dist/AmazonApiGatewayEndpointAdaptor-Cx1oqcqh.mjs +124 -0
- package/dist/AmazonApiGatewayEndpointAdaptor-Cx1oqcqh.mjs.map +1 -0
- package/dist/AmazonApiGatewayEndpointAdaptor-DtzgQ9Vb.d.cts +61 -0
- package/dist/AmazonApiGatewayEndpointAdaptor-i74DEUbc.cjs +130 -0
- package/dist/AmazonApiGatewayEndpointAdaptor-i74DEUbc.cjs.map +1 -0
- package/dist/AmazonApiGatewayV1EndpointAdaptor-CLmBDYsl.mjs +42 -0
- package/dist/AmazonApiGatewayV1EndpointAdaptor-CLmBDYsl.mjs.map +1 -0
- package/dist/AmazonApiGatewayV1EndpointAdaptor-EhMd1YqV.d.mts +21 -0
- package/dist/AmazonApiGatewayV1EndpointAdaptor-GkMAUPL5.cjs +47 -0
- package/dist/AmazonApiGatewayV1EndpointAdaptor-GkMAUPL5.cjs.map +1 -0
- package/dist/AmazonApiGatewayV1EndpointAdaptor-Gw-j61qM.d.cts +21 -0
- package/dist/AmazonApiGatewayV2EndpointAdaptor-3RqegmJC.mjs +41 -0
- package/dist/AmazonApiGatewayV2EndpointAdaptor-3RqegmJC.mjs.map +1 -0
- package/dist/AmazonApiGatewayV2EndpointAdaptor-LUlpwmUW.d.cts +21 -0
- package/dist/AmazonApiGatewayV2EndpointAdaptor-YlFoFSS9.cjs +46 -0
- package/dist/AmazonApiGatewayV2EndpointAdaptor-YlFoFSS9.cjs.map +1 -0
- package/dist/AmazonApiGatewayV2EndpointAdaptor-zfd1gqXA.d.mts +21 -0
- package/dist/BaseFunctionBuilder-5QCHkchp.d.cts +31 -0
- package/dist/BaseFunctionBuilder-BFPVGnKi.d.mts +31 -0
- package/dist/BaseFunctionBuilder-BPE9JBbT.mjs +56 -0
- package/dist/BaseFunctionBuilder-BPE9JBbT.mjs.map +1 -0
- package/dist/BaseFunctionBuilder-DtO4Nwxm.cjs +62 -0
- package/dist/BaseFunctionBuilder-DtO4Nwxm.cjs.map +1 -0
- package/dist/Construct-BSEs6uwW.cjs +75 -0
- package/dist/Construct-BSEs6uwW.cjs.map +1 -0
- package/dist/Construct-BbKCIPQm.mjs +63 -0
- package/dist/Construct-BbKCIPQm.mjs.map +1 -0
- package/dist/Construct-Bm-PSO2V.d.cts +42 -0
- package/dist/Construct-DIguIyw4.d.mts +42 -0
- package/dist/Construct.cjs +4 -0
- package/dist/Construct.d.cts +2 -0
- package/dist/Construct.d.mts +2 -0
- package/dist/Construct.mjs +3 -0
- package/dist/Cron-Bgs6EQOb.mjs +20 -0
- package/dist/Cron-Bgs6EQOb.mjs.map +1 -0
- package/dist/Cron-DQiCj3ef.cjs +25 -0
- package/dist/Cron-DQiCj3ef.cjs.map +1 -0
- package/dist/Cron-FpAw03k6.d.mts +25 -0
- package/dist/Cron-ztnK6zgU.d.cts +25 -0
- package/dist/CronBuilder-B2clNQSP.d.mts +24 -0
- package/dist/CronBuilder-Cje9K8lZ.d.cts +24 -0
- package/dist/CronBuilder-DIBqJkh_.cjs +60 -0
- package/dist/CronBuilder-DIBqJkh_.cjs.map +1 -0
- package/dist/CronBuilder-DecAvvcn.mjs +54 -0
- package/dist/CronBuilder-DecAvvcn.mjs.map +1 -0
- package/dist/Endpoint-BaHC9y4Z.cjs +291 -0
- package/dist/Endpoint-BaHC9y4Z.cjs.map +1 -0
- package/dist/Endpoint-C7z9YJHK.d.cts +405 -0
- package/dist/Endpoint-DCn53Vd8.d.mts +405 -0
- package/dist/Endpoint-ierdM62O.mjs +279 -0
- package/dist/Endpoint-ierdM62O.mjs.map +1 -0
- package/dist/EndpointBuilder-BHFSpbPR.cjs +107 -0
- package/dist/EndpointBuilder-BHFSpbPR.cjs.map +1 -0
- package/dist/EndpointBuilder-BLUsoK3l.mjs +101 -0
- package/dist/EndpointBuilder-BLUsoK3l.mjs.map +1 -0
- package/dist/EndpointBuilder-Bfnb2oJr.d.mts +49 -0
- package/dist/EndpointBuilder-CP9RGwZH.d.cts +49 -0
- package/dist/EndpointFactory-BYdDVCNj.mjs +127 -0
- package/dist/EndpointFactory-BYdDVCNj.mjs.map +1 -0
- package/dist/EndpointFactory-CNtMXgIh.d.mts +52 -0
- package/dist/EndpointFactory-CXX4E6Gx.cjs +139 -0
- package/dist/EndpointFactory-CXX4E6Gx.cjs.map +1 -0
- package/dist/EndpointFactory-D2zgWbXZ.d.cts +52 -0
- package/dist/Function-BP58p9Mp.d.cts +59 -0
- package/dist/Function-BsBxc2wA.d.mts +59 -0
- package/dist/Function-C5mW-38v.mjs +72 -0
- package/dist/Function-C5mW-38v.mjs.map +1 -0
- package/dist/Function-CbO2NZx-.cjs +84 -0
- package/dist/Function-CbO2NZx-.cjs.map +1 -0
- package/dist/FunctionBuilder-BS1KgxA_.d.cts +24 -0
- package/dist/FunctionBuilder-C-PfPN3r.d.mts +24 -0
- package/dist/FunctionBuilder-CosgPmMl.mjs +53 -0
- package/dist/FunctionBuilder-CosgPmMl.mjs.map +1 -0
- package/dist/FunctionBuilder-DuOeWCAl.cjs +59 -0
- package/dist/FunctionBuilder-DuOeWCAl.cjs.map +1 -0
- package/dist/FunctionExecutionWrapper-Bx-Dl-2a.d.cts +24 -0
- package/dist/FunctionExecutionWrapper-CElXEjPe.cjs +42 -0
- package/dist/FunctionExecutionWrapper-CElXEjPe.cjs.map +1 -0
- package/dist/FunctionExecutionWrapper-DvglBBjE.d.mts +24 -0
- package/dist/FunctionExecutionWrapper-XGrSAAPD.mjs +36 -0
- package/dist/FunctionExecutionWrapper-XGrSAAPD.mjs.map +1 -0
- package/dist/HonoEndpointAdaptor-B0IO1zj2.d.mts +41 -0
- package/dist/HonoEndpointAdaptor-B4snrp7v.cjs +154 -0
- package/dist/HonoEndpointAdaptor-B4snrp7v.cjs.map +1 -0
- package/dist/HonoEndpointAdaptor-B6lW9Q1k.d.cts +41 -0
- package/dist/HonoEndpointAdaptor-D-M4-6Tf.mjs +148 -0
- package/dist/HonoEndpointAdaptor-D-M4-6Tf.mjs.map +1 -0
- package/dist/Subscriber-BoFm12i_.d.cts +33 -0
- package/dist/Subscriber-BwuCaC9G.mjs +28 -0
- package/dist/Subscriber-BwuCaC9G.mjs.map +1 -0
- package/dist/Subscriber-THGsj7Iy.d.mts +33 -0
- package/dist/Subscriber-iMRFG7ba.cjs +34 -0
- package/dist/Subscriber-iMRFG7ba.cjs.map +1 -0
- package/dist/SubscriberBuilder-CiPxgnKT.d.mts +26 -0
- package/dist/SubscriberBuilder-Dhz0C_t-.mjs +54 -0
- package/dist/SubscriberBuilder-Dhz0C_t-.mjs.map +1 -0
- package/dist/SubscriberBuilder-DuIgxuzc.d.cts +26 -0
- package/dist/SubscriberBuilder-wthr-FL9.cjs +60 -0
- package/dist/SubscriberBuilder-wthr-FL9.cjs.map +1 -0
- package/dist/adaptors/aws.cjs +19 -0
- package/dist/adaptors/aws.d.cts +15 -0
- package/dist/adaptors/aws.d.mts +15 -0
- package/dist/adaptors/aws.mjs +16 -0
- package/dist/adaptors/hono.cjs +12 -0
- package/dist/adaptors/hono.d.cts +9 -0
- package/dist/adaptors/hono.d.mts +9 -0
- package/dist/adaptors/hono.mjs +12 -0
- package/dist/chunk-CUT6urMc.cjs +30 -0
- package/dist/crons/Cron.cjs +8 -0
- package/dist/crons/Cron.d.cts +7 -0
- package/dist/crons/Cron.d.mts +7 -0
- package/dist/crons/Cron.mjs +8 -0
- package/dist/crons/CronBuilder.cjs +9 -0
- package/dist/crons/CronBuilder.d.cts +8 -0
- package/dist/crons/CronBuilder.d.mts +8 -0
- package/dist/crons/CronBuilder.mjs +9 -0
- package/dist/crons/index.cjs +16 -0
- package/dist/crons/index.cjs.map +1 -0
- package/dist/crons/index.d.cts +16 -0
- package/dist/crons/index.d.mts +16 -0
- package/dist/crons/index.mjs +14 -0
- package/dist/crons/index.mjs.map +1 -0
- package/dist/endpoints/AmazonApiGatewayEndpointAdaptor.cjs +10 -0
- package/dist/endpoints/AmazonApiGatewayEndpointAdaptor.d.cts +9 -0
- package/dist/endpoints/AmazonApiGatewayEndpointAdaptor.d.mts +9 -0
- package/dist/endpoints/AmazonApiGatewayEndpointAdaptor.mjs +10 -0
- package/dist/endpoints/AmazonApiGatewayV1EndpointAdaptor.cjs +12 -0
- package/dist/endpoints/AmazonApiGatewayV1EndpointAdaptor.d.cts +10 -0
- package/dist/endpoints/AmazonApiGatewayV1EndpointAdaptor.d.mts +10 -0
- package/dist/endpoints/AmazonApiGatewayV1EndpointAdaptor.mjs +12 -0
- package/dist/endpoints/AmazonApiGatewayV2EndpointAdaptor.cjs +12 -0
- package/dist/endpoints/AmazonApiGatewayV2EndpointAdaptor.d.cts +10 -0
- package/dist/endpoints/AmazonApiGatewayV2EndpointAdaptor.d.mts +10 -0
- package/dist/endpoints/AmazonApiGatewayV2EndpointAdaptor.mjs +12 -0
- package/dist/endpoints/Endpoint.cjs +9 -0
- package/dist/endpoints/Endpoint.d.cts +8 -0
- package/dist/endpoints/Endpoint.d.mts +8 -0
- package/dist/endpoints/Endpoint.mjs +8 -0
- package/dist/endpoints/EndpointBuilder.cjs +9 -0
- package/dist/endpoints/EndpointBuilder.d.cts +9 -0
- package/dist/endpoints/EndpointBuilder.d.mts +9 -0
- package/dist/endpoints/EndpointBuilder.mjs +9 -0
- package/dist/endpoints/EndpointFactory.cjs +11 -0
- package/dist/endpoints/EndpointFactory.d.cts +10 -0
- package/dist/endpoints/EndpointFactory.d.mts +10 -0
- package/dist/endpoints/EndpointFactory.mjs +10 -0
- package/dist/endpoints/HonoEndpointAdaptor.cjs +12 -0
- package/dist/endpoints/HonoEndpointAdaptor.d.cts +9 -0
- package/dist/endpoints/HonoEndpointAdaptor.d.mts +9 -0
- package/dist/endpoints/HonoEndpointAdaptor.mjs +12 -0
- package/dist/endpoints/TestEndpointAdaptor.cjs +54 -0
- package/dist/endpoints/TestEndpointAdaptor.cjs.map +1 -0
- package/dist/endpoints/TestEndpointAdaptor.d.cts +29 -0
- package/dist/endpoints/TestEndpointAdaptor.d.mts +29 -0
- package/dist/endpoints/TestEndpointAdaptor.mjs +53 -0
- package/dist/endpoints/TestEndpointAdaptor.mjs.map +1 -0
- package/dist/endpoints/helpers.cjs +10 -0
- package/dist/endpoints/helpers.d.cts +58 -0
- package/dist/endpoints/helpers.d.mts +58 -0
- package/dist/endpoints/helpers.mjs +9 -0
- package/dist/endpoints/index.cjs +16 -0
- package/dist/endpoints/index.cjs.map +1 -0
- package/dist/endpoints/index.d.cts +16 -0
- package/dist/endpoints/index.d.mts +16 -0
- package/dist/endpoints/index.mjs +15 -0
- package/dist/endpoints/index.mjs.map +1 -0
- package/dist/endpoints/parseHonoQuery.cjs +3 -0
- package/dist/endpoints/parseHonoQuery.d.cts +12 -0
- package/dist/endpoints/parseHonoQuery.d.mts +12 -0
- package/dist/endpoints/parseHonoQuery.mjs +3 -0
- package/dist/endpoints/parseQueryParams.cjs +3 -0
- package/dist/endpoints/parseQueryParams.d.cts +13 -0
- package/dist/endpoints/parseQueryParams.d.mts +13 -0
- package/dist/endpoints/parseQueryParams.mjs +3 -0
- package/dist/functions/AWSLambdaFunction.cjs +9 -0
- package/dist/functions/AWSLambdaFunction.d.cts +5 -0
- package/dist/functions/AWSLambdaFunction.d.mts +5 -0
- package/dist/functions/AWSLambdaFunction.mjs +9 -0
- package/dist/functions/BaseFunctionBuilder.cjs +4 -0
- package/dist/functions/BaseFunctionBuilder.d.cts +3 -0
- package/dist/functions/BaseFunctionBuilder.d.mts +3 -0
- package/dist/functions/BaseFunctionBuilder.mjs +4 -0
- package/dist/functions/Function.cjs +5 -0
- package/dist/functions/Function.d.cts +3 -0
- package/dist/functions/Function.d.mts +3 -0
- package/dist/functions/Function.mjs +4 -0
- package/dist/functions/FunctionBuilder.cjs +6 -0
- package/dist/functions/FunctionBuilder.d.cts +5 -0
- package/dist/functions/FunctionBuilder.d.mts +5 -0
- package/dist/functions/FunctionBuilder.mjs +6 -0
- package/dist/functions/FunctionExecutionWrapper.cjs +8 -0
- package/dist/functions/FunctionExecutionWrapper.d.cts +4 -0
- package/dist/functions/FunctionExecutionWrapper.d.mts +4 -0
- package/dist/functions/FunctionExecutionWrapper.mjs +8 -0
- package/dist/functions/TestFunctionAdaptor.cjs +38 -0
- package/dist/functions/TestFunctionAdaptor.cjs.map +1 -0
- package/dist/functions/TestFunctionAdaptor.d.cts +26 -0
- package/dist/functions/TestFunctionAdaptor.d.mts +26 -0
- package/dist/functions/TestFunctionAdaptor.mjs +37 -0
- package/dist/functions/TestFunctionAdaptor.mjs.map +1 -0
- package/dist/functions/index.cjs +10 -0
- package/dist/functions/index.d.cts +6 -0
- package/dist/functions/index.d.mts +6 -0
- package/dist/functions/index.mjs +7 -0
- package/dist/functions-DVDb5wEA.cjs +13 -0
- package/dist/functions-DVDb5wEA.cjs.map +1 -0
- package/dist/functions-mM-jcphA.mjs +8 -0
- package/dist/functions-mM-jcphA.mjs.map +1 -0
- package/dist/helpers-BeGM4pP_.cjs +95 -0
- package/dist/helpers-BeGM4pP_.cjs.map +1 -0
- package/dist/helpers-DbpO95aE.mjs +83 -0
- package/dist/helpers-DbpO95aE.mjs.map +1 -0
- package/dist/index-CuGR4L7O.d.mts +9 -0
- package/dist/index-Fg3N3EKD.d.cts +9 -0
- package/dist/index.cjs +4 -0
- package/dist/index.d.cts +4 -0
- package/dist/index.d.mts +4 -0
- package/dist/index.mjs +3 -0
- package/dist/parseHonoQuery-DopC24vB.cjs +37 -0
- package/dist/parseHonoQuery-DopC24vB.cjs.map +1 -0
- package/dist/parseHonoQuery-znDKBhdE.mjs +31 -0
- package/dist/parseHonoQuery-znDKBhdE.mjs.map +1 -0
- package/dist/parseQueryParams-BJaRh3OB.mjs +32 -0
- package/dist/parseQueryParams-BJaRh3OB.mjs.map +1 -0
- package/dist/parseQueryParams-BzPop4I1.cjs +38 -0
- package/dist/parseQueryParams-BzPop4I1.cjs.map +1 -0
- package/dist/publisher-Bw4770Hi.mjs +41 -0
- package/dist/publisher-Bw4770Hi.mjs.map +1 -0
- package/dist/publisher-lFQleddL.cjs +53 -0
- package/dist/publisher-lFQleddL.cjs.map +1 -0
- package/dist/publisher.cjs +4 -0
- package/dist/publisher.d.cts +13 -0
- package/dist/publisher.d.mts +13 -0
- package/dist/publisher.mjs +3 -0
- package/dist/subscribers/AWSLambdaSubscriberAdaptor.cjs +3 -0
- package/dist/subscribers/AWSLambdaSubscriberAdaptor.d.cts +4 -0
- package/dist/subscribers/AWSLambdaSubscriberAdaptor.d.mts +4 -0
- package/dist/subscribers/AWSLambdaSubscriberAdaptor.mjs +3 -0
- package/dist/subscribers/Subscriber.cjs +4 -0
- package/dist/subscribers/Subscriber.d.cts +3 -0
- package/dist/subscribers/Subscriber.d.mts +3 -0
- package/dist/subscribers/Subscriber.mjs +4 -0
- package/dist/subscribers/SubscriberBuilder.cjs +5 -0
- package/dist/subscribers/SubscriberBuilder.d.cts +4 -0
- package/dist/subscribers/SubscriberBuilder.d.mts +4 -0
- package/dist/subscribers/SubscriberBuilder.mjs +5 -0
- package/dist/subscribers/index.cjs +12 -0
- package/dist/subscribers/index.cjs.map +1 -0
- package/dist/subscribers/index.d.cts +10 -0
- package/dist/subscribers/index.d.mts +10 -0
- package/dist/subscribers/index.mjs +10 -0
- package/dist/subscribers/index.mjs.map +1 -0
- package/dist/types-Bp9ysFXd.d.cts +7 -0
- package/dist/types-DBKNYvsW.d.mts +7 -0
- package/dist/types.cjs +0 -0
- package/dist/types.d.cts +2 -0
- package/dist/types.d.mts +2 -0
- package/dist/types.mjs +0 -0
- package/package.json +91 -0
- package/src/Construct.ts +98 -0
- package/src/__tests__/Construct.environment.spec.ts +360 -0
- package/src/__tests__/publisher.setting.spec.ts +511 -0
- package/src/__tests__/publisher.spec.ts +454 -0
- package/src/adaptors/aws.ts +4 -0
- package/src/adaptors/hono.ts +1 -0
- package/src/crons/Cron.ts +137 -0
- package/src/crons/CronBuilder.ts +192 -0
- package/src/crons/__tests__/Cron.spec.ts +464 -0
- package/src/crons/index.ts +11 -0
- package/src/endpoints/AmazonApiGatewayEndpointAdaptor.ts +315 -0
- package/src/endpoints/AmazonApiGatewayV1EndpointAdaptor.ts +101 -0
- package/src/endpoints/AmazonApiGatewayV2EndpointAdaptor.ts +95 -0
- package/src/endpoints/Endpoint.ts +771 -0
- package/src/endpoints/EndpointBuilder.ts +308 -0
- package/src/endpoints/EndpointFactory.ts +329 -0
- package/src/endpoints/HonoEndpointAdaptor.ts +365 -0
- package/src/endpoints/TestEndpointAdaptor.ts +130 -0
- package/src/endpoints/__tests__/AmazonApiGatewayV1EndpointAdaptor.events.spec.ts +553 -0
- package/src/endpoints/__tests__/AmazonApiGatewayV1EndpointAdaptor.spec.ts +927 -0
- package/src/endpoints/__tests__/AmazonApiGatewayV2EndpointAdaptor.events.spec.ts +721 -0
- package/src/endpoints/__tests__/AmazonApiGatewayV2EndpointAdaptor.factory-publisher.spec.ts +296 -0
- package/src/endpoints/__tests__/AmazonApiGatewayV2EndpointAdaptor.spec.ts +441 -0
- package/src/endpoints/__tests__/Endpoint.spec.ts +800 -0
- package/src/endpoints/__tests__/EndpointBuilder.spec.ts +488 -0
- package/src/endpoints/__tests__/EndpointFactory.spec.ts +479 -0
- package/src/endpoints/__tests__/HonoEndpointAdaptor.events.spec.ts +569 -0
- package/src/endpoints/__tests__/HonoEndpointAdaptor.openapi.spec.ts +313 -0
- package/src/endpoints/__tests__/HonoEndpointAdaptor.spec.ts +1078 -0
- package/src/endpoints/__tests__/TestEndpointAdaptor.spec.ts +236 -0
- package/src/endpoints/__tests__/__snapshots__/HonoEndpointAdaptor.spec.ts.snap +54 -0
- package/src/endpoints/__tests__/endpoint-types.test.ts +88 -0
- package/src/endpoints/helpers.ts +99 -0
- package/src/endpoints/index.ts +5 -0
- package/src/endpoints/parseHonoQuery.ts +51 -0
- package/src/endpoints/parseQueryParams.ts +51 -0
- package/src/functions/AWSLambdaFunction.ts +222 -0
- package/src/functions/BaseFunctionBuilder.ts +110 -0
- package/src/functions/Function.ts +160 -0
- package/src/functions/FunctionBuilder.ts +182 -0
- package/src/functions/FunctionExecutionWrapper.ts +86 -0
- package/src/functions/TestFunctionAdaptor.ts +125 -0
- package/src/functions/__tests__/AWSLambdaFunctionAdaptor.spec.ts +376 -0
- package/src/functions/__tests__/Function.spec.ts +402 -0
- package/src/functions/__tests__/TestFunctionAdaptor.spec.ts +398 -0
- package/src/functions/index.ts +10 -0
- package/src/index.ts +14 -0
- package/src/publisher.ts +83 -0
- package/src/subscribers/AWSLambdaSubscriberAdaptor.ts +269 -0
- package/src/subscribers/Subscriber.ts +112 -0
- package/src/subscribers/SubscriberBuilder.ts +150 -0
- package/src/subscribers/__tests__/AWSLambdaSubscriberAdaptor.spec.ts +623 -0
- package/src/subscribers/__tests__/Subscriber.spec.ts +432 -0
- package/src/subscribers/index.ts +5 -0
- package/src/types.ts +13 -0
- package/tsdown.config.ts +3 -0
|
@@ -0,0 +1,511 @@
|
|
|
1
|
+
import type { Logger } from '@geekmidas/logger';
|
|
2
|
+
import { type Service, ServiceDiscovery } from '@geekmidas/services';
|
|
3
|
+
import { beforeEach, describe, expect, it, vi } from 'vitest';
|
|
4
|
+
import { z } from 'zod/v4';
|
|
5
|
+
|
|
6
|
+
import { EnvironmentParser } from '@geekmidas/envkit';
|
|
7
|
+
import { e } from '../endpoints';
|
|
8
|
+
|
|
9
|
+
import type { EventPublisher, PublishableMessage } from '@geekmidas/events';
|
|
10
|
+
import { publishConstructEvents } from '../publisher';
|
|
11
|
+
|
|
12
|
+
// Test event types
|
|
13
|
+
type TestEvent =
|
|
14
|
+
| PublishableMessage<'test.created', { id: string }>
|
|
15
|
+
| PublishableMessage<'test.updated', { id: string; changes: string[] }>
|
|
16
|
+
| PublishableMessage<'test.deleted', { id: string }>;
|
|
17
|
+
|
|
18
|
+
describe('publisher service setting combinations', () => {
|
|
19
|
+
const mockLogger: Logger = {
|
|
20
|
+
debug: vi.fn(),
|
|
21
|
+
info: vi.fn(),
|
|
22
|
+
warn: vi.fn(),
|
|
23
|
+
error: vi.fn(),
|
|
24
|
+
fatal: vi.fn(),
|
|
25
|
+
trace: vi.fn(),
|
|
26
|
+
child: vi.fn(() => mockLogger),
|
|
27
|
+
};
|
|
28
|
+
|
|
29
|
+
const serviceDiscovery = ServiceDiscovery.getInstance(
|
|
30
|
+
mockLogger,
|
|
31
|
+
new EnvironmentParser({}),
|
|
32
|
+
);
|
|
33
|
+
|
|
34
|
+
// Create mock publishers
|
|
35
|
+
const createMockPublisher = (_name: string): EventPublisher<TestEvent> => ({
|
|
36
|
+
publish: vi.fn().mockResolvedValue(undefined),
|
|
37
|
+
});
|
|
38
|
+
|
|
39
|
+
const createMockPublisherService = (
|
|
40
|
+
name: string,
|
|
41
|
+
): Service<string, EventPublisher<TestEvent>> => {
|
|
42
|
+
const publisher = createMockPublisher(name);
|
|
43
|
+
return {
|
|
44
|
+
serviceName: `${name}-publisher-${Math.random()}`,
|
|
45
|
+
register: vi.fn().mockResolvedValue(publisher),
|
|
46
|
+
};
|
|
47
|
+
};
|
|
48
|
+
|
|
49
|
+
beforeEach(() => {
|
|
50
|
+
vi.clearAllMocks();
|
|
51
|
+
});
|
|
52
|
+
|
|
53
|
+
describe('setting publisher via endpoint.publisher()', () => {
|
|
54
|
+
it('should use publisher set directly on endpoint', async () => {
|
|
55
|
+
const mockPublisher = createMockPublisher('endpoint');
|
|
56
|
+
const mockPublisherService = createMockPublisherService('endpoint');
|
|
57
|
+
mockPublisherService.register = vi.fn().mockResolvedValue(mockPublisher);
|
|
58
|
+
|
|
59
|
+
const endpoint = e
|
|
60
|
+
.logger(mockLogger)
|
|
61
|
+
.post('/test')
|
|
62
|
+
.publisher(mockPublisherService)
|
|
63
|
+
.output(z.object({ id: z.string() }))
|
|
64
|
+
.event({
|
|
65
|
+
type: 'test.created',
|
|
66
|
+
payload: (response) => ({ id: response.id }),
|
|
67
|
+
})
|
|
68
|
+
.handle(async () => ({ id: '123' }));
|
|
69
|
+
|
|
70
|
+
await publishConstructEvents(
|
|
71
|
+
endpoint,
|
|
72
|
+
{ id: '123' },
|
|
73
|
+
serviceDiscovery as ServiceDiscovery<any, any>,
|
|
74
|
+
);
|
|
75
|
+
|
|
76
|
+
expect(mockPublisher.publish).toHaveBeenCalledWith([
|
|
77
|
+
{
|
|
78
|
+
type: 'test.created',
|
|
79
|
+
payload: { id: '123' },
|
|
80
|
+
},
|
|
81
|
+
]);
|
|
82
|
+
});
|
|
83
|
+
});
|
|
84
|
+
|
|
85
|
+
describe('setting publisher via factory.publisher()', () => {
|
|
86
|
+
it('should use publisher from factory when not overridden', async () => {
|
|
87
|
+
const mockPublisher = createMockPublisher('factory');
|
|
88
|
+
const mockPublisherService = createMockPublisherService('factory');
|
|
89
|
+
mockPublisherService.register = vi.fn().mockResolvedValue(mockPublisher);
|
|
90
|
+
|
|
91
|
+
// Create factory with publisher
|
|
92
|
+
const factory = e.logger(mockLogger).publisher(mockPublisherService);
|
|
93
|
+
|
|
94
|
+
// Create endpoint using factory
|
|
95
|
+
const endpoint = factory
|
|
96
|
+
.post('/test')
|
|
97
|
+
.output(z.object({ id: z.string() }))
|
|
98
|
+
.event({
|
|
99
|
+
type: 'test.created',
|
|
100
|
+
payload: (response) => ({ id: response.id }),
|
|
101
|
+
})
|
|
102
|
+
.handle(async () => ({ id: '123' }));
|
|
103
|
+
|
|
104
|
+
// Verify the publisher service is set on the endpoint
|
|
105
|
+
expect(endpoint.publisherService).toBeDefined();
|
|
106
|
+
expect(endpoint.publisherService?.serviceName).toBe(
|
|
107
|
+
mockPublisherService.serviceName,
|
|
108
|
+
);
|
|
109
|
+
|
|
110
|
+
await publishConstructEvents(
|
|
111
|
+
endpoint,
|
|
112
|
+
{ id: '123' },
|
|
113
|
+
serviceDiscovery as ServiceDiscovery<any, any>,
|
|
114
|
+
);
|
|
115
|
+
|
|
116
|
+
expect(mockPublisher.publish).toHaveBeenCalledWith([
|
|
117
|
+
{
|
|
118
|
+
type: 'test.created',
|
|
119
|
+
payload: { id: '123' },
|
|
120
|
+
},
|
|
121
|
+
]);
|
|
122
|
+
});
|
|
123
|
+
|
|
124
|
+
it('should work with factory that has logger and services', async () => {
|
|
125
|
+
const mockPublisher = createMockPublisher('factory-with-services');
|
|
126
|
+
const mockPublisherService = createMockPublisherService(
|
|
127
|
+
'factory-with-services',
|
|
128
|
+
);
|
|
129
|
+
mockPublisherService.register = vi.fn().mockResolvedValue(mockPublisher);
|
|
130
|
+
|
|
131
|
+
// Create factory with logger, services, and publisher
|
|
132
|
+
const factory = e
|
|
133
|
+
.logger(mockLogger)
|
|
134
|
+
.services([])
|
|
135
|
+
.publisher(mockPublisherService);
|
|
136
|
+
|
|
137
|
+
const endpoint = factory
|
|
138
|
+
.post('/test')
|
|
139
|
+
.output(z.object({ id: z.string() }))
|
|
140
|
+
.event({
|
|
141
|
+
type: 'test.created',
|
|
142
|
+
payload: (response) => ({ id: response.id }),
|
|
143
|
+
})
|
|
144
|
+
.handle(async () => ({ id: '456' }));
|
|
145
|
+
|
|
146
|
+
// Verify the publisher service is set
|
|
147
|
+
expect(endpoint.publisherService).toBeDefined();
|
|
148
|
+
expect(endpoint.publisherService?.serviceName).toBe(
|
|
149
|
+
mockPublisherService.serviceName,
|
|
150
|
+
);
|
|
151
|
+
|
|
152
|
+
await publishConstructEvents(
|
|
153
|
+
endpoint,
|
|
154
|
+
{ id: '456' },
|
|
155
|
+
serviceDiscovery as ServiceDiscovery<any, any>,
|
|
156
|
+
);
|
|
157
|
+
|
|
158
|
+
expect(mockPublisher.publish).toHaveBeenCalledWith([
|
|
159
|
+
{
|
|
160
|
+
type: 'test.created',
|
|
161
|
+
payload: { id: '456' },
|
|
162
|
+
},
|
|
163
|
+
]);
|
|
164
|
+
});
|
|
165
|
+
});
|
|
166
|
+
|
|
167
|
+
describe('overriding factory publisher at endpoint level', () => {
|
|
168
|
+
it('should use endpoint publisher over factory publisher', async () => {
|
|
169
|
+
const factoryPublisher = createMockPublisher('factory');
|
|
170
|
+
const factoryPublisherService = createMockPublisherService('factory');
|
|
171
|
+
factoryPublisherService.register = vi
|
|
172
|
+
.fn()
|
|
173
|
+
.mockResolvedValue(factoryPublisher);
|
|
174
|
+
|
|
175
|
+
const endpointPublisher = createMockPublisher('endpoint-override');
|
|
176
|
+
const endpointPublisherService =
|
|
177
|
+
createMockPublisherService('endpoint-override');
|
|
178
|
+
endpointPublisherService.register = vi
|
|
179
|
+
.fn()
|
|
180
|
+
.mockResolvedValue(endpointPublisher);
|
|
181
|
+
|
|
182
|
+
// Create factory with publisher
|
|
183
|
+
const factory = e.logger(mockLogger).publisher(factoryPublisherService);
|
|
184
|
+
|
|
185
|
+
// Create endpoint that overrides factory publisher
|
|
186
|
+
const endpoint = factory
|
|
187
|
+
.post('/test')
|
|
188
|
+
.publisher(endpointPublisherService) // Override factory publisher
|
|
189
|
+
.output(z.object({ id: z.string() }))
|
|
190
|
+
.event({
|
|
191
|
+
type: 'test.updated',
|
|
192
|
+
payload: (response) => ({ id: response.id, changes: ['name'] }),
|
|
193
|
+
})
|
|
194
|
+
.handle(async () => ({ id: '789' }));
|
|
195
|
+
|
|
196
|
+
await publishConstructEvents(
|
|
197
|
+
endpoint,
|
|
198
|
+
{ id: '789' },
|
|
199
|
+
serviceDiscovery as ServiceDiscovery<any, any>,
|
|
200
|
+
);
|
|
201
|
+
|
|
202
|
+
// Factory publisher should NOT be called
|
|
203
|
+
expect(factoryPublisher.publish).not.toHaveBeenCalled();
|
|
204
|
+
|
|
205
|
+
// Endpoint publisher SHOULD be called
|
|
206
|
+
expect(endpointPublisher.publish).toHaveBeenCalledWith([
|
|
207
|
+
{
|
|
208
|
+
type: 'test.updated',
|
|
209
|
+
payload: { id: '789', changes: ['name'] },
|
|
210
|
+
},
|
|
211
|
+
]);
|
|
212
|
+
});
|
|
213
|
+
});
|
|
214
|
+
|
|
215
|
+
describe('publisher inheritance through endpoint builder chain', () => {
|
|
216
|
+
it('should maintain publisher through builder method chain', async () => {
|
|
217
|
+
const mockPublisher = createMockPublisher('chain');
|
|
218
|
+
const mockPublisherService = createMockPublisherService('chain');
|
|
219
|
+
mockPublisherService.register = vi.fn().mockResolvedValue(mockPublisher);
|
|
220
|
+
|
|
221
|
+
const endpoint = e
|
|
222
|
+
.logger(mockLogger)
|
|
223
|
+
.post('/test')
|
|
224
|
+
.publisher(mockPublisherService)
|
|
225
|
+
.body(z.object({ name: z.string() }))
|
|
226
|
+
.output(z.object({ id: z.string() }))
|
|
227
|
+
.event({
|
|
228
|
+
type: 'test.created',
|
|
229
|
+
payload: (response) => ({ id: response.id }),
|
|
230
|
+
})
|
|
231
|
+
.handle(async (_body) => ({ id: '999' }));
|
|
232
|
+
|
|
233
|
+
expect(endpoint.publisherService).toBeDefined();
|
|
234
|
+
|
|
235
|
+
await publishConstructEvents(
|
|
236
|
+
endpoint,
|
|
237
|
+
{ id: '999' },
|
|
238
|
+
serviceDiscovery as ServiceDiscovery<any, any>,
|
|
239
|
+
);
|
|
240
|
+
|
|
241
|
+
expect(mockPublisher.publish).toHaveBeenCalledWith([
|
|
242
|
+
{
|
|
243
|
+
type: 'test.created',
|
|
244
|
+
payload: { id: '999' },
|
|
245
|
+
},
|
|
246
|
+
]);
|
|
247
|
+
});
|
|
248
|
+
|
|
249
|
+
it('should maintain factory publisher through builder chain', async () => {
|
|
250
|
+
const mockPublisher = createMockPublisher('factory-chain');
|
|
251
|
+
const mockPublisherService = createMockPublisherService('factory-chain');
|
|
252
|
+
mockPublisherService.register = vi.fn().mockResolvedValue(mockPublisher);
|
|
253
|
+
|
|
254
|
+
const factory = e.logger(mockLogger).publisher(mockPublisherService);
|
|
255
|
+
|
|
256
|
+
const endpoint = factory
|
|
257
|
+
.post('/test')
|
|
258
|
+
.body(z.object({ name: z.string() }))
|
|
259
|
+
.query(z.object({ filter: z.string().optional() }))
|
|
260
|
+
.output(z.object({ id: z.string() }))
|
|
261
|
+
.event({
|
|
262
|
+
type: 'test.created',
|
|
263
|
+
payload: (response) => ({ id: response.id }),
|
|
264
|
+
})
|
|
265
|
+
.handle(async () => ({ id: '111' }));
|
|
266
|
+
|
|
267
|
+
expect(endpoint.publisherService).toBeDefined();
|
|
268
|
+
|
|
269
|
+
await publishConstructEvents(
|
|
270
|
+
endpoint,
|
|
271
|
+
{ id: '111' },
|
|
272
|
+
serviceDiscovery as ServiceDiscovery<any, any>,
|
|
273
|
+
);
|
|
274
|
+
|
|
275
|
+
expect(mockPublisher.publish).toHaveBeenCalledWith([
|
|
276
|
+
{
|
|
277
|
+
type: 'test.created',
|
|
278
|
+
payload: { id: '111' },
|
|
279
|
+
},
|
|
280
|
+
]);
|
|
281
|
+
});
|
|
282
|
+
});
|
|
283
|
+
|
|
284
|
+
describe('multiple endpoints with same/different publishers', () => {
|
|
285
|
+
it('should handle multiple endpoints from same factory', async () => {
|
|
286
|
+
const mockPublisher = createMockPublisher('shared-factory');
|
|
287
|
+
const mockPublisherService = createMockPublisherService('shared-factory');
|
|
288
|
+
mockPublisherService.register = vi.fn().mockResolvedValue(mockPublisher);
|
|
289
|
+
|
|
290
|
+
const factory = e.logger(mockLogger).publisher(mockPublisherService);
|
|
291
|
+
|
|
292
|
+
// Create multiple endpoints from same factory
|
|
293
|
+
const endpoint1 = factory
|
|
294
|
+
.post('/users')
|
|
295
|
+
.output(z.object({ id: z.string() }))
|
|
296
|
+
.event({
|
|
297
|
+
type: 'test.created',
|
|
298
|
+
payload: (response) => ({ id: response.id }),
|
|
299
|
+
})
|
|
300
|
+
.handle(async () => ({ id: 'user-1' }));
|
|
301
|
+
|
|
302
|
+
const endpoint2 = factory
|
|
303
|
+
.put('/users/:id')
|
|
304
|
+
.output(z.object({ id: z.string() }))
|
|
305
|
+
.event({
|
|
306
|
+
type: 'test.updated',
|
|
307
|
+
payload: (response) => ({ id: response.id, changes: ['status'] }),
|
|
308
|
+
})
|
|
309
|
+
.handle(async () => ({ id: 'user-2' }));
|
|
310
|
+
|
|
311
|
+
// Both endpoints should have the same publisher service
|
|
312
|
+
expect(endpoint1.publisherService?.serviceName).toBe(
|
|
313
|
+
mockPublisherService.serviceName,
|
|
314
|
+
);
|
|
315
|
+
expect(endpoint2.publisherService?.serviceName).toBe(
|
|
316
|
+
mockPublisherService.serviceName,
|
|
317
|
+
);
|
|
318
|
+
|
|
319
|
+
// Test both endpoints
|
|
320
|
+
await publishConstructEvents(
|
|
321
|
+
endpoint1,
|
|
322
|
+
{ id: 'user-1' },
|
|
323
|
+
serviceDiscovery as ServiceDiscovery<any, any>,
|
|
324
|
+
);
|
|
325
|
+
|
|
326
|
+
await publishConstructEvents(
|
|
327
|
+
endpoint2,
|
|
328
|
+
{ id: 'user-2' },
|
|
329
|
+
serviceDiscovery as ServiceDiscovery<any, any>,
|
|
330
|
+
);
|
|
331
|
+
|
|
332
|
+
// Publisher should be called twice
|
|
333
|
+
expect(mockPublisher.publish).toHaveBeenCalledTimes(2);
|
|
334
|
+
expect(mockPublisher.publish).toHaveBeenNthCalledWith(1, [
|
|
335
|
+
{
|
|
336
|
+
type: 'test.created',
|
|
337
|
+
payload: { id: 'user-1' },
|
|
338
|
+
},
|
|
339
|
+
]);
|
|
340
|
+
expect(mockPublisher.publish).toHaveBeenNthCalledWith(2, [
|
|
341
|
+
{
|
|
342
|
+
type: 'test.updated',
|
|
343
|
+
payload: { id: 'user-2', changes: ['status'] },
|
|
344
|
+
},
|
|
345
|
+
]);
|
|
346
|
+
});
|
|
347
|
+
|
|
348
|
+
it('should handle different publishers for different endpoints', async () => {
|
|
349
|
+
const publisher1 = createMockPublisher('endpoint-1');
|
|
350
|
+
const publisherService1 = createMockPublisherService('endpoint-1');
|
|
351
|
+
publisherService1.register = vi.fn().mockResolvedValue(publisher1);
|
|
352
|
+
|
|
353
|
+
const publisher2 = createMockPublisher('endpoint-2');
|
|
354
|
+
const publisherService2 = createMockPublisherService('endpoint-2');
|
|
355
|
+
publisherService2.register = vi.fn().mockResolvedValue(publisher2);
|
|
356
|
+
|
|
357
|
+
const endpoint1 = e
|
|
358
|
+
.logger(mockLogger)
|
|
359
|
+
.post('/api/v1/resource')
|
|
360
|
+
.publisher(publisherService1)
|
|
361
|
+
.output(z.object({ id: z.string() }))
|
|
362
|
+
.event({
|
|
363
|
+
type: 'test.created',
|
|
364
|
+
payload: (response) => ({ id: response.id }),
|
|
365
|
+
})
|
|
366
|
+
.handle(async () => ({ id: 'res-1' }));
|
|
367
|
+
|
|
368
|
+
const endpoint2 = e
|
|
369
|
+
.logger(mockLogger)
|
|
370
|
+
.post('/api/v2/resource')
|
|
371
|
+
.publisher(publisherService2)
|
|
372
|
+
.output(z.object({ id: z.string() }))
|
|
373
|
+
.event({
|
|
374
|
+
type: 'test.created',
|
|
375
|
+
payload: (response) => ({ id: response.id }),
|
|
376
|
+
})
|
|
377
|
+
.handle(async () => ({ id: 'res-2' }));
|
|
378
|
+
|
|
379
|
+
// Test both endpoints
|
|
380
|
+
await publishConstructEvents(
|
|
381
|
+
endpoint1,
|
|
382
|
+
{ id: 'res-1' },
|
|
383
|
+
serviceDiscovery as ServiceDiscovery<any, any>,
|
|
384
|
+
);
|
|
385
|
+
|
|
386
|
+
await publishConstructEvents(
|
|
387
|
+
endpoint2,
|
|
388
|
+
{ id: 'res-2' },
|
|
389
|
+
serviceDiscovery as ServiceDiscovery<any, any>,
|
|
390
|
+
);
|
|
391
|
+
|
|
392
|
+
// Each publisher should only be called once
|
|
393
|
+
expect(publisher1.publish).toHaveBeenCalledTimes(1);
|
|
394
|
+
expect(publisher1.publish).toHaveBeenCalledWith([
|
|
395
|
+
{
|
|
396
|
+
type: 'test.created',
|
|
397
|
+
payload: { id: 'res-1' },
|
|
398
|
+
},
|
|
399
|
+
]);
|
|
400
|
+
|
|
401
|
+
expect(publisher2.publish).toHaveBeenCalledTimes(1);
|
|
402
|
+
expect(publisher2.publish).toHaveBeenCalledWith([
|
|
403
|
+
{
|
|
404
|
+
type: 'test.created',
|
|
405
|
+
payload: { id: 'res-2' },
|
|
406
|
+
},
|
|
407
|
+
]);
|
|
408
|
+
});
|
|
409
|
+
});
|
|
410
|
+
|
|
411
|
+
describe('edge cases and error scenarios', () => {
|
|
412
|
+
it('should handle undefined publisher gracefully', async () => {
|
|
413
|
+
const endpoint = e
|
|
414
|
+
.logger(mockLogger)
|
|
415
|
+
.post('/test')
|
|
416
|
+
.output(z.object({ id: z.string() }))
|
|
417
|
+
|
|
418
|
+
.event({
|
|
419
|
+
// @ts-ignore
|
|
420
|
+
type: 'test.created',
|
|
421
|
+
// @ts-ignore
|
|
422
|
+
payload: (response) => ({ id: response.id }),
|
|
423
|
+
})
|
|
424
|
+
.handle(async () => ({ id: '000' }));
|
|
425
|
+
|
|
426
|
+
// Should not have publisher service
|
|
427
|
+
expect(endpoint.publisherService).toBeUndefined();
|
|
428
|
+
|
|
429
|
+
// Should not throw, but should warn
|
|
430
|
+
await publishConstructEvents(
|
|
431
|
+
endpoint,
|
|
432
|
+
{ id: '000' },
|
|
433
|
+
serviceDiscovery as ServiceDiscovery<any, any>,
|
|
434
|
+
);
|
|
435
|
+
|
|
436
|
+
expect(mockLogger.warn).toHaveBeenCalledWith(
|
|
437
|
+
'No publisher service available',
|
|
438
|
+
);
|
|
439
|
+
});
|
|
440
|
+
|
|
441
|
+
it('should handle publisher service registration failure', async () => {
|
|
442
|
+
const registrationError = new Error('Service registration failed');
|
|
443
|
+
const mockPublisherService = createMockPublisherService('failing');
|
|
444
|
+
mockPublisherService.register = vi
|
|
445
|
+
.fn()
|
|
446
|
+
.mockRejectedValue(registrationError);
|
|
447
|
+
|
|
448
|
+
const endpoint = e
|
|
449
|
+
.logger(mockLogger)
|
|
450
|
+
.post('/test')
|
|
451
|
+
.publisher(mockPublisherService)
|
|
452
|
+
.output(z.object({ id: z.string() }))
|
|
453
|
+
.event({
|
|
454
|
+
type: 'test.created',
|
|
455
|
+
payload: (response) => ({ id: response.id }),
|
|
456
|
+
})
|
|
457
|
+
.handle(async () => ({ id: '404' }));
|
|
458
|
+
|
|
459
|
+
// Should not throw but should log error
|
|
460
|
+
await publishConstructEvents(
|
|
461
|
+
endpoint,
|
|
462
|
+
{ id: '404' },
|
|
463
|
+
serviceDiscovery as ServiceDiscovery<any, any>,
|
|
464
|
+
);
|
|
465
|
+
|
|
466
|
+
expect(mockLogger.error).toHaveBeenCalledWith(
|
|
467
|
+
registrationError,
|
|
468
|
+
'Something went wrong publishing events',
|
|
469
|
+
);
|
|
470
|
+
});
|
|
471
|
+
});
|
|
472
|
+
|
|
473
|
+
describe('factory publisher with services', () => {
|
|
474
|
+
it('should maintain publisher with services factory', async () => {
|
|
475
|
+
const mockPublisher = createMockPublisher('services');
|
|
476
|
+
const mockPublisherService = createMockPublisherService('services');
|
|
477
|
+
mockPublisherService.register = vi.fn().mockResolvedValue(mockPublisher);
|
|
478
|
+
|
|
479
|
+
// Test a typical factory setup with logger, services, and publisher
|
|
480
|
+
const factory = e
|
|
481
|
+
.logger(mockLogger)
|
|
482
|
+
.services([])
|
|
483
|
+
.publisher(mockPublisherService);
|
|
484
|
+
|
|
485
|
+
const endpoint = factory
|
|
486
|
+
.post('/api/v1/users')
|
|
487
|
+
.output(z.object({ id: z.string() }))
|
|
488
|
+
.event({
|
|
489
|
+
type: 'test.created',
|
|
490
|
+
payload: (response) => ({ id: response.id }),
|
|
491
|
+
})
|
|
492
|
+
.handle(async () => ({ id: 'services-123' }));
|
|
493
|
+
|
|
494
|
+
expect(endpoint._path).toBe('/api/v1/users');
|
|
495
|
+
expect(endpoint.publisherService).toBeDefined();
|
|
496
|
+
|
|
497
|
+
await publishConstructEvents(
|
|
498
|
+
endpoint,
|
|
499
|
+
{ id: 'services-123' },
|
|
500
|
+
serviceDiscovery as ServiceDiscovery<any, any>,
|
|
501
|
+
);
|
|
502
|
+
|
|
503
|
+
expect(mockPublisher.publish).toHaveBeenCalledWith([
|
|
504
|
+
{
|
|
505
|
+
type: 'test.created',
|
|
506
|
+
payload: { id: 'services-123' },
|
|
507
|
+
},
|
|
508
|
+
]);
|
|
509
|
+
});
|
|
510
|
+
});
|
|
511
|
+
});
|